summaryrefslogtreecommitdiff
path: root/print-cip.c
diff options
context:
space:
mode:
authorDenis Ovsienko <denis@ovsienko.info>2020-10-16 16:57:01 +0100
committerDenis Ovsienko <denis@ovsienko.info>2020-10-16 16:57:01 +0100
commit9418e2b7eb4622260ad27fb3829e80e44b3b9e65 (patch)
tree6c6902e43dc1dbaaffd8a994654880e9b89a2e31 /print-cip.c
parent9ec0a1a346253b9f6052d37aa98c9c5ef7a28ac1 (diff)
downloadtcpdump-9418e2b7eb4622260ad27fb3829e80e44b3b9e65.tar.gz
CIP: Modernize packet parsing style.
Enable ND_LONGJMP_FROM_TCHECK. Lose a function and a variable. Require at least the LLC header worth of data. Update a test.
Diffstat (limited to 'print-cip.c')
-rw-r--r--print-cip.c28
1 files changed, 7 insertions, 21 deletions
diff --git a/print-cip.c b/print-cip.c
index 8838dc99..b8ef77fd 100644
--- a/print-cip.c
+++ b/print-cip.c
@@ -30,6 +30,7 @@
#include "netdissect-stdinc.h"
+#define ND_LONGJMP_FROM_TCHECK
#include "netdissect.h"
#include "addrtoname.h"
@@ -41,15 +42,6 @@ static const unsigned char rfcllc[] = {
0x00,
0x00 };
-static void
-cip_print(netdissect_options *ndo, u_int length)
-{
- /*
- * There is no MAC-layer header, so just print the length.
- */
- ND_PRINT("%u: ", length);
-}
-
/*
* This is the top level routine of the printer. 'p' points
* to the LLC/SNAP or raw header of the packet, 'h->ts' is the timestamp,
@@ -61,24 +53,18 @@ cip_if_print(netdissect_options *ndo, const struct pcap_pkthdr *h, const u_char
{
u_int caplen = h->caplen;
u_int length = h->len;
- size_t cmplen;
int llc_hdrlen;
ndo->ndo_protocol = "cip";
- cmplen = sizeof(rfcllc);
- if (cmplen > caplen)
- cmplen = caplen;
- if (cmplen > length)
- cmplen = length;
if (ndo->ndo_eflag)
- cip_print(ndo, length);
+ /*
+ * There is no MAC-layer header, so just print the length.
+ */
+ ND_PRINT("%u: ", length);
- if (cmplen == 0) {
- nd_print_trunc(ndo);
- return;
- }
- if (memcmp(rfcllc, p, cmplen) == 0) {
+ ND_TCHECK_LEN(p, sizeof(rfcllc));
+ if (memcmp(rfcllc, p, sizeof(rfcllc)) == 0) {
/*
* LLC header is present. Try to print it & higher layers.
*/