diff options
author | Olaf Kirch <okir@suse.de> | 2005-07-12 06:01:42 +0200 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2005-07-12 06:01:42 +0200 |
commit | 0b7f22aab4e960c75e82ad696ef852f9b0015e7d (patch) | |
tree | 4c689dd688fbe7cbb4c3c61e2b246d5f48805aa6 | |
parent | [IPVS]: Add and reorder bh locks after moving to keventd. (diff) | |
download | linux-0b7f22aab4e960c75e82ad696ef852f9b0015e7d.tar.xz linux-0b7f22aab4e960c75e82ad696ef852f9b0015e7d.zip |
[IPV4]: Prevent oops when printing martian source
In some cases, we may be generating packets with a source address that
qualifies as martian. This can happen when we're in the middle of setting
up the network, and netfilter decides to reject a packet with an RST.
The IPv4 routing code would try to print a warning and oops, because
locally generated packets do not have a valid skb->mac.raw pointer
at this point.
Signed-off-by: David S. Miller <davem@davemloft.net>
-rw-r--r-- | net/ipv4/route.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/net/ipv4/route.c b/net/ipv4/route.c index 726ea5e8180a..d675ff80b04d 100644 --- a/net/ipv4/route.c +++ b/net/ipv4/route.c @@ -1685,7 +1685,7 @@ static void ip_handle_martian_source(struct net_device *dev, printk(KERN_WARNING "martian source %u.%u.%u.%u from " "%u.%u.%u.%u, on dev %s\n", NIPQUAD(daddr), NIPQUAD(saddr), dev->name); - if (dev->hard_header_len) { + if (dev->hard_header_len && skb->mac.raw) { int i; unsigned char *p = skb->mac.raw; printk(KERN_WARNING "ll header: "); |