Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
L
linux
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
nexedi
linux
Commits
aff4f914
Commit
aff4f914
authored
Feb 10, 2004
by
Hideaki Yoshifuji
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
[IPV6]: Clean up ndisc printks.
parent
5850f935
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
104 additions
and
77 deletions
+104
-77
net/ipv6/ndisc.c
net/ipv6/ndisc.c
+104
-77
No files found.
net/ipv6/ndisc.c
View file @
aff4f914
...
@@ -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,8 +215,10 @@ static struct ndisc_options *ndisc_parse_options(u8 *opt, int opt_len,
...
@@ -210,8 +215,10 @@ 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
nd_opt
->
nd_opt_type
);
"%s(): duplicated ND6 option found: type=%d
\n
"
,
__FUNCTION__
,
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
"ICMP
6 NS: bad DAD packet (wrong destination)
\n
"
);
"ICMPv
6 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
"ICMP
6 NS: bad DAD packet (link-layer address option)
\n
"
);
"ICMPv
6 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 options
\n
"
);
"ICMP6 RA: invalid ND option, ignored.
\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
"ICMPv6 RA: invalid link-layer address length
\n
"
);
"ICMP6 RA: Invalid lladdr 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
"ICMPv6 Redirect: invalid ND options
\n
"
);
"ICMP6 Redirect: invalid ND options, rejected.
\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
"ICMPv6 Redirect: invalid link-layer address length
\n
"
);
"ICMP6 Redirect: invalid lladdr 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,9 +1437,9 @@ int __init ndisc_init(struct net_proto_family *ops)
...
@@ -1410,9 +1437,9 @@ 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
;
}
}
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment