]> The Tcpdump Group git mirrors - tcpdump/blobdiff - print-ah.c
Use more the ND_TTEST_1() macro
[tcpdump] / print-ah.c
index a37574d14e8af4acb36450e3f8357b5c98f5c0fe..30fb8d266b4f4ad1fd9d1f78c3a45051bce083be 100644 (file)
  * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
  */
 
+/* \summary: IPSEC Authentication Header printer */
+
 #ifdef HAVE_CONFIG_H
 #include "config.h"
 #endif
 
-#include <tcpdump-stdinc.h>
+#include <netdissect-stdinc.h>
 
-#include <stdio.h>
+#include "netdissect.h"
+#include "extract.h"
 
 #include "ah.h"
 
-#include "interface.h"
-#include "addrtoname.h"
-#include "extract.h"
-
 int
-ah_print(register const u_char *bp)
+ah_print(netdissect_options *ndo, const u_char *bp)
 {
-       register const struct ah *ah;
-       register const u_char *ep;
+       const struct ah *ah;
        int sumlen;
-       u_int32_t spi;
 
        ah = (const struct ah *)bp;
-       ep = snapend;           /* 'ep' points to the end of available data. */
 
-       TCHECK(*ah);
+       ND_TCHECK(*ah);
 
-       sumlen = ah->ah_len << 2;
-       spi = EXTRACT_32BITS(&ah->ah_spi);
+       sumlen = EXTRACT_U_1(ah->ah_len) << 2;
 
-       printf("AH(spi=0x%08x", spi);
-       if (vflag)
-               printf(",sumlen=%d", sumlen);
-       printf(",seq=0x%x", EXTRACT_32BITS(ah + 1));
-       if (bp + sizeof(struct ah) + sumlen > ep)
-               fputs("[truncated]", stdout);
-       fputs("): ", stdout);
+       ND_PRINT((ndo, "AH(spi=0x%08x", EXTRACT_BE_U_4(ah->ah_spi)));
+       if (ndo->ndo_vflag)
+               ND_PRINT((ndo, ",sumlen=%d", sumlen));
+       ND_TCHECK_4(ah + 1);
+       ND_PRINT((ndo, ",seq=0x%x", EXTRACT_BE_U_4(ah + 1)));
+       if (!ND_TTEST_LEN(bp, sizeof(struct ah) + sumlen)) {
+               ND_PRINT((ndo, "[truncated]):"));
+               return -1;
+       }
+       ND_PRINT((ndo, "): "));
 
        return sizeof(struct ah) + sumlen;
  trunc:
-       fputs("[|AH]", stdout);
+       ND_PRINT((ndo, "[|AH]"));
        return -1;
 }