diff options
author | guy <guy> | 2005-05-05 23:08:43 +0000 |
---|---|---|
committer | guy <guy> | 2005-05-05 23:08:43 +0000 |
commit | 13247041388fef082829d0ca1d89fe1c0adc6db6 (patch) | |
tree | 3852e22bb6db1a487fc5a5c514c1b54a1c1cce2f /print-sctp.c | |
parent | 9bd9227c3282c2c685daeb26885a4fb66b4379f0 (diff) | |
download | tcpdump-13247041388fef082829d0ca1d89fe1c0adc6db6.tar.gz |
Add more bounds checks, and check for bogus chunk lengths (too short).
Diffstat (limited to 'print-sctp.c')
-rw-r--r-- | print-sctp.c | 30 |
1 files changed, 19 insertions, 11 deletions
diff --git a/print-sctp.c b/print-sctp.c index beb289e9..a491481b 100644 --- a/print-sctp.c +++ b/print-sctp.c @@ -35,7 +35,7 @@ #ifndef lint static const char rcsid[] _U_ = -"@(#) $Header: /tcpdump/master/tcpdump/print-sctp.c,v 1.17 2005-04-13 08:30:41 guy Exp $ (NETLAB/PEL)"; +"@(#) $Header: /tcpdump/master/tcpdump/print-sctp.c,v 1.18 2005-05-05 23:08:43 guy Exp $ (NETLAB/PEL)"; #endif #ifdef HAVE_CONFIG_H @@ -68,7 +68,6 @@ void sctp_print(const u_char *bp, /* beginning of sctp packet */ #ifdef INET6 const struct ip6_hdr *ip6; #endif - const u_char *cp; const void *endPacketPtr; u_short sourcePort, destPort; int chunkCount; @@ -88,12 +87,7 @@ void sctp_print(const u_char *bp, /* beginning of sctp packet */ else ip6 = NULL; #endif /*INET6*/ - cp = (const u_char *)(sctpPktHdr + 1); - if (cp > snapend) - { - printf("[|sctp]"); - return; - } + TCHECK(*sctpPktHdr); if (sctpPacketLength < sizeof(struct sctpHeader)) { @@ -141,12 +135,21 @@ void sctp_print(const u_char *bp, /* beginning of sctp packet */ chunkDescPtr = (const struct sctpChunkDesc *) nextChunk, chunkCount++) { - u_short align; + u_int16_t chunkLength; const u_char *chunkEnd; + u_int16_t align; - chunkEnd = ((const u_char*)chunkDescPtr + EXTRACT_16BITS(&chunkDescPtr->chunkLength)); + TCHECK(*chunkDescPtr); + chunkLength = EXTRACT_16BITS(&chunkDescPtr->chunkLength); + if (chunkLength < sizeof(*chunkDescPtr)) { + printf("%s%d) [Bad chunk length %u]", sep, chunkCount+1, chunkLength); + break; + } - align=EXTRACT_16BITS(&chunkDescPtr->chunkLength) % 4; + TCHECK2(*(((u_int8_t *)chunkDescPtr) + chunkLength), chunkLength); + chunkEnd = ((const u_char*)chunkDescPtr + chunkLength); + + align=chunkLength % 4; if (align != 0) align = 4 - align; @@ -347,4 +350,9 @@ void sctp_print(const u_char *bp, /* beginning of sctp packet */ if (vflag < 2) sep = ", ("; } + return; + +trunc: + printf("[|sctp]"); + return; } |