1*05b00f60SXin Li /*
2*05b00f60SXin Li * Copyright (c) 1988, 1989, 1990, 1991, 1992, 1993, 1994, 1995, 1996, 1997
3*05b00f60SXin Li * The Regents of the University of California. All rights reserved.
4*05b00f60SXin Li *
5*05b00f60SXin Li * Redistribution and use in source and binary forms, with or without
6*05b00f60SXin Li * modification, are permitted provided that: (1) source code distributions
7*05b00f60SXin Li * retain the above copyright notice and this paragraph in its entirety, (2)
8*05b00f60SXin Li * distributions including binary code include the above copyright notice and
9*05b00f60SXin Li * this paragraph in its entirety in the documentation or other materials
10*05b00f60SXin Li * provided with the distribution, and (3) all advertising materials mentioning
11*05b00f60SXin Li * features or use of this software display the following acknowledgement:
12*05b00f60SXin Li * ``This product includes software developed by the University of California,
13*05b00f60SXin Li * Lawrence Berkeley Laboratory and its contributors.'' Neither the name of
14*05b00f60SXin Li * the University nor the names of its contributors may be used to endorse
15*05b00f60SXin Li * or promote products derived from this software without specific prior
16*05b00f60SXin Li * written permission.
17*05b00f60SXin Li * THIS SOFTWARE IS PROVIDED ``AS IS'' AND WITHOUT ANY EXPRESS OR IMPLIED
18*05b00f60SXin Li * WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED WARRANTIES OF
19*05b00f60SXin Li * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
20*05b00f60SXin Li */
21*05b00f60SXin Li
22*05b00f60SXin Li /* \summary: Transparent Inter-Process Communication (TIPC) protocol printer */
23*05b00f60SXin Li
24*05b00f60SXin Li /*
25*05b00f60SXin Li * specification:
26*05b00f60SXin Li * https://web.archive.org/web/20150302152944/http://tipc.sourceforge.net/doc/draft-spec-tipc-07.html
27*05b00f60SXin Li * https://web.archive.org/web/20161025110514/http://tipc.sourceforge.net/doc/tipc_message_formats.html
28*05b00f60SXin Li */
29*05b00f60SXin Li
30*05b00f60SXin Li #ifdef HAVE_CONFIG_H
31*05b00f60SXin Li #include <config.h>
32*05b00f60SXin Li #endif
33*05b00f60SXin Li
34*05b00f60SXin Li #include "netdissect-stdinc.h"
35*05b00f60SXin Li
36*05b00f60SXin Li #include "netdissect.h"
37*05b00f60SXin Li #include "ethertype.h"
38*05b00f60SXin Li #include "extract.h"
39*05b00f60SXin Li
40*05b00f60SXin Li
41*05b00f60SXin Li #define TIPC_USER_LOW_IMPORTANCE 0
42*05b00f60SXin Li #define TIPC_USER_MEDIUM_IMPORTANCE 1
43*05b00f60SXin Li #define TIPC_USER_HIGH_IMPORTANCE 2
44*05b00f60SXin Li #define TIPC_USER_CRITICAL_IMPORTANCE 3
45*05b00f60SXin Li #define TIPC_USER_BCAST_PROTOCOL 5
46*05b00f60SXin Li #define TIPC_USER_MSG_BUNDLER 6
47*05b00f60SXin Li #define TIPC_USER_LINK_PROTOCOL 7
48*05b00f60SXin Li #define TIPC_USER_CONN_MANAGER 8
49*05b00f60SXin Li #define TIPC_USER_CHANGEOVER_PROTOCOL 10
50*05b00f60SXin Li #define TIPC_USER_NAME_DISTRIBUTOR 11
51*05b00f60SXin Li #define TIPC_USER_MSG_FRAGMENTER 12
52*05b00f60SXin Li #define TIPC_USER_LINK_CONFIG 13
53*05b00f60SXin Li
54*05b00f60SXin Li #define TIPC_CONN_MSG 0
55*05b00f60SXin Li #define TIPC_DIRECT_MSG 1
56*05b00f60SXin Li #define TIPC_NAMED_MSG 2
57*05b00f60SXin Li #define TIPC_MCAST_MSG 3
58*05b00f60SXin Li
59*05b00f60SXin Li #define TIPC_ZONE(addr) (((addr) >> 24) & 0xFF)
60*05b00f60SXin Li #define TIPC_CLUSTER(addr) (((addr) >> 12) & 0xFFF)
61*05b00f60SXin Li #define TIPC_NODE(addr) (((addr) >> 0) & 0xFFF)
62*05b00f60SXin Li
63*05b00f60SXin Li struct tipc_pkthdr {
64*05b00f60SXin Li nd_uint32_t w0;
65*05b00f60SXin Li nd_uint32_t w1;
66*05b00f60SXin Li };
67*05b00f60SXin Li
68*05b00f60SXin Li #define TIPC_VER(w0) (((w0) >> 29) & 0x07)
69*05b00f60SXin Li #define TIPC_USER(w0) (((w0) >> 25) & 0x0F)
70*05b00f60SXin Li #define TIPC_HSIZE(w0) (((w0) >> 21) & 0x0F)
71*05b00f60SXin Li #define TIPC_MSIZE(w0) (((w0) >> 0) & 0x1FFFF)
72*05b00f60SXin Li #define TIPC_MTYPE(w1) (((w1) >> 29) & 0x07)
73*05b00f60SXin Li #define TIPC_BROADCAST_ACK(w1) (((w1) >> 0) & 0xFFFF)
74*05b00f60SXin Li #define TIPC_LINK_ACK(w2) (((w2) >> 16) & 0xFFFF)
75*05b00f60SXin Li #define TIPC_LINK_SEQ(w2) (((w2) >> 0) & 0xFFFF)
76*05b00f60SXin Li
77*05b00f60SXin Li static const struct tok tipcuser_values[] = {
78*05b00f60SXin Li { TIPC_USER_LOW_IMPORTANCE, "Low Importance Data payload" },
79*05b00f60SXin Li { TIPC_USER_MEDIUM_IMPORTANCE, "Medium Importance Data payload" },
80*05b00f60SXin Li { TIPC_USER_HIGH_IMPORTANCE, "High Importance Data payload" },
81*05b00f60SXin Li { TIPC_USER_CRITICAL_IMPORTANCE, "Critical Importance Data payload" },
82*05b00f60SXin Li { TIPC_USER_BCAST_PROTOCOL, "Broadcast Link Protocol internal" },
83*05b00f60SXin Li { TIPC_USER_MSG_BUNDLER, "Message Bundler Protocol internal" },
84*05b00f60SXin Li { TIPC_USER_LINK_PROTOCOL, "Link State Protocol internal" },
85*05b00f60SXin Li { TIPC_USER_CONN_MANAGER, "Connection Manager internal" },
86*05b00f60SXin Li { TIPC_USER_CHANGEOVER_PROTOCOL, "Link Changeover Protocol internal" },
87*05b00f60SXin Li { TIPC_USER_NAME_DISTRIBUTOR, "Name Table Update Protocol internal" },
88*05b00f60SXin Li { TIPC_USER_MSG_FRAGMENTER, "Message Fragmentation Protocol internal" },
89*05b00f60SXin Li { TIPC_USER_LINK_CONFIG, "Neighbor Detection Protocol internal" },
90*05b00f60SXin Li { 0, NULL }
91*05b00f60SXin Li };
92*05b00f60SXin Li
93*05b00f60SXin Li static const struct tok tipcmtype_values[] = {
94*05b00f60SXin Li { TIPC_CONN_MSG, "CONN_MSG" },
95*05b00f60SXin Li { TIPC_DIRECT_MSG, "MCAST_MSG" },
96*05b00f60SXin Li { TIPC_NAMED_MSG, "NAMED_MSG" },
97*05b00f60SXin Li { TIPC_MCAST_MSG, "DIRECT_MSG" },
98*05b00f60SXin Li { 0, NULL }
99*05b00f60SXin Li };
100*05b00f60SXin Li
101*05b00f60SXin Li static const struct tok tipc_linkconf_mtype_values[] = {
102*05b00f60SXin Li { 0, "Link request" },
103*05b00f60SXin Li { 1, "Link response" },
104*05b00f60SXin Li { 0, NULL }
105*05b00f60SXin Li };
106*05b00f60SXin Li
107*05b00f60SXin Li struct payload_tipc_pkthdr {
108*05b00f60SXin Li nd_uint32_t w0;
109*05b00f60SXin Li nd_uint32_t w1;
110*05b00f60SXin Li nd_uint32_t w2;
111*05b00f60SXin Li nd_uint32_t prev_node;
112*05b00f60SXin Li nd_uint32_t orig_port;
113*05b00f60SXin Li nd_uint32_t dest_port;
114*05b00f60SXin Li nd_uint32_t orig_node;
115*05b00f60SXin Li nd_uint32_t dest_node;
116*05b00f60SXin Li nd_uint32_t name_type;
117*05b00f60SXin Li nd_uint32_t w9;
118*05b00f60SXin Li nd_uint32_t wA;
119*05b00f60SXin Li };
120*05b00f60SXin Li
121*05b00f60SXin Li struct internal_tipc_pkthdr {
122*05b00f60SXin Li nd_uint32_t w0;
123*05b00f60SXin Li nd_uint32_t w1;
124*05b00f60SXin Li nd_uint32_t w2;
125*05b00f60SXin Li nd_uint32_t prev_node;
126*05b00f60SXin Li nd_uint32_t w4;
127*05b00f60SXin Li nd_uint32_t w5;
128*05b00f60SXin Li nd_uint32_t orig_node;
129*05b00f60SXin Li nd_uint32_t dest_node;
130*05b00f60SXin Li nd_uint32_t trans_seq;
131*05b00f60SXin Li nd_uint32_t w9;
132*05b00f60SXin Li };
133*05b00f60SXin Li
134*05b00f60SXin Li #define TIPC_SEQ_GAP(w1) (((w1) >> 16) & 0x1FFF)
135*05b00f60SXin Li #define TIPC_BC_GAP_AFTER(w2) (((w2) >> 16) & 0xFFFF)
136*05b00f60SXin Li #define TIPC_BC_GAP_TO(w2) (((w2) >> 0) & 0xFFFF)
137*05b00f60SXin Li #define TIPC_LAST_SENT_FRAG(w4) (((w4) >> 16) & 0xFFFF)
138*05b00f60SXin Li #define TIPC_NEXT_SENT_FRAG(w4) (((w4) >> 0) & 0xFFFF)
139*05b00f60SXin Li #define TIPC_SESS_NO(w5) (((w5) >> 16) & 0xFFFF)
140*05b00f60SXin Li #define TIPC_MSG_CNT(w9) (((w9) >> 16) & 0xFFFF)
141*05b00f60SXin Li #define TIPC_LINK_TOL(w9) (((w9) >> 0) & 0xFFFF)
142*05b00f60SXin Li
143*05b00f60SXin Li struct link_conf_tipc_pkthdr {
144*05b00f60SXin Li nd_uint32_t w0;
145*05b00f60SXin Li nd_uint32_t w1;
146*05b00f60SXin Li nd_uint32_t dest_domain;
147*05b00f60SXin Li nd_uint32_t prev_node;
148*05b00f60SXin Li nd_uint32_t ntwrk_id;
149*05b00f60SXin Li nd_uint32_t w5;
150*05b00f60SXin Li nd_byte media_address[16];
151*05b00f60SXin Li };
152*05b00f60SXin Li
153*05b00f60SXin Li #define TIPC_NODE_SIG(w1) (((w1) >> 0) & 0xFFFF)
154*05b00f60SXin Li #define TIPC_MEDIA_ID(w5) (((w5) >> 0) & 0xFF)
155*05b00f60SXin Li
156*05b00f60SXin Li static void
print_payload(netdissect_options * ndo,const struct payload_tipc_pkthdr * ap)157*05b00f60SXin Li print_payload(netdissect_options *ndo, const struct payload_tipc_pkthdr *ap)
158*05b00f60SXin Li {
159*05b00f60SXin Li uint32_t w0, w1, w2;
160*05b00f60SXin Li u_int user;
161*05b00f60SXin Li u_int hsize;
162*05b00f60SXin Li u_int msize;
163*05b00f60SXin Li u_int mtype;
164*05b00f60SXin Li u_int broadcast_ack;
165*05b00f60SXin Li u_int link_ack;
166*05b00f60SXin Li u_int link_seq;
167*05b00f60SXin Li u_int prev_node;
168*05b00f60SXin Li u_int orig_port;
169*05b00f60SXin Li u_int dest_port;
170*05b00f60SXin Li u_int orig_node;
171*05b00f60SXin Li u_int dest_node;
172*05b00f60SXin Li
173*05b00f60SXin Li w0 = GET_BE_U_4(ap->w0);
174*05b00f60SXin Li user = TIPC_USER(w0);
175*05b00f60SXin Li hsize = TIPC_HSIZE(w0);
176*05b00f60SXin Li msize = TIPC_MSIZE(w0);
177*05b00f60SXin Li w1 = GET_BE_U_4(ap->w1);
178*05b00f60SXin Li mtype = TIPC_MTYPE(w1);
179*05b00f60SXin Li prev_node = GET_BE_U_4(ap->prev_node);
180*05b00f60SXin Li orig_port = GET_BE_U_4(ap->orig_port);
181*05b00f60SXin Li dest_port = GET_BE_U_4(ap->dest_port);
182*05b00f60SXin Li if (hsize <= 6) {
183*05b00f60SXin Li ND_PRINT("TIPC v%u.0 %u.%u.%u:%u > %u, headerlength %u bytes, MessageSize %u bytes, %s, messageType %s",
184*05b00f60SXin Li TIPC_VER(w0),
185*05b00f60SXin Li TIPC_ZONE(prev_node), TIPC_CLUSTER(prev_node), TIPC_NODE(prev_node),
186*05b00f60SXin Li orig_port, dest_port,
187*05b00f60SXin Li hsize*4, msize,
188*05b00f60SXin Li tok2str(tipcuser_values, "unknown", user),
189*05b00f60SXin Li tok2str(tipcmtype_values, "Unknown", mtype));
190*05b00f60SXin Li } else {
191*05b00f60SXin Li orig_node = GET_BE_U_4(ap->orig_node);
192*05b00f60SXin Li dest_node = GET_BE_U_4(ap->dest_node);
193*05b00f60SXin Li ND_PRINT("TIPC v%u.0 %u.%u.%u:%u > %u.%u.%u:%u, headerlength %u bytes, MessageSize %u bytes, %s, messageType %s",
194*05b00f60SXin Li TIPC_VER(w0),
195*05b00f60SXin Li TIPC_ZONE(orig_node), TIPC_CLUSTER(orig_node), TIPC_NODE(orig_node),
196*05b00f60SXin Li orig_port,
197*05b00f60SXin Li TIPC_ZONE(dest_node), TIPC_CLUSTER(dest_node), TIPC_NODE(dest_node),
198*05b00f60SXin Li dest_port,
199*05b00f60SXin Li hsize*4, msize,
200*05b00f60SXin Li tok2str(tipcuser_values, "unknown", user),
201*05b00f60SXin Li tok2str(tipcmtype_values, "Unknown", mtype));
202*05b00f60SXin Li
203*05b00f60SXin Li if (ndo->ndo_vflag) {
204*05b00f60SXin Li broadcast_ack = TIPC_BROADCAST_ACK(w1);
205*05b00f60SXin Li w2 = GET_BE_U_4(ap->w2);
206*05b00f60SXin Li link_ack = TIPC_LINK_ACK(w2);
207*05b00f60SXin Li link_seq = TIPC_LINK_SEQ(w2);
208*05b00f60SXin Li ND_PRINT("\n\tPrevious Node %u.%u.%u, Broadcast Ack %u, Link Ack %u, Link Sequence %u",
209*05b00f60SXin Li TIPC_ZONE(prev_node), TIPC_CLUSTER(prev_node), TIPC_NODE(prev_node),
210*05b00f60SXin Li broadcast_ack, link_ack, link_seq);
211*05b00f60SXin Li }
212*05b00f60SXin Li }
213*05b00f60SXin Li }
214*05b00f60SXin Li
215*05b00f60SXin Li static void
print_internal(netdissect_options * ndo,const struct internal_tipc_pkthdr * ap)216*05b00f60SXin Li print_internal(netdissect_options *ndo, const struct internal_tipc_pkthdr *ap)
217*05b00f60SXin Li {
218*05b00f60SXin Li uint32_t w0, w1, w2, w4, w5, w9;
219*05b00f60SXin Li u_int user;
220*05b00f60SXin Li u_int hsize;
221*05b00f60SXin Li u_int msize;
222*05b00f60SXin Li u_int mtype;
223*05b00f60SXin Li u_int seq_gap;
224*05b00f60SXin Li u_int broadcast_ack;
225*05b00f60SXin Li u_int bc_gap_after;
226*05b00f60SXin Li u_int bc_gap_to;
227*05b00f60SXin Li u_int prev_node;
228*05b00f60SXin Li u_int last_sent_frag;
229*05b00f60SXin Li u_int next_sent_frag;
230*05b00f60SXin Li u_int sess_no;
231*05b00f60SXin Li u_int orig_node;
232*05b00f60SXin Li u_int dest_node;
233*05b00f60SXin Li u_int trans_seq;
234*05b00f60SXin Li u_int msg_cnt;
235*05b00f60SXin Li u_int link_tol;
236*05b00f60SXin Li
237*05b00f60SXin Li w0 = GET_BE_U_4(ap->w0);
238*05b00f60SXin Li user = TIPC_USER(w0);
239*05b00f60SXin Li hsize = TIPC_HSIZE(w0);
240*05b00f60SXin Li msize = TIPC_MSIZE(w0);
241*05b00f60SXin Li w1 = GET_BE_U_4(ap->w1);
242*05b00f60SXin Li mtype = TIPC_MTYPE(w1);
243*05b00f60SXin Li orig_node = GET_BE_U_4(ap->orig_node);
244*05b00f60SXin Li dest_node = GET_BE_U_4(ap->dest_node);
245*05b00f60SXin Li ND_PRINT("TIPC v%u.0 %u.%u.%u > %u.%u.%u, headerlength %u bytes, MessageSize %u bytes, %s, messageType %s (0x%08x)",
246*05b00f60SXin Li TIPC_VER(w0),
247*05b00f60SXin Li TIPC_ZONE(orig_node), TIPC_CLUSTER(orig_node), TIPC_NODE(orig_node),
248*05b00f60SXin Li TIPC_ZONE(dest_node), TIPC_CLUSTER(dest_node), TIPC_NODE(dest_node),
249*05b00f60SXin Li hsize*4, msize,
250*05b00f60SXin Li tok2str(tipcuser_values, "unknown", user),
251*05b00f60SXin Li tok2str(tipcmtype_values, "Unknown", mtype), w1);
252*05b00f60SXin Li
253*05b00f60SXin Li if (ndo->ndo_vflag) {
254*05b00f60SXin Li seq_gap = TIPC_SEQ_GAP(w1);
255*05b00f60SXin Li broadcast_ack = TIPC_BROADCAST_ACK(w1);
256*05b00f60SXin Li w2 = GET_BE_U_4(ap->w2);
257*05b00f60SXin Li bc_gap_after = TIPC_BC_GAP_AFTER(w2);
258*05b00f60SXin Li bc_gap_to = TIPC_BC_GAP_TO(w2);
259*05b00f60SXin Li prev_node = GET_BE_U_4(ap->prev_node);
260*05b00f60SXin Li w4 = GET_BE_U_4(ap->w4);
261*05b00f60SXin Li last_sent_frag = TIPC_LAST_SENT_FRAG(w4);
262*05b00f60SXin Li next_sent_frag = TIPC_NEXT_SENT_FRAG(w4);
263*05b00f60SXin Li w5 = GET_BE_U_4(ap->w5);
264*05b00f60SXin Li sess_no = TIPC_SESS_NO(w5);
265*05b00f60SXin Li trans_seq = GET_BE_U_4(ap->trans_seq);
266*05b00f60SXin Li w9 = GET_BE_U_4(ap->w9);
267*05b00f60SXin Li msg_cnt = TIPC_MSG_CNT(w9);
268*05b00f60SXin Li link_tol = TIPC_LINK_TOL(w9);
269*05b00f60SXin Li ND_PRINT("\n\tPrevious Node %u.%u.%u, Session No. %u, Broadcast Ack %u, Sequence Gap %u, Broadcast Gap After %u, Broadcast Gap To %u, Last Sent Packet No. %u, Next sent Packet No. %u, Transport Sequence %u, msg_count %u, Link Tolerance %u",
270*05b00f60SXin Li TIPC_ZONE(prev_node), TIPC_CLUSTER(prev_node), TIPC_NODE(prev_node),
271*05b00f60SXin Li sess_no, broadcast_ack, seq_gap, bc_gap_after, bc_gap_to,
272*05b00f60SXin Li last_sent_frag, next_sent_frag, trans_seq, msg_cnt,
273*05b00f60SXin Li link_tol);
274*05b00f60SXin Li }
275*05b00f60SXin Li }
276*05b00f60SXin Li
277*05b00f60SXin Li static void
print_link_conf(netdissect_options * ndo,const struct link_conf_tipc_pkthdr * ap)278*05b00f60SXin Li print_link_conf(netdissect_options *ndo, const struct link_conf_tipc_pkthdr *ap)
279*05b00f60SXin Li {
280*05b00f60SXin Li uint32_t w0, w1, w5;
281*05b00f60SXin Li u_int user;
282*05b00f60SXin Li u_int hsize;
283*05b00f60SXin Li u_int msize;
284*05b00f60SXin Li u_int mtype;
285*05b00f60SXin Li u_int node_sig;
286*05b00f60SXin Li u_int prev_node;
287*05b00f60SXin Li u_int dest_domain;
288*05b00f60SXin Li u_int ntwrk_id;
289*05b00f60SXin Li u_int media_id;
290*05b00f60SXin Li
291*05b00f60SXin Li w0 = GET_BE_U_4(ap->w0);
292*05b00f60SXin Li user = TIPC_USER(w0);
293*05b00f60SXin Li hsize = TIPC_HSIZE(w0);
294*05b00f60SXin Li msize = TIPC_MSIZE(w0);
295*05b00f60SXin Li w1 = GET_BE_U_4(ap->w1);
296*05b00f60SXin Li mtype = TIPC_MTYPE(w1);
297*05b00f60SXin Li dest_domain = GET_BE_U_4(ap->dest_domain);
298*05b00f60SXin Li prev_node = GET_BE_U_4(ap->prev_node);
299*05b00f60SXin Li
300*05b00f60SXin Li ND_PRINT("TIPC v%u.0 %u.%u.%u > %u.%u.%u, headerlength %u bytes, MessageSize %u bytes, %s, messageType %s",
301*05b00f60SXin Li TIPC_VER(w0),
302*05b00f60SXin Li TIPC_ZONE(prev_node), TIPC_CLUSTER(prev_node), TIPC_NODE(prev_node),
303*05b00f60SXin Li TIPC_ZONE(dest_domain), TIPC_CLUSTER(dest_domain), TIPC_NODE(dest_domain),
304*05b00f60SXin Li hsize*4, msize,
305*05b00f60SXin Li tok2str(tipcuser_values, "unknown", user),
306*05b00f60SXin Li tok2str(tipc_linkconf_mtype_values, "Unknown", mtype));
307*05b00f60SXin Li if (ndo->ndo_vflag) {
308*05b00f60SXin Li node_sig = TIPC_NODE_SIG(w1);
309*05b00f60SXin Li ntwrk_id = GET_BE_U_4(ap->ntwrk_id);
310*05b00f60SXin Li w5 = GET_BE_U_4(ap->w5);
311*05b00f60SXin Li media_id = TIPC_MEDIA_ID(w5);
312*05b00f60SXin Li ND_PRINT("\n\tNodeSignature %u, network_id %u, media_id %u",
313*05b00f60SXin Li node_sig, ntwrk_id, media_id);
314*05b00f60SXin Li }
315*05b00f60SXin Li }
316*05b00f60SXin Li
317*05b00f60SXin Li void
tipc_print(netdissect_options * ndo,const u_char * bp,u_int length _U_,u_int caplen _U_)318*05b00f60SXin Li tipc_print(netdissect_options *ndo, const u_char *bp, u_int length _U_,
319*05b00f60SXin Li u_int caplen _U_)
320*05b00f60SXin Li {
321*05b00f60SXin Li const struct tipc_pkthdr *ap;
322*05b00f60SXin Li uint32_t w0;
323*05b00f60SXin Li u_int user;
324*05b00f60SXin Li
325*05b00f60SXin Li ndo->ndo_protocol = "tipc";
326*05b00f60SXin Li ap = (const struct tipc_pkthdr *)bp;
327*05b00f60SXin Li w0 = GET_BE_U_4(ap->w0);
328*05b00f60SXin Li user = TIPC_USER(w0);
329*05b00f60SXin Li
330*05b00f60SXin Li switch (user)
331*05b00f60SXin Li {
332*05b00f60SXin Li case TIPC_USER_LOW_IMPORTANCE:
333*05b00f60SXin Li case TIPC_USER_MEDIUM_IMPORTANCE:
334*05b00f60SXin Li case TIPC_USER_HIGH_IMPORTANCE:
335*05b00f60SXin Li case TIPC_USER_CRITICAL_IMPORTANCE:
336*05b00f60SXin Li case TIPC_USER_NAME_DISTRIBUTOR:
337*05b00f60SXin Li case TIPC_USER_CONN_MANAGER:
338*05b00f60SXin Li print_payload(ndo, (const struct payload_tipc_pkthdr *)bp);
339*05b00f60SXin Li break;
340*05b00f60SXin Li
341*05b00f60SXin Li case TIPC_USER_LINK_CONFIG:
342*05b00f60SXin Li print_link_conf(ndo, (const struct link_conf_tipc_pkthdr *)bp);
343*05b00f60SXin Li break;
344*05b00f60SXin Li
345*05b00f60SXin Li case TIPC_USER_BCAST_PROTOCOL:
346*05b00f60SXin Li case TIPC_USER_MSG_BUNDLER:
347*05b00f60SXin Li case TIPC_USER_LINK_PROTOCOL:
348*05b00f60SXin Li case TIPC_USER_CHANGEOVER_PROTOCOL:
349*05b00f60SXin Li case TIPC_USER_MSG_FRAGMENTER:
350*05b00f60SXin Li print_internal(ndo, (const struct internal_tipc_pkthdr *)bp);
351*05b00f60SXin Li break;
352*05b00f60SXin Li
353*05b00f60SXin Li }
354*05b00f60SXin Li }
355