]> The Tcpdump Group git mirrors - tcpdump/commitdiff
bugfix: do not attempt to decode zero-length TLVs, only attempt to decode IS-REACH...
authorhannes <hannes>
Mon, 25 Apr 2005 09:09:11 +0000 (09:09 +0000)
committerhannes <hannes>
Mon, 25 Apr 2005 09:09:11 +0000 (09:09 +0000)
print-isoclns.c

index ca6ebc692f7453b8834a6eaa8542b1111f9b6c83..74ce023dbd17552361d9d6937d43439ce17482f3 100644 (file)
@@ -26,7 +26,7 @@
 
 #ifndef lint
 static const char rcsid[] _U_ =
-    "@(#) $Header: /tcpdump/master/tcpdump/print-isoclns.c,v 1.134 2005-04-25 08:42:30 guy Exp $ (LBL)";
+    "@(#) $Header: /tcpdump/master/tcpdump/print-isoclns.c,v 1.135 2005-04-25 09:09:11 hannes Exp $ (LBL)";
 #endif
 
 #ifdef HAVE_CONFIG_H
@@ -1905,6 +1905,9 @@ static int isis_print (const u_int8_t *p, u_int length)
                tlv_type,
                tlv_len);
 
+        if (tlv_len == 0) /* something is malformed */
+            break;
+
         /* now check if we have a decoder otherwise do a hexdump at the end*/
        switch (tlv_type) {
        case ISIS_TLV_AREA_ADDR:
@@ -1935,7 +1938,7 @@ static int isis_print (const u_int8_t *p, u_int length)
            break;
 
         case ISIS_TLV_ISNEIGH_VARLEN:
-            if (!TTEST2(*tptr, 1))
+            if (!TTEST2(*tptr, 1) && tmp > 1)
                goto trunctlv;
            lan_alen = *tptr++; /* LAN address length */
            if (lan_alen == 0) {