1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2025-01-18 12:52:44 +01:00

notify registered threads about _all_ received IP packets

(Before notifications were only sent for IP packets that were not
forwarded.)
This commit is contained in:
Oleg Hahm 2013-11-24 15:07:46 +01:00
parent 079d654104
commit 160c3f1794

View File

@ -275,6 +275,15 @@ void ipv6_process(void)
/* identifiy packet */ /* identifiy packet */
nextheader = &ipv6_buf->nextheader; nextheader = &ipv6_buf->nextheader;
for (i = 0; i < SIXLOWIP_MAX_REGISTERED; i++) {
if (sixlowip_reg[i]) {
msg_t m_send;
m_send.type = IPV6_PACKET_RECEIVED;
m_send.content.ptr = (char *) ipv6_buf;
msg_send(&m_send, sixlowip_reg[i], 1);
}
}
/* destination is foreign address */ /* destination is foreign address */
if ((ipv6_get_addr_match(&myaddr, &ipv6_buf->destaddr) >= 112) && if ((ipv6_get_addr_match(&myaddr, &ipv6_buf->destaddr) >= 112) &&
(ipv6_buf->destaddr.uint8[15] != myaddr.uint8[15])) { (ipv6_buf->destaddr.uint8[15] != myaddr.uint8[15])) {
@ -301,15 +310,6 @@ void ipv6_process(void)
} }
/* destination is our address */ /* destination is our address */
else { else {
for (i = 0; i < SIXLOWIP_MAX_REGISTERED; i++) {
if (sixlowip_reg[i]) {
msg_t m_send;
m_send.type = IPV6_PACKET_RECEIVED;
m_send.content.ptr = (char *) &ipv6_buf;
msg_send(&m_send, sixlowip_reg[i], 1);
}
}
switch (*nextheader) { switch (*nextheader) {
case (IPV6_PROTO_NUM_ICMPV6): { case (IPV6_PROTO_NUM_ICMPV6): {
/* checksum test*/ /* checksum test*/