]> The Tcpdump Group git mirrors - tcpdump/blobdiff - print-enc.c
Use more the ND_TTEST_1() macro
[tcpdump] / print-enc.c
index c8bb3dec19d8dfe6efd7e474facf8e8cc0e71a75..c3fcf10c7da0d287c590282092b09bfbe82ad464 100644 (file)
  * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
  */
 
+/* \summary: OpenBSD IPsec encapsulation BPF layer printer */
+
 #ifdef HAVE_CONFIG_H
 #include "config.h"
 #endif
 
-#include <tcpdump-stdinc.h>
+#include <netdissect-stdinc.h>
 
-#include "interface.h"
+#include "netdissect.h"
 #include "extract.h"
 
 /* From $OpenBSD: if_enc.h,v 1.8 2001/06/25 05:14:00 angelos Exp $ */
 /*
  * The authors of this code are John Ioannidis ([email protected]),
- * Angelos D. Keromytis ([email protected]) and 
+ * Angelos D. Keromytis ([email protected]) and
  * Niels Provos ([email protected]).
  *
- * This code was written by John Ioannidis for BSD/OS in Athens, Greece, 
+ * This code was written by John Ioannidis for BSD/OS in Athens, Greece,
  * in November 1995.
  *
  * Ported to OpenBSD and NetBSD, with additional transforms, in December 1996,
@@ -52,7 +54,7 @@
  * Permission to use, copy, and modify this software with or without fee
  * is hereby granted, provided that this entire notice is included in
  * all copies of any software which is or includes a copy or
- * modification of this software. 
+ * modification of this software.
  * You may use this code under the GNU public license if you so wish. Please
  * contribute changes back to the authors under this freer than GPL license
  * so that we may further the use of strong encryption without limitations to
 #define M_AUTH         0x0800  /* packet was authenticated (AH) */
 
 struct enchdr {
-       u_int32_t af;
-       u_int32_t spi;
-       u_int32_t flags;
+       uint32_t af;
+       uint32_t spi;
+       uint32_t flags;
 };
 
 #define ENC_PRINT_TYPE(wh, xf, nam) \
        if ((wh) & (xf)) { \
-               printf("%s%s", nam, (wh) == (xf) ? "): " : ","); \
+               ND_PRINT((ndo, "%s%s", nam, (wh) == (xf) ? "): " : ",")); \
                (wh) &= ~(xf); \
        }
 
 u_int
-enc_if_print(const struct pcap_pkthdr *h, register const u_char *p)
+enc_if_print(netdissect_options *ndo,
+             const struct pcap_pkthdr *h, const u_char *p)
 {
-       register u_int length = h->len;
-       register u_int caplen = h->caplen;
+       u_int length = h->len;
+       u_int caplen = h->caplen;
        int flags;
        const struct enchdr *hdr;
 
        if (caplen < ENC_HDRLEN) {
-               printf("[|enc]");
+               ND_PRINT((ndo, "[|enc]"));
                goto out;
        }
 
-       hdr = (struct enchdr *)p;
+       hdr = (const struct enchdr *)p;
        flags = hdr->flags;
        if (flags == 0)
-               printf("(unprotected): ");
+               ND_PRINT((ndo, "(unprotected): "));
        else
-               printf("(");
+               ND_PRINT((ndo, "("));
        ENC_PRINT_TYPE(flags, M_AUTH, "authentic");
        ENC_PRINT_TYPE(flags, M_CONF, "confidential");
        /* ENC_PRINT_TYPE(flags, M_TUNNEL, "tunnel"); */
-       printf("SPI 0x%08x: ", EXTRACT_32BITS(&hdr->spi));
+       ND_PRINT((ndo, "SPI 0x%08x: ", EXTRACT_BE_U_4(&hdr->spi)));
 
        length -= ENC_HDRLEN;
        caplen -= ENC_HDRLEN;
@@ -113,13 +116,13 @@ enc_if_print(const struct pcap_pkthdr *h, register const u_char *p)
 
        switch (hdr->af) {
        case AF_INET:
-               ip_print(gndo, p, length);
+               ip_print(ndo, p, length);
                break;
-#ifdef INET6
+#ifdef AF_INET6
        case AF_INET6:
-               ip6_print(gndo, p, length);
+               ip6_print(ndo, p, length);
                break;
-#endif /*INET6*/
+#endif
        }
 
 out: