sm_statetable.c 31 KB

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