sm_statetable.c 33 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980
  1. /* SCTP kernel reference Implementation
  2. * (C) Copyright IBM Corp. 2001, 2004
  3. * Copyright (c) 1999-2000 Cisco, Inc.
  4. * Copyright (c) 1999-2001 Motorola, Inc.
  5. * Copyright (c) 2001 Intel Corp.
  6. * Copyright (c) 2001 Nokia, Inc.
  7. *
  8. * This file is part of the SCTP kernel reference Implementation
  9. *
  10. * These are the state tables for the SCTP state machine.
  11. *
  12. * The SCTP reference implementation is free software;
  13. * you can redistribute it and/or modify it under the terms of
  14. * the GNU General Public License as published by
  15. * the Free Software Foundation; either version 2, or (at your option)
  16. * any later version.
  17. *
  18. * The SCTP reference implementation is distributed in the hope that it
  19. * will be useful, but WITHOUT ANY WARRANTY; without even the implied
  20. * ************************
  21. * warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
  22. * See the GNU General Public License for more details.
  23. *
  24. * You should have received a copy of the GNU General Public License
  25. * along with GNU CC; see the file COPYING. If not, write to
  26. * the Free Software Foundation, 59 Temple Place - Suite 330,
  27. * Boston, MA 02111-1307, USA.
  28. *
  29. * Please send any bug reports or fixes you make to the
  30. * email address(es):
  31. * lksctp developers <lksctp-developers@lists.sourceforge.net>
  32. *
  33. * Or submit a bug report through the following website:
  34. * http://www.sf.net/projects/lksctp
  35. *
  36. * Written or modified by:
  37. * La Monte H.P. Yarroll <piggy@acm.org>
  38. * Karl Knutson <karl@athena.chicago.il.us>
  39. * Jon Grimm <jgrimm@us.ibm.com>
  40. * Hui Huang <hui.huang@nokia.com>
  41. * Daisy Chang <daisyc@us.ibm.com>
  42. * Ardelle Fan <ardelle.fan@intel.com>
  43. * Sridhar Samudrala <sri@us.ibm.com>
  44. *
  45. * Any bugs reported given to us we will try to fix... any fixes shared will
  46. * be incorporated into the next SCTP release.
  47. */
  48. #include <linux/skbuff.h>
  49. #include <net/sctp/sctp.h>
  50. #include <net/sctp/sm.h>
  51. static const sctp_sm_table_entry_t
  52. primitive_event_table[SCTP_NUM_PRIMITIVE_TYPES][SCTP_STATE_NUM_STATES];
  53. static const sctp_sm_table_entry_t
  54. other_event_table[SCTP_NUM_OTHER_TYPES][SCTP_STATE_NUM_STATES];
  55. static const sctp_sm_table_entry_t
  56. timeout_event_table[SCTP_NUM_TIMEOUT_TYPES][SCTP_STATE_NUM_STATES];
  57. static const sctp_sm_table_entry_t *sctp_chunk_event_lookup(sctp_cid_t cid,
  58. sctp_state_t state);
  59. static const sctp_sm_table_entry_t bug = {
  60. .fn = sctp_sf_bug,
  61. .name = "sctp_sf_bug"
  62. };
  63. #define DO_LOOKUP(_max, _type, _table) \
  64. if ((event_subtype._type > (_max))) { \
  65. printk(KERN_WARNING \
  66. "sctp table %p possible attack:" \
  67. " event %d exceeds max %d\n", \
  68. _table, event_subtype._type, _max); \
  69. return &bug; \
  70. } \
  71. return &_table[event_subtype._type][(int)state];
  72. const sctp_sm_table_entry_t *sctp_sm_lookup_event(sctp_event_t event_type,
  73. sctp_state_t state,
  74. sctp_subtype_t event_subtype)
  75. {
  76. switch (event_type) {
  77. case SCTP_EVENT_T_CHUNK:
  78. return sctp_chunk_event_lookup(event_subtype.chunk, state);
  79. break;
  80. case SCTP_EVENT_T_TIMEOUT:
  81. DO_LOOKUP(SCTP_EVENT_TIMEOUT_MAX, timeout,
  82. timeout_event_table);
  83. break;
  84. case SCTP_EVENT_T_OTHER:
  85. DO_LOOKUP(SCTP_EVENT_OTHER_MAX, other, other_event_table);
  86. break;
  87. case SCTP_EVENT_T_PRIMITIVE:
  88. DO_LOOKUP(SCTP_EVENT_PRIMITIVE_MAX, primitive,
  89. primitive_event_table);
  90. break;
  91. default:
  92. /* Yikes! We got an illegal event type. */
  93. return &bug;
  94. }
  95. }
  96. #define TYPE_SCTP_FUNC(func) {.fn = func, .name = #func}
  97. #define TYPE_SCTP_DATA { \
  98. /* SCTP_STATE_EMPTY */ \
  99. TYPE_SCTP_FUNC(sctp_sf_ootb), \
  100. /* SCTP_STATE_CLOSED */ \
  101. TYPE_SCTP_FUNC(sctp_sf_tabort_8_4_8), \
  102. /* SCTP_STATE_COOKIE_WAIT */ \
  103. TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
  104. /* SCTP_STATE_COOKIE_ECHOED */ \
  105. TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
  106. /* SCTP_STATE_ESTABLISHED */ \
  107. TYPE_SCTP_FUNC(sctp_sf_eat_data_6_2), \
  108. /* SCTP_STATE_SHUTDOWN_PENDING */ \
  109. TYPE_SCTP_FUNC(sctp_sf_eat_data_6_2), \
  110. /* SCTP_STATE_SHUTDOWN_SENT */ \
  111. TYPE_SCTP_FUNC(sctp_sf_eat_data_fast_4_4), \
  112. /* SCTP_STATE_SHUTDOWN_RECEIVED */ \
  113. TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
  114. /* SCTP_STATE_SHUTDOWN_ACK_SENT */ \
  115. TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
  116. } /* TYPE_SCTP_DATA */
  117. #define TYPE_SCTP_INIT { \
  118. /* SCTP_STATE_EMPTY */ \
  119. TYPE_SCTP_FUNC(sctp_sf_bug), \
  120. /* SCTP_STATE_CLOSED */ \
  121. TYPE_SCTP_FUNC(sctp_sf_do_5_1B_init), \
  122. /* SCTP_STATE_COOKIE_WAIT */ \
  123. TYPE_SCTP_FUNC(sctp_sf_do_5_2_1_siminit), \
  124. /* SCTP_STATE_COOKIE_ECHOED */ \
  125. TYPE_SCTP_FUNC(sctp_sf_do_5_2_1_siminit), \
  126. /* SCTP_STATE_ESTABLISHED */ \
  127. TYPE_SCTP_FUNC(sctp_sf_do_5_2_2_dupinit), \
  128. /* SCTP_STATE_SHUTDOWN_PENDING */ \
  129. TYPE_SCTP_FUNC(sctp_sf_do_5_2_2_dupinit), \
  130. /* SCTP_STATE_SHUTDOWN_SENT */ \
  131. TYPE_SCTP_FUNC(sctp_sf_do_5_2_2_dupinit), \
  132. /* SCTP_STATE_SHUTDOWN_RECEIVED */ \
  133. TYPE_SCTP_FUNC(sctp_sf_do_5_2_2_dupinit), \
  134. /* SCTP_STATE_SHUTDOWN_ACK_SENT */ \
  135. TYPE_SCTP_FUNC(sctp_sf_do_9_2_reshutack), \
  136. } /* TYPE_SCTP_INIT */
  137. #define TYPE_SCTP_INIT_ACK { \
  138. /* SCTP_STATE_EMPTY */ \
  139. TYPE_SCTP_FUNC(sctp_sf_ootb), \
  140. /* SCTP_STATE_CLOSED */ \
  141. TYPE_SCTP_FUNC(sctp_sf_do_5_2_3_initack), \
  142. /* SCTP_STATE_COOKIE_WAIT */ \
  143. TYPE_SCTP_FUNC(sctp_sf_do_5_1C_ack), \
  144. /* SCTP_STATE_COOKIE_ECHOED */ \
  145. TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
  146. /* SCTP_STATE_ESTABLISHED */ \
  147. TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
  148. /* SCTP_STATE_SHUTDOWN_PENDING */ \
  149. TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
  150. /* SCTP_STATE_SHUTDOWN_SENT */ \
  151. TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
  152. /* SCTP_STATE_SHUTDOWN_RECEIVED */ \
  153. TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
  154. /* SCTP_STATE_SHUTDOWN_ACK_SENT */ \
  155. TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
  156. } /* TYPE_SCTP_INIT_ACK */
  157. #define TYPE_SCTP_SACK { \
  158. /* SCTP_STATE_EMPTY */ \
  159. TYPE_SCTP_FUNC(sctp_sf_ootb), \
  160. /* SCTP_STATE_CLOSED */ \
  161. TYPE_SCTP_FUNC(sctp_sf_tabort_8_4_8), \
  162. /* SCTP_STATE_COOKIE_WAIT */ \
  163. TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
  164. /* SCTP_STATE_COOKIE_ECHOED */ \
  165. TYPE_SCTP_FUNC(sctp_sf_eat_sack_6_2), \
  166. /* SCTP_STATE_ESTABLISHED */ \
  167. TYPE_SCTP_FUNC(sctp_sf_eat_sack_6_2), \
  168. /* SCTP_STATE_SHUTDOWN_PENDING */ \
  169. TYPE_SCTP_FUNC(sctp_sf_eat_sack_6_2), \
  170. /* SCTP_STATE_SHUTDOWN_SENT */ \
  171. TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
  172. /* SCTP_STATE_SHUTDOWN_RECEIVED */ \
  173. TYPE_SCTP_FUNC(sctp_sf_eat_sack_6_2), \
  174. /* SCTP_STATE_SHUTDOWN_ACK_SENT */ \
  175. TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
  176. } /* TYPE_SCTP_SACK */
  177. #define TYPE_SCTP_HEARTBEAT { \
  178. /* SCTP_STATE_EMPTY */ \
  179. TYPE_SCTP_FUNC(sctp_sf_ootb), \
  180. /* SCTP_STATE_CLOSED */ \
  181. TYPE_SCTP_FUNC(sctp_sf_tabort_8_4_8), \
  182. /* SCTP_STATE_COOKIE_WAIT */ \
  183. TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
  184. /* SCTP_STATE_COOKIE_ECHOED */ \
  185. TYPE_SCTP_FUNC(sctp_sf_beat_8_3), \
  186. /* SCTP_STATE_ESTABLISHED */ \
  187. TYPE_SCTP_FUNC(sctp_sf_beat_8_3), \
  188. /* SCTP_STATE_SHUTDOWN_PENDING */ \
  189. TYPE_SCTP_FUNC(sctp_sf_beat_8_3), \
  190. /* SCTP_STATE_SHUTDOWN_SENT */ \
  191. TYPE_SCTP_FUNC(sctp_sf_beat_8_3), \
  192. /* SCTP_STATE_SHUTDOWN_RECEIVED */ \
  193. TYPE_SCTP_FUNC(sctp_sf_beat_8_3), \
  194. /* SCTP_STATE_SHUTDOWN_ACK_SENT */ \
  195. /* This should not happen, but we are nice. */ \
  196. TYPE_SCTP_FUNC(sctp_sf_beat_8_3), \
  197. } /* TYPE_SCTP_HEARTBEAT */
  198. #define TYPE_SCTP_HEARTBEAT_ACK { \
  199. /* SCTP_STATE_EMPTY */ \
  200. TYPE_SCTP_FUNC(sctp_sf_ootb), \
  201. /* SCTP_STATE_CLOSED */ \
  202. TYPE_SCTP_FUNC(sctp_sf_tabort_8_4_8), \
  203. /* SCTP_STATE_COOKIE_WAIT */ \
  204. TYPE_SCTP_FUNC(sctp_sf_violation), \
  205. /* SCTP_STATE_COOKIE_ECHOED */ \
  206. TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
  207. /* SCTP_STATE_ESTABLISHED */ \
  208. TYPE_SCTP_FUNC(sctp_sf_backbeat_8_3), \
  209. /* SCTP_STATE_SHUTDOWN_PENDING */ \
  210. TYPE_SCTP_FUNC(sctp_sf_backbeat_8_3), \
  211. /* SCTP_STATE_SHUTDOWN_SENT */ \
  212. TYPE_SCTP_FUNC(sctp_sf_backbeat_8_3), \
  213. /* SCTP_STATE_SHUTDOWN_RECEIVED */ \
  214. TYPE_SCTP_FUNC(sctp_sf_backbeat_8_3), \
  215. /* SCTP_STATE_SHUTDOWN_ACK_SENT */ \
  216. TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
  217. } /* TYPE_SCTP_HEARTBEAT_ACK */
  218. #define TYPE_SCTP_ABORT { \
  219. /* SCTP_STATE_EMPTY */ \
  220. TYPE_SCTP_FUNC(sctp_sf_ootb), \
  221. /* SCTP_STATE_CLOSED */ \
  222. TYPE_SCTP_FUNC(sctp_sf_pdiscard), \
  223. /* SCTP_STATE_COOKIE_WAIT */ \
  224. TYPE_SCTP_FUNC(sctp_sf_cookie_wait_abort), \
  225. /* SCTP_STATE_COOKIE_ECHOED */ \
  226. TYPE_SCTP_FUNC(sctp_sf_cookie_echoed_abort), \
  227. /* SCTP_STATE_ESTABLISHED */ \
  228. TYPE_SCTP_FUNC(sctp_sf_do_9_1_abort), \
  229. /* SCTP_STATE_SHUTDOWN_PENDING */ \
  230. TYPE_SCTP_FUNC(sctp_sf_shutdown_pending_abort), \
  231. /* SCTP_STATE_SHUTDOWN_SENT */ \
  232. TYPE_SCTP_FUNC(sctp_sf_shutdown_sent_abort), \
  233. /* SCTP_STATE_SHUTDOWN_RECEIVED */ \
  234. TYPE_SCTP_FUNC(sctp_sf_do_9_1_abort), \
  235. /* SCTP_STATE_SHUTDOWN_ACK_SENT */ \
  236. TYPE_SCTP_FUNC(sctp_sf_shutdown_ack_sent_abort), \
  237. } /* TYPE_SCTP_ABORT */
  238. #define TYPE_SCTP_SHUTDOWN { \
  239. /* SCTP_STATE_EMPTY */ \
  240. TYPE_SCTP_FUNC(sctp_sf_ootb), \
  241. /* SCTP_STATE_CLOSED */ \
  242. TYPE_SCTP_FUNC(sctp_sf_tabort_8_4_8), \
  243. /* SCTP_STATE_COOKIE_WAIT */ \
  244. TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
  245. /* SCTP_STATE_COOKIE_ECHOED */ \
  246. TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
  247. /* SCTP_STATE_ESTABLISHED */ \
  248. TYPE_SCTP_FUNC(sctp_sf_do_9_2_shutdown), \
  249. /* SCTP_STATE_SHUTDOWN_PENDING */ \
  250. TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
  251. /* SCTP_STATE_SHUTDOWN_SENT */ \
  252. TYPE_SCTP_FUNC(sctp_sf_do_9_2_shutdown_ack), \
  253. /* SCTP_STATE_SHUTDOWN_RECEIVED */ \
  254. TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
  255. /* SCTP_STATE_SHUTDOWN_ACK_SENT */ \
  256. TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
  257. } /* TYPE_SCTP_SHUTDOWN */
  258. #define TYPE_SCTP_SHUTDOWN_ACK { \
  259. /* SCTP_STATE_EMPTY */ \
  260. TYPE_SCTP_FUNC(sctp_sf_ootb), \
  261. /* SCTP_STATE_CLOSED */ \
  262. TYPE_SCTP_FUNC(sctp_sf_ootb), \
  263. /* SCTP_STATE_COOKIE_WAIT */ \
  264. TYPE_SCTP_FUNC(sctp_sf_do_8_5_1_E_sa), \
  265. /* SCTP_STATE_COOKIE_ECHOED */ \
  266. TYPE_SCTP_FUNC(sctp_sf_do_8_5_1_E_sa), \
  267. /* SCTP_STATE_ESTABLISHED */ \
  268. TYPE_SCTP_FUNC(sctp_sf_violation), \
  269. /* SCTP_STATE_SHUTDOWN_PENDING */ \
  270. TYPE_SCTP_FUNC(sctp_sf_violation), \
  271. /* SCTP_STATE_SHUTDOWN_SENT */ \
  272. TYPE_SCTP_FUNC(sctp_sf_do_9_2_final), \
  273. /* SCTP_STATE_SHUTDOWN_RECEIVED */ \
  274. TYPE_SCTP_FUNC(sctp_sf_violation), \
  275. /* SCTP_STATE_SHUTDOWN_ACK_SENT */ \
  276. TYPE_SCTP_FUNC(sctp_sf_do_9_2_final), \
  277. } /* TYPE_SCTP_SHUTDOWN_ACK */
  278. #define TYPE_SCTP_ERROR { \
  279. /* SCTP_STATE_EMPTY */ \
  280. TYPE_SCTP_FUNC(sctp_sf_ootb), \
  281. /* SCTP_STATE_CLOSED */ \
  282. TYPE_SCTP_FUNC(sctp_sf_tabort_8_4_8), \
  283. /* SCTP_STATE_COOKIE_WAIT */ \
  284. TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
  285. /* SCTP_STATE_COOKIE_ECHOED */ \
  286. TYPE_SCTP_FUNC(sctp_sf_cookie_echoed_err), \
  287. /* SCTP_STATE_ESTABLISHED */ \
  288. TYPE_SCTP_FUNC(sctp_sf_operr_notify), \
  289. /* SCTP_STATE_SHUTDOWN_PENDING */ \
  290. TYPE_SCTP_FUNC(sctp_sf_operr_notify), \
  291. /* SCTP_STATE_SHUTDOWN_SENT */ \
  292. TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
  293. /* SCTP_STATE_SHUTDOWN_RECEIVED */ \
  294. TYPE_SCTP_FUNC(sctp_sf_operr_notify), \
  295. /* SCTP_STATE_SHUTDOWN_ACK_SENT */ \
  296. TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
  297. } /* TYPE_SCTP_ERROR */
  298. #define TYPE_SCTP_COOKIE_ECHO { \
  299. /* SCTP_STATE_EMPTY */ \
  300. TYPE_SCTP_FUNC(sctp_sf_bug), \
  301. /* SCTP_STATE_CLOSED */ \
  302. TYPE_SCTP_FUNC(sctp_sf_do_5_1D_ce), \
  303. /* SCTP_STATE_COOKIE_WAIT */ \
  304. TYPE_SCTP_FUNC(sctp_sf_do_5_2_4_dupcook), \
  305. /* SCTP_STATE_COOKIE_ECHOED */ \
  306. TYPE_SCTP_FUNC(sctp_sf_do_5_2_4_dupcook), \
  307. /* SCTP_STATE_ESTABLISHED */ \
  308. TYPE_SCTP_FUNC(sctp_sf_do_5_2_4_dupcook), \
  309. /* SCTP_STATE_SHUTDOWN_PENDING */ \
  310. TYPE_SCTP_FUNC(sctp_sf_do_5_2_4_dupcook), \
  311. /* SCTP_STATE_SHUTDOWN_SENT */ \
  312. TYPE_SCTP_FUNC(sctp_sf_do_5_2_4_dupcook), \
  313. /* SCTP_STATE_SHUTDOWN_RECEIVED */ \
  314. TYPE_SCTP_FUNC(sctp_sf_do_5_2_4_dupcook), \
  315. /* SCTP_STATE_SHUTDOWN_ACK_SENT */ \
  316. TYPE_SCTP_FUNC(sctp_sf_do_5_2_4_dupcook), \
  317. } /* TYPE_SCTP_COOKIE_ECHO */
  318. #define TYPE_SCTP_COOKIE_ACK { \
  319. /* SCTP_STATE_EMPTY */ \
  320. TYPE_SCTP_FUNC(sctp_sf_ootb), \
  321. /* SCTP_STATE_CLOSED */ \
  322. TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
  323. /* SCTP_STATE_COOKIE_WAIT */ \
  324. TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
  325. /* SCTP_STATE_COOKIE_ECHOED */ \
  326. TYPE_SCTP_FUNC(sctp_sf_do_5_1E_ca), \
  327. /* SCTP_STATE_ESTABLISHED */ \
  328. TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
  329. /* SCTP_STATE_SHUTDOWN_PENDING */ \
  330. TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
  331. /* SCTP_STATE_SHUTDOWN_SENT */ \
  332. TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
  333. /* SCTP_STATE_SHUTDOWN_RECEIVED */ \
  334. TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
  335. /* SCTP_STATE_SHUTDOWN_ACK_SENT */ \
  336. TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
  337. } /* TYPE_SCTP_COOKIE_ACK */
  338. #define TYPE_SCTP_ECN_ECNE { \
  339. /* SCTP_STATE_EMPTY */ \
  340. TYPE_SCTP_FUNC(sctp_sf_ootb), \
  341. /* SCTP_STATE_CLOSED */ \
  342. TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
  343. /* SCTP_STATE_COOKIE_WAIT */ \
  344. TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
  345. /* SCTP_STATE_COOKIE_ECHOED */ \
  346. TYPE_SCTP_FUNC(sctp_sf_do_ecne), \
  347. /* SCTP_STATE_ESTABLISHED */ \
  348. TYPE_SCTP_FUNC(sctp_sf_do_ecne), \
  349. /* SCTP_STATE_SHUTDOWN_PENDING */ \
  350. TYPE_SCTP_FUNC(sctp_sf_do_ecne), \
  351. /* SCTP_STATE_SHUTDOWN_SENT */ \
  352. TYPE_SCTP_FUNC(sctp_sf_do_ecne), \
  353. /* SCTP_STATE_SHUTDOWN_RECEIVED */ \
  354. TYPE_SCTP_FUNC(sctp_sf_do_ecne), \
  355. /* SCTP_STATE_SHUTDOWN_ACK_SENT */ \
  356. TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
  357. } /* TYPE_SCTP_ECN_ECNE */
  358. #define TYPE_SCTP_ECN_CWR { \
  359. /* SCTP_STATE_EMPTY */ \
  360. TYPE_SCTP_FUNC(sctp_sf_ootb), \
  361. /* SCTP_STATE_CLOSED */ \
  362. TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
  363. /* SCTP_STATE_COOKIE_WAIT */ \
  364. TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
  365. /* SCTP_STATE_COOKIE_ECHOED */ \
  366. TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
  367. /* SCTP_STATE_ESTABLISHED */ \
  368. TYPE_SCTP_FUNC(sctp_sf_do_ecn_cwr), \
  369. /* SCTP_STATE_SHUTDOWN_PENDING */ \
  370. TYPE_SCTP_FUNC(sctp_sf_do_ecn_cwr), \
  371. /* SCTP_STATE_SHUTDOWN_SENT */ \
  372. TYPE_SCTP_FUNC(sctp_sf_do_ecn_cwr), \
  373. /* SCTP_STATE_SHUTDOWN_RECEIVED */ \
  374. TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
  375. /* SCTP_STATE_SHUTDOWN_ACK_SENT */ \
  376. TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
  377. } /* TYPE_SCTP_ECN_CWR */
  378. #define TYPE_SCTP_SHUTDOWN_COMPLETE { \
  379. /* SCTP_STATE_EMPTY */ \
  380. TYPE_SCTP_FUNC(sctp_sf_ootb), \
  381. /* SCTP_STATE_CLOSED */ \
  382. TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
  383. /* SCTP_STATE_COOKIE_WAIT */ \
  384. TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
  385. /* SCTP_STATE_COOKIE_ECHOED */ \
  386. TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
  387. /* SCTP_STATE_ESTABLISHED */ \
  388. TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
  389. /* SCTP_STATE_SHUTDOWN_PENDING */ \
  390. TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
  391. /* SCTP_STATE_SHUTDOWN_SENT */ \
  392. TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
  393. /* SCTP_STATE_SHUTDOWN_RECEIVED */ \
  394. TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
  395. /* SCTP_STATE_SHUTDOWN_ACK_SENT */ \
  396. TYPE_SCTP_FUNC(sctp_sf_do_4_C), \
  397. } /* TYPE_SCTP_SHUTDOWN_COMPLETE */
  398. /* The primary index for this table is the chunk type.
  399. * The secondary index for this table is the state.
  400. *
  401. * For base protocol (RFC 2960).
  402. */
  403. static const sctp_sm_table_entry_t chunk_event_table[SCTP_NUM_BASE_CHUNK_TYPES][SCTP_STATE_NUM_STATES] = {
  404. TYPE_SCTP_DATA,
  405. TYPE_SCTP_INIT,
  406. TYPE_SCTP_INIT_ACK,
  407. TYPE_SCTP_SACK,
  408. TYPE_SCTP_HEARTBEAT,
  409. TYPE_SCTP_HEARTBEAT_ACK,
  410. TYPE_SCTP_ABORT,
  411. TYPE_SCTP_SHUTDOWN,
  412. TYPE_SCTP_SHUTDOWN_ACK,
  413. TYPE_SCTP_ERROR,
  414. TYPE_SCTP_COOKIE_ECHO,
  415. TYPE_SCTP_COOKIE_ACK,
  416. TYPE_SCTP_ECN_ECNE,
  417. TYPE_SCTP_ECN_CWR,
  418. TYPE_SCTP_SHUTDOWN_COMPLETE,
  419. }; /* state_fn_t chunk_event_table[][] */
  420. #define TYPE_SCTP_ASCONF { \
  421. /* SCTP_STATE_EMPTY */ \
  422. TYPE_SCTP_FUNC(sctp_sf_ootb), \
  423. /* SCTP_STATE_CLOSED */ \
  424. TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
  425. /* SCTP_STATE_COOKIE_WAIT */ \
  426. TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
  427. /* SCTP_STATE_COOKIE_ECHOED */ \
  428. TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
  429. /* SCTP_STATE_ESTABLISHED */ \
  430. TYPE_SCTP_FUNC(sctp_sf_do_asconf), \
  431. /* SCTP_STATE_SHUTDOWN_PENDING */ \
  432. TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
  433. /* SCTP_STATE_SHUTDOWN_SENT */ \
  434. TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
  435. /* SCTP_STATE_SHUTDOWN_RECEIVED */ \
  436. TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
  437. /* SCTP_STATE_SHUTDOWN_ACK_SENT */ \
  438. TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
  439. } /* TYPE_SCTP_ASCONF */
  440. #define TYPE_SCTP_ASCONF_ACK { \
  441. /* SCTP_STATE_EMPTY */ \
  442. TYPE_SCTP_FUNC(sctp_sf_ootb), \
  443. /* SCTP_STATE_CLOSED */ \
  444. TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
  445. /* SCTP_STATE_COOKIE_WAIT */ \
  446. TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
  447. /* SCTP_STATE_COOKIE_ECHOED */ \
  448. TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
  449. /* SCTP_STATE_ESTABLISHED */ \
  450. TYPE_SCTP_FUNC(sctp_sf_do_asconf_ack), \
  451. /* SCTP_STATE_SHUTDOWN_PENDING */ \
  452. TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
  453. /* SCTP_STATE_SHUTDOWN_SENT */ \
  454. TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
  455. /* SCTP_STATE_SHUTDOWN_RECEIVED */ \
  456. TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
  457. /* SCTP_STATE_SHUTDOWN_ACK_SENT */ \
  458. TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
  459. } /* TYPE_SCTP_ASCONF_ACK */
  460. /* The primary index for this table is the chunk type.
  461. * The secondary index for this table is the state.
  462. */
  463. static const sctp_sm_table_entry_t addip_chunk_event_table[SCTP_NUM_ADDIP_CHUNK_TYPES][SCTP_STATE_NUM_STATES] = {
  464. TYPE_SCTP_ASCONF,
  465. TYPE_SCTP_ASCONF_ACK,
  466. }; /*state_fn_t addip_chunk_event_table[][] */
  467. #define TYPE_SCTP_FWD_TSN { \
  468. /* SCTP_STATE_EMPTY */ \
  469. TYPE_SCTP_FUNC(sctp_sf_ootb), \
  470. /* SCTP_STATE_CLOSED */ \
  471. TYPE_SCTP_FUNC(sctp_sf_tabort_8_4_8), \
  472. /* SCTP_STATE_COOKIE_WAIT */ \
  473. TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
  474. /* SCTP_STATE_COOKIE_ECHOED */ \
  475. TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
  476. /* SCTP_STATE_ESTABLISHED */ \
  477. TYPE_SCTP_FUNC(sctp_sf_eat_fwd_tsn), \
  478. /* SCTP_STATE_SHUTDOWN_PENDING */ \
  479. TYPE_SCTP_FUNC(sctp_sf_eat_fwd_tsn), \
  480. /* SCTP_STATE_SHUTDOWN_SENT */ \
  481. TYPE_SCTP_FUNC(sctp_sf_eat_fwd_tsn_fast), \
  482. /* SCTP_STATE_SHUTDOWN_RECEIVED */ \
  483. TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
  484. /* SCTP_STATE_SHUTDOWN_ACK_SENT */ \
  485. TYPE_SCTP_FUNC(sctp_sf_discard_chunk), \
  486. } /* TYPE_SCTP_FWD_TSN */
  487. /* The primary index for this table is the chunk type.
  488. * The secondary index for this table is the state.
  489. */
  490. static const sctp_sm_table_entry_t prsctp_chunk_event_table[SCTP_NUM_PRSCTP_CHUNK_TYPES][SCTP_STATE_NUM_STATES] = {
  491. TYPE_SCTP_FWD_TSN,
  492. }; /*state_fn_t prsctp_chunk_event_table[][] */
  493. static const sctp_sm_table_entry_t
  494. chunk_event_table_unknown[SCTP_STATE_NUM_STATES] = {
  495. /* SCTP_STATE_EMPTY */
  496. TYPE_SCTP_FUNC(sctp_sf_ootb),
  497. /* SCTP_STATE_CLOSED */
  498. TYPE_SCTP_FUNC(sctp_sf_tabort_8_4_8),
  499. /* SCTP_STATE_COOKIE_WAIT */
  500. TYPE_SCTP_FUNC(sctp_sf_unk_chunk),
  501. /* SCTP_STATE_COOKIE_ECHOED */
  502. TYPE_SCTP_FUNC(sctp_sf_unk_chunk),
  503. /* SCTP_STATE_ESTABLISHED */
  504. TYPE_SCTP_FUNC(sctp_sf_unk_chunk),
  505. /* SCTP_STATE_SHUTDOWN_PENDING */
  506. TYPE_SCTP_FUNC(sctp_sf_unk_chunk),
  507. /* SCTP_STATE_SHUTDOWN_SENT */
  508. TYPE_SCTP_FUNC(sctp_sf_unk_chunk),
  509. /* SCTP_STATE_SHUTDOWN_RECEIVED */
  510. TYPE_SCTP_FUNC(sctp_sf_unk_chunk),
  511. /* SCTP_STATE_SHUTDOWN_ACK_SENT */
  512. TYPE_SCTP_FUNC(sctp_sf_unk_chunk),
  513. }; /* chunk unknown */
  514. #define TYPE_SCTP_PRIMITIVE_ASSOCIATE { \
  515. /* SCTP_STATE_EMPTY */ \
  516. TYPE_SCTP_FUNC(sctp_sf_bug), \
  517. /* SCTP_STATE_CLOSED */ \
  518. TYPE_SCTP_FUNC(sctp_sf_do_prm_asoc), \
  519. /* SCTP_STATE_COOKIE_WAIT */ \
  520. TYPE_SCTP_FUNC(sctp_sf_not_impl), \
  521. /* SCTP_STATE_COOKIE_ECHOED */ \
  522. TYPE_SCTP_FUNC(sctp_sf_not_impl), \
  523. /* SCTP_STATE_ESTABLISHED */ \
  524. TYPE_SCTP_FUNC(sctp_sf_not_impl), \
  525. /* SCTP_STATE_SHUTDOWN_PENDING */ \
  526. TYPE_SCTP_FUNC(sctp_sf_not_impl), \
  527. /* SCTP_STATE_SHUTDOWN_SENT */ \
  528. TYPE_SCTP_FUNC(sctp_sf_not_impl), \
  529. /* SCTP_STATE_SHUTDOWN_RECEIVED */ \
  530. TYPE_SCTP_FUNC(sctp_sf_not_impl), \
  531. /* SCTP_STATE_SHUTDOWN_ACK_SENT */ \
  532. TYPE_SCTP_FUNC(sctp_sf_not_impl), \
  533. } /* TYPE_SCTP_PRIMITIVE_ASSOCIATE */
  534. #define TYPE_SCTP_PRIMITIVE_SHUTDOWN { \
  535. /* SCTP_STATE_EMPTY */ \
  536. TYPE_SCTP_FUNC(sctp_sf_bug), \
  537. /* SCTP_STATE_CLOSED */ \
  538. TYPE_SCTP_FUNC(sctp_sf_error_closed), \
  539. /* SCTP_STATE_COOKIE_WAIT */ \
  540. TYPE_SCTP_FUNC(sctp_sf_cookie_wait_prm_shutdown), \
  541. /* SCTP_STATE_COOKIE_ECHOED */ \
  542. TYPE_SCTP_FUNC(sctp_sf_cookie_echoed_prm_shutdown),\
  543. /* SCTP_STATE_ESTABLISHED */ \
  544. TYPE_SCTP_FUNC(sctp_sf_do_9_2_prm_shutdown), \
  545. /* SCTP_STATE_SHUTDOWN_PENDING */ \
  546. TYPE_SCTP_FUNC(sctp_sf_ignore_primitive), \
  547. /* SCTP_STATE_SHUTDOWN_SENT */ \
  548. TYPE_SCTP_FUNC(sctp_sf_ignore_primitive), \
  549. /* SCTP_STATE_SHUTDOWN_RECEIVED */ \
  550. TYPE_SCTP_FUNC(sctp_sf_ignore_primitive), \
  551. /* SCTP_STATE_SHUTDOWN_ACK_SENT */ \
  552. TYPE_SCTP_FUNC(sctp_sf_ignore_primitive), \
  553. } /* TYPE_SCTP_PRIMITIVE_SHUTDOWN */
  554. #define TYPE_SCTP_PRIMITIVE_ABORT { \
  555. /* SCTP_STATE_EMPTY */ \
  556. TYPE_SCTP_FUNC(sctp_sf_bug), \
  557. /* SCTP_STATE_CLOSED */ \
  558. TYPE_SCTP_FUNC(sctp_sf_error_closed), \
  559. /* SCTP_STATE_COOKIE_WAIT */ \
  560. TYPE_SCTP_FUNC(sctp_sf_cookie_wait_prm_abort), \
  561. /* SCTP_STATE_COOKIE_ECHOED */ \
  562. TYPE_SCTP_FUNC(sctp_sf_cookie_echoed_prm_abort), \
  563. /* SCTP_STATE_ESTABLISHED */ \
  564. TYPE_SCTP_FUNC(sctp_sf_do_9_1_prm_abort), \
  565. /* SCTP_STATE_SHUTDOWN_PENDING */ \
  566. TYPE_SCTP_FUNC(sctp_sf_shutdown_pending_prm_abort), \
  567. /* SCTP_STATE_SHUTDOWN_SENT */ \
  568. TYPE_SCTP_FUNC(sctp_sf_shutdown_sent_prm_abort), \
  569. /* SCTP_STATE_SHUTDOWN_RECEIVED */ \
  570. TYPE_SCTP_FUNC(sctp_sf_do_9_1_prm_abort), \
  571. /* SCTP_STATE_SHUTDOWN_ACK_SENT */ \
  572. TYPE_SCTP_FUNC(sctp_sf_shutdown_ack_sent_prm_abort), \
  573. } /* TYPE_SCTP_PRIMITIVE_ABORT */
  574. #define TYPE_SCTP_PRIMITIVE_SEND { \
  575. /* SCTP_STATE_EMPTY */ \
  576. TYPE_SCTP_FUNC(sctp_sf_bug), \
  577. /* SCTP_STATE_CLOSED */ \
  578. TYPE_SCTP_FUNC(sctp_sf_error_closed), \
  579. /* SCTP_STATE_COOKIE_WAIT */ \
  580. TYPE_SCTP_FUNC(sctp_sf_do_prm_send), \
  581. /* SCTP_STATE_COOKIE_ECHOED */ \
  582. TYPE_SCTP_FUNC(sctp_sf_do_prm_send), \
  583. /* SCTP_STATE_ESTABLISHED */ \
  584. TYPE_SCTP_FUNC(sctp_sf_do_prm_send), \
  585. /* SCTP_STATE_SHUTDOWN_PENDING */ \
  586. TYPE_SCTP_FUNC(sctp_sf_error_shutdown), \
  587. /* SCTP_STATE_SHUTDOWN_SENT */ \
  588. TYPE_SCTP_FUNC(sctp_sf_error_shutdown), \
  589. /* SCTP_STATE_SHUTDOWN_RECEIVED */ \
  590. TYPE_SCTP_FUNC(sctp_sf_error_shutdown), \
  591. /* SCTP_STATE_SHUTDOWN_ACK_SENT */ \
  592. TYPE_SCTP_FUNC(sctp_sf_error_shutdown), \
  593. } /* TYPE_SCTP_PRIMITIVE_SEND */
  594. #define TYPE_SCTP_PRIMITIVE_REQUESTHEARTBEAT { \
  595. /* SCTP_STATE_EMPTY */ \
  596. TYPE_SCTP_FUNC(sctp_sf_bug), \
  597. /* SCTP_STATE_CLOSED */ \
  598. TYPE_SCTP_FUNC(sctp_sf_error_closed), \
  599. /* SCTP_STATE_COOKIE_WAIT */ \
  600. TYPE_SCTP_FUNC(sctp_sf_do_prm_requestheartbeat), \
  601. /* SCTP_STATE_COOKIE_ECHOED */ \
  602. TYPE_SCTP_FUNC(sctp_sf_do_prm_requestheartbeat), \
  603. /* SCTP_STATE_ESTABLISHED */ \
  604. TYPE_SCTP_FUNC(sctp_sf_do_prm_requestheartbeat), \
  605. /* SCTP_STATE_SHUTDOWN_PENDING */ \
  606. TYPE_SCTP_FUNC(sctp_sf_do_prm_requestheartbeat), \
  607. /* SCTP_STATE_SHUTDOWN_SENT */ \
  608. TYPE_SCTP_FUNC(sctp_sf_do_prm_requestheartbeat), \
  609. /* SCTP_STATE_SHUTDOWN_RECEIVED */ \
  610. TYPE_SCTP_FUNC(sctp_sf_do_prm_requestheartbeat), \
  611. /* SCTP_STATE_SHUTDOWN_ACK_SENT */ \
  612. TYPE_SCTP_FUNC(sctp_sf_do_prm_requestheartbeat), \
  613. } /* TYPE_SCTP_PRIMITIVE_REQUESTHEARTBEAT */
  614. #define TYPE_SCTP_PRIMITIVE_ASCONF { \
  615. /* SCTP_STATE_EMPTY */ \
  616. TYPE_SCTP_FUNC(sctp_sf_bug), \
  617. /* SCTP_STATE_CLOSED */ \
  618. TYPE_SCTP_FUNC(sctp_sf_error_closed), \
  619. /* SCTP_STATE_COOKIE_WAIT */ \
  620. TYPE_SCTP_FUNC(sctp_sf_error_closed), \
  621. /* SCTP_STATE_COOKIE_ECHOED */ \
  622. TYPE_SCTP_FUNC(sctp_sf_error_closed), \
  623. /* SCTP_STATE_ESTABLISHED */ \
  624. TYPE_SCTP_FUNC(sctp_sf_do_prm_asconf), \
  625. /* SCTP_STATE_SHUTDOWN_PENDING */ \
  626. TYPE_SCTP_FUNC(sctp_sf_error_shutdown), \
  627. /* SCTP_STATE_SHUTDOWN_SENT */ \
  628. TYPE_SCTP_FUNC(sctp_sf_error_shutdown), \
  629. /* SCTP_STATE_SHUTDOWN_RECEIVED */ \
  630. TYPE_SCTP_FUNC(sctp_sf_error_shutdown), \
  631. /* SCTP_STATE_SHUTDOWN_ACK_SENT */ \
  632. TYPE_SCTP_FUNC(sctp_sf_error_shutdown), \
  633. } /* TYPE_SCTP_PRIMITIVE_REQUESTHEARTBEAT */
  634. /* The primary index for this table is the primitive type.
  635. * The secondary index for this table is the state.
  636. */
  637. static const sctp_sm_table_entry_t primitive_event_table[SCTP_NUM_PRIMITIVE_TYPES][SCTP_STATE_NUM_STATES] = {
  638. TYPE_SCTP_PRIMITIVE_ASSOCIATE,
  639. TYPE_SCTP_PRIMITIVE_SHUTDOWN,
  640. TYPE_SCTP_PRIMITIVE_ABORT,
  641. TYPE_SCTP_PRIMITIVE_SEND,
  642. TYPE_SCTP_PRIMITIVE_REQUESTHEARTBEAT,
  643. TYPE_SCTP_PRIMITIVE_ASCONF,
  644. };
  645. #define TYPE_SCTP_OTHER_NO_PENDING_TSN { \
  646. /* SCTP_STATE_EMPTY */ \
  647. TYPE_SCTP_FUNC(sctp_sf_bug), \
  648. /* SCTP_STATE_CLOSED */ \
  649. TYPE_SCTP_FUNC(sctp_sf_ignore_other), \
  650. /* SCTP_STATE_COOKIE_WAIT */ \
  651. TYPE_SCTP_FUNC(sctp_sf_ignore_other), \
  652. /* SCTP_STATE_COOKIE_ECHOED */ \
  653. TYPE_SCTP_FUNC(sctp_sf_ignore_other), \
  654. /* SCTP_STATE_ESTABLISHED */ \
  655. TYPE_SCTP_FUNC(sctp_sf_ignore_other), \
  656. /* SCTP_STATE_SHUTDOWN_PENDING */ \
  657. TYPE_SCTP_FUNC(sctp_sf_do_9_2_start_shutdown), \
  658. /* SCTP_STATE_SHUTDOWN_SENT */ \
  659. TYPE_SCTP_FUNC(sctp_sf_ignore_other), \
  660. /* SCTP_STATE_SHUTDOWN_RECEIVED */ \
  661. TYPE_SCTP_FUNC(sctp_sf_do_9_2_shutdown_ack), \
  662. /* SCTP_STATE_SHUTDOWN_ACK_SENT */ \
  663. TYPE_SCTP_FUNC(sctp_sf_ignore_other), \
  664. }
  665. #define TYPE_SCTP_OTHER_ICMP_PROTO_UNREACH { \
  666. /* SCTP_STATE_EMPTY */ \
  667. TYPE_SCTP_FUNC(sctp_sf_bug), \
  668. /* SCTP_STATE_CLOSED */ \
  669. TYPE_SCTP_FUNC(sctp_sf_ignore_other), \
  670. /* SCTP_STATE_COOKIE_WAIT */ \
  671. TYPE_SCTP_FUNC(sctp_sf_cookie_wait_icmp_abort), \
  672. /* SCTP_STATE_COOKIE_ECHOED */ \
  673. TYPE_SCTP_FUNC(sctp_sf_ignore_other), \
  674. /* SCTP_STATE_ESTABLISHED */ \
  675. TYPE_SCTP_FUNC(sctp_sf_ignore_other), \
  676. /* SCTP_STATE_SHUTDOWN_PENDING */ \
  677. TYPE_SCTP_FUNC(sctp_sf_ignore_other), \
  678. /* SCTP_STATE_SHUTDOWN_SENT */ \
  679. TYPE_SCTP_FUNC(sctp_sf_ignore_other), \
  680. /* SCTP_STATE_SHUTDOWN_RECEIVED */ \
  681. TYPE_SCTP_FUNC(sctp_sf_ignore_other), \
  682. /* SCTP_STATE_SHUTDOWN_ACK_SENT */ \
  683. TYPE_SCTP_FUNC(sctp_sf_ignore_other), \
  684. }
  685. static const sctp_sm_table_entry_t other_event_table[SCTP_NUM_OTHER_TYPES][SCTP_STATE_NUM_STATES] = {
  686. TYPE_SCTP_OTHER_NO_PENDING_TSN,
  687. TYPE_SCTP_OTHER_ICMP_PROTO_UNREACH,
  688. };
  689. #define TYPE_SCTP_EVENT_TIMEOUT_NONE { \
  690. /* SCTP_STATE_EMPTY */ \
  691. TYPE_SCTP_FUNC(sctp_sf_bug), \
  692. /* SCTP_STATE_CLOSED */ \
  693. TYPE_SCTP_FUNC(sctp_sf_bug), \
  694. /* SCTP_STATE_COOKIE_WAIT */ \
  695. TYPE_SCTP_FUNC(sctp_sf_bug), \
  696. /* SCTP_STATE_COOKIE_ECHOED */ \
  697. TYPE_SCTP_FUNC(sctp_sf_bug), \
  698. /* SCTP_STATE_ESTABLISHED */ \
  699. TYPE_SCTP_FUNC(sctp_sf_bug), \
  700. /* SCTP_STATE_SHUTDOWN_PENDING */ \
  701. TYPE_SCTP_FUNC(sctp_sf_bug), \
  702. /* SCTP_STATE_SHUTDOWN_SENT */ \
  703. TYPE_SCTP_FUNC(sctp_sf_bug), \
  704. /* SCTP_STATE_SHUTDOWN_RECEIVED */ \
  705. TYPE_SCTP_FUNC(sctp_sf_bug), \
  706. /* SCTP_STATE_SHUTDOWN_ACK_SENT */ \
  707. TYPE_SCTP_FUNC(sctp_sf_bug), \
  708. }
  709. #define TYPE_SCTP_EVENT_TIMEOUT_T1_COOKIE { \
  710. /* SCTP_STATE_EMPTY */ \
  711. TYPE_SCTP_FUNC(sctp_sf_bug), \
  712. /* SCTP_STATE_CLOSED */ \
  713. TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
  714. /* SCTP_STATE_COOKIE_WAIT */ \
  715. TYPE_SCTP_FUNC(sctp_sf_bug), \
  716. /* SCTP_STATE_COOKIE_ECHOED */ \
  717. TYPE_SCTP_FUNC(sctp_sf_t1_cookie_timer_expire), \
  718. /* SCTP_STATE_ESTABLISHED */ \
  719. TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
  720. /* SCTP_STATE_SHUTDOWN_PENDING */ \
  721. TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
  722. /* SCTP_STATE_SHUTDOWN_SENT */ \
  723. TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
  724. /* SCTP_STATE_SHUTDOWN_RECEIVED */ \
  725. TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
  726. /* SCTP_STATE_SHUTDOWN_ACK_SENT */ \
  727. TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
  728. }
  729. #define TYPE_SCTP_EVENT_TIMEOUT_T1_INIT { \
  730. /* SCTP_STATE_EMPTY */ \
  731. TYPE_SCTP_FUNC(sctp_sf_bug), \
  732. /* SCTP_STATE_CLOSED */ \
  733. TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
  734. /* SCTP_STATE_COOKIE_WAIT */ \
  735. TYPE_SCTP_FUNC(sctp_sf_t1_init_timer_expire), \
  736. /* SCTP_STATE_COOKIE_ECHOED */ \
  737. TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
  738. /* SCTP_STATE_ESTABLISHED */ \
  739. TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
  740. /* SCTP_STATE_SHUTDOWN_PENDING */ \
  741. TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
  742. /* SCTP_STATE_SHUTDOWN_SENT */ \
  743. TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
  744. /* SCTP_STATE_SHUTDOWN_RECEIVED */ \
  745. TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
  746. /* SCTP_STATE_SHUTDOWN_ACK_SENT */ \
  747. TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
  748. }
  749. #define TYPE_SCTP_EVENT_TIMEOUT_T2_SHUTDOWN { \
  750. /* SCTP_STATE_EMPTY */ \
  751. TYPE_SCTP_FUNC(sctp_sf_bug), \
  752. /* SCTP_STATE_CLOSED */ \
  753. TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
  754. /* SCTP_STATE_COOKIE_WAIT */ \
  755. TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
  756. /* SCTP_STATE_COOKIE_ECHOED */ \
  757. TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
  758. /* SCTP_STATE_ESTABLISHED */ \
  759. TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
  760. /* SCTP_STATE_SHUTDOWN_PENDING */ \
  761. TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
  762. /* SCTP_STATE_SHUTDOWN_SENT */ \
  763. TYPE_SCTP_FUNC(sctp_sf_t2_timer_expire), \
  764. /* SCTP_STATE_SHUTDOWN_RECEIVED */ \
  765. TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
  766. /* SCTP_STATE_SHUTDOWN_ACK_SENT */ \
  767. TYPE_SCTP_FUNC(sctp_sf_t2_timer_expire), \
  768. }
  769. #define TYPE_SCTP_EVENT_TIMEOUT_T3_RTX { \
  770. /* SCTP_STATE_EMPTY */ \
  771. TYPE_SCTP_FUNC(sctp_sf_bug), \
  772. /* SCTP_STATE_CLOSED */ \
  773. TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
  774. /* SCTP_STATE_COOKIE_WAIT */ \
  775. TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
  776. /* SCTP_STATE_COOKIE_ECHOED */ \
  777. TYPE_SCTP_FUNC(sctp_sf_do_6_3_3_rtx), \
  778. /* SCTP_STATE_ESTABLISHED */ \
  779. TYPE_SCTP_FUNC(sctp_sf_do_6_3_3_rtx), \
  780. /* SCTP_STATE_SHUTDOWN_PENDING */ \
  781. TYPE_SCTP_FUNC(sctp_sf_do_6_3_3_rtx), \
  782. /* SCTP_STATE_SHUTDOWN_SENT */ \
  783. TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
  784. /* SCTP_STATE_SHUTDOWN_RECEIVED */ \
  785. TYPE_SCTP_FUNC(sctp_sf_do_6_3_3_rtx), \
  786. /* SCTP_STATE_SHUTDOWN_ACK_SENT */ \
  787. TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
  788. }
  789. #define TYPE_SCTP_EVENT_TIMEOUT_T4_RTO { \
  790. /* SCTP_STATE_EMPTY */ \
  791. TYPE_SCTP_FUNC(sctp_sf_bug), \
  792. /* SCTP_STATE_CLOSED */ \
  793. TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
  794. /* SCTP_STATE_COOKIE_WAIT */ \
  795. TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
  796. /* SCTP_STATE_COOKIE_ECHOED */ \
  797. TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
  798. /* SCTP_STATE_ESTABLISHED */ \
  799. TYPE_SCTP_FUNC(sctp_sf_t4_timer_expire), \
  800. /* SCTP_STATE_SHUTDOWN_PENDING */ \
  801. TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
  802. /* SCTP_STATE_SHUTDOWN_SENT */ \
  803. TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
  804. /* SCTP_STATE_SHUTDOWN_RECEIVED */ \
  805. TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
  806. /* SCTP_STATE_SHUTDOWN_ACK_SENT */ \
  807. TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
  808. }
  809. #define TYPE_SCTP_EVENT_TIMEOUT_T5_SHUTDOWN_GUARD { \
  810. /* SCTP_STATE_EMPTY */ \
  811. TYPE_SCTP_FUNC(sctp_sf_bug), \
  812. /* SCTP_STATE_CLOSED */ \
  813. TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
  814. /* SCTP_STATE_COOKIE_WAIT */ \
  815. TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
  816. /* SCTP_STATE_COOKIE_ECHOED */ \
  817. TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
  818. /* SCTP_STATE_ESTABLISHED */ \
  819. TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
  820. /* SCTP_STATE_SHUTDOWN_PENDING */ \
  821. TYPE_SCTP_FUNC(sctp_sf_t5_timer_expire), \
  822. /* SCTP_STATE_SHUTDOWN_SENT */ \
  823. TYPE_SCTP_FUNC(sctp_sf_t5_timer_expire), \
  824. /* SCTP_STATE_SHUTDOWN_RECEIVED */ \
  825. TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
  826. /* SCTP_STATE_SHUTDOWN_ACK_SENT */ \
  827. TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
  828. }
  829. #define TYPE_SCTP_EVENT_TIMEOUT_HEARTBEAT { \
  830. /* SCTP_STATE_EMPTY */ \
  831. TYPE_SCTP_FUNC(sctp_sf_bug), \
  832. /* SCTP_STATE_CLOSED */ \
  833. TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
  834. /* SCTP_STATE_COOKIE_WAIT */ \
  835. TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
  836. /* SCTP_STATE_COOKIE_ECHOED */ \
  837. TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
  838. /* SCTP_STATE_ESTABLISHED */ \
  839. TYPE_SCTP_FUNC(sctp_sf_sendbeat_8_3), \
  840. /* SCTP_STATE_SHUTDOWN_PENDING */ \
  841. TYPE_SCTP_FUNC(sctp_sf_sendbeat_8_3), \
  842. /* SCTP_STATE_SHUTDOWN_SENT */ \
  843. TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
  844. /* SCTP_STATE_SHUTDOWN_RECEIVED */ \
  845. TYPE_SCTP_FUNC(sctp_sf_sendbeat_8_3), \
  846. /* SCTP_STATE_SHUTDOWN_ACK_SENT */ \
  847. TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
  848. }
  849. #define TYPE_SCTP_EVENT_TIMEOUT_SACK { \
  850. /* SCTP_STATE_EMPTY */ \
  851. TYPE_SCTP_FUNC(sctp_sf_bug), \
  852. /* SCTP_STATE_CLOSED */ \
  853. TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
  854. /* SCTP_STATE_COOKIE_WAIT */ \
  855. TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
  856. /* SCTP_STATE_COOKIE_ECHOED */ \
  857. TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
  858. /* SCTP_STATE_ESTABLISHED */ \
  859. TYPE_SCTP_FUNC(sctp_sf_do_6_2_sack), \
  860. /* SCTP_STATE_SHUTDOWN_PENDING */ \
  861. TYPE_SCTP_FUNC(sctp_sf_do_6_2_sack), \
  862. /* SCTP_STATE_SHUTDOWN_SENT */ \
  863. TYPE_SCTP_FUNC(sctp_sf_do_6_2_sack), \
  864. /* SCTP_STATE_SHUTDOWN_RECEIVED */ \
  865. TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
  866. /* SCTP_STATE_SHUTDOWN_ACK_SENT */ \
  867. TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
  868. }
  869. #define TYPE_SCTP_EVENT_TIMEOUT_AUTOCLOSE { \
  870. /* SCTP_STATE_EMPTY */ \
  871. TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
  872. /* SCTP_STATE_CLOSED */ \
  873. TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
  874. /* SCTP_STATE_COOKIE_WAIT */ \
  875. TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
  876. /* SCTP_STATE_COOKIE_ECHOED */ \
  877. TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
  878. /* SCTP_STATE_ESTABLISHED */ \
  879. TYPE_SCTP_FUNC(sctp_sf_autoclose_timer_expire), \
  880. /* SCTP_STATE_SHUTDOWN_PENDING */ \
  881. TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
  882. /* SCTP_STATE_SHUTDOWN_SENT */ \
  883. TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
  884. /* SCTP_STATE_SHUTDOWN_RECEIVED */ \
  885. TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
  886. /* SCTP_STATE_SHUTDOWN_ACK_SENT */ \
  887. TYPE_SCTP_FUNC(sctp_sf_timer_ignore), \
  888. }
  889. static const sctp_sm_table_entry_t timeout_event_table[SCTP_NUM_TIMEOUT_TYPES][SCTP_STATE_NUM_STATES] = {
  890. TYPE_SCTP_EVENT_TIMEOUT_NONE,
  891. TYPE_SCTP_EVENT_TIMEOUT_T1_COOKIE,
  892. TYPE_SCTP_EVENT_TIMEOUT_T1_INIT,
  893. TYPE_SCTP_EVENT_TIMEOUT_T2_SHUTDOWN,
  894. TYPE_SCTP_EVENT_TIMEOUT_T3_RTX,
  895. TYPE_SCTP_EVENT_TIMEOUT_T4_RTO,
  896. TYPE_SCTP_EVENT_TIMEOUT_T5_SHUTDOWN_GUARD,
  897. TYPE_SCTP_EVENT_TIMEOUT_HEARTBEAT,
  898. TYPE_SCTP_EVENT_TIMEOUT_SACK,
  899. TYPE_SCTP_EVENT_TIMEOUT_AUTOCLOSE,
  900. };
  901. static const sctp_sm_table_entry_t *sctp_chunk_event_lookup(sctp_cid_t cid,
  902. sctp_state_t state)
  903. {
  904. if (state > SCTP_STATE_MAX)
  905. return &bug;
  906. if (cid <= SCTP_CID_BASE_MAX)
  907. return &chunk_event_table[cid][state];
  908. if (sctp_prsctp_enable) {
  909. if (cid == SCTP_CID_FWD_TSN)
  910. return &prsctp_chunk_event_table[0][state];
  911. }
  912. if (sctp_addip_enable) {
  913. if (cid == SCTP_CID_ASCONF)
  914. return &addip_chunk_event_table[0][state];
  915. if (cid == SCTP_CID_ASCONF_ACK)
  916. return &addip_chunk_event_table[1][state];
  917. }
  918. return &chunk_event_table_unknown[state];
  919. }