/* \summary: Solaris DLT_IPNET printer */
-#ifdef HAVE_CONFIG_H
#include <config.h>
-#endif
#include "netdissect-stdinc.h"
+#define ND_LONGJMP_FROM_TCHECK
#include "netdissect.h"
#include "extract.h"
-static const char tstr[] = "[|ipnet]";
typedef struct ipnet_hdr {
nd_uint8_t iph_version;
const ipnet_hdr_t *hdr;
hdr = (const ipnet_hdr_t *)bp;
- ND_TCHECK_SIZE(hdr);
- ND_PRINT("%u > %u", EXTRACT_BE_U_4(hdr->iph_zsrc),
- EXTRACT_BE_U_4(hdr->iph_zdst));
+ ND_PRINT("%u > %u", GET_BE_U_4(hdr->iph_zsrc),
+ GET_BE_U_4(hdr->iph_zdst));
if (!ndo->ndo_qflag) {
ND_PRINT(", family %s (%u)",
tok2str(ipnet_values, "Unknown",
- EXTRACT_U_1(hdr->iph_family)),
- EXTRACT_U_1(hdr->iph_family));
+ GET_U_1(hdr->iph_family)),
+ GET_U_1(hdr->iph_family));
} else {
ND_PRINT(", %s",
tok2str(ipnet_values,
"Unknown Ethertype (0x%04x)",
- EXTRACT_U_1(hdr->iph_family)));
+ GET_U_1(hdr->iph_family)));
}
ND_PRINT(", length %u: ", length);
- return;
-trunc:
- ND_PRINT(" %s", tstr);
}
static void
{
const ipnet_hdr_t *hdr;
- ndo->ndo_protocol = "ipnet";
- if (caplen < sizeof(ipnet_hdr_t))
- goto trunc;
+ ND_TCHECK_LEN(p, sizeof(ipnet_hdr_t));
+ ndo->ndo_ll_hdr_len += sizeof(ipnet_hdr_t);
if (ndo->ndo_eflag)
ipnet_hdr_print(ndo, p, length);
hdr = (const ipnet_hdr_t *)p;
p += sizeof(ipnet_hdr_t);
- ND_TCHECK_1(hdr->iph_family);
- switch (EXTRACT_U_1(hdr->iph_family)) {
+ switch (GET_U_1(hdr->iph_family)) {
case IPH_AF_INET:
ip_print(ndo, p, length);
ND_DEFAULTPRINT(p, caplen);
break;
}
- return;
-trunc:
- ND_PRINT(" %s", tstr);
}
/*
* 'h->len' is the length of the packet off the wire, and 'h->caplen'
* is the number of bytes actually captured.
*/
-u_int
+void
ipnet_if_print(netdissect_options *ndo,
const struct pcap_pkthdr *h, const u_char *p)
{
- ndo->ndo_protocol = "ipnet_if";
+ ndo->ndo_protocol = "ipnet";
ipnet_print(ndo, p, h->len, h->caplen);
-
- return (sizeof(ipnet_hdr_t));
}
#endif /* DLT_IPNET */