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