X-Git-Url: https://git.tcpdump.org/tcpdump/blobdiff_plain/5c4f91da945d3cbc573b5c306ae42d2fe3723248..0023eaa78f123676bfa9c5fba72ea4b8a59aaa70:/print-ah.c diff --git a/print-ah.c b/print-ah.c index b4fae2eb..3b3a7921 100644 --- a/print-ah.c +++ b/print-ah.c @@ -21,80 +21,53 @@ * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. */ -#ifndef lint -static char rcsid[] = - "@(#) Header: print-ah.c,v 1.37 94/06/10 17:01:42 mccanne Exp (LBL)"; -#endif +/* \summary: IPSEC Authentication Header printer */ -#include -#include -#include -#include +#include -#include -#include -#include -#include -#include -#include +#include "netdissect-stdinc.h" -#undef NOERROR /* Solaris sucks */ -#include -#include +#include "netdissect.h" +#include "extract.h" -#ifdef SOLARIS -#include -#endif -#include +#include "ah.h" -#include -#include - -#include "interface.h" -#include "addrtoname.h" - -extern int packettype; - - -void -ah_print(register const u_char *bp, int length, register const u_char *bp2) +int +ah_print(netdissect_options *ndo, const u_char *bp) { - register const struct ip *ip; - register const u_char *cp, *nh; - u_short nextheader; - u_short ahlen, authlen; - u_long spi, seqno; - - ip = (struct ip *)bp2; - - (void)printf("AH %s > %s\n\t\t", - ipaddr_string(&ip->ip_src), - ipaddr_string(&ip->ip_dst)); - - if (length < 8) { - (void)printf(" [|ah] truncated-ah %d", length); - return; - } + const struct ah *ah; + uint8_t ah_len; + u_int ah_hdr_len; + uint16_t reserved; + const u_char *p; - nextheader = bp[0]; - ahlen = bp[1]; - spi = ntohl(*((u_long *)(bp+4))); - seqno = ntohl(*((u_long *)(bp+8))); - authlen = ahlen - 12; + ndo->ndo_protocol = "ah"; + ah = (const struct ah *)bp; - nh = bp+ahlen; - - if(authlen > length || authlen == 0) - { - authlen = length; - } - - (void)printf("spi:%08x seqno:%d authlen: %d authdata: ", spi, - seqno, authlen); - (void)default_print_unaligned(bp+12, authlen); - - /* PRINT rest of packet, requires some reorg of print-ip.c */ -#if XXX - (void)ip_print(nextheader, ip, nh, length-authlen); -#endif + nd_print_protocol_caps(ndo); +/* + * RFC4302 + * + * 2.2. Payload Length + * + * This 8-bit field specifies the length of AH in 32-bit words (4-byte + * units), minus "2". + */ + ah_len = GET_U_1(ah->ah_len); + ah_hdr_len = (ah_len + 2) * 4; + + ND_PRINT("("); + if (ndo->ndo_vflag) + ND_PRINT("length=%u(%u-bytes),", ah_len, ah_hdr_len); + reserved = GET_BE_U_2(ah->ah_reserved); + if (reserved) + ND_PRINT("reserved=0x%x[MustBeZero],", reserved); + ND_PRINT("spi=0x%08x,", GET_BE_U_4(ah->ah_spi)); + ND_PRINT("seq=0x%x,", GET_BE_U_4(ah->ah_seq)); + ND_PRINT("icv=0x"); + for (p = (const u_char *)(ah + 1); p < bp + ah_hdr_len; p++) + ND_PRINT("%02x", GET_U_1(p)); + ND_PRINT("): "); + + return ah_hdr_len; }