aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJaap Keuter <jaap.keuter@xs4all.nl>2008-03-24 10:49:23 +0000
committerJaap Keuter <jaap.keuter@xs4all.nl>2008-03-24 10:49:23 +0000
commit0a34df9b85813d28633e28a884c6539fa751eb76 (patch)
treef6cc5aeb1b7b75bbe7924d4f51d2098688983703
parentb6bf2335996094cc760cf431bbd0f25f3dad6fe8 (diff)
FIx for bug 2381:
The eigrp update packets may contain more than one destination advertisement per one "IP external route" or "IP internal route" TLV. Recurse over prefix/network address pairs until TLV is exhausted. svn path=/trunk/; revision=24721
-rw-r--r--epan/dissectors/packet-eigrp.c54
1 files changed, 30 insertions, 24 deletions
diff --git a/epan/dissectors/packet-eigrp.c b/epan/dissectors/packet-eigrp.c
index 8b8cd28a50..d29b5f24d7 100644
--- a/epan/dissectors/packet-eigrp.c
+++ b/epan/dissectors/packet-eigrp.c
@@ -309,7 +309,7 @@ static void dissect_eigrp_nms (tvbuff_t *tvb, proto_tree *tree, proto_item *ti)
static void dissect_eigrp_ip_int (tvbuff_t *tvb, proto_tree *tree, proto_item *ti)
{
guint8 ip_addr[4],length;
- int addr_len;
+ int addr_len,offset;
tvb_memcpy(tvb,ip_addr,0,4);
proto_tree_add_text (tree,tvb,0,4, "Next Hop = %s",ip_to_str(ip_addr));
@@ -320,24 +320,27 @@ static void dissect_eigrp_ip_int (tvbuff_t *tvb, proto_tree *tree, proto_item *t
proto_tree_add_text (tree,tvb,16,1,"Reliability = %u",tvb_get_guint8(tvb,16));
proto_tree_add_text (tree,tvb,17,1,"Load = %u",tvb_get_guint8(tvb,17));
proto_tree_add_text (tree,tvb,18,2,"Reserved ");
- length=tvb_get_guint8(tvb,20);
- /* XXX - the EIGRP page whose URL appears at the top says this
- field is 24 bits; what if the prefix length is > 24? */
- addr_len=ipv4_addr_and_mask (tvb,21,ip_addr,length);
- if (addr_len < 0) {
- proto_tree_add_text (tree,tvb,20,1,"Prefix length = %u (invalid, must be <= 32)",length);
- proto_item_append_text (ti," [Invalid prefix length %u > 32]",length);
- } else {
- proto_tree_add_text (tree,tvb,20,1,"Prefix Length = %u",length);
- proto_tree_add_text (tree,tvb,21,addr_len,"Destination = %s",ip_to_str(ip_addr));
- proto_item_append_text (ti," = %s/%u%s",ip_to_str(ip_addr),length,((tvb_get_ntohl(tvb,4)==0xffffffff)?" - Destination unreachable":""));
+
+ for (offset = 20; tvb_length_remaining(tvb, offset) > 0; offset += (1+addr_len))
+ {
+ length=tvb_get_guint8(tvb,offset);
+ addr_len=ipv4_addr_and_mask (tvb,offset+1,ip_addr,length);
+ if (addr_len < 0) {
+ proto_tree_add_text (tree,tvb,offset,1,"Prefix length = %u (invalid, must be <= 32)",length);
+ proto_item_append_text (ti," [Invalid prefix length %u > 32]",length);
+ addr_len = 4; /* assure we can exit the loop */
+ } else {
+ proto_tree_add_text (tree,tvb,offset,1,"Prefix Length = %u",length);
+ proto_tree_add_text (tree,tvb,offset+1,addr_len,"Destination = %s",ip_to_str(ip_addr));
+ proto_item_append_text (ti," %c %s/%u%s",offset==20?'=':',',ip_to_str(ip_addr),length,((tvb_get_ntohl(tvb,4)==0xffffffff)?" - Destination unreachable":""));
+ }
}
}
static void dissect_eigrp_ip_ext (tvbuff_t *tvb, proto_tree *tree, proto_item *ti)
{
guint8 ip_addr[4],length;
- int addr_len;
+ int addr_len,offset;
tvb_memcpy(tvb,ip_addr,0,4);
proto_tree_add_text (tree,tvb,0,4,"Next Hop = %s",ip_to_str(ip_addr));
@@ -357,17 +360,20 @@ static void dissect_eigrp_ip_ext (tvbuff_t *tvb, proto_tree *tree, proto_item *t
proto_tree_add_text (tree,tvb,36,1,"Reliability = %u",tvb_get_guint8(tvb,36));
proto_tree_add_text (tree,tvb,37,1,"Load = %u",tvb_get_guint8(tvb,37));
proto_tree_add_text (tree,tvb,38,2,"Reserved ");
- length=tvb_get_guint8(tvb,40);
- /* XXX - the EIGRP page whose URL appears at the top says this
- field is 24 bits; what if the prefix length is > 24? */
- addr_len=ipv4_addr_and_mask (tvb,41,ip_addr,length);
- if (addr_len < 0) {
- proto_tree_add_text (tree,tvb,40,1,"Prefix length = %u (invalid, must be <= 32)",length);
- proto_item_append_text (ti," [Invalid prefix length %u > 32]",length);
- } else {
- proto_tree_add_text (tree,tvb,40,1,"Prefix Length = %u",length);
- proto_tree_add_text (tree,tvb,41,addr_len,"Destination = %s",ip_to_str(ip_addr));
- proto_item_append_text (ti," = %s/%u%s",ip_to_str(ip_addr),length,((tvb_get_ntohl(tvb,4)==0xffffffff)?" - Destination unreachable":""));
+
+ for (offset = 40; tvb_length_remaining(tvb, offset) > 0; offset += (1+addr_len))
+ {
+ length=tvb_get_guint8(tvb,offset);
+ addr_len=ipv4_addr_and_mask (tvb,offset+1,ip_addr,length);
+ if (addr_len < 0) {
+ proto_tree_add_text (tree,tvb,offset,1,"Prefix length = %u (invalid, must be <= 32)",length);
+ proto_item_append_text (ti," [Invalid prefix length %u > 32]",length);
+ addr_len = 4; /* assure we can exit the loop */
+ } else {
+ proto_tree_add_text (tree,tvb,offset,1,"Prefix Length = %u",length);
+ proto_tree_add_text (tree,tvb,offset+1,addr_len,"Destination = %s",ip_to_str(ip_addr));
+ proto_item_append_text (ti," %c %s/%u%s",offset==40?'=':',',ip_to_str(ip_addr),length,((tvb_get_ntohl(tvb,4)==0xffffffff)?" - Destination unreachable":""));
+ }
}
}