This source file includes following definitions.
- sctp_sm_lookup_event
- sctp_chunk_event_lookup
   1 
   2 
   3 
   4 
   5 
   6 
   7 
   8 
   9 
  10 
  11 
  12 
  13 
  14 
  15 
  16 
  17 
  18 
  19 
  20 
  21 
  22 
  23 
  24 
  25 
  26 
  27 #define pr_fmt(fmt) KBUILD_MODNAME ": " fmt
  28 
  29 #include <linux/skbuff.h>
  30 #include <net/sctp/sctp.h>
  31 #include <net/sctp/sm.h>
  32 
  33 static const struct sctp_sm_table_entry
  34 primitive_event_table[SCTP_NUM_PRIMITIVE_TYPES][SCTP_STATE_NUM_STATES];
  35 static const struct sctp_sm_table_entry
  36 other_event_table[SCTP_NUM_OTHER_TYPES][SCTP_STATE_NUM_STATES];
  37 static const struct sctp_sm_table_entry
  38 timeout_event_table[SCTP_NUM_TIMEOUT_TYPES][SCTP_STATE_NUM_STATES];
  39 
  40 static const struct sctp_sm_table_entry *sctp_chunk_event_lookup(
  41                                                 struct net *net,
  42                                                 enum sctp_cid cid,
  43                                                 enum sctp_state state);
  44 
  45 
  46 static const struct sctp_sm_table_entry bug = {
  47         .fn = sctp_sf_bug,
  48         .name = "sctp_sf_bug"
  49 };
  50 
  51 #define DO_LOOKUP(_max, _type, _table)                                  \
  52 ({                                                                      \
  53         const struct sctp_sm_table_entry *rtn;                          \
  54                                                                         \
  55         if ((event_subtype._type > (_max))) {                           \
  56                 pr_warn("table %p possible attack: event %d exceeds max %d\n", \
  57                         _table, event_subtype._type, _max);             \
  58                 rtn = &bug;                                             \
  59         } else                                                          \
  60                 rtn = &_table[event_subtype._type][(int)state];         \
  61                                                                         \
  62         rtn;                                                            \
  63 })
  64 
  65 const struct sctp_sm_table_entry *sctp_sm_lookup_event(
  66                                         struct net *net,
  67                                         enum sctp_event_type event_type,
  68                                         enum sctp_state state,
  69                                         union sctp_subtype event_subtype)
  70 {
  71         switch (event_type) {
  72         case SCTP_EVENT_T_CHUNK:
  73                 return sctp_chunk_event_lookup(net, event_subtype.chunk, state);
  74         case SCTP_EVENT_T_TIMEOUT:
  75                 return DO_LOOKUP(SCTP_EVENT_TIMEOUT_MAX, timeout,
  76                                  timeout_event_table);
  77         case SCTP_EVENT_T_OTHER:
  78                 return DO_LOOKUP(SCTP_EVENT_OTHER_MAX, other,
  79                                  other_event_table);
  80         case SCTP_EVENT_T_PRIMITIVE:
  81                 return DO_LOOKUP(SCTP_EVENT_PRIMITIVE_MAX, primitive,
  82                                  primitive_event_table);
  83         default:
  84                 
  85                 return &bug;
  86         }
  87 }
  88 
  89 #define TYPE_SCTP_FUNC(func) {.fn = func, .name = #func}
  90 
  91 #define TYPE_SCTP_DATA { \
  92          \
  93         TYPE_SCTP_FUNC(sctp_sf_ootb), \
  94          \
  95         TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
  96          \
  97         TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
  98          \
  99         TYPE_SCTP_FUNC(sctp_sf_eat_data_6_2), \
 100          \
 101         TYPE_SCTP_FUNC(sctp_sf_eat_data_6_2), \
 102          \
 103         TYPE_SCTP_FUNC(sctp_sf_eat_data_fast_4_4), \
 104          \
 105         TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
 106          \
 107         TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
 108 } 
 109 
 110 #define TYPE_SCTP_INIT { \
 111          \
 112         TYPE_SCTP_FUNC(sctp_sf_do_5_1B_init), \
 113          \
 114         TYPE_SCTP_FUNC(sctp_sf_do_5_2_1_siminit), \
 115          \
 116         TYPE_SCTP_FUNC(sctp_sf_do_5_2_1_siminit), \
 117          \
 118         TYPE_SCTP_FUNC(sctp_sf_do_5_2_2_dupinit), \
 119          \
 120         TYPE_SCTP_FUNC(sctp_sf_do_5_2_2_dupinit), \
 121          \
 122         TYPE_SCTP_FUNC(sctp_sf_do_5_2_2_dupinit), \
 123          \
 124         TYPE_SCTP_FUNC(sctp_sf_do_5_2_2_dupinit), \
 125          \
 126         TYPE_SCTP_FUNC(sctp_sf_do_9_2_reshutack), \
 127 } 
 128 
 129 #define TYPE_SCTP_INIT_ACK { \
 130          \
 131         TYPE_SCTP_FUNC(sctp_sf_do_5_2_3_initack), \
 132          \
 133         TYPE_SCTP_FUNC(sctp_sf_do_5_1C_ack), \
 134          \
 135         TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
 136          \
 137         TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
 138          \
 139         TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
 140          \
 141         TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
 142          \
 143         TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
 144          \
 145         TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
 146 } 
 147 
 148 #define TYPE_SCTP_SACK { \
 149          \
 150         TYPE_SCTP_FUNC(sctp_sf_ootb), \
 151          \
 152         TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
 153          \
 154         TYPE_SCTP_FUNC(sctp_sf_eat_sack_6_2), \
 155          \
 156         TYPE_SCTP_FUNC(sctp_sf_eat_sack_6_2), \
 157          \
 158         TYPE_SCTP_FUNC(sctp_sf_eat_sack_6_2), \
 159          \
 160         TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
 161          \
 162         TYPE_SCTP_FUNC(sctp_sf_eat_sack_6_2), \
 163          \
 164         TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
 165 } 
 166 
 167 #define TYPE_SCTP_HEARTBEAT { \
 168          \
 169         TYPE_SCTP_FUNC(sctp_sf_ootb), \
 170          \
 171         TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
 172          \
 173         TYPE_SCTP_FUNC(sctp_sf_beat_8_3), \
 174          \
 175         TYPE_SCTP_FUNC(sctp_sf_beat_8_3), \
 176          \
 177         TYPE_SCTP_FUNC(sctp_sf_beat_8_3), \
 178          \
 179         TYPE_SCTP_FUNC(sctp_sf_beat_8_3), \
 180          \
 181         TYPE_SCTP_FUNC(sctp_sf_beat_8_3), \
 182          \
 183          \
 184         TYPE_SCTP_FUNC(sctp_sf_beat_8_3), \
 185 } 
 186 
 187 #define TYPE_SCTP_HEARTBEAT_ACK { \
 188          \
 189         TYPE_SCTP_FUNC(sctp_sf_ootb), \
 190          \
 191         TYPE_SCTP_FUNC(sctp_sf_violation), \
 192          \
 193         TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
 194          \
 195         TYPE_SCTP_FUNC(sctp_sf_backbeat_8_3), \
 196          \
 197         TYPE_SCTP_FUNC(sctp_sf_backbeat_8_3), \
 198          \
 199         TYPE_SCTP_FUNC(sctp_sf_backbeat_8_3), \
 200          \
 201         TYPE_SCTP_FUNC(sctp_sf_backbeat_8_3), \
 202          \
 203         TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
 204 } 
 205 
 206 #define TYPE_SCTP_ABORT { \
 207          \
 208         TYPE_SCTP_FUNC(sctp_sf_pdiscard), \
 209          \
 210         TYPE_SCTP_FUNC(sctp_sf_cookie_wait_abort), \
 211          \
 212         TYPE_SCTP_FUNC(sctp_sf_cookie_echoed_abort), \
 213          \
 214         TYPE_SCTP_FUNC(sctp_sf_do_9_1_abort), \
 215          \
 216         TYPE_SCTP_FUNC(sctp_sf_shutdown_pending_abort), \
 217          \
 218         TYPE_SCTP_FUNC(sctp_sf_shutdown_sent_abort), \
 219          \
 220         TYPE_SCTP_FUNC(sctp_sf_do_9_1_abort), \
 221          \
 222         TYPE_SCTP_FUNC(sctp_sf_shutdown_ack_sent_abort), \
 223 } 
 224 
 225 #define TYPE_SCTP_SHUTDOWN { \
 226          \
 227         TYPE_SCTP_FUNC(sctp_sf_ootb), \
 228          \
 229         TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
 230          \
 231         TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
 232          \
 233         TYPE_SCTP_FUNC(sctp_sf_do_9_2_shutdown), \
 234          \
 235         TYPE_SCTP_FUNC(sctp_sf_do_9_2_shutdown), \
 236          \
 237         TYPE_SCTP_FUNC(sctp_sf_do_9_2_shutdown_ack), \
 238          \
 239         TYPE_SCTP_FUNC(sctp_sf_do_9_2_shut_ctsn), \
 240          \
 241         TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
 242 } 
 243 
 244 #define TYPE_SCTP_SHUTDOWN_ACK { \
 245          \
 246         TYPE_SCTP_FUNC(sctp_sf_ootb), \
 247          \
 248         TYPE_SCTP_FUNC(sctp_sf_do_8_5_1_E_sa), \
 249          \
 250         TYPE_SCTP_FUNC(sctp_sf_do_8_5_1_E_sa), \
 251          \
 252         TYPE_SCTP_FUNC(sctp_sf_violation), \
 253          \
 254         TYPE_SCTP_FUNC(sctp_sf_violation), \
 255          \
 256         TYPE_SCTP_FUNC(sctp_sf_do_9_2_final), \
 257          \
 258         TYPE_SCTP_FUNC(sctp_sf_violation), \
 259          \
 260         TYPE_SCTP_FUNC(sctp_sf_do_9_2_final), \
 261 } 
 262 
 263 #define TYPE_SCTP_ERROR { \
 264          \
 265         TYPE_SCTP_FUNC(sctp_sf_ootb), \
 266          \
 267         TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
 268          \
 269         TYPE_SCTP_FUNC(sctp_sf_cookie_echoed_err), \
 270          \
 271         TYPE_SCTP_FUNC(sctp_sf_operr_notify), \
 272          \
 273         TYPE_SCTP_FUNC(sctp_sf_operr_notify), \
 274          \
 275         TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
 276          \
 277         TYPE_SCTP_FUNC(sctp_sf_operr_notify), \
 278          \
 279         TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
 280 } 
 281 
 282 #define TYPE_SCTP_COOKIE_ECHO { \
 283          \
 284         TYPE_SCTP_FUNC(sctp_sf_do_5_1D_ce), \
 285          \
 286         TYPE_SCTP_FUNC(sctp_sf_do_5_2_4_dupcook), \
 287          \
 288         TYPE_SCTP_FUNC(sctp_sf_do_5_2_4_dupcook), \
 289          \
 290         TYPE_SCTP_FUNC(sctp_sf_do_5_2_4_dupcook), \
 291          \
 292         TYPE_SCTP_FUNC(sctp_sf_do_5_2_4_dupcook), \
 293          \
 294         TYPE_SCTP_FUNC(sctp_sf_do_5_2_4_dupcook), \
 295          \
 296         TYPE_SCTP_FUNC(sctp_sf_do_5_2_4_dupcook), \
 297          \
 298         TYPE_SCTP_FUNC(sctp_sf_do_5_2_4_dupcook), \
 299 } 
 300 
 301 #define TYPE_SCTP_COOKIE_ACK { \
 302          \
 303         TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
 304          \
 305         TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
 306          \
 307         TYPE_SCTP_FUNC(sctp_sf_do_5_1E_ca), \
 308          \
 309         TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
 310          \
 311         TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
 312          \
 313         TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
 314          \
 315         TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
 316          \
 317         TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
 318 } 
 319 
 320 #define TYPE_SCTP_ECN_ECNE { \
 321          \
 322         TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
 323          \
 324         TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
 325          \
 326         TYPE_SCTP_FUNC(sctp_sf_do_ecne), \
 327          \
 328         TYPE_SCTP_FUNC(sctp_sf_do_ecne), \
 329          \
 330         TYPE_SCTP_FUNC(sctp_sf_do_ecne), \
 331          \
 332         TYPE_SCTP_FUNC(sctp_sf_do_ecne), \
 333          \
 334         TYPE_SCTP_FUNC(sctp_sf_do_ecne), \
 335          \
 336         TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
 337 } 
 338 
 339 #define TYPE_SCTP_ECN_CWR { \
 340          \
 341         TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
 342          \
 343         TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
 344          \
 345         TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
 346          \
 347         TYPE_SCTP_FUNC(sctp_sf_do_ecn_cwr), \
 348          \
 349         TYPE_SCTP_FUNC(sctp_sf_do_ecn_cwr), \
 350          \
 351         TYPE_SCTP_FUNC(sctp_sf_do_ecn_cwr), \
 352          \
 353         TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
 354          \
 355         TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
 356 } 
 357 
 358 #define TYPE_SCTP_SHUTDOWN_COMPLETE { \
 359          \
 360         TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
 361          \
 362         TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
 363          \
 364         TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
 365          \
 366         TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
 367          \
 368         TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
 369          \
 370         TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
 371          \
 372         TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
 373          \
 374         TYPE_SCTP_FUNC(sctp_sf_do_4_C), \
 375 } 
 376 
 377 
 378 
 379 
 380 
 381 
 382 static const struct sctp_sm_table_entry
 383 chunk_event_table[SCTP_NUM_BASE_CHUNK_TYPES][SCTP_STATE_NUM_STATES] = {
 384         TYPE_SCTP_DATA,
 385         TYPE_SCTP_INIT,
 386         TYPE_SCTP_INIT_ACK,
 387         TYPE_SCTP_SACK,
 388         TYPE_SCTP_HEARTBEAT,
 389         TYPE_SCTP_HEARTBEAT_ACK,
 390         TYPE_SCTP_ABORT,
 391         TYPE_SCTP_SHUTDOWN,
 392         TYPE_SCTP_SHUTDOWN_ACK,
 393         TYPE_SCTP_ERROR,
 394         TYPE_SCTP_COOKIE_ECHO,
 395         TYPE_SCTP_COOKIE_ACK,
 396         TYPE_SCTP_ECN_ECNE,
 397         TYPE_SCTP_ECN_CWR,
 398         TYPE_SCTP_SHUTDOWN_COMPLETE,
 399 }; 
 400 
 401 #define TYPE_SCTP_ASCONF { \
 402          \
 403         TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
 404          \
 405         TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
 406          \
 407         TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
 408          \
 409         TYPE_SCTP_FUNC(sctp_sf_do_asconf), \
 410          \
 411         TYPE_SCTP_FUNC(sctp_sf_do_asconf), \
 412          \
 413         TYPE_SCTP_FUNC(sctp_sf_do_asconf), \
 414          \
 415         TYPE_SCTP_FUNC(sctp_sf_do_asconf), \
 416          \
 417         TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
 418 } 
 419 
 420 #define TYPE_SCTP_ASCONF_ACK { \
 421          \
 422         TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
 423          \
 424         TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
 425          \
 426         TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
 427          \
 428         TYPE_SCTP_FUNC(sctp_sf_do_asconf_ack), \
 429          \
 430         TYPE_SCTP_FUNC(sctp_sf_do_asconf_ack), \
 431          \
 432         TYPE_SCTP_FUNC(sctp_sf_do_asconf_ack), \
 433          \
 434         TYPE_SCTP_FUNC(sctp_sf_do_asconf_ack), \
 435          \
 436         TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
 437 } 
 438 
 439 
 440 
 441 
 442 static const struct sctp_sm_table_entry
 443 addip_chunk_event_table[SCTP_NUM_ADDIP_CHUNK_TYPES][SCTP_STATE_NUM_STATES] = {
 444         TYPE_SCTP_ASCONF,
 445         TYPE_SCTP_ASCONF_ACK,
 446 }; 
 447 
 448 #define TYPE_SCTP_FWD_TSN { \
 449          \
 450         TYPE_SCTP_FUNC(sctp_sf_ootb), \
 451          \
 452         TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
 453          \
 454         TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
 455          \
 456         TYPE_SCTP_FUNC(sctp_sf_eat_fwd_tsn), \
 457          \
 458         TYPE_SCTP_FUNC(sctp_sf_eat_fwd_tsn), \
 459          \
 460         TYPE_SCTP_FUNC(sctp_sf_eat_fwd_tsn_fast), \
 461          \
 462         TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
 463          \
 464         TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
 465 } 
 466 
 467 
 468 
 469 
 470 static const struct sctp_sm_table_entry
 471 prsctp_chunk_event_table[SCTP_NUM_PRSCTP_CHUNK_TYPES][SCTP_STATE_NUM_STATES] = {
 472         TYPE_SCTP_FWD_TSN,
 473 }; 
 474 
 475 #define TYPE_SCTP_RECONF { \
 476          \
 477         TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
 478          \
 479         TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
 480          \
 481         TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
 482          \
 483         TYPE_SCTP_FUNC(sctp_sf_do_reconf), \
 484          \
 485         TYPE_SCTP_FUNC(sctp_sf_do_reconf), \
 486          \
 487         TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
 488          \
 489         TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
 490          \
 491         TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
 492 } 
 493 
 494 
 495 
 496 
 497 static const struct sctp_sm_table_entry
 498 reconf_chunk_event_table[SCTP_NUM_RECONF_CHUNK_TYPES][SCTP_STATE_NUM_STATES] = {
 499         TYPE_SCTP_RECONF,
 500 }; 
 501 
 502 #define TYPE_SCTP_AUTH { \
 503          \
 504         TYPE_SCTP_FUNC(sctp_sf_ootb), \
 505          \
 506         TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
 507          \
 508         TYPE_SCTP_FUNC(sctp_sf_eat_auth), \
 509          \
 510         TYPE_SCTP_FUNC(sctp_sf_eat_auth), \
 511          \
 512         TYPE_SCTP_FUNC(sctp_sf_eat_auth), \
 513          \
 514         TYPE_SCTP_FUNC(sctp_sf_eat_auth), \
 515          \
 516         TYPE_SCTP_FUNC(sctp_sf_eat_auth), \
 517          \
 518         TYPE_SCTP_FUNC(sctp_sf_eat_auth), \
 519 } 
 520 
 521 
 522 
 523 
 524 static const struct sctp_sm_table_entry
 525 auth_chunk_event_table[SCTP_NUM_AUTH_CHUNK_TYPES][SCTP_STATE_NUM_STATES] = {
 526         TYPE_SCTP_AUTH,
 527 }; 
 528 
 529 static const struct sctp_sm_table_entry
 530 chunk_event_table_unknown[SCTP_STATE_NUM_STATES] = {
 531         
 532         TYPE_SCTP_FUNC(sctp_sf_ootb),
 533         
 534         TYPE_SCTP_FUNC(sctp_sf_unk_chunk),
 535         
 536         TYPE_SCTP_FUNC(sctp_sf_unk_chunk),
 537         
 538         TYPE_SCTP_FUNC(sctp_sf_unk_chunk),
 539         
 540         TYPE_SCTP_FUNC(sctp_sf_unk_chunk),
 541         
 542         TYPE_SCTP_FUNC(sctp_sf_unk_chunk),
 543         
 544         TYPE_SCTP_FUNC(sctp_sf_unk_chunk),
 545         
 546         TYPE_SCTP_FUNC(sctp_sf_unk_chunk),
 547 };      
 548 
 549 
 550 #define TYPE_SCTP_PRIMITIVE_ASSOCIATE  { \
 551          \
 552         TYPE_SCTP_FUNC(sctp_sf_do_prm_asoc), \
 553          \
 554         TYPE_SCTP_FUNC(sctp_sf_not_impl), \
 555          \
 556         TYPE_SCTP_FUNC(sctp_sf_not_impl), \
 557          \
 558         TYPE_SCTP_FUNC(sctp_sf_not_impl), \
 559          \
 560         TYPE_SCTP_FUNC(sctp_sf_not_impl), \
 561          \
 562         TYPE_SCTP_FUNC(sctp_sf_not_impl), \
 563          \
 564         TYPE_SCTP_FUNC(sctp_sf_not_impl), \
 565          \
 566         TYPE_SCTP_FUNC(sctp_sf_not_impl), \
 567 } 
 568 
 569 #define TYPE_SCTP_PRIMITIVE_SHUTDOWN  { \
 570          \
 571         TYPE_SCTP_FUNC(sctp_sf_error_closed), \
 572          \
 573         TYPE_SCTP_FUNC(sctp_sf_cookie_wait_prm_shutdown), \
 574          \
 575         TYPE_SCTP_FUNC(sctp_sf_cookie_echoed_prm_shutdown),\
 576          \
 577         TYPE_SCTP_FUNC(sctp_sf_do_9_2_prm_shutdown), \
 578          \
 579         TYPE_SCTP_FUNC(sctp_sf_ignore_primitive), \
 580          \
 581         TYPE_SCTP_FUNC(sctp_sf_ignore_primitive), \
 582          \
 583         TYPE_SCTP_FUNC(sctp_sf_ignore_primitive), \
 584          \
 585         TYPE_SCTP_FUNC(sctp_sf_ignore_primitive), \
 586 } 
 587 
 588 #define TYPE_SCTP_PRIMITIVE_ABORT  { \
 589          \
 590         TYPE_SCTP_FUNC(sctp_sf_error_closed), \
 591          \
 592         TYPE_SCTP_FUNC(sctp_sf_cookie_wait_prm_abort), \
 593          \
 594         TYPE_SCTP_FUNC(sctp_sf_cookie_echoed_prm_abort), \
 595          \
 596         TYPE_SCTP_FUNC(sctp_sf_do_9_1_prm_abort), \
 597          \
 598         TYPE_SCTP_FUNC(sctp_sf_shutdown_pending_prm_abort), \
 599          \
 600         TYPE_SCTP_FUNC(sctp_sf_shutdown_sent_prm_abort), \
 601          \
 602         TYPE_SCTP_FUNC(sctp_sf_do_9_1_prm_abort), \
 603          \
 604         TYPE_SCTP_FUNC(sctp_sf_shutdown_ack_sent_prm_abort), \
 605 } 
 606 
 607 #define TYPE_SCTP_PRIMITIVE_SEND  { \
 608          \
 609         TYPE_SCTP_FUNC(sctp_sf_error_closed), \
 610          \
 611         TYPE_SCTP_FUNC(sctp_sf_do_prm_send), \
 612          \
 613         TYPE_SCTP_FUNC(sctp_sf_do_prm_send), \
 614          \
 615         TYPE_SCTP_FUNC(sctp_sf_do_prm_send), \
 616          \
 617         TYPE_SCTP_FUNC(sctp_sf_error_shutdown), \
 618          \
 619         TYPE_SCTP_FUNC(sctp_sf_error_shutdown), \
 620          \
 621         TYPE_SCTP_FUNC(sctp_sf_error_shutdown), \
 622          \
 623         TYPE_SCTP_FUNC(sctp_sf_error_shutdown), \
 624 } 
 625 
 626 #define TYPE_SCTP_PRIMITIVE_REQUESTHEARTBEAT  { \
 627          \
 628         TYPE_SCTP_FUNC(sctp_sf_error_closed), \
 629          \
 630         TYPE_SCTP_FUNC(sctp_sf_do_prm_requestheartbeat),          \
 631          \
 632         TYPE_SCTP_FUNC(sctp_sf_do_prm_requestheartbeat),          \
 633          \
 634         TYPE_SCTP_FUNC(sctp_sf_do_prm_requestheartbeat),          \
 635          \
 636         TYPE_SCTP_FUNC(sctp_sf_do_prm_requestheartbeat),          \
 637          \
 638         TYPE_SCTP_FUNC(sctp_sf_do_prm_requestheartbeat),          \
 639          \
 640         TYPE_SCTP_FUNC(sctp_sf_do_prm_requestheartbeat),          \
 641          \
 642         TYPE_SCTP_FUNC(sctp_sf_do_prm_requestheartbeat),          \
 643 } 
 644 
 645 #define TYPE_SCTP_PRIMITIVE_ASCONF { \
 646          \
 647         TYPE_SCTP_FUNC(sctp_sf_error_closed), \
 648          \
 649         TYPE_SCTP_FUNC(sctp_sf_error_closed), \
 650          \
 651         TYPE_SCTP_FUNC(sctp_sf_error_closed), \
 652          \
 653         TYPE_SCTP_FUNC(sctp_sf_do_prm_asconf), \
 654          \
 655         TYPE_SCTP_FUNC(sctp_sf_do_prm_asconf), \
 656          \
 657         TYPE_SCTP_FUNC(sctp_sf_do_prm_asconf), \
 658          \
 659         TYPE_SCTP_FUNC(sctp_sf_do_prm_asconf), \
 660          \
 661         TYPE_SCTP_FUNC(sctp_sf_error_shutdown), \
 662 } 
 663 
 664 #define TYPE_SCTP_PRIMITIVE_RECONF { \
 665          \
 666         TYPE_SCTP_FUNC(sctp_sf_error_closed), \
 667          \
 668         TYPE_SCTP_FUNC(sctp_sf_error_closed), \
 669          \
 670         TYPE_SCTP_FUNC(sctp_sf_error_closed), \
 671          \
 672         TYPE_SCTP_FUNC(sctp_sf_do_prm_reconf), \
 673          \
 674         TYPE_SCTP_FUNC(sctp_sf_do_prm_reconf), \
 675          \
 676         TYPE_SCTP_FUNC(sctp_sf_do_prm_reconf), \
 677          \
 678         TYPE_SCTP_FUNC(sctp_sf_do_prm_reconf), \
 679          \
 680         TYPE_SCTP_FUNC(sctp_sf_error_shutdown), \
 681 } 
 682 
 683 
 684 
 685 
 686 static const struct sctp_sm_table_entry
 687 primitive_event_table[SCTP_NUM_PRIMITIVE_TYPES][SCTP_STATE_NUM_STATES] = {
 688         TYPE_SCTP_PRIMITIVE_ASSOCIATE,
 689         TYPE_SCTP_PRIMITIVE_SHUTDOWN,
 690         TYPE_SCTP_PRIMITIVE_ABORT,
 691         TYPE_SCTP_PRIMITIVE_SEND,
 692         TYPE_SCTP_PRIMITIVE_REQUESTHEARTBEAT,
 693         TYPE_SCTP_PRIMITIVE_ASCONF,
 694         TYPE_SCTP_PRIMITIVE_RECONF,
 695 };
 696 
 697 #define TYPE_SCTP_OTHER_NO_PENDING_TSN  { \
 698          \
 699         TYPE_SCTP_FUNC(sctp_sf_ignore_other), \
 700          \
 701         TYPE_SCTP_FUNC(sctp_sf_ignore_other), \
 702          \
 703         TYPE_SCTP_FUNC(sctp_sf_ignore_other), \
 704          \
 705         TYPE_SCTP_FUNC(sctp_sf_do_no_pending_tsn), \
 706          \
 707         TYPE_SCTP_FUNC(sctp_sf_do_9_2_start_shutdown), \
 708          \
 709         TYPE_SCTP_FUNC(sctp_sf_ignore_other), \
 710          \
 711         TYPE_SCTP_FUNC(sctp_sf_do_9_2_shutdown_ack), \
 712          \
 713         TYPE_SCTP_FUNC(sctp_sf_ignore_other), \
 714 }
 715 
 716 #define TYPE_SCTP_OTHER_ICMP_PROTO_UNREACH  { \
 717          \
 718         TYPE_SCTP_FUNC(sctp_sf_ignore_other), \
 719          \
 720         TYPE_SCTP_FUNC(sctp_sf_cookie_wait_icmp_abort), \
 721          \
 722         TYPE_SCTP_FUNC(sctp_sf_ignore_other), \
 723          \
 724         TYPE_SCTP_FUNC(sctp_sf_ignore_other), \
 725          \
 726         TYPE_SCTP_FUNC(sctp_sf_ignore_other), \
 727          \
 728         TYPE_SCTP_FUNC(sctp_sf_ignore_other), \
 729          \
 730         TYPE_SCTP_FUNC(sctp_sf_ignore_other), \
 731          \
 732         TYPE_SCTP_FUNC(sctp_sf_ignore_other), \
 733 }
 734 
 735 static const struct sctp_sm_table_entry
 736 other_event_table[SCTP_NUM_OTHER_TYPES][SCTP_STATE_NUM_STATES] = {
 737         TYPE_SCTP_OTHER_NO_PENDING_TSN,
 738         TYPE_SCTP_OTHER_ICMP_PROTO_UNREACH,
 739 };
 740 
 741 #define TYPE_SCTP_EVENT_TIMEOUT_NONE { \
 742          \
 743         TYPE_SCTP_FUNC(sctp_sf_bug), \
 744          \
 745         TYPE_SCTP_FUNC(sctp_sf_bug), \
 746          \
 747         TYPE_SCTP_FUNC(sctp_sf_bug), \
 748          \
 749         TYPE_SCTP_FUNC(sctp_sf_bug), \
 750          \
 751         TYPE_SCTP_FUNC(sctp_sf_bug), \
 752          \
 753         TYPE_SCTP_FUNC(sctp_sf_bug), \
 754          \
 755         TYPE_SCTP_FUNC(sctp_sf_bug), \
 756          \
 757         TYPE_SCTP_FUNC(sctp_sf_bug), \
 758 }
 759 
 760 #define TYPE_SCTP_EVENT_TIMEOUT_T1_COOKIE { \
 761          \
 762         TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
 763          \
 764         TYPE_SCTP_FUNC(sctp_sf_bug), \
 765          \
 766         TYPE_SCTP_FUNC(sctp_sf_t1_cookie_timer_expire), \
 767          \
 768         TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
 769          \
 770         TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
 771          \
 772         TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
 773          \
 774         TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
 775          \
 776         TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
 777 }
 778 
 779 #define TYPE_SCTP_EVENT_TIMEOUT_T1_INIT { \
 780          \
 781         TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
 782          \
 783         TYPE_SCTP_FUNC(sctp_sf_t1_init_timer_expire), \
 784          \
 785         TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
 786          \
 787         TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
 788          \
 789         TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
 790          \
 791         TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
 792          \
 793         TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
 794          \
 795         TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
 796 }
 797 
 798 #define TYPE_SCTP_EVENT_TIMEOUT_T2_SHUTDOWN { \
 799          \
 800         TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
 801          \
 802         TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
 803          \
 804         TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
 805          \
 806         TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
 807          \
 808         TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
 809          \
 810         TYPE_SCTP_FUNC(sctp_sf_t2_timer_expire), \
 811          \
 812         TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
 813          \
 814         TYPE_SCTP_FUNC(sctp_sf_t2_timer_expire), \
 815 }
 816 
 817 #define TYPE_SCTP_EVENT_TIMEOUT_T3_RTX { \
 818          \
 819         TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
 820          \
 821         TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
 822          \
 823         TYPE_SCTP_FUNC(sctp_sf_do_6_3_3_rtx), \
 824          \
 825         TYPE_SCTP_FUNC(sctp_sf_do_6_3_3_rtx), \
 826          \
 827         TYPE_SCTP_FUNC(sctp_sf_do_6_3_3_rtx), \
 828          \
 829         TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
 830          \
 831         TYPE_SCTP_FUNC(sctp_sf_do_6_3_3_rtx), \
 832          \
 833         TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
 834 }
 835 
 836 #define TYPE_SCTP_EVENT_TIMEOUT_T4_RTO { \
 837          \
 838         TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
 839          \
 840         TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
 841          \
 842         TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
 843          \
 844         TYPE_SCTP_FUNC(sctp_sf_t4_timer_expire), \
 845          \
 846         TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
 847          \
 848         TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
 849          \
 850         TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
 851          \
 852         TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
 853 }
 854 
 855 #define TYPE_SCTP_EVENT_TIMEOUT_T5_SHUTDOWN_GUARD { \
 856          \
 857         TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
 858          \
 859         TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
 860          \
 861         TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
 862          \
 863         TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
 864          \
 865         TYPE_SCTP_FUNC(sctp_sf_t5_timer_expire), \
 866          \
 867         TYPE_SCTP_FUNC(sctp_sf_t5_timer_expire), \
 868          \
 869         TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
 870          \
 871         TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
 872 }
 873 
 874 #define TYPE_SCTP_EVENT_TIMEOUT_HEARTBEAT { \
 875          \
 876         TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
 877          \
 878         TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
 879          \
 880         TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
 881          \
 882         TYPE_SCTP_FUNC(sctp_sf_sendbeat_8_3), \
 883          \
 884         TYPE_SCTP_FUNC(sctp_sf_sendbeat_8_3), \
 885          \
 886         TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
 887          \
 888         TYPE_SCTP_FUNC(sctp_sf_sendbeat_8_3), \
 889          \
 890         TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
 891 }
 892 
 893 #define TYPE_SCTP_EVENT_TIMEOUT_SACK { \
 894          \
 895         TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
 896          \
 897         TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
 898          \
 899         TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
 900          \
 901         TYPE_SCTP_FUNC(sctp_sf_do_6_2_sack), \
 902          \
 903         TYPE_SCTP_FUNC(sctp_sf_do_6_2_sack), \
 904          \
 905         TYPE_SCTP_FUNC(sctp_sf_do_6_2_sack), \
 906          \
 907         TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
 908          \
 909         TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
 910 }
 911 
 912 #define TYPE_SCTP_EVENT_TIMEOUT_AUTOCLOSE { \
 913          \
 914         TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
 915          \
 916         TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
 917          \
 918         TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
 919          \
 920         TYPE_SCTP_FUNC(sctp_sf_autoclose_timer_expire), \
 921          \
 922         TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
 923          \
 924         TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
 925          \
 926         TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
 927          \
 928         TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
 929 }
 930 
 931 #define TYPE_SCTP_EVENT_TIMEOUT_RECONF { \
 932          \
 933         TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
 934          \
 935         TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
 936          \
 937         TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
 938          \
 939         TYPE_SCTP_FUNC(sctp_sf_send_reconf), \
 940          \
 941         TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
 942          \
 943         TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
 944          \
 945         TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
 946          \
 947         TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
 948 }
 949 
 950 static const struct sctp_sm_table_entry
 951 timeout_event_table[SCTP_NUM_TIMEOUT_TYPES][SCTP_STATE_NUM_STATES] = {
 952         TYPE_SCTP_EVENT_TIMEOUT_NONE,
 953         TYPE_SCTP_EVENT_TIMEOUT_T1_COOKIE,
 954         TYPE_SCTP_EVENT_TIMEOUT_T1_INIT,
 955         TYPE_SCTP_EVENT_TIMEOUT_T2_SHUTDOWN,
 956         TYPE_SCTP_EVENT_TIMEOUT_T3_RTX,
 957         TYPE_SCTP_EVENT_TIMEOUT_T4_RTO,
 958         TYPE_SCTP_EVENT_TIMEOUT_T5_SHUTDOWN_GUARD,
 959         TYPE_SCTP_EVENT_TIMEOUT_HEARTBEAT,
 960         TYPE_SCTP_EVENT_TIMEOUT_RECONF,
 961         TYPE_SCTP_EVENT_TIMEOUT_SACK,
 962         TYPE_SCTP_EVENT_TIMEOUT_AUTOCLOSE,
 963 };
 964 
 965 static const struct sctp_sm_table_entry *sctp_chunk_event_lookup(
 966                                                 struct net *net,
 967                                                 enum sctp_cid cid,
 968                                                 enum sctp_state state)
 969 {
 970         if (state > SCTP_STATE_MAX)
 971                 return &bug;
 972 
 973         if (cid == SCTP_CID_I_DATA)
 974                 cid = SCTP_CID_DATA;
 975 
 976         if (cid <= SCTP_CID_BASE_MAX)
 977                 return &chunk_event_table[cid][state];
 978 
 979         switch ((u16)cid) {
 980         case SCTP_CID_FWD_TSN:
 981         case SCTP_CID_I_FWD_TSN:
 982                 return &prsctp_chunk_event_table[0][state];
 983 
 984         case SCTP_CID_ASCONF:
 985                 return &addip_chunk_event_table[0][state];
 986 
 987         case SCTP_CID_ASCONF_ACK:
 988                 return &addip_chunk_event_table[1][state];
 989 
 990         case SCTP_CID_RECONF:
 991                 return &reconf_chunk_event_table[0][state];
 992 
 993         case SCTP_CID_AUTH:
 994                 return &auth_chunk_event_table[0][state];
 995         }
 996 
 997         return &chunk_event_table_unknown[state];
 998 }