Commit aff4f914 authored by Hideaki Yoshifuji's avatar Hideaki Yoshifuji

[IPV6]: Clean up ndisc printks.

parent 5850f935
...@@ -28,11 +28,12 @@ ...@@ -28,11 +28,12 @@
/* Set to 3 to get tracing... */ /* Set to 3 to get tracing... */
#define ND_DEBUG 1 #define ND_DEBUG 1
#define ND_PRINTK(x...) printk(KERN_DEBUG x) #define ND_PRINTK(fmt, args...) do { if (net_ratelimit()) { printk(fmt, ## args); } } while(0)
#define ND_NOPRINTK(x...) do { ; } while(0) #define ND_NOPRINTK(x...) do { ; } while(0)
#define ND_PRINTK0 ND_PRINTK #define ND_PRINTK0 ND_PRINTK
#define ND_PRINTK1 ND_NOPRINTK #define ND_PRINTK1 ND_NOPRINTK
#define ND_PRINTK2 ND_NOPRINTK #define ND_PRINTK2 ND_NOPRINTK
#define ND_PRINTK3 ND_NOPRINTK
#if ND_DEBUG >= 1 #if ND_DEBUG >= 1
#undef ND_PRINTK1 #undef ND_PRINTK1
#define ND_PRINTK1 ND_PRINTK #define ND_PRINTK1 ND_PRINTK
...@@ -41,6 +42,10 @@ ...@@ -41,6 +42,10 @@
#undef ND_PRINTK2 #undef ND_PRINTK2
#define ND_PRINTK2 ND_PRINTK #define ND_PRINTK2 ND_PRINTK
#endif #endif
#if ND_DEBUG >= 3
#undef ND_PRINTK3
#define ND_PRINTK3 ND_PRINTK
#endif
#include <linux/module.h> #include <linux/module.h>
#include <linux/config.h> #include <linux/config.h>
...@@ -210,7 +215,9 @@ static struct ndisc_options *ndisc_parse_options(u8 *opt, int opt_len, ...@@ -210,7 +215,9 @@ static struct ndisc_options *ndisc_parse_options(u8 *opt, int opt_len,
case ND_OPT_MTU: case ND_OPT_MTU:
case ND_OPT_REDIRECT_HDR: case ND_OPT_REDIRECT_HDR:
if (ndopts->nd_opt_array[nd_opt->nd_opt_type]) { if (ndopts->nd_opt_array[nd_opt->nd_opt_type]) {
ND_PRINTK2("ndisc_parse_options(): duplicated ND6 option found: type=%d\n", ND_PRINTK2(KERN_WARNING
"%s(): duplicated ND6 option found: type=%d\n",
__FUNCTION__,
nd_opt->nd_opt_type); nd_opt->nd_opt_type);
} else { } else {
ndopts->nd_opt_array[nd_opt->nd_opt_type] = nd_opt; ndopts->nd_opt_array[nd_opt->nd_opt_type] = nd_opt;
...@@ -226,8 +233,9 @@ static struct ndisc_options *ndisc_parse_options(u8 *opt, int opt_len, ...@@ -226,8 +233,9 @@ static struct ndisc_options *ndisc_parse_options(u8 *opt, int opt_len,
* Unknown options must be silently ignored, * Unknown options must be silently ignored,
* to accommodate future extension to the protocol. * to accommodate future extension to the protocol.
*/ */
ND_PRINTK2(KERN_WARNING ND_PRINTK2(KERN_NOTICE
"ndisc_parse_options(): ignored unsupported option; type=%d, len=%d\n", "%s(): ignored unsupported option; type=%d, len=%d\n",
__FUNCTION__,
nd_opt->nd_opt_type, nd_opt->nd_opt_len); nd_opt->nd_opt_type, nd_opt->nd_opt_len);
} }
opt_len -= l; opt_len -= l;
...@@ -408,7 +416,9 @@ static void ndisc_send_na(struct net_device *dev, struct neighbour *neigh, ...@@ -408,7 +416,9 @@ static void ndisc_send_na(struct net_device *dev, struct neighbour *neigh,
1, &err); 1, &err);
if (skb == NULL) { if (skb == NULL) {
ND_PRINTK1("send_na: alloc skb failed\n"); ND_PRINTK0(KERN_ERR
"ICMPv6 NA: %s() failed to allocate an skb.\n",
__FUNCTION__);
dst_release(dst); dst_release(dst);
return; return;
} }
...@@ -493,7 +503,9 @@ void ndisc_send_ns(struct net_device *dev, struct neighbour *neigh, ...@@ -493,7 +503,9 @@ void ndisc_send_ns(struct net_device *dev, struct neighbour *neigh,
skb = sock_alloc_send_skb(sk, MAX_HEADER + len + LL_RESERVED_SPACE(dev), skb = sock_alloc_send_skb(sk, MAX_HEADER + len + LL_RESERVED_SPACE(dev),
1, &err); 1, &err);
if (skb == NULL) { if (skb == NULL) {
ND_PRINTK1("send_ns: alloc skb failed\n"); ND_PRINTK0(KERN_ERR
"ICMPv6 NA: %s() failed to allocate an skb.\n",
__FUNCTION__);
dst_release(dst); dst_release(dst);
return; return;
} }
...@@ -565,7 +577,9 @@ void ndisc_send_rs(struct net_device *dev, struct in6_addr *saddr, ...@@ -565,7 +577,9 @@ void ndisc_send_rs(struct net_device *dev, struct in6_addr *saddr,
skb = sock_alloc_send_skb(sk, MAX_HEADER + len + LL_RESERVED_SPACE(dev), skb = sock_alloc_send_skb(sk, MAX_HEADER + len + LL_RESERVED_SPACE(dev),
1, &err); 1, &err);
if (skb == NULL) { if (skb == NULL) {
ND_PRINTK1("send_ns: alloc skb failed\n"); ND_PRINTK0(KERN_ERR
"ICMPv6 RS: %s() failed to allocate an skb.\n",
__FUNCTION__);
dst_release(dst); dst_release(dst);
return; return;
} }
...@@ -628,8 +642,13 @@ static void ndisc_solicit(struct neighbour *neigh, struct sk_buff *skb) ...@@ -628,8 +642,13 @@ static void ndisc_solicit(struct neighbour *neigh, struct sk_buff *skb)
saddr = &skb->nh.ipv6h->saddr; saddr = &skb->nh.ipv6h->saddr;
if ((probes -= neigh->parms->ucast_probes) < 0) { if ((probes -= neigh->parms->ucast_probes) < 0) {
if (!(neigh->nud_state&NUD_VALID)) if (!(neigh->nud_state & NUD_VALID)) {
ND_PRINTK1("trying to ucast probe in NUD_INVALID\n"); ND_PRINTK1(KERN_DEBUG
"%s(): trying to ucast probe in NUD_INVALID: "
"%04x:%04x:%04x:%04x:%04x:%04x:%04x:%04x\n",
__FUNCTION__,
NIP6(*target));
}
ndisc_send_ns(dev, neigh, target, target, saddr); ndisc_send_ns(dev, neigh, target, target, saddr);
} else if ((probes -= neigh->parms->app_probes) < 0) { } else if ((probes -= neigh->parms->app_probes) < 0) {
#ifdef CONFIG_ARPD #ifdef CONFIG_ARPD
...@@ -658,8 +677,8 @@ static void ndisc_recv_ns(struct sk_buff *skb) ...@@ -658,8 +677,8 @@ static void ndisc_recv_ns(struct sk_buff *skb)
int inc; int inc;
if (ipv6_addr_is_multicast(&msg->target)) { if (ipv6_addr_is_multicast(&msg->target)) {
if (net_ratelimit()) ND_PRINTK2(KERN_WARNING
printk(KERN_WARNING "ICMP NS: target address is multicast\n"); "ICMPv6 NS: multicast target address");
return; return;
} }
...@@ -672,14 +691,14 @@ static void ndisc_recv_ns(struct sk_buff *skb) ...@@ -672,14 +691,14 @@ static void ndisc_recv_ns(struct sk_buff *skb)
daddr->s6_addr32[1] == htonl(0x00000000) && daddr->s6_addr32[1] == htonl(0x00000000) &&
daddr->s6_addr32[2] == htonl(0x00000001) && daddr->s6_addr32[2] == htonl(0x00000001) &&
daddr->s6_addr [12] == 0xff )) { daddr->s6_addr [12] == 0xff )) {
if (net_ratelimit()) ND_PRINTK2(KERN_WARNING
printk(KERN_DEBUG "ICMP6 NS: bad DAD packet (wrong destination)\n"); "ICMPv6 NS: bad DAD packet (wrong destination)\n");
return; return;
} }
if (!ndisc_parse_options(msg->opt, ndoptlen, &ndopts)) { if (!ndisc_parse_options(msg->opt, ndoptlen, &ndopts)) {
if (net_ratelimit()) ND_PRINTK2(KERN_WARNING
printk(KERN_WARNING "ICMP NS: invalid ND option, ignored.\n"); "ICMPv6 NS: invalid ND options\n");
return; return;
} }
...@@ -687,8 +706,8 @@ static void ndisc_recv_ns(struct sk_buff *skb) ...@@ -687,8 +706,8 @@ static void ndisc_recv_ns(struct sk_buff *skb)
lladdr = (u8*)(ndopts.nd_opts_src_lladdr + 1); lladdr = (u8*)(ndopts.nd_opts_src_lladdr + 1);
lladdrlen = ndopts.nd_opts_src_lladdr->nd_opt_len << 3; lladdrlen = ndopts.nd_opts_src_lladdr->nd_opt_len << 3;
if (lladdrlen != NDISC_OPT_SPACE(dev->addr_len)) { if (lladdrlen != NDISC_OPT_SPACE(dev->addr_len)) {
if (net_ratelimit()) ND_PRINTK2(KERN_WARNING
printk(KERN_WARNING "ICMP NS: bad lladdr length.\n"); "ICMPv6 NS: invalid link-layer address length\n");
return; return;
} }
...@@ -698,8 +717,8 @@ static void ndisc_recv_ns(struct sk_buff *skb) ...@@ -698,8 +717,8 @@ static void ndisc_recv_ns(struct sk_buff *skb)
* in the message. * in the message.
*/ */
if (dad) { if (dad) {
if (net_ratelimit()) ND_PRINTK2(KERN_WARNING
printk(KERN_WARNING "ICMP6 NS: bad DAD packet (link-layer address option)\n"); "ICMPv6 NS: bad DAD packet (link-layer address option)\n");
return; return;
} }
} }
...@@ -813,34 +832,35 @@ static void ndisc_recv_na(struct sk_buff *skb) ...@@ -813,34 +832,35 @@ static void ndisc_recv_na(struct sk_buff *skb)
struct neighbour *neigh; struct neighbour *neigh;
if (skb->len < sizeof(struct nd_msg)) { if (skb->len < sizeof(struct nd_msg)) {
if (net_ratelimit()) ND_PRINTK2(KERN_WARNING
printk(KERN_WARNING "ICMP NA: packet too short\n"); "ICMPv6 NA: packet too short\n");
return; return;
} }
if (ipv6_addr_is_multicast(&msg->target)) { if (ipv6_addr_is_multicast(&msg->target)) {
if (net_ratelimit()) ND_PRINTK2(KERN_WARNING
printk(KERN_WARNING "NDISC NA: target address is multicast\n"); "ICMPv6 NA: target address is multicast.\n");
return; return;
} }
if (ipv6_addr_is_multicast(daddr) && if (ipv6_addr_is_multicast(daddr) &&
msg->icmph.icmp6_solicited) { msg->icmph.icmp6_solicited) {
ND_PRINTK0("NDISC: solicited NA is multicasted\n"); ND_PRINTK2(KERN_WARNING
"ICMPv6 NA: solicited NA is multicasted.\n");
return; return;
} }
if (!ndisc_parse_options(msg->opt, ndoptlen, &ndopts)) { if (!ndisc_parse_options(msg->opt, ndoptlen, &ndopts)) {
if (net_ratelimit()) ND_PRINTK2(KERN_WARNING
printk(KERN_WARNING "ICMP NS: invalid ND option, ignored.\n"); "ICMPv6 NS: invalid ND option\n");
return; return;
} }
if (ndopts.nd_opts_tgt_lladdr) { if (ndopts.nd_opts_tgt_lladdr) {
lladdr = (u8*)(ndopts.nd_opts_tgt_lladdr + 1); lladdr = (u8*)(ndopts.nd_opts_tgt_lladdr + 1);
lladdrlen = ndopts.nd_opts_tgt_lladdr->nd_opt_len << 3; lladdrlen = ndopts.nd_opts_tgt_lladdr->nd_opt_len << 3;
if (lladdrlen != NDISC_OPT_SPACE(dev->addr_len)) { if (lladdrlen != NDISC_OPT_SPACE(dev->addr_len)) {
if (net_ratelimit()) ND_PRINTK2(KERN_WARNING
printk(KERN_WARNING "NDISC NA: invalid lladdr length.\n"); "ICMPv6 NA: invalid link-layer address length\n");
return; return;
} }
} }
...@@ -854,7 +874,8 @@ static void ndisc_recv_na(struct sk_buff *skb) ...@@ -854,7 +874,8 @@ static void ndisc_recv_na(struct sk_buff *skb)
about it. It could be misconfiguration, or about it. It could be misconfiguration, or
an smart proxy agent tries to help us :-) an smart proxy agent tries to help us :-)
*/ */
ND_PRINTK0("%s: someone advertises our address!\n", ND_PRINTK1(KERN_WARNING
"ICMPv6 NA: someone advertises our address on %s!\n",
ifp->idev->dev->name); ifp->idev->dev->name);
in6_ifa_put(ifp); in6_ifa_put(ifp);
return; return;
...@@ -899,13 +920,13 @@ static void ndisc_router_discovery(struct sk_buff *skb) ...@@ -899,13 +920,13 @@ static void ndisc_router_discovery(struct sk_buff *skb)
optlen = (skb->tail - skb->h.raw) - sizeof(struct ra_msg); optlen = (skb->tail - skb->h.raw) - sizeof(struct ra_msg);
if (!(ipv6_addr_type(&skb->nh.ipv6h->saddr) & IPV6_ADDR_LINKLOCAL)) { if (!(ipv6_addr_type(&skb->nh.ipv6h->saddr) & IPV6_ADDR_LINKLOCAL)) {
if (net_ratelimit()) ND_PRINTK2(KERN_WARNING
printk(KERN_WARNING "ICMP RA: source address is not linklocal\n"); "ICMPv6 RA: source address is not link-local.\n");
return; return;
} }
if (optlen < 0) { if (optlen < 0) {
if (net_ratelimit()) ND_PRINTK2(KERN_WARNING
printk(KERN_WARNING "ICMP RA: packet too short\n"); "ICMPv6 RA: packet too short\n");
return; return;
} }
...@@ -915,7 +936,9 @@ static void ndisc_router_discovery(struct sk_buff *skb) ...@@ -915,7 +936,9 @@ static void ndisc_router_discovery(struct sk_buff *skb)
in6_dev = in6_dev_get(skb->dev); in6_dev = in6_dev_get(skb->dev);
if (in6_dev == NULL) { if (in6_dev == NULL) {
ND_PRINTK1("RA: can't find in6 device\n"); ND_PRINTK0(KERN_ERR
"ICMPv6 RA: can't find inet6 device for %s.\n",
skb->dev->name);
return; return;
} }
if (in6_dev->cnf.forwarding || !in6_dev->cnf.accept_ra) { if (in6_dev->cnf.forwarding || !in6_dev->cnf.accept_ra) {
...@@ -925,9 +948,8 @@ static void ndisc_router_discovery(struct sk_buff *skb) ...@@ -925,9 +948,8 @@ static void ndisc_router_discovery(struct sk_buff *skb)
if (!ndisc_parse_options(opt, optlen, &ndopts)) { if (!ndisc_parse_options(opt, optlen, &ndopts)) {
in6_dev_put(in6_dev); in6_dev_put(in6_dev);
if (net_ratelimit())
ND_PRINTK2(KERN_WARNING ND_PRINTK2(KERN_WARNING
"ICMP6 RA: invalid ND option, ignored.\n"); "ICMP6 RA: invalid ND options\n");
return; return;
} }
...@@ -960,18 +982,23 @@ static void ndisc_router_discovery(struct sk_buff *skb) ...@@ -960,18 +982,23 @@ static void ndisc_router_discovery(struct sk_buff *skb)
} }
if (rt == NULL && lifetime) { if (rt == NULL && lifetime) {
ND_PRINTK2("ndisc_rdisc: adding default router\n"); ND_PRINTK3(KERN_DEBUG
"ICMPv6 RA: adding default router.\n");
rt = rt6_add_dflt_router(&skb->nh.ipv6h->saddr, skb->dev); rt = rt6_add_dflt_router(&skb->nh.ipv6h->saddr, skb->dev);
if (rt == NULL) { if (rt == NULL) {
ND_PRINTK1("route_add failed\n"); ND_PRINTK0(KERN_ERR
"ICMPv6 RA: %s() failed to add default route.\n",
__FUNCTION__);
in6_dev_put(in6_dev); in6_dev_put(in6_dev);
return; return;
} }
neigh = rt->rt6i_nexthop; neigh = rt->rt6i_nexthop;
if (neigh == NULL) { if (neigh == NULL) {
ND_PRINTK1("nd: add default router: null neighbour\n"); ND_PRINTK0(KERN_ERR
"ICMPv6 RA: %s() got default router without neighbour.\n",
__FUNCTION__);
dst_release(&rt->u.dst); dst_release(&rt->u.dst);
in6_dev_put(in6_dev); in6_dev_put(in6_dev);
return; return;
...@@ -1036,9 +1063,8 @@ static void ndisc_router_discovery(struct sk_buff *skb) ...@@ -1036,9 +1063,8 @@ static void ndisc_router_discovery(struct sk_buff *skb)
lladdr = (u8*)((ndopts.nd_opts_src_lladdr)+1); lladdr = (u8*)((ndopts.nd_opts_src_lladdr)+1);
lladdrlen = ndopts.nd_opts_src_lladdr->nd_opt_len << 3; lladdrlen = ndopts.nd_opts_src_lladdr->nd_opt_len << 3;
if (lladdrlen != NDISC_OPT_SPACE(skb->dev->addr_len)) { if (lladdrlen != NDISC_OPT_SPACE(skb->dev->addr_len)) {
if (net_ratelimit())
ND_PRINTK2(KERN_WARNING ND_PRINTK2(KERN_WARNING
"ICMP6 RA: Invalid lladdr length.\n"); "ICMPv6 RA: invalid link-layer address length\n");
goto out; goto out;
} }
} }
...@@ -1061,10 +1087,9 @@ static void ndisc_router_discovery(struct sk_buff *skb) ...@@ -1061,10 +1087,9 @@ static void ndisc_router_discovery(struct sk_buff *skb)
mtu = ntohl(mtu); mtu = ntohl(mtu);
if (mtu < IPV6_MIN_MTU || mtu > skb->dev->mtu) { if (mtu < IPV6_MIN_MTU || mtu > skb->dev->mtu) {
if (net_ratelimit()) { ND_PRINTK2(KERN_WARNING
ND_PRINTK0("NDISC: router announcement with mtu = %d\n", "ICMPv6 RA: invalid mtu: %d\n",
mtu); mtu);
}
} else if (in6_dev->cnf.mtu6 != mtu) { } else if (in6_dev->cnf.mtu6 != mtu) {
in6_dev->cnf.mtu6 = mtu; in6_dev->cnf.mtu6 = mtu;
...@@ -1076,9 +1101,8 @@ static void ndisc_router_discovery(struct sk_buff *skb) ...@@ -1076,9 +1101,8 @@ static void ndisc_router_discovery(struct sk_buff *skb)
} }
if (ndopts.nd_opts_tgt_lladdr || ndopts.nd_opts_rh) { if (ndopts.nd_opts_tgt_lladdr || ndopts.nd_opts_rh) {
if (net_ratelimit()) ND_PRINTK2(KERN_WARNING
ND_PRINTK0(KERN_WARNING "ICMPv6 RA: invalid RA options");
"ICMP6 RA: got invalid option with RA");
} }
out: out:
if (rt) if (rt)
...@@ -1100,8 +1124,8 @@ static void ndisc_redirect_rcv(struct sk_buff *skb) ...@@ -1100,8 +1124,8 @@ static void ndisc_redirect_rcv(struct sk_buff *skb)
int lladdrlen; int lladdrlen;
if (!(ipv6_addr_type(&skb->nh.ipv6h->saddr) & IPV6_ADDR_LINKLOCAL)) { if (!(ipv6_addr_type(&skb->nh.ipv6h->saddr) & IPV6_ADDR_LINKLOCAL)) {
if (net_ratelimit()) ND_PRINTK2(KERN_WARNING
printk(KERN_WARNING "ICMP redirect: source address is not linklocal\n"); "ICMPv6 Redirect: source address is not link-local.\n");
return; return;
} }
...@@ -1109,8 +1133,8 @@ static void ndisc_redirect_rcv(struct sk_buff *skb) ...@@ -1109,8 +1133,8 @@ static void ndisc_redirect_rcv(struct sk_buff *skb)
optlen -= sizeof(struct icmp6hdr) + 2 * sizeof(struct in6_addr); optlen -= sizeof(struct icmp6hdr) + 2 * sizeof(struct in6_addr);
if (optlen < 0) { if (optlen < 0) {
if (net_ratelimit()) ND_PRINTK2(KERN_WARNING
printk(KERN_WARNING "ICMP redirect: packet too small\n"); "ICMPv6 Redirect: packet too short\n");
return; return;
} }
...@@ -1119,16 +1143,16 @@ static void ndisc_redirect_rcv(struct sk_buff *skb) ...@@ -1119,16 +1143,16 @@ static void ndisc_redirect_rcv(struct sk_buff *skb)
dest = target + 1; dest = target + 1;
if (ipv6_addr_is_multicast(dest)) { if (ipv6_addr_is_multicast(dest)) {
if (net_ratelimit()) ND_PRINTK2(KERN_WARNING
printk(KERN_WARNING "ICMP redirect for multicast addr\n"); "ICMPv6 Redirect: destination address is multicast.\n");
return; return;
} }
if (ipv6_addr_cmp(dest, target) == 0) { if (ipv6_addr_cmp(dest, target) == 0) {
on_link = 1; on_link = 1;
} else if (!(ipv6_addr_type(target) & IPV6_ADDR_LINKLOCAL)) { } else if (!(ipv6_addr_type(target) & IPV6_ADDR_LINKLOCAL)) {
if (net_ratelimit()) ND_PRINTK2(KERN_WARNING
printk(KERN_WARNING "ICMP redirect: target address is not linklocal\n"); "ICMPv6 Redirect: target address is not link-local.\n");
return; return;
} }
...@@ -1146,9 +1170,8 @@ static void ndisc_redirect_rcv(struct sk_buff *skb) ...@@ -1146,9 +1170,8 @@ static void ndisc_redirect_rcv(struct sk_buff *skb)
*/ */
if (!ndisc_parse_options((u8*)(dest + 1), optlen, &ndopts)) { if (!ndisc_parse_options((u8*)(dest + 1), optlen, &ndopts)) {
if (net_ratelimit())
ND_PRINTK2(KERN_WARNING ND_PRINTK2(KERN_WARNING
"ICMP6 Redirect: invalid ND options, rejected.\n"); "ICMPv6 Redirect: invalid ND options\n");
in6_dev_put(in6_dev); in6_dev_put(in6_dev);
return; return;
} }
...@@ -1156,9 +1179,8 @@ static void ndisc_redirect_rcv(struct sk_buff *skb) ...@@ -1156,9 +1179,8 @@ static void ndisc_redirect_rcv(struct sk_buff *skb)
lladdr = (u8*)(ndopts.nd_opts_tgt_lladdr + 1); lladdr = (u8*)(ndopts.nd_opts_tgt_lladdr + 1);
lladdrlen = ndopts.nd_opts_tgt_lladdr->nd_opt_len << 3; lladdrlen = ndopts.nd_opts_tgt_lladdr->nd_opt_len << 3;
if (lladdrlen != NDISC_OPT_SPACE(skb->dev->addr_len)) { if (lladdrlen != NDISC_OPT_SPACE(skb->dev->addr_len)) {
if (net_ratelimit())
ND_PRINTK2(KERN_WARNING ND_PRINTK2(KERN_WARNING
"ICMP6 Redirect: invalid lladdr length.\n"); "ICMPv6 Redirect: invalid link-layer address length\n");
in6_dev_put(in6_dev); in6_dev_put(in6_dev);
return; return;
} }
...@@ -1203,7 +1225,9 @@ void ndisc_send_redirect(struct sk_buff *skb, struct neighbour *neigh, ...@@ -1203,7 +1225,9 @@ void ndisc_send_redirect(struct sk_buff *skb, struct neighbour *neigh,
dev = skb->dev; dev = skb->dev;
if (ipv6_get_lladdr(dev, &saddr_buf)) { if (ipv6_get_lladdr(dev, &saddr_buf)) {
ND_PRINTK1("redirect: no link_local addr for dev\n"); ND_PRINTK2(KERN_WARNING
"ICMPv6 Redirect: no link-local address on %s\n",
dev->name);
return; return;
} }
...@@ -1223,7 +1247,8 @@ void ndisc_send_redirect(struct sk_buff *skb, struct neighbour *neigh, ...@@ -1223,7 +1247,8 @@ void ndisc_send_redirect(struct sk_buff *skb, struct neighbour *neigh,
rt = (struct rt6_info *) dst; rt = (struct rt6_info *) dst;
if (rt->rt6i_flags & RTF_GATEWAY) { if (rt->rt6i_flags & RTF_GATEWAY) {
ND_PRINTK1("ndisc_send_redirect: not a neighbour\n"); ND_PRINTK2(KERN_WARNING
"ICMPv6 Redirect: destination is not a neighbour.\n");
dst_release(dst); dst_release(dst);
return; return;
} }
...@@ -1253,7 +1278,9 @@ void ndisc_send_redirect(struct sk_buff *skb, struct neighbour *neigh, ...@@ -1253,7 +1278,9 @@ void ndisc_send_redirect(struct sk_buff *skb, struct neighbour *neigh,
buff = sock_alloc_send_skb(sk, MAX_HEADER + len + LL_RESERVED_SPACE(dev), buff = sock_alloc_send_skb(sk, MAX_HEADER + len + LL_RESERVED_SPACE(dev),
1, &err); 1, &err);
if (buff == NULL) { if (buff == NULL) {
ND_PRINTK1("ndisc_send_redirect: alloc_skb failed\n"); ND_PRINTK0(KERN_ERR
"ICMPv6 Redirect: %s() failed to allocate an skb.\n",
__FUNCTION__);
dst_release(dst); dst_release(dst);
return; return;
} }
...@@ -1333,16 +1360,16 @@ int ndisc_rcv(struct sk_buff *skb) ...@@ -1333,16 +1360,16 @@ int ndisc_rcv(struct sk_buff *skb)
__skb_push(skb, skb->data-skb->h.raw); __skb_push(skb, skb->data-skb->h.raw);
if (skb->nh.ipv6h->hop_limit != 255) { if (skb->nh.ipv6h->hop_limit != 255) {
if (net_ratelimit()) ND_PRINTK2(KERN_WARNING
printk(KERN_WARNING "ICMPv6 NDISC: invalid hop-limit: %d\n",
"ICMP NDISC: fake message with non-255 Hop Limit received: %d\n",
skb->nh.ipv6h->hop_limit); skb->nh.ipv6h->hop_limit);
return 0; return 0;
} }
if (msg->icmph.icmp6_code != 0) { if (msg->icmph.icmp6_code != 0) {
if (net_ratelimit()) ND_PRINTK2(KERN_WARNING
printk(KERN_WARNING "ICMP NDISC: code is not zero\n"); "ICMPv6 NDISC: invalid ICMPv6 code: %d\n",
msg->icmph.icmp6_code);
return 0; return 0;
} }
...@@ -1410,8 +1437,8 @@ int __init ndisc_init(struct net_proto_family *ops) ...@@ -1410,8 +1437,8 @@ int __init ndisc_init(struct net_proto_family *ops)
err = sock_create(PF_INET6, SOCK_RAW, IPPROTO_ICMPV6, &ndisc_socket); err = sock_create(PF_INET6, SOCK_RAW, IPPROTO_ICMPV6, &ndisc_socket);
if (err < 0) { if (err < 0) {
printk(KERN_ERR ND_PRINTK0(KERN_ERR
"Failed to initialize the NDISC control socket (err %d).\n", "ICMPv6 NDISC: Failed to initialize the control socket (err %d).\n",
err); err);
ndisc_socket = NULL; /* For safety. */ ndisc_socket = NULL; /* For safety. */
return err; return err;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment