Skip site navigation (1)Skip section navigation (2)
Date:      Sat, 31 Jan 2015 16:26:21 +0000 (UTC)
From:      "Pedro F. Giffuni" <pfg@FreeBSD.org>
To:        src-committers@freebsd.org, svn-src-all@freebsd.org, svn-src-vendor@freebsd.org
Subject:   svn commit: r277981 - vendor/tcpdump/dist
Message-ID:  <201501311626.t0VGQLqs062416@svn.freebsd.org>

next in thread | raw e-mail | index | archive | help
Author: pfg
Date: Sat Jan 31 16:26:21 2015
New Revision: 277981
URL: https://svnweb.freebsd.org/changeset/base/277981

Log:
  Upstream fixes for issues found with afl (Issue #417).
  
  - Fix length checking.
  
  Check both the captured length and the on-the-wire length (the latter
  *should* be greater than or equal to the former, but that's not
  guaranteed).
  
  Add some additional length checks, so neither caplen nor length
  underflow.
  
  If we stop dissecting because the packet is too short, return 1, not 0,
  as we've "dissected" what we can; 0 means "this is LLC+SNAP with an OUI
  of 0 and an unknown Ethertype".
  
  commit:	743bcecdc92f88b118ec7aac4f68b606601205cc
  
  - Clean up length checks.
  
  Check only the amount of length that matters at any given point; yes,
  this means we do multiple checks, but so it goes.
  
  We don't need to check for LLC+SNAP - llc_print() does that for us.  We
  do, however, need to check to make sure we can safely skip the Fore
  header.
  
  commit:	5c65e7532fa16308e01299988852b0dc5b027559

Modified:
  vendor/tcpdump/dist/print-atm.c
  vendor/tcpdump/dist/print-llc.c

Modified: vendor/tcpdump/dist/print-atm.c
==============================================================================
--- vendor/tcpdump/dist/print-atm.c	Sat Jan 31 15:50:19 2015	(r277980)
+++ vendor/tcpdump/dist/print-atm.c	Sat Jan 31 16:26:21 2015	(r277981)
@@ -165,7 +165,7 @@ atm_if_print(netdissect_options *ndo,
 	uint32_t llchdr;
 	u_int hdrlen = 0;
 
-	if (caplen < 8) {
+	if (caplen < 1 || length < 1) {
 		ND_PRINT((ndo, "%s", tstr));
 		return (caplen);
 	}
@@ -179,6 +179,15 @@ atm_if_print(netdissect_options *ndo,
         }
 
 	/*
+	 * Must have at least a DSAP, an SSAP, and the first byte of the
+	 * control field.
+	 */
+	if (caplen < 3 || length < 3) {
+		ND_PRINT((ndo, "%s", tstr));
+		return (caplen);
+	}
+
+	/*
 	 * Extract the presumed LLC header into a variable, for quick
 	 * testing.
 	 * Then check for a header that's neither a header for a SNAP
@@ -205,6 +214,10 @@ atm_if_print(netdissect_options *ndo,
 		 * packets?  If so, could it be changed to use a
 		 * new DLT_IEEE802_6 value if we added it?
 		 */
+		if (caplen < 20 || length < 20) {
+			ND_PRINT((ndo, "%s", tstr));
+			return (caplen);
+		}
 		if (ndo->ndo_eflag)
 			ND_PRINT((ndo, "%08x%08x %08x%08x ",
 			       EXTRACT_32BITS(p),

Modified: vendor/tcpdump/dist/print-llc.c
==============================================================================
--- vendor/tcpdump/dist/print-llc.c	Sat Jan 31 15:50:19 2015	(r277980)
+++ vendor/tcpdump/dist/print-llc.c	Sat Jan 31 16:26:21 2015	(r277981)
@@ -151,10 +151,10 @@ llc_print(netdissect_options *ndo, const
 
 	*extracted_ethertype = 0;
 
-	if (caplen < 3) {
+	if (caplen < 3 || length < 3) {
 		ND_PRINT((ndo, "[|llc]"));
 		ND_DEFAULTPRINT((u_char *)p, caplen);
-		return(0);
+		return (1);
 	}
 
 	dsap_field = *p;
@@ -177,10 +177,10 @@ llc_print(netdissect_options *ndo, const
 		 * The control field in I and S frames is
 		 * 2 bytes...
 		 */
-		if (caplen < 4) {
+		if (caplen < 4 || length < 4) {
 			ND_PRINT((ndo, "[|llc]"));
 			ND_DEFAULTPRINT((u_char *)p, caplen);
-			return(0);
+			return (1);
 		}
 
 		/*
@@ -240,6 +240,11 @@ llc_print(netdissect_options *ndo, const
 
 	if (ssap == LLCSAP_IP && dsap == LLCSAP_IP &&
 	    control == LLC_UI) {
+		if (caplen < 4 || length < 4) {
+			ND_PRINT((ndo, "[|llc]"));
+			ND_DEFAULTPRINT((u_char *)p, caplen);
+			return (1);
+		}
 		ip_print(ndo, p+4, length-4);
 		return (1);
 	}
@@ -368,6 +373,8 @@ snap_print(netdissect_options *ndo, cons
 	register int ret;
 
 	ND_TCHECK2(*p, 5);
+	if (caplen < 5 || length < 5)
+		goto trunc;
 	orgcode = EXTRACT_24BITS(p);
 	et = EXTRACT_16BITS(p + 3);
 



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?201501311626.t0VGQLqs062416>