mirror of
https://github.com/oliverschmidt/contiki.git
synced 2024-12-23 01:29:33 +00:00
[multicast] Do not forward every incoming TM ICMP
The Trickle Multicast ICMP packet handler was not resetting uip_len to zero, so all incoming TM ICMP packets were forwarded overloading the network.
This commit is contained in:
parent
512f9984b6
commit
b9aa88b504
@ -1107,26 +1107,26 @@ icmp_input()
|
|||||||
PRINT6ADDR(&UIP_IP_BUF->destipaddr);
|
PRINT6ADDR(&UIP_IP_BUF->destipaddr);
|
||||||
PRINTF("\n");
|
PRINTF("\n");
|
||||||
ROLL_TM_STATS_ADD(icmp_bad);
|
ROLL_TM_STATS_ADD(icmp_bad);
|
||||||
return;
|
goto discard;
|
||||||
}
|
}
|
||||||
|
|
||||||
if(!uip_is_addr_linklocal_allnodes_mcast(&UIP_IP_BUF->destipaddr)
|
if(!uip_is_addr_linklocal_allnodes_mcast(&UIP_IP_BUF->destipaddr)
|
||||||
&& !uip_is_addr_linklocal_allrouters_mcast(&UIP_IP_BUF->destipaddr)) {
|
&& !uip_is_addr_linklocal_allrouters_mcast(&UIP_IP_BUF->destipaddr)) {
|
||||||
PRINTF("ROLL TM: ICMPv6 In, bad destination\n");
|
PRINTF("ROLL TM: ICMPv6 In, bad destination\n");
|
||||||
ROLL_TM_STATS_ADD(icmp_bad);
|
ROLL_TM_STATS_ADD(icmp_bad);
|
||||||
return;
|
goto discard;
|
||||||
}
|
}
|
||||||
|
|
||||||
if(UIP_ICMP_BUF->icode != ROLL_TM_ICMP_CODE) {
|
if(UIP_ICMP_BUF->icode != ROLL_TM_ICMP_CODE) {
|
||||||
PRINTF("ROLL TM: ICMPv6 In, bad ICMP code\n");
|
PRINTF("ROLL TM: ICMPv6 In, bad ICMP code\n");
|
||||||
ROLL_TM_STATS_ADD(icmp_bad);
|
ROLL_TM_STATS_ADD(icmp_bad);
|
||||||
return;
|
goto discard;
|
||||||
}
|
}
|
||||||
|
|
||||||
if(UIP_IP_BUF->ttl != ROLL_TM_IP_HOP_LIMIT) {
|
if(UIP_IP_BUF->ttl != ROLL_TM_IP_HOP_LIMIT) {
|
||||||
PRINTF("ROLL TM: ICMPv6 In, bad TTL\n");
|
PRINTF("ROLL TM: ICMPv6 In, bad TTL\n");
|
||||||
ROLL_TM_STATS_ADD(icmp_bad);
|
ROLL_TM_STATS_ADD(icmp_bad);
|
||||||
return;
|
goto discard;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -1311,6 +1311,9 @@ drop:
|
|||||||
t[1].c++;
|
t[1].c++;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
discard:
|
||||||
|
|
||||||
|
uip_len = 0;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
/*---------------------------------------------------------------------------*/
|
/*---------------------------------------------------------------------------*/
|
||||||
|
Loading…
Reference in New Issue
Block a user