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
ebec1711
Commit
ebec1711
authored
Feb 11, 2004
by
David S. Miller
Browse files
Options
Browse Files
Download
Plain Diff
Merge nuts.davemloft.net:/disk1/BK/network-2.6
into nuts.davemloft.net:/disk1/BK/net-2.6
parents
d0d0b2da
67fa3c7e
Changes
24
Hide whitespace changes
Inline
Side-by-side
Showing
24 changed files
with
204 additions
and
197 deletions
+204
-197
drivers/net/Kconfig
drivers/net/Kconfig
+2
-1
drivers/net/hamradio/Kconfig
drivers/net/hamradio/Kconfig
+8
-5
drivers/net/irda/Kconfig
drivers/net/irda/Kconfig
+1
-1
include/linux/ipv6_route.h
include/linux/ipv6_route.h
+0
-1
include/net/addrconf.h
include/net/addrconf.h
+1
-0
include/net/ip6_route.h
include/net/ip6_route.h
+1
-0
include/net/ipv6.h
include/net/ipv6.h
+1
-0
net/core/ethtool.c
net/core/ethtool.c
+1
-1
net/core/neighbour.c
net/core/neighbour.c
+1
-2
net/core/pktgen.c
net/core/pktgen.c
+12
-6
net/decnet/dn_rules.c
net/decnet/dn_rules.c
+1
-1
net/ipv4/fib_rules.c
net/ipv4/fib_rules.c
+1
-1
net/ipv6/addrconf.c
net/ipv6/addrconf.c
+2
-2
net/ipv6/exthdrs.c
net/ipv6/exthdrs.c
+1
-1
net/ipv6/ip6_fib.c
net/ipv6/ip6_fib.c
+1
-1
net/ipv6/ip6_input.c
net/ipv6/ip6_input.c
+19
-14
net/ipv6/ip6_tunnel.c
net/ipv6/ip6_tunnel.c
+1
-1
net/ipv6/mcast.c
net/ipv6/mcast.c
+28
-1
net/ipv6/ndisc.c
net/ipv6/ndisc.c
+110
-138
net/ipv6/netfilter/ip6t_eui64.c
net/ipv6/netfilter/ip6t_eui64.c
+1
-1
net/ipv6/raw.c
net/ipv6/raw.c
+3
-3
net/ipv6/route.c
net/ipv6/route.c
+6
-5
net/ipv6/xfrm6_policy.c
net/ipv6/xfrm6_policy.c
+1
-11
net/sched/sch_sfq.c
net/sched/sch_sfq.c
+1
-0
No files found.
drivers/net/Kconfig
View file @
ebec1711
...
@@ -1715,7 +1715,8 @@ config NET_POCKET
...
@@ -1715,7 +1715,8 @@ config NET_POCKET
<file:Documentation/Changes>) and you can say N here.
<file:Documentation/Changes>) and you can say N here.
Laptop users should read the Linux Laptop home page at
Laptop users should read the Linux Laptop home page at
<http://www.linux-on-laptops.com/>.
<http://www.linux-on-laptops.com/> or
Tuxmobil - Linux on Mobile Computers at <http://www.tuxmobil.org/>.
Note that the answer to this question doesn't directly affect the
Note that the answer to this question doesn't directly affect the
kernel: saying N will just cause the configurator to skip all
kernel: saying N will just cause the configurator to skip all
...
...
drivers/net/hamradio/Kconfig
View file @
ebec1711
...
@@ -72,8 +72,8 @@ config DMASCC
...
@@ -72,8 +72,8 @@ config DMASCC
certain parameters, such as channel access timing, clock mode, and
certain parameters, such as channel access timing, clock mode, and
DMA channel. This is accomplished with a small utility program,
DMA channel. This is accomplished with a small utility program,
dmascc_cfg, available at
dmascc_cfg, available at
<http://
www.nt.tuwien.ac.at/~kkudielk/Linux/>. Please be sure to get
<http://
cacofonix.nt.tuwien.ac.at/~oe1kib/Linux/>. Please be sure to
at least version 1.27 of dmascc_cfg, as older versions will not
get
at least version 1.27 of dmascc_cfg, as older versions will not
work with the current driver.
work with the current driver.
config SCC
config SCC
...
@@ -96,8 +96,9 @@ config SCC_DELAY
...
@@ -96,8 +96,9 @@ config SCC_DELAY
help
help
Say Y here if you experience problems with the SCC driver not
Say Y here if you experience problems with the SCC driver not
working properly; please read
working properly; please read
<file:Documentation/networking/z8530drv.txt> for details. If unsure,
<file:Documentation/networking/z8530drv.txt> for details.
say N.
If unsure, say N.
config SCC_TRXECHO
config SCC_TRXECHO
bool "support for TRX that feedback the tx signal to rx"
bool "support for TRX that feedback the tx signal to rx"
...
@@ -105,7 +106,9 @@ config SCC_TRXECHO
...
@@ -105,7 +106,9 @@ config SCC_TRXECHO
help
help
Some transmitters feed the transmitted signal back to the receive
Some transmitters feed the transmitted signal back to the receive
line. Say Y here to foil this by explicitly disabling the receiver
line. Say Y here to foil this by explicitly disabling the receiver
during data transmission. If in doubt, say Y.
during data transmission.
If in doubt, say Y.
config BAYCOM_SER_FDX
config BAYCOM_SER_FDX
tristate "BAYCOM ser12 fullduplex driver for AX.25"
tristate "BAYCOM ser12 fullduplex driver for AX.25"
...
...
drivers/net/irda/Kconfig
View file @
ebec1711
...
@@ -269,7 +269,7 @@ config MA600_DONGLE_OLD
...
@@ -269,7 +269,7 @@ config MA600_DONGLE_OLD
information, download the following tar gzip file.
information, download the following tar gzip file.
There is a pre-compiled module on
There is a pre-compiled module on
<http://engsvr.ust.hk/~eetwl95/
download/ma600-2.4.x.tar.gz
>
<http://engsvr.ust.hk/~eetwl95/
ma600.html
>
config EP7211_IR
config EP7211_IR
tristate "EP7211 I/R support"
tristate "EP7211 I/R support"
...
...
include/linux/ipv6_route.h
View file @
ebec1711
...
@@ -24,7 +24,6 @@
...
@@ -24,7 +24,6 @@
#define RTF_CACHE 0x01000000
/* cache entry */
#define RTF_CACHE 0x01000000
/* cache entry */
#define RTF_FLOW 0x02000000
/* flow significant route */
#define RTF_FLOW 0x02000000
/* flow significant route */
#define RTF_POLICY 0x04000000
/* policy route */
#define RTF_POLICY 0x04000000
/* policy route */
#define RTF_NDISC 0x08000000
/* ndisc route */
#define RTF_LOCAL 0x80000000
#define RTF_LOCAL 0x80000000
...
...
include/net/addrconf.h
View file @
ebec1711
...
@@ -98,6 +98,7 @@ extern void addrconf_dad_failure(struct inet6_ifaddr *ifp);
...
@@ -98,6 +98,7 @@ extern void addrconf_dad_failure(struct inet6_ifaddr *ifp);
extern
int
ipv6_chk_mcast_addr
(
struct
net_device
*
dev
,
struct
in6_addr
*
group
,
extern
int
ipv6_chk_mcast_addr
(
struct
net_device
*
dev
,
struct
in6_addr
*
group
,
struct
in6_addr
*
src_addr
);
struct
in6_addr
*
src_addr
);
extern
int
ipv6_is_mld
(
struct
sk_buff
*
skb
,
int
nexthdr
);
extern
void
addrconf_prefix_rcv
(
struct
net_device
*
dev
,
u8
*
opt
,
int
len
);
extern
void
addrconf_prefix_rcv
(
struct
net_device
*
dev
,
u8
*
opt
,
int
len
);
...
...
include/net/ip6_route.h
View file @
ebec1711
...
@@ -64,6 +64,7 @@ extern struct rt6_info *rt6_lookup(struct in6_addr *daddr,
...
@@ -64,6 +64,7 @@ extern struct rt6_info *rt6_lookup(struct in6_addr *daddr,
extern
struct
dst_entry
*
ndisc_dst_alloc
(
struct
net_device
*
dev
,
extern
struct
dst_entry
*
ndisc_dst_alloc
(
struct
net_device
*
dev
,
struct
neighbour
*
neigh
,
struct
neighbour
*
neigh
,
struct
in6_addr
*
addr
,
int
(
*
output
)(
struct
sk_buff
*
));
int
(
*
output
)(
struct
sk_buff
*
));
extern
int
ndisc_dst_gc
(
int
*
more
);
extern
int
ndisc_dst_gc
(
int
*
more
);
extern
void
fib6_force_start_gc
(
void
);
extern
void
fib6_force_start_gc
(
void
);
...
...
include/net/ipv6.h
View file @
ebec1711
...
@@ -355,6 +355,7 @@ extern int ip6_dst_lookup(struct sock *sk,
...
@@ -355,6 +355,7 @@ extern int ip6_dst_lookup(struct sock *sk,
*/
*/
extern
int
ip6_output
(
struct
sk_buff
*
skb
);
extern
int
ip6_output
(
struct
sk_buff
*
skb
);
extern
int
ip6_output2
(
struct
sk_buff
*
skb
);
extern
int
ip6_forward
(
struct
sk_buff
*
skb
);
extern
int
ip6_forward
(
struct
sk_buff
*
skb
);
extern
int
ip6_input
(
struct
sk_buff
*
skb
);
extern
int
ip6_input
(
struct
sk_buff
*
skb
);
extern
int
ip6_mc_input
(
struct
sk_buff
*
skb
);
extern
int
ip6_mc_input
(
struct
sk_buff
*
skb
);
...
...
net/core/ethtool.c
View file @
ebec1711
...
@@ -374,7 +374,7 @@ static int ethtool_set_ringparam(struct net_device *dev, void *useraddr)
...
@@ -374,7 +374,7 @@ static int ethtool_set_ringparam(struct net_device *dev, void *useraddr)
{
{
struct
ethtool_ringparam
ringparam
;
struct
ethtool_ringparam
ringparam
;
if
(
!
dev
->
ethtool_ops
->
g
et_ringparam
)
if
(
!
dev
->
ethtool_ops
->
s
et_ringparam
)
return
-
EOPNOTSUPP
;
return
-
EOPNOTSUPP
;
if
(
copy_from_user
(
&
ringparam
,
useraddr
,
sizeof
(
ringparam
)))
if
(
copy_from_user
(
&
ringparam
,
useraddr
,
sizeof
(
ringparam
)))
...
...
net/core/neighbour.c
View file @
ebec1711
...
@@ -1164,8 +1164,7 @@ void neigh_table_init(struct neigh_table *tbl)
...
@@ -1164,8 +1164,7 @@ void neigh_table_init(struct neigh_table *tbl)
if
(
!
tbl
->
kmem_cachep
)
if
(
!
tbl
->
kmem_cachep
)
tbl
->
kmem_cachep
=
kmem_cache_create
(
tbl
->
id
,
tbl
->
kmem_cachep
=
kmem_cache_create
(
tbl
->
id
,
(
tbl
->
entry_size
+
tbl
->
entry_size
,
15
)
&
~
15
,
0
,
SLAB_HWCACHE_ALIGN
,
0
,
SLAB_HWCACHE_ALIGN
,
NULL
,
NULL
);
NULL
,
NULL
);
tbl
->
lock
=
RW_LOCK_UNLOCKED
;
tbl
->
lock
=
RW_LOCK_UNLOCKED
;
...
...
net/core/pktgen.c
View file @
ebec1711
...
@@ -50,6 +50,8 @@
...
@@ -50,6 +50,8 @@
* Fix refcount off by one if first packet fails, potential null deref,
* Fix refcount off by one if first packet fails, potential null deref,
* memleak 030710- KJP
* memleak 030710- KJP
*
*
* Fixed unaligned access on IA-64 Grant Grundler <grundler@parisc-linux.org>
*
* See Documentation/networking/pktgen.txt for how to use this.
* See Documentation/networking/pktgen.txt for how to use this.
*/
*/
...
@@ -88,7 +90,7 @@
...
@@ -88,7 +90,7 @@
#define cycles() ((u32)get_cycles())
#define cycles() ((u32)get_cycles())
#define VERSION "pktgen version 1.3
1
"
#define VERSION "pktgen version 1.3
2
"
static
char
version
[]
__initdata
=
static
char
version
[]
__initdata
=
"pktgen.c: v1.3: Packet Generator for packet performance testing.
\n
"
;
"pktgen.c: v1.3: Packet Generator for packet performance testing.
\n
"
;
...
@@ -193,7 +195,8 @@ struct pktgen_info {
...
@@ -193,7 +195,8 @@ struct pktgen_info {
struct
pktgen_hdr
{
struct
pktgen_hdr
{
__u32
pgh_magic
;
__u32
pgh_magic
;
__u32
seq_num
;
__u32
seq_num
;
struct
timeval
timestamp
;
__u32
tv_sec
;
__u32
tv_usec
;
};
};
static
int
cpu_speed
;
static
int
cpu_speed
;
...
@@ -563,11 +566,14 @@ static struct sk_buff *fill_packet(struct net_device *odev, struct pktgen_info*
...
@@ -563,11 +566,14 @@ static struct sk_buff *fill_packet(struct net_device *odev, struct pktgen_info*
/* Stamp the time, and sequence number, convert them to network byte order */
/* Stamp the time, and sequence number, convert them to network byte order */
if
(
pgh
)
{
if
(
pgh
)
{
struct
timeval
timestamp
;
pgh
->
pgh_magic
=
htonl
(
PKTGEN_MAGIC
);
pgh
->
pgh_magic
=
htonl
(
PKTGEN_MAGIC
);
do_gettimeofday
(
&
(
pgh
->
timestamp
));
pgh
->
seq_num
=
htonl
(
info
->
seq_num
);
pgh
->
timestamp
.
tv_usec
=
htonl
(
pgh
->
timestamp
.
tv_usec
);
pgh
->
timestamp
.
tv_sec
=
htonl
(
pgh
->
timestamp
.
tv_sec
);
do_gettimeofday
(
&
timestamp
);
pgh
->
seq_num
=
htonl
(
info
->
seq_num
);
pgh
->
tv_sec
=
htonl
(
timestamp
.
tv_sec
);
pgh
->
tv_usec
=
htonl
(
timestamp
.
tv_usec
);
}
}
return
skb
;
return
skb
;
...
...
net/decnet/dn_rules.c
View file @
ebec1711
...
@@ -381,7 +381,7 @@ static int dn_fib_fill_rule(struct sk_buff *skb, struct dn_fib_rule *r, struct n
...
@@ -381,7 +381,7 @@ static int dn_fib_fill_rule(struct sk_buff *skb, struct dn_fib_rule *r, struct n
nlmsg_failure:
nlmsg_failure:
rtattr_failure:
rtattr_failure:
skb_
put
(
skb
,
b
-
skb
->
tail
);
skb_
trim
(
skb
,
b
-
skb
->
data
);
return
-
1
;
return
-
1
;
}
}
...
...
net/ipv4/fib_rules.c
View file @
ebec1711
...
@@ -438,7 +438,7 @@ static __inline__ int inet_fill_rule(struct sk_buff *skb,
...
@@ -438,7 +438,7 @@ static __inline__ int inet_fill_rule(struct sk_buff *skb,
nlmsg_failure:
nlmsg_failure:
rtattr_failure:
rtattr_failure:
skb_
put
(
skb
,
b
-
skb
->
tail
);
skb_
trim
(
skb
,
b
-
skb
->
data
);
return
-
1
;
return
-
1
;
}
}
...
...
net/ipv6/addrconf.c
View file @
ebec1711
...
@@ -231,7 +231,7 @@ int ipv6_addr_type(const struct in6_addr *addr)
...
@@ -231,7 +231,7 @@ int ipv6_addr_type(const struct in6_addr *addr)
if
((
addr
->
s6_addr32
[
0
]
|
addr
->
s6_addr32
[
1
])
==
0
)
{
if
((
addr
->
s6_addr32
[
0
]
|
addr
->
s6_addr32
[
1
])
==
0
)
{
if
(
addr
->
s6_addr32
[
2
]
==
0
)
{
if
(
addr
->
s6_addr32
[
2
]
==
0
)
{
if
(
addr
->
in6_u
.
u
6_addr32
[
3
]
==
0
)
if
(
addr
->
s
6_addr32
[
3
]
==
0
)
return
IPV6_ADDR_ANY
;
return
IPV6_ADDR_ANY
;
if
(
addr
->
s6_addr32
[
3
]
==
htonl
(
0x00000001
))
if
(
addr
->
s6_addr32
[
3
]
==
htonl
(
0x00000001
))
...
@@ -1071,7 +1071,7 @@ static int ipv6_generate_eui64(u8 *eui, struct net_device *dev)
...
@@ -1071,7 +1071,7 @@ static int ipv6_generate_eui64(u8 *eui, struct net_device *dev)
eui
[
0
]
^=
2
;
eui
[
0
]
^=
2
;
return
0
;
return
0
;
case
ARPHRD_ARCNET
:
case
ARPHRD_ARCNET
:
/* XXX: inherit EUI-64 fro
m
other interface -- yoshfuji */
/* XXX: inherit EUI-64 fro
m
other interface -- yoshfuji */
if
(
dev
->
addr_len
!=
ARCNET_ALEN
)
if
(
dev
->
addr_len
!=
ARCNET_ALEN
)
return
-
1
;
return
-
1
;
memset
(
eui
,
0
,
7
);
memset
(
eui
,
0
,
7
);
...
...
net/ipv6/exthdrs.c
View file @
ebec1711
...
@@ -120,7 +120,7 @@ static int ip6_parse_tlv(struct tlvtype_proc *procs, struct sk_buff *skb)
...
@@ -120,7 +120,7 @@ static int ip6_parse_tlv(struct tlvtype_proc *procs, struct sk_buff *skb)
for
(
curr
=
procs
;
curr
->
type
>=
0
;
curr
++
)
{
for
(
curr
=
procs
;
curr
->
type
>=
0
;
curr
++
)
{
if
(
curr
->
type
==
skb
->
nh
.
raw
[
off
])
{
if
(
curr
->
type
==
skb
->
nh
.
raw
[
off
])
{
/* type specific length/alignment
/* type specific length/alignment
checks will be perfomed in the
checks will be perfo
r
med in the
func(). */
func(). */
if
(
curr
->
func
(
skb
,
off
)
==
0
)
if
(
curr
->
func
(
skb
,
off
)
==
0
)
return
0
;
return
0
;
...
...
net/ipv6/ip6_fib.c
View file @
ebec1711
...
@@ -85,7 +85,7 @@ static struct fib6_node * fib6_repair_tree(struct fib6_node *fn);
...
@@ -85,7 +85,7 @@ static struct fib6_node * fib6_repair_tree(struct fib6_node *fn);
/*
/*
* A routing update causes an increase of the serial number on the
* A routing update causes an increase of the serial number on the
* afected subtree. This allows for cached routes to be asynchronously
* af
f
ected subtree. This allows for cached routes to be asynchronously
* tested when modifications are made to the destination cache as a
* tested when modifications are made to the destination cache as a
* result of redirects, path MTU changes, etc.
* result of redirects, path MTU changes, etc.
*/
*/
...
...
net/ipv6/ip6_input.c
View file @
ebec1711
...
@@ -168,11 +168,19 @@ static inline int ip6_input_finish(struct sk_buff *skb)
...
@@ -168,11 +168,19 @@ static inline int ip6_input_finish(struct sk_buff *skb)
smp_read_barrier_depends
();
smp_read_barrier_depends
();
if
(
ipprot
->
flags
&
INET6_PROTO_FINAL
)
{
if
(
ipprot
->
flags
&
INET6_PROTO_FINAL
)
{
struct
ipv6hdr
*
hdr
;
if
(
!
cksum_sub
&&
skb
->
ip_summed
==
CHECKSUM_HW
)
{
if
(
!
cksum_sub
&&
skb
->
ip_summed
==
CHECKSUM_HW
)
{
skb
->
csum
=
csum_sub
(
skb
->
csum
,
skb
->
csum
=
csum_sub
(
skb
->
csum
,
csum_partial
(
skb
->
nh
.
raw
,
skb
->
h
.
raw
-
skb
->
nh
.
raw
,
0
));
csum_partial
(
skb
->
nh
.
raw
,
skb
->
h
.
raw
-
skb
->
nh
.
raw
,
0
));
cksum_sub
++
;
cksum_sub
++
;
}
}
hdr
=
skb
->
nh
.
ipv6h
;
if
(
ipv6_addr_is_multicast
(
&
hdr
->
daddr
)
&&
!
ipv6_chk_mcast_addr
(
skb
->
dev
,
&
hdr
->
daddr
,
&
hdr
->
saddr
)
&&
!
ipv6_is_mld
(
skb
,
nexthdr
))
goto
discard
;
}
}
if
(
!
(
ipprot
->
flags
&
INET6_PROTO_NOPOLICY
)
&&
if
(
!
(
ipprot
->
flags
&
INET6_PROTO_NOPOLICY
)
&&
!
xfrm6_policy_check
(
NULL
,
XFRM_POLICY_IN
,
skb
))
!
xfrm6_policy_check
(
NULL
,
XFRM_POLICY_IN
,
skb
))
...
@@ -211,15 +219,14 @@ int ip6_input(struct sk_buff *skb)
...
@@ -211,15 +219,14 @@ int ip6_input(struct sk_buff *skb)
int
ip6_mc_input
(
struct
sk_buff
*
skb
)
int
ip6_mc_input
(
struct
sk_buff
*
skb
)
{
{
struct
ipv6hdr
*
hdr
;
struct
ipv6hdr
*
hdr
;
int
deliver
=
0
;
int
deliver
;
int
discard
=
1
;
IP6_INC_STATS_BH
(
Ip6InMcastPkts
);
IP6_INC_STATS_BH
(
Ip6InMcastPkts
);
hdr
=
skb
->
nh
.
ipv6h
;
hdr
=
skb
->
nh
.
ipv6h
;
if
(
ipv6_chk_mcast_addr
(
skb
->
dev
,
&
hdr
->
daddr
,
&
hdr
->
saddr
))
deliver
=
likely
(
!
(
skb
->
dev
->
flags
&
(
IFF_PROMISC
|
IFF_ALLMULTI
)))
||
deliver
=
1
;
ipv6_chk_mcast_addr
(
skb
->
dev
,
&
hdr
->
daddr
,
NULL
)
;
/*
/*
* IPv6 multicast router mode isnt currently supported.
* IPv6 multicast router mode isnt currently supported.
...
@@ -238,23 +245,21 @@ int ip6_mc_input(struct sk_buff *skb)
...
@@ -238,23 +245,21 @@ int ip6_mc_input(struct sk_buff *skb)
if (deliver) {
if (deliver) {
skb2 = skb_clone(skb, GFP_ATOMIC);
skb2 = skb_clone(skb, GFP_ATOMIC);
dst_output(skb2);
} else {
} else {
d
iscard = 0
;
d
st_output(skb)
;
skb2 = skb
;
return 0
;
}
}
dst_output(skb2);
}
}
}
}
#endif
#endif
if
(
deliver
)
{
if
(
likely
(
deliver
))
{
discard
=
0
;
ip6_input
(
skb
);
ip6_input
(
skb
);
return
0
;
}
}
/* discard */
if
(
discard
)
kfree_skb
(
skb
);
kfree_skb
(
skb
);
return
0
;
return
0
;
}
}
net/ipv6/ip6_tunnel.c
View file @
ebec1711
...
@@ -399,7 +399,7 @@ void ip6ip6_err(struct sk_buff *skb, struct inet6_skb_parm *opt,
...
@@ -399,7 +399,7 @@ void ip6ip6_err(struct sk_buff *skb, struct inet6_skb_parm *opt,
__u16
len
;
__u16
len
;
/* If the packet doesn't contain the original IPv6 header we are
/* If the packet doesn't contain the original IPv6 header we are
in trouble since we might need the source address for furter
in trouble since we might need the source address for furt
h
er
processing of the error. */
processing of the error. */
read_lock
(
&
ip6ip6_lock
);
read_lock
(
&
ip6ip6_lock
);
...
...
net/ipv6/mcast.c
View file @
ebec1711
...
@@ -900,6 +900,33 @@ int ipv6_dev_mc_dec(struct net_device *dev, struct in6_addr *addr)
...
@@ -900,6 +900,33 @@ int ipv6_dev_mc_dec(struct net_device *dev, struct in6_addr *addr)
return
err
;
return
err
;
}
}
/*
* identify MLD packets for MLD filter exceptions
*/
int
ipv6_is_mld
(
struct
sk_buff
*
skb
,
int
nexthdr
)
{
struct
icmp6hdr
*
pic
;
if
(
nexthdr
!=
IPPROTO_ICMPV6
)
return
0
;
if
(
!
pskb_may_pull
(
skb
,
sizeof
(
struct
icmp6hdr
)))
return
0
;
pic
=
(
struct
icmp6hdr
*
)
skb
->
h
.
raw
;
switch
(
pic
->
icmp6_type
)
{
case
ICMPV6_MGM_QUERY
:
case
ICMPV6_MGM_REPORT
:
case
ICMPV6_MGM_REDUCTION
:
case
ICMPV6_MLD2_REPORT
:
return
1
;
default:
break
;
}
return
0
;
}
/*
/*
* check if the interface/address pair is valid
* check if the interface/address pair is valid
*/
*/
...
@@ -918,7 +945,7 @@ int ipv6_chk_mcast_addr(struct net_device *dev, struct in6_addr *group,
...
@@ -918,7 +945,7 @@ int ipv6_chk_mcast_addr(struct net_device *dev, struct in6_addr *group,
break
;
break
;
}
}
if
(
mc
)
{
if
(
mc
)
{
if
(
!
ipv6_addr_any
(
src_addr
))
{
if
(
src_addr
&&
!
ipv6_addr_any
(
src_addr
))
{
struct
ip6_sf_list
*
psf
;
struct
ip6_sf_list
*
psf
;
spin_lock_bh
(
&
mc
->
mca_lock
);
spin_lock_bh
(
&
mc
->
mca_lock
);
...
...
net/ipv6/ndisc.c
View file @
ebec1711
...
@@ -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
;
...
@@ -341,65 +349,10 @@ static void pndisc_destructor(struct pneigh_entry *n)
...
@@ -341,65 +349,10 @@ static void pndisc_destructor(struct pneigh_entry *n)
ipv6_dev_mc_dec
(
dev
,
&
maddr
);
ipv6_dev_mc_dec
(
dev
,
&
maddr
);
}
}
static
int
ndisc_build_ll_hdr
(
struct
sk_buff
*
skb
,
struct
net_device
*
dev
,
struct
in6_addr
*
daddr
,
struct
neighbour
*
neigh
,
int
len
)
{
unsigned
char
ha
[
MAX_ADDR_LEN
];
unsigned
char
*
h_dest
=
NULL
;
if
(
dev
->
hard_header
)
{
if
(
ipv6_addr_is_multicast
(
daddr
))
{
ndisc_mc_map
(
daddr
,
ha
,
dev
,
1
);
h_dest
=
ha
;
}
else
if
(
neigh
)
{
read_lock_bh
(
&
neigh
->
lock
);
if
(
neigh
->
nud_state
&
NUD_VALID
)
{
memcpy
(
ha
,
neigh
->
ha
,
dev
->
addr_len
);
h_dest
=
ha
;
}
read_unlock_bh
(
&
neigh
->
lock
);
}
else
{
neigh
=
neigh_lookup
(
&
nd_tbl
,
daddr
,
dev
);
if
(
neigh
)
{
read_lock_bh
(
&
neigh
->
lock
);
if
(
neigh
->
nud_state
&
NUD_VALID
)
{
memcpy
(
ha
,
neigh
->
ha
,
dev
->
addr_len
);
h_dest
=
ha
;
}
read_unlock_bh
(
&
neigh
->
lock
);
neigh_release
(
neigh
);
}
}
if
(
dev
->
hard_header
(
skb
,
dev
,
ETH_P_IPV6
,
h_dest
,
NULL
,
len
)
<
0
)
return
0
;
}
return
1
;
}
/*
/*
* Send a Neighbour Advertisement
* Send a Neighbour Advertisement
*/
*/
static
int
ndisc_output
(
struct
sk_buff
*
skb
)
{
if
(
skb
)
{
struct
neighbour
*
neigh
=
(
skb
->
dst
?
skb
->
dst
->
neighbour
:
NULL
);
if
(
ndisc_build_ll_hdr
(
skb
,
skb
->
dev
,
&
skb
->
nh
.
ipv6h
->
daddr
,
neigh
,
skb
->
len
)
==
0
)
{
kfree_skb
(
skb
);
return
-
EINVAL
;
}
dev_queue_xmit
(
skb
);
return
0
;
}
return
-
EINVAL
;
}
static
inline
void
ndisc_flow_init
(
struct
flowi
*
fl
,
u8
type
,
static
inline
void
ndisc_flow_init
(
struct
flowi
*
fl
,
u8
type
,
struct
in6_addr
*
saddr
,
struct
in6_addr
*
daddr
)
struct
in6_addr
*
saddr
,
struct
in6_addr
*
daddr
)
{
{
...
@@ -442,7 +395,7 @@ static void ndisc_send_na(struct net_device *dev, struct neighbour *neigh,
...
@@ -442,7 +395,7 @@ static void ndisc_send_na(struct net_device *dev, struct neighbour *neigh,
ndisc_flow_init
(
&
fl
,
NDISC_NEIGHBOUR_ADVERTISEMENT
,
src_addr
,
daddr
);
ndisc_flow_init
(
&
fl
,
NDISC_NEIGHBOUR_ADVERTISEMENT
,
src_addr
,
daddr
);
dst
=
ndisc_dst_alloc
(
dev
,
neigh
,
ndisc_output
);
dst
=
ndisc_dst_alloc
(
dev
,
neigh
,
daddr
,
ip6_output2
);
if
(
!
dst
)
if
(
!
dst
)
return
;
return
;
...
@@ -463,7 +416,9 @@ static void ndisc_send_na(struct net_device *dev, struct neighbour *neigh,
...
@@ -463,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
;
}
}
...
@@ -530,7 +485,7 @@ void ndisc_send_ns(struct net_device *dev, struct neighbour *neigh,
...
@@ -530,7 +485,7 @@ void ndisc_send_ns(struct net_device *dev, struct neighbour *neigh,
ndisc_flow_init
(
&
fl
,
NDISC_NEIGHBOUR_SOLICITATION
,
saddr
,
daddr
);
ndisc_flow_init
(
&
fl
,
NDISC_NEIGHBOUR_SOLICITATION
,
saddr
,
daddr
);
dst
=
ndisc_dst_alloc
(
dev
,
neigh
,
ndisc_output
);
dst
=
ndisc_dst_alloc
(
dev
,
neigh
,
daddr
,
ip6_output2
);
if
(
!
dst
)
if
(
!
dst
)
return
;
return
;
...
@@ -548,7 +503,9 @@ void ndisc_send_ns(struct net_device *dev, struct neighbour *neigh,
...
@@ -548,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
;
}
}
...
@@ -603,7 +560,7 @@ void ndisc_send_rs(struct net_device *dev, struct in6_addr *saddr,
...
@@ -603,7 +560,7 @@ void ndisc_send_rs(struct net_device *dev, struct in6_addr *saddr,
ndisc_flow_init
(
&
fl
,
NDISC_ROUTER_SOLICITATION
,
saddr
,
daddr
);
ndisc_flow_init
(
&
fl
,
NDISC_ROUTER_SOLICITATION
,
saddr
,
daddr
);
dst
=
ndisc_dst_alloc
(
dev
,
NULL
,
ndisc_output
);
dst
=
ndisc_dst_alloc
(
dev
,
NULL
,
daddr
,
ip6_output2
);
if
(
!
dst
)
if
(
!
dst
)
return
;
return
;
...
@@ -620,7 +577,9 @@ void ndisc_send_rs(struct net_device *dev, struct in6_addr *saddr,
...
@@ -620,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
;
}
}
...
@@ -683,8 +642,13 @@ static void ndisc_solicit(struct neighbour *neigh, struct sk_buff *skb)
...
@@ -683,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
...
@@ -713,8 +677,8 @@ static void ndisc_recv_ns(struct sk_buff *skb)
...
@@ -713,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
;
}
}
...
@@ -727,14 +691,14 @@ static void ndisc_recv_ns(struct sk_buff *skb)
...
@@ -727,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
;
}
}
...
@@ -742,19 +706,19 @@ static void ndisc_recv_ns(struct sk_buff *skb)
...
@@ -742,19 +706,19 @@ 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
;
}
}
/*
XXX:
RFC2461 7.1.1:
/* RFC2461 7.1.1:
* If the IP source address is the unspecified address,
* If the IP source address is the unspecified address,
* there MUST NOT be source link-layer address option
* there MUST NOT be source link-layer address option
* 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
;
}
}
}
}
...
@@ -868,34 +832,35 @@ static void ndisc_recv_na(struct sk_buff *skb)
...
@@ -868,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
;
}
}
}
}
...
@@ -909,7 +874,8 @@ static void ndisc_recv_na(struct sk_buff *skb)
...
@@ -909,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
;
...
@@ -954,13 +920,13 @@ static void ndisc_router_discovery(struct sk_buff *skb)
...
@@ -954,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
;
}
}
...
@@ -970,7 +936,9 @@ static void ndisc_router_discovery(struct sk_buff *skb)
...
@@ -970,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
)
{
...
@@ -980,9 +948,8 @@ static void ndisc_router_discovery(struct sk_buff *skb)
...
@@ -980,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
;
}
}
...
@@ -1015,18 +982,23 @@ static void ndisc_router_discovery(struct sk_buff *skb)
...
@@ -1015,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
;
...
@@ -1052,7 +1024,7 @@ static void ndisc_router_discovery(struct sk_buff *skb)
...
@@ -1052,7 +1024,7 @@ static void ndisc_router_discovery(struct sk_buff *skb)
*/
*/
if
(
in6_dev
->
nd_parms
)
{
if
(
in6_dev
->
nd_parms
)
{
__u32
rtime
=
ntohl
(
ra_msg
->
retrans_timer
);
unsigned
long
rtime
=
ntohl
(
ra_msg
->
retrans_timer
);
if
(
rtime
&&
rtime
/
1000
<
MAX_SCHEDULE_TIMEOUT
/
HZ
)
{
if
(
rtime
&&
rtime
/
1000
<
MAX_SCHEDULE_TIMEOUT
/
HZ
)
{
rtime
=
(
rtime
*
HZ
)
/
1000
;
rtime
=
(
rtime
*
HZ
)
/
1000
;
...
@@ -1091,9 +1063,8 @@ static void ndisc_router_discovery(struct sk_buff *skb)
...
@@ -1091,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
;
}
}
}
}
...
@@ -1116,10 +1087,9 @@ static void ndisc_router_discovery(struct sk_buff *skb)
...
@@ -1116,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
;
...
@@ -1131,9 +1101,8 @@ static void ndisc_router_discovery(struct sk_buff *skb)
...
@@ -1131,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
)
...
@@ -1155,8 +1124,8 @@ static void ndisc_redirect_rcv(struct sk_buff *skb)
...
@@ -1155,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
;
}
}
...
@@ -1164,8 +1133,8 @@ static void ndisc_redirect_rcv(struct sk_buff *skb)
...
@@ -1164,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
;
}
}
...
@@ -1174,16 +1143,16 @@ static void ndisc_redirect_rcv(struct sk_buff *skb)
...
@@ -1174,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
;
}
}
...
@@ -1195,15 +1164,14 @@ static void ndisc_redirect_rcv(struct sk_buff *skb)
...
@@ -1195,15 +1164,14 @@ static void ndisc_redirect_rcv(struct sk_buff *skb)
return
;
return
;
}
}
/*
XXX:
RFC2461 8.1:
/* RFC2461 8.1:
* The IP source address of the Redirect MUST be the same as the current
* The IP source address of the Redirect MUST be the same as the current
* first-hop router for the specified ICMP Destination Address.
* first-hop router for the specified ICMP Destination Address.
*/
*/
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
;
}
}
...
@@ -1211,9 +1179,8 @@ static void ndisc_redirect_rcv(struct sk_buff *skb)
...
@@ -1211,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
;
}
}
...
@@ -1258,7 +1225,9 @@ void ndisc_send_redirect(struct sk_buff *skb, struct neighbour *neigh,
...
@@ -1258,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
;
}
}
...
@@ -1278,7 +1247,8 @@ void ndisc_send_redirect(struct sk_buff *skb, struct neighbour *neigh,
...
@@ -1278,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
;
}
}
...
@@ -1308,7 +1278,9 @@ void ndisc_send_redirect(struct sk_buff *skb, struct neighbour *neigh,
...
@@ -1308,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
;
}
}
...
@@ -1388,16 +1360,16 @@ int ndisc_rcv(struct sk_buff *skb)
...
@@ -1388,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
;
}
}
...
@@ -1465,9 +1437,9 @@ int __init ndisc_init(struct net_proto_family *ops)
...
@@ -1465,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
;
}
}
...
...
net/ipv6/netfilter/ip6t_eui64.c
View file @
ebec1711
...
@@ -50,7 +50,7 @@ match(const struct sk_buff *skb,
...
@@ -50,7 +50,7 @@ match(const struct sk_buff *skb,
eui64
[
0
]
|=
0x02
;
eui64
[
0
]
|=
0x02
;
i
=
0
;
i
=
0
;
while
((
skb
->
nh
.
ipv6h
->
saddr
.
in6_u
.
u6_addr8
[
8
+
i
]
==
while
((
skb
->
nh
.
ipv6h
->
saddr
.
s6_addr
[
8
+
i
]
==
eui64
[
i
])
&&
(
i
<
8
))
i
++
;
eui64
[
i
])
&&
(
i
<
8
))
i
++
;
if
(
i
==
8
)
if
(
i
==
8
)
...
...
net/ipv6/raw.c
View file @
ebec1711
...
@@ -222,7 +222,7 @@ static int rawv6_bind(struct sock *sk, struct sockaddr *uaddr, int addr_len)
...
@@ -222,7 +222,7 @@ static int rawv6_bind(struct sock *sk, struct sockaddr *uaddr, int addr_len)
}
}
/* ipv4 addr of the socket is invalid. Only the
/* ipv4 addr of the socket is invalid. Only the
* unpecified and mapped address have a v4 equivalent.
* un
s
pecified and mapped address have a v4 equivalent.
*/
*/
v4addr
=
LOOPBACK4_IPV6
;
v4addr
=
LOOPBACK4_IPV6
;
if
(
!
(
addr_type
&
IPV6_ADDR_MULTICAST
))
{
if
(
!
(
addr_type
&
IPV6_ADDR_MULTICAST
))
{
...
@@ -306,7 +306,7 @@ static inline int rawv6_rcv_skb(struct sock * sk, struct sk_buff * skb)
...
@@ -306,7 +306,7 @@ static inline int rawv6_rcv_skb(struct sock * sk, struct sk_buff * skb)
* This is next to useless...
* This is next to useless...
* if we demultiplex in network layer we don't need the extra call
* if we demultiplex in network layer we don't need the extra call
* just to queue the skb...
* just to queue the skb...
* maybe we could have the network decide up
p
on a hint if it
* maybe we could have the network decide upon a hint if it
* should call raw_rcv for demultiplexing
* should call raw_rcv for demultiplexing
*/
*/
int
rawv6_rcv
(
struct
sock
*
sk
,
struct
sk_buff
*
skb
)
int
rawv6_rcv
(
struct
sock
*
sk
,
struct
sk_buff
*
skb
)
...
@@ -627,7 +627,7 @@ static int rawv6_sendmsg(struct kiocb *iocb, struct sock *sk,
...
@@ -627,7 +627,7 @@ static int rawv6_sendmsg(struct kiocb *iocb, struct sock *sk,
if
(
ipv6_addr_any
(
daddr
))
{
if
(
ipv6_addr_any
(
daddr
))
{
/*
/*
* unspecfied destination address
* unspec
i
fied destination address
* treated as error... is this correct ?
* treated as error... is this correct ?
*/
*/
fl6_sock_release
(
flowlabel
);
fl6_sock_release
(
flowlabel
);
...
...
net/ipv6/route.c
View file @
ebec1711
...
@@ -223,7 +223,7 @@ static struct rt6_info *rt6_best_dflt(struct rt6_info *rt, int oif)
...
@@ -223,7 +223,7 @@ static struct rt6_info *rt6_best_dflt(struct rt6_info *rt, int oif)
match
=
sprt
;
match
=
sprt
;
mpri
=
m
;
mpri
=
m
;
if
(
m
>=
12
)
{
if
(
m
>=
12
)
{
/* we choose the last
est
default router if it
/* we choose the last default router if it
* is in (probably) reachable state.
* is in (probably) reachable state.
* If route changed, we should do pmtu
* If route changed, we should do pmtu
* discovery. --yoshfuji
* discovery. --yoshfuji
...
@@ -563,6 +563,7 @@ static struct dst_entry *ndisc_dst_gc_list;
...
@@ -563,6 +563,7 @@ static struct dst_entry *ndisc_dst_gc_list;
struct
dst_entry
*
ndisc_dst_alloc
(
struct
net_device
*
dev
,
struct
dst_entry
*
ndisc_dst_alloc
(
struct
net_device
*
dev
,
struct
neighbour
*
neigh
,
struct
neighbour
*
neigh
,
struct
in6_addr
*
addr
,
int
(
*
output
)(
struct
sk_buff
*
))
int
(
*
output
)(
struct
sk_buff
*
))
{
{
struct
rt6_info
*
rt
=
ip6_dst_alloc
();
struct
rt6_info
*
rt
=
ip6_dst_alloc
();
...
@@ -574,11 +575,13 @@ struct dst_entry *ndisc_dst_alloc(struct net_device *dev,
...
@@ -574,11 +575,13 @@ struct dst_entry *ndisc_dst_alloc(struct net_device *dev,
dev_hold
(
dev
);
dev_hold
(
dev
);
if
(
neigh
)
if
(
neigh
)
neigh_hold
(
neigh
);
neigh_hold
(
neigh
);
else
neigh
=
ndisc_get_neigh
(
dev
,
addr
);
rt
->
rt6i_dev
=
dev
;
rt
->
rt6i_dev
=
dev
;
rt
->
rt6i_nexthop
=
neigh
;
rt
->
rt6i_nexthop
=
neigh
;
rt
->
rt6i_expires
=
0
;
rt
->
rt6i_expires
=
0
;
rt
->
rt6i_flags
=
RTF_LOCAL
|
RTF_NDISC
;
rt
->
rt6i_flags
=
RTF_LOCAL
;
rt
->
rt6i_metric
=
0
;
rt
->
rt6i_metric
=
0
;
atomic_set
(
&
rt
->
u
.
dst
.
__refcnt
,
1
);
atomic_set
(
&
rt
->
u
.
dst
.
__refcnt
,
1
);
rt
->
u
.
dst
.
metrics
[
RTAX_HOPLIMIT
-
1
]
=
255
;
rt
->
u
.
dst
.
metrics
[
RTAX_HOPLIMIT
-
1
]
=
255
;
...
@@ -832,7 +835,7 @@ int ip6_route_add(struct in6_rtmsg *rtmsg, struct nlmsghdr *nlh, void *_rtattr)
...
@@ -832,7 +835,7 @@ int ip6_route_add(struct in6_rtmsg *rtmsg, struct nlmsghdr *nlh, void *_rtattr)
}
}
}
}
rt
->
rt6i_flags
=
rtmsg
->
rtmsg_flags
&
~
RTF_NDISC
;
rt
->
rt6i_flags
=
rtmsg
->
rtmsg_flags
;
install_route:
install_route:
if
(
rta
&&
rta
[
RTA_METRICS
-
1
])
{
if
(
rta
&&
rta
[
RTA_METRICS
-
1
])
{
...
@@ -1125,8 +1128,6 @@ static struct rt6_info * ip6_rt_copy(struct rt6_info *ort)
...
@@ -1125,8 +1128,6 @@ static struct rt6_info * ip6_rt_copy(struct rt6_info *ort)
{
{
struct
rt6_info
*
rt
=
ip6_dst_alloc
();
struct
rt6_info
*
rt
=
ip6_dst_alloc
();
BUG_ON
(
ort
->
rt6i_flags
&
RTF_NDISC
);
if
(
rt
)
{
if
(
rt
)
{
rt
->
u
.
dst
.
input
=
ort
->
u
.
dst
.
input
;
rt
->
u
.
dst
.
input
=
ort
->
u
.
dst
.
input
;
rt
->
u
.
dst
.
output
=
ort
->
u
.
dst
.
output
;
rt
->
u
.
dst
.
output
=
ort
->
u
.
dst
.
output
;
...
...
net/ipv6/xfrm6_policy.c
View file @
ebec1711
...
@@ -55,13 +55,6 @@ static struct dst_entry *
...
@@ -55,13 +55,6 @@ static struct dst_entry *
__xfrm6_find_bundle
(
struct
flowi
*
fl
,
struct
rtable
*
rt
,
struct
xfrm_policy
*
policy
)
__xfrm6_find_bundle
(
struct
flowi
*
fl
,
struct
rtable
*
rt
,
struct
xfrm_policy
*
policy
)
{
{
struct
dst_entry
*
dst
;
struct
dst_entry
*
dst
;
u32
ndisc_bit
=
0
;
if
(
fl
->
proto
==
IPPROTO_ICMPV6
&&
(
fl
->
fl_icmp_type
==
NDISC_NEIGHBOUR_ADVERTISEMENT
||
fl
->
fl_icmp_type
==
NDISC_NEIGHBOUR_SOLICITATION
||
fl
->
fl_icmp_type
==
NDISC_ROUTER_SOLICITATION
))
ndisc_bit
=
RTF_NDISC
;
/* Still not clear if we should set fl->fl6_{src,dst}... */
/* Still not clear if we should set fl->fl6_{src,dst}... */
read_lock_bh
(
&
policy
->
lock
);
read_lock_bh
(
&
policy
->
lock
);
...
@@ -69,9 +62,6 @@ __xfrm6_find_bundle(struct flowi *fl, struct rtable *rt, struct xfrm_policy *pol
...
@@ -69,9 +62,6 @@ __xfrm6_find_bundle(struct flowi *fl, struct rtable *rt, struct xfrm_policy *pol
struct
xfrm_dst
*
xdst
=
(
struct
xfrm_dst
*
)
dst
;
struct
xfrm_dst
*
xdst
=
(
struct
xfrm_dst
*
)
dst
;
struct
in6_addr
fl_dst_prefix
,
fl_src_prefix
;
struct
in6_addr
fl_dst_prefix
,
fl_src_prefix
;
if
((
xdst
->
u
.
rt6
.
rt6i_flags
&
RTF_NDISC
)
!=
ndisc_bit
)
continue
;
ipv6_addr_prefix
(
&
fl_dst_prefix
,
ipv6_addr_prefix
(
&
fl_dst_prefix
,
&
fl
->
fl6_dst
,
&
fl
->
fl6_dst
,
xdst
->
u
.
rt6
.
rt6i_dst
.
plen
);
xdst
->
u
.
rt6
.
rt6i_dst
.
plen
);
...
@@ -169,7 +159,7 @@ __xfrm6_bundle_create(struct xfrm_policy *policy, struct xfrm_state **xfrm, int
...
@@ -169,7 +159,7 @@ __xfrm6_bundle_create(struct xfrm_policy *policy, struct xfrm_state **xfrm, int
dst_prev
->
output
=
dst_prev
->
xfrm
->
type
->
output
;
dst_prev
->
output
=
dst_prev
->
xfrm
->
type
->
output
;
/* Sheit... I remember I did this right. Apparently,
/* Sheit... I remember I did this right. Apparently,
* it was magically lost, so this code needs audit */
* it was magically lost, so this code needs audit */
x
->
u
.
rt6
.
rt6i_flags
=
rt0
->
rt6i_flags
&
(
RTCF_BROADCAST
|
RTCF_MULTICAST
|
RTCF_LOCAL
|
RTF_NDISC
);
x
->
u
.
rt6
.
rt6i_flags
=
rt0
->
rt6i_flags
&
(
RTCF_BROADCAST
|
RTCF_MULTICAST
|
RTCF_LOCAL
);
x
->
u
.
rt6
.
rt6i_metric
=
rt0
->
rt6i_metric
;
x
->
u
.
rt6
.
rt6i_metric
=
rt0
->
rt6i_metric
;
x
->
u
.
rt6
.
rt6i_node
=
rt0
->
rt6i_node
;
x
->
u
.
rt6
.
rt6i_node
=
rt0
->
rt6i_node
;
x
->
u
.
rt6
.
rt6i_gateway
=
rt0
->
rt6i_gateway
;
x
->
u
.
rt6
.
rt6i_gateway
=
rt0
->
rt6i_gateway
;
...
...
net/sched/sch_sfq.c
View file @
ebec1711
...
@@ -341,6 +341,7 @@ sfq_dequeue(struct Qdisc* sch)
...
@@ -341,6 +341,7 @@ sfq_dequeue(struct Qdisc* sch)
/* Is the slot empty? */
/* Is the slot empty? */
if
(
q
->
qs
[
a
].
qlen
==
0
)
{
if
(
q
->
qs
[
a
].
qlen
==
0
)
{
q
->
ht
[
q
->
hash
[
a
]]
=
SFQ_DEPTH
;
a
=
q
->
next
[
a
];
a
=
q
->
next
[
a
];
if
(
a
==
old_a
)
{
if
(
a
==
old_a
)
{
q
->
tail
=
SFQ_DEPTH
;
q
->
tail
=
SFQ_DEPTH
;
...
...
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