~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

TOMOYO Linux Cross Reference
Linux/net/sctp/debug.c

Version: ~ [ linux-6.12-rc7 ] ~ [ linux-6.11.7 ] ~ [ linux-6.10.14 ] ~ [ linux-6.9.12 ] ~ [ linux-6.8.12 ] ~ [ linux-6.7.12 ] ~ [ linux-6.6.60 ] ~ [ linux-6.5.13 ] ~ [ linux-6.4.16 ] ~ [ linux-6.3.13 ] ~ [ linux-6.2.16 ] ~ [ linux-6.1.116 ] ~ [ linux-6.0.19 ] ~ [ linux-5.19.17 ] ~ [ linux-5.18.19 ] ~ [ linux-5.17.15 ] ~ [ linux-5.16.20 ] ~ [ linux-5.15.171 ] ~ [ linux-5.14.21 ] ~ [ linux-5.13.19 ] ~ [ linux-5.12.19 ] ~ [ linux-5.11.22 ] ~ [ linux-5.10.229 ] ~ [ linux-5.9.16 ] ~ [ linux-5.8.18 ] ~ [ linux-5.7.19 ] ~ [ linux-5.6.19 ] ~ [ linux-5.5.19 ] ~ [ linux-5.4.285 ] ~ [ linux-5.3.18 ] ~ [ linux-5.2.21 ] ~ [ linux-5.1.21 ] ~ [ linux-5.0.21 ] ~ [ linux-4.20.17 ] ~ [ linux-4.19.323 ] ~ [ linux-4.18.20 ] ~ [ linux-4.17.19 ] ~ [ linux-4.16.18 ] ~ [ linux-4.15.18 ] ~ [ linux-4.14.336 ] ~ [ linux-4.13.16 ] ~ [ linux-4.12.14 ] ~ [ linux-4.11.12 ] ~ [ linux-4.10.17 ] ~ [ linux-4.9.337 ] ~ [ linux-4.4.302 ] ~ [ linux-3.10.108 ] ~ [ linux-2.6.32.71 ] ~ [ linux-2.6.0 ] ~ [ linux-2.4.37.11 ] ~ [ unix-v6-master ] ~ [ ccs-tools-1.8.12 ] ~ [ policy-sample ] ~
Architecture: ~ [ i386 ] ~ [ alpha ] ~ [ m68k ] ~ [ mips ] ~ [ ppc ] ~ [ sparc ] ~ [ sparc64 ] ~

Diff markup

Differences between /net/sctp/debug.c (Version linux-6.12-rc7) and /net/sctp/debug.c (Version linux-2.6.32.71)


  1 // SPDX-License-Identifier: GPL-2.0-or-later   << 
  2 /* SCTP kernel implementation                       1 /* SCTP kernel implementation
  3  * (C) Copyright IBM Corp. 2001, 2004               2  * (C) Copyright IBM Corp. 2001, 2004
  4  * Copyright (c) 1999-2000 Cisco, Inc.              3  * Copyright (c) 1999-2000 Cisco, Inc.
  5  * Copyright (c) 1999-2001 Motorola, Inc.           4  * Copyright (c) 1999-2001 Motorola, Inc.
  6  * Copyright (c) 2001 Intel Corp.                   5  * Copyright (c) 2001 Intel Corp.
  7  *                                                  6  *
  8  * This file is part of the SCTP kernel implem      7  * This file is part of the SCTP kernel implementation
  9  *                                                  8  *
 10  * This file converts numerical ID value to al      9  * This file converts numerical ID value to alphabetical names for SCTP
 11  * terms such as chunk type, parameter time, e     10  * terms such as chunk type, parameter time, event type, etc.
 12  *                                                 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  *
 13  * Please send any bug reports or fixes you ma     29  * Please send any bug reports or fixes you make to the
 14  * email address(es):                              30  * email address(es):
 15  *    lksctp developers <linux-sctp@vger.kerne !!  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
 16  *                                                 35  *
 17  * Written or modified by:                         36  * Written or modified by:
 18  *    La Monte H.P. Yarroll <piggy@acm.org>        37  *    La Monte H.P. Yarroll <piggy@acm.org>
 19  *    Karl Knutson          <karl@athena.chica     38  *    Karl Knutson          <karl@athena.chicago.il.us>
 20  *    Xingang Guo           <xingang.guo@intel     39  *    Xingang Guo           <xingang.guo@intel.com>
 21  *    Jon Grimm             <jgrimm@us.ibm.com     40  *    Jon Grimm             <jgrimm@us.ibm.com>
 22  *    Daisy Chang           <daisyc@us.ibm.com     41  *    Daisy Chang           <daisyc@us.ibm.com>
 23  *    Sridhar Samudrala     <sri@us.ibm.com>       42  *    Sridhar Samudrala     <sri@us.ibm.com>
                                                   >>  43  *
                                                   >>  44  * Any bugs reported given to us we will try to fix... any fixes shared will
                                                   >>  45  * be incorporated into the next SCTP release.
 24  */                                                46  */
 25                                                    47 
 26 #include <net/sctp/sctp.h>                         48 #include <net/sctp/sctp.h>
 27                                                    49 
                                                   >>  50 #if SCTP_DEBUG
                                                   >>  51 int sctp_debug_flag = 1;        /* Initially enable DEBUG */
                                                   >>  52 #endif  /* SCTP_DEBUG */
                                                   >>  53 
 28 /* These are printable forms of Chunk ID's fro     54 /* These are printable forms of Chunk ID's from section 3.1.  */
 29 static const char *const sctp_cid_tbl[SCTP_NUM     55 static const char *const sctp_cid_tbl[SCTP_NUM_BASE_CHUNK_TYPES] = {
 30         "DATA",                                    56         "DATA",
 31         "INIT",                                    57         "INIT",
 32         "INIT_ACK",                                58         "INIT_ACK",
 33         "SACK",                                    59         "SACK",
 34         "HEARTBEAT",                               60         "HEARTBEAT",
 35         "HEARTBEAT_ACK",                           61         "HEARTBEAT_ACK",
 36         "ABORT",                                   62         "ABORT",
 37         "SHUTDOWN",                                63         "SHUTDOWN",
 38         "SHUTDOWN_ACK",                            64         "SHUTDOWN_ACK",
 39         "ERROR",                                   65         "ERROR",
 40         "COOKIE_ECHO",                             66         "COOKIE_ECHO",
 41         "COOKIE_ACK",                              67         "COOKIE_ACK",
 42         "ECN_ECNE",                                68         "ECN_ECNE",
 43         "ECN_CWR",                                 69         "ECN_CWR",
 44         "SHUTDOWN_COMPLETE",                       70         "SHUTDOWN_COMPLETE",
 45 };                                                 71 };
 46                                                    72 
 47 /* Lookup "chunk type" debug name. */              73 /* Lookup "chunk type" debug name. */
 48 const char *sctp_cname(const union sctp_subtyp !!  74 const char *sctp_cname(const sctp_subtype_t cid)
 49 {                                                  75 {
 50         if (cid.chunk <= SCTP_CID_BASE_MAX)        76         if (cid.chunk <= SCTP_CID_BASE_MAX)
 51                 return sctp_cid_tbl[cid.chunk]     77                 return sctp_cid_tbl[cid.chunk];
 52                                                    78 
 53         switch (cid.chunk) {                       79         switch (cid.chunk) {
 54         case SCTP_CID_ASCONF:                      80         case SCTP_CID_ASCONF:
 55                 return "ASCONF";                   81                 return "ASCONF";
 56                                                    82 
 57         case SCTP_CID_ASCONF_ACK:                  83         case SCTP_CID_ASCONF_ACK:
 58                 return "ASCONF_ACK";               84                 return "ASCONF_ACK";
 59                                                    85 
 60         case SCTP_CID_FWD_TSN:                     86         case SCTP_CID_FWD_TSN:
 61                 return "FWD_TSN";                  87                 return "FWD_TSN";
 62                                                    88 
 63         case SCTP_CID_AUTH:                        89         case SCTP_CID_AUTH:
 64                 return "AUTH";                     90                 return "AUTH";
 65                                                    91 
 66         case SCTP_CID_RECONF:                  << 
 67                 return "RECONF";               << 
 68                                                << 
 69         case SCTP_CID_I_DATA:                  << 
 70                 return "I_DATA";               << 
 71                                                << 
 72         case SCTP_CID_I_FWD_TSN:               << 
 73                 return "I_FWD_TSN";            << 
 74                                                << 
 75         default:                                   92         default:
 76                 break;                             93                 break;
 77         }                                          94         }
 78                                                    95 
 79         return "unknown chunk";                    96         return "unknown chunk";
 80 }                                                  97 }
 81                                                    98 
 82 /* These are printable forms of the states.  *     99 /* These are printable forms of the states.  */
 83 const char *const sctp_state_tbl[SCTP_STATE_NU    100 const char *const sctp_state_tbl[SCTP_STATE_NUM_STATES] = {
                                                   >> 101         "STATE_EMPTY",
 84         "STATE_CLOSED",                           102         "STATE_CLOSED",
 85         "STATE_COOKIE_WAIT",                      103         "STATE_COOKIE_WAIT",
 86         "STATE_COOKIE_ECHOED",                    104         "STATE_COOKIE_ECHOED",
 87         "STATE_ESTABLISHED",                      105         "STATE_ESTABLISHED",
 88         "STATE_SHUTDOWN_PENDING",                 106         "STATE_SHUTDOWN_PENDING",
 89         "STATE_SHUTDOWN_SENT",                    107         "STATE_SHUTDOWN_SENT",
 90         "STATE_SHUTDOWN_RECEIVED",                108         "STATE_SHUTDOWN_RECEIVED",
 91         "STATE_SHUTDOWN_ACK_SENT",                109         "STATE_SHUTDOWN_ACK_SENT",
 92 };                                                110 };
 93                                                   111 
 94 /* Events that could change the state of an as    112 /* Events that could change the state of an association.  */
 95 const char *const sctp_evttype_tbl[] = {          113 const char *const sctp_evttype_tbl[] = {
 96         "EVENT_T_unknown",                        114         "EVENT_T_unknown",
 97         "EVENT_T_CHUNK",                          115         "EVENT_T_CHUNK",
 98         "EVENT_T_TIMEOUT",                        116         "EVENT_T_TIMEOUT",
 99         "EVENT_T_OTHER",                          117         "EVENT_T_OTHER",
100         "EVENT_T_PRIMITIVE"                       118         "EVENT_T_PRIMITIVE"
101 };                                                119 };
102                                                   120 
103 /* Return value of a state function */            121 /* Return value of a state function */
104 const char *const sctp_status_tbl[] = {           122 const char *const sctp_status_tbl[] = {
105         "DISPOSITION_DISCARD",                    123         "DISPOSITION_DISCARD",
106         "DISPOSITION_CONSUME",                    124         "DISPOSITION_CONSUME",
107         "DISPOSITION_NOMEM",                      125         "DISPOSITION_NOMEM",
108         "DISPOSITION_DELETE_TCB",                 126         "DISPOSITION_DELETE_TCB",
109         "DISPOSITION_ABORT",                      127         "DISPOSITION_ABORT",
110         "DISPOSITION_VIOLATION",                  128         "DISPOSITION_VIOLATION",
111         "DISPOSITION_NOT_IMPL",                   129         "DISPOSITION_NOT_IMPL",
112         "DISPOSITION_ERROR",                      130         "DISPOSITION_ERROR",
113         "DISPOSITION_BUG"                         131         "DISPOSITION_BUG"
114 };                                                132 };
115                                                   133 
116 /* Printable forms of primitives */               134 /* Printable forms of primitives */
117 static const char *const sctp_primitive_tbl[SC    135 static const char *const sctp_primitive_tbl[SCTP_NUM_PRIMITIVE_TYPES] = {
118         "PRIMITIVE_ASSOCIATE",                    136         "PRIMITIVE_ASSOCIATE",
119         "PRIMITIVE_SHUTDOWN",                     137         "PRIMITIVE_SHUTDOWN",
120         "PRIMITIVE_ABORT",                        138         "PRIMITIVE_ABORT",
121         "PRIMITIVE_SEND",                         139         "PRIMITIVE_SEND",
122         "PRIMITIVE_REQUESTHEARTBEAT",             140         "PRIMITIVE_REQUESTHEARTBEAT",
123         "PRIMITIVE_ASCONF",                       141         "PRIMITIVE_ASCONF",
124 };                                                142 };
125                                                   143 
126 /* Lookup primitive debug name. */                144 /* Lookup primitive debug name. */
127 const char *sctp_pname(const union sctp_subtyp !! 145 const char *sctp_pname(const sctp_subtype_t id)
128 {                                                 146 {
129         if (id.primitive <= SCTP_EVENT_PRIMITI    147         if (id.primitive <= SCTP_EVENT_PRIMITIVE_MAX)
130                 return sctp_primitive_tbl[id.p    148                 return sctp_primitive_tbl[id.primitive];
131         return "unknown_primitive";               149         return "unknown_primitive";
132 }                                                 150 }
133                                                   151 
134 static const char *const sctp_other_tbl[] = {     152 static const char *const sctp_other_tbl[] = {
135         "NO_PENDING_TSN",                         153         "NO_PENDING_TSN",
136         "ICMP_PROTO_UNREACH",                     154         "ICMP_PROTO_UNREACH",
137 };                                                155 };
138                                                   156 
139 /* Lookup "other" debug name. */                  157 /* Lookup "other" debug name. */
140 const char *sctp_oname(const union sctp_subtyp !! 158 const char *sctp_oname(const sctp_subtype_t id)
141 {                                                 159 {
142         if (id.other <= SCTP_EVENT_OTHER_MAX)     160         if (id.other <= SCTP_EVENT_OTHER_MAX)
143                 return sctp_other_tbl[id.other    161                 return sctp_other_tbl[id.other];
144         return "unknown 'other' event";           162         return "unknown 'other' event";
145 }                                                 163 }
146                                                   164 
147 static const char *const sctp_timer_tbl[] = {     165 static const char *const sctp_timer_tbl[] = {
148         "TIMEOUT_NONE",                           166         "TIMEOUT_NONE",
149         "TIMEOUT_T1_COOKIE",                      167         "TIMEOUT_T1_COOKIE",
150         "TIMEOUT_T1_INIT",                        168         "TIMEOUT_T1_INIT",
151         "TIMEOUT_T2_SHUTDOWN",                    169         "TIMEOUT_T2_SHUTDOWN",
152         "TIMEOUT_T3_RTX",                         170         "TIMEOUT_T3_RTX",
153         "TIMEOUT_T4_RTO",                         171         "TIMEOUT_T4_RTO",
154         "TIMEOUT_T5_SHUTDOWN_GUARD",              172         "TIMEOUT_T5_SHUTDOWN_GUARD",
155         "TIMEOUT_HEARTBEAT",                      173         "TIMEOUT_HEARTBEAT",
156         "TIMEOUT_RECONF",                      << 
157         "TIMEOUT_PROBE",                       << 
158         "TIMEOUT_SACK",                           174         "TIMEOUT_SACK",
159         "TIMEOUT_AUTOCLOSE",                      175         "TIMEOUT_AUTOCLOSE",
160 };                                                176 };
161                                                   177 
162 /* Lookup timer debug name. */                    178 /* Lookup timer debug name. */
163 const char *sctp_tname(const union sctp_subtyp !! 179 const char *sctp_tname(const sctp_subtype_t id)
164 {                                                 180 {
165         BUILD_BUG_ON(SCTP_EVENT_TIMEOUT_MAX +  !! 181         if (id.timeout <= SCTP_EVENT_TIMEOUT_MAX)
166                                                << 
167         if (id.timeout < ARRAY_SIZE(sctp_timer << 
168                 return sctp_timer_tbl[id.timeo    182                 return sctp_timer_tbl[id.timeout];
169         return "unknown_timer";                   183         return "unknown_timer";
170 }                                                 184 }
171                                                   185 

~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

kernel.org | git.kernel.org | LWN.net | Project Home | SVN repository | Mail admin

Linux® is a registered trademark of Linus Torvalds in the United States and other countries.
TOMOYO® is a registered trademark of NTT DATA CORPORATION.

sflogo.php