]>
The Tcpdump Group git mirrors - tcpdump/blob - print-loopback.c
2 * This module implements decoding of the Loopback Protocol, originally
3 * defined as the Configuration Testing Protocol. It is based on the following
5 * http://www.mit.edu/people/jhawk/ctp.pdf
7 * Copyright (c) 2014 The TCPDUMP project
10 * Redistribution and use in source and binary forms, with or without
11 * modification, are permitted provided that the following conditions
13 * 1. Redistributions of source code must retain the above copyright
14 * notice, this list of conditions and the following disclaimer.
15 * 2. Redistributions in binary form must reproduce the above copyright
16 * notice, this list of conditions and the following disclaimer in the
17 * documentation and/or other materials provided with the distribution.
19 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
20 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
21 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
22 * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
23 * COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
24 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
25 * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
26 * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
27 * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
28 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
29 * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
30 * POSSIBILITY OF SUCH DAMAGE.
37 #include <tcpdump-stdinc.h>
39 #include "netdissect.h"
42 #include "addrtoname.h"
44 static const char tstr
[] = " [|loopback]";
45 static const char istr
[] = " (invalid)";
47 #define LOOPBACK_REPLY 1
48 #define LOOPBACK_FWDDATA 2
50 static const struct tok fcode_str
[] = {
51 { LOOPBACK_REPLY
, "Reply" },
52 { LOOPBACK_FWDDATA
, "Forward Data" },
57 loopback_message_print(netdissect_options
*ndo
, const u_char
*cp
, const u_int len
)
59 const u_char
*ep
= cp
+ len
;
66 function
= EXTRACT_LE_16BITS(cp
);
68 ND_PRINT((ndo
, ", %s", tok2str(fcode_str
, " invalid (%u)", function
)));
76 ND_PRINT((ndo
, ", receipt number %u", EXTRACT_LE_16BITS(cp
)));
79 ND_PRINT((ndo
, ", data (%u octets)", len
- 4));
80 ND_TCHECK2(*cp
, len
- 4);
82 case LOOPBACK_FWDDATA
:
85 /* forwarding address */
86 ND_TCHECK2(*cp
, ETHER_ADDR_LEN
);
87 ND_PRINT((ndo
, ", forwarding address %s", etheraddr_string(ndo
, cp
)));
90 ND_PRINT((ndo
, ", data (%u octets)", len
- 8));
91 ND_TCHECK2(*cp
, len
- 8);
94 ND_TCHECK2(*cp
, len
- 2);
100 ND_PRINT((ndo
, "%s", istr
));
101 ND_TCHECK2(*cp
, ep
- cp
);
104 ND_PRINT((ndo
, "%s", tstr
));
108 loopback_print(netdissect_options
*ndo
, const u_char
*cp
, const u_int len
)
110 const u_char
*ep
= cp
+ len
;
113 ND_PRINT((ndo
, "Loopback"));
118 skipCount
= EXTRACT_LE_16BITS(cp
);
120 ND_PRINT((ndo
, ", skipCount %u", skipCount
));
122 ND_PRINT((ndo
, " (bogus)"));
123 if (skipCount
> len
- 2)
125 loopback_message_print(ndo
, cp
+ skipCount
, len
- 2 - skipCount
);
129 ND_PRINT((ndo
, "%s", istr
));
130 ND_TCHECK2(*cp
, ep
- cp
);
133 ND_PRINT((ndo
, "%s", tstr
));