]>
The Tcpdump Group git mirrors - tcpdump/blob - print-802_15_4.c
3 * Siemens AG, All rights reserved.
4 * Dmitry Eremin-Solenikov (dbaryshkov@gmail.com)
6 * Redistribution and use in source and binary forms, with or without
7 * modification, are permitted provided that: (1) source code distributions
8 * retain the above copyright notice and this paragraph in its entirety, (2)
9 * distributions including binary code include the above copyright notice and
10 * this paragraph in its entirety in the documentation or other materials
11 * provided with the distribution, and (3) all advertising materials mentioning
12 * features or use of this software display the following acknowledgement:
13 * ``This product includes software developed by the University of California,
14 * Lawrence Berkeley Laboratory and its contributors.'' Neither the name of
15 * the University nor the names of its contributors may be used to endorse
16 * or promote products derived from this software without specific prior
18 * THIS SOFTWARE IS PROVIDED ``AS IS'' AND WITHOUT ANY EXPRESS OR IMPLIED
19 * WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED WARRANTIES OF
20 * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
27 #include <tcpdump-stdinc.h>
32 #include "interface.h"
33 #include "addrtoname.h"
37 static const char *ftypes
[] = {
49 extract_header_length(u_int16_t fc
)
53 switch ((fc
>> 10) & 0x3) {
55 if (fc
& (1 << 6)) /* intra-PAN with none dest addr */
68 switch ((fc
>> 14) & 0x3) {
92 ieee802_15_4_if_print(struct netdissect_options
*ndo
,
93 const struct pcap_pkthdr
*h
, const u_char
*p
)
95 u_int caplen
= h
->caplen
;
101 ND_PRINT((ndo
, "[|802.15.4] %x", caplen
));
105 fc
= EXTRACT_LE_16BITS(p
);
106 hdrlen
= extract_header_length(fc
);
108 seq
= EXTRACT_LE_8BITS(p
+ 2);
113 ND_PRINT((ndo
,"IEEE 802.15.4 %s packet ", ftypes
[fc
& 0x7]));
115 ND_PRINT((ndo
,"seq %02x ", seq
));
117 ND_PRINT((ndo
,"malformed! "));
128 switch ((fc
>> 10) & 0x3) {
130 ND_PRINT((ndo
,"none "));
133 ND_PRINT((ndo
,"reserved destination addressing mode"));
136 panid
= EXTRACT_LE_16BITS(p
);
138 ND_PRINT((ndo
,"%04x:%04x ", panid
, EXTRACT_LE_16BITS(p
)));
142 panid
= EXTRACT_LE_16BITS(p
);
144 ND_PRINT((ndo
,"%04x:%s ", panid
, le64addr_string(p
)));
150 switch ((fc
>> 14) & 0x3) {
152 ND_PRINT((ndo
,"none "));
155 ND_PRINT((ndo
,"reserved source addressing mode"));
158 if (!(fc
& (1 << 6))) {
159 panid
= EXTRACT_LE_16BITS(p
);
162 ND_PRINT((ndo
,"%04x:%04x ", panid
, EXTRACT_LE_16BITS(p
)));
166 if (!(fc
& (1 << 6))) {
167 panid
= EXTRACT_LE_16BITS(p
);
170 ND_PRINT((ndo
,"%04x:%s ", panid
, le64addr_string(p
))));
178 if (!suppress_default_print
)
179 (ndo
->ndo_default_print
)(ndo
, p
, caplen
);