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
8f701a3e
Commit
8f701a3e
authored
Jan 05, 2003
by
Linus Torvalds
Browse files
Options
Browse Files
Download
Plain Diff
Merge
bk://kernel.bkbits.net/davem/net-2.5
into home.transmeta.com:/home/torvalds/v2.5/linux
parents
da085726
c627bc55
Changes
3
Show whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
27 additions
and
10 deletions
+27
-10
net/core/dv.c
net/core/dv.c
+3
-3
net/ipv4/route.c
net/ipv4/route.c
+17
-6
net/ipv6/exthdrs.c
net/ipv6/exthdrs.c
+7
-1
No files found.
net/core/dv.c
View file @
8f701a3e
...
@@ -97,7 +97,7 @@ void free_divert_blk(struct net_device *dev)
...
@@ -97,7 +97,7 @@ void free_divert_blk(struct net_device *dev)
/*
/*
* Adds a tcp/udp (source or dest) port to an array
* Adds a tcp/udp (source or dest) port to an array
*/
*/
int
add_port
(
u16
ports
[],
u16
port
)
static
int
add_port
(
u16
ports
[],
u16
port
)
{
{
int
i
;
int
i
;
...
@@ -127,7 +127,7 @@ int add_port(u16 ports[], u16 port)
...
@@ -127,7 +127,7 @@ int add_port(u16 ports[], u16 port)
/*
/*
* Removes a port from an array tcp/udp (source or dest)
* Removes a port from an array tcp/udp (source or dest)
*/
*/
int
remove_port
(
u16
ports
[],
u16
port
)
static
int
remove_port
(
u16
ports
[],
u16
port
)
{
{
int
i
;
int
i
;
...
@@ -150,7 +150,7 @@ int remove_port(u16 ports[], u16 port)
...
@@ -150,7 +150,7 @@ int remove_port(u16 ports[], u16 port)
}
}
/* Some basic sanity checks on the arguments passed to divert_ioctl() */
/* Some basic sanity checks on the arguments passed to divert_ioctl() */
int
check_args
(
struct
divert_cf
*
div_cf
,
struct
net_device
**
dev
)
static
int
check_args
(
struct
divert_cf
*
div_cf
,
struct
net_device
**
dev
)
{
{
char
devname
[
32
];
char
devname
[
32
];
int
ret
;
int
ret
;
...
...
net/ipv4/route.c
View file @
8f701a3e
...
@@ -234,7 +234,7 @@ static struct rtable *rt_cache_get_next(struct seq_file *seq, struct rtable *r)
...
@@ -234,7 +234,7 @@ static struct rtable *rt_cache_get_next(struct seq_file *seq, struct rtable *r)
{
{
struct
rt_cache_iter_state
*
st
=
seq
->
private
;
struct
rt_cache_iter_state
*
st
=
seq
->
private
;
read_barrier_depends
();
smp_
read_barrier_depends
();
r
=
r
->
u
.
rt_next
;
r
=
r
->
u
.
rt_next
;
while
(
!
r
)
{
while
(
!
r
)
{
rcu_read_unlock
();
rcu_read_unlock
();
...
@@ -718,7 +718,18 @@ static int rt_intern_hash(unsigned hash, struct rtable *rt, struct rtable **rp)
...
@@ -718,7 +718,18 @@ static int rt_intern_hash(unsigned hash, struct rtable *rt, struct rtable **rp)
if
(
compare_keys
(
&
rth
->
fl
,
&
rt
->
fl
))
{
if
(
compare_keys
(
&
rth
->
fl
,
&
rt
->
fl
))
{
/* Put it first */
/* Put it first */
*
rthp
=
rth
->
u
.
rt_next
;
*
rthp
=
rth
->
u
.
rt_next
;
/*
* Since lookup is lockfree, the deletion
* must be visible to another weakly ordered CPU before
* the insertion at the start of the hash chain.
*/
smp_wmb
();
rth
->
u
.
rt_next
=
rt_hash_table
[
hash
].
chain
;
rth
->
u
.
rt_next
=
rt_hash_table
[
hash
].
chain
;
/*
* Since lookup is lockfree, the update writes
* must be ordered for consistency on SMP.
*/
smp_wmb
();
rt_hash_table
[
hash
].
chain
=
rth
;
rt_hash_table
[
hash
].
chain
=
rth
;
rth
->
u
.
dst
.
__use
++
;
rth
->
u
.
dst
.
__use
++
;
...
@@ -900,7 +911,7 @@ void ip_rt_redirect(u32 old_gw, u32 daddr, u32 new_gw,
...
@@ -900,7 +911,7 @@ void ip_rt_redirect(u32 old_gw, u32 daddr, u32 new_gw,
while
((
rth
=
*
rthp
)
!=
NULL
)
{
while
((
rth
=
*
rthp
)
!=
NULL
)
{
struct
rtable
*
rt
;
struct
rtable
*
rt
;
read_barrier_depends
();
smp_
read_barrier_depends
();
if
(
rth
->
fl
.
fl4_dst
!=
daddr
||
if
(
rth
->
fl
.
fl4_dst
!=
daddr
||
rth
->
fl
.
fl4_src
!=
skeys
[
i
]
||
rth
->
fl
.
fl4_src
!=
skeys
[
i
]
||
rth
->
fl
.
fl4_tos
!=
tos
||
rth
->
fl
.
fl4_tos
!=
tos
||
...
@@ -1148,7 +1159,7 @@ unsigned short ip_rt_frag_needed(struct iphdr *iph, unsigned short new_mtu)
...
@@ -1148,7 +1159,7 @@ unsigned short ip_rt_frag_needed(struct iphdr *iph, unsigned short new_mtu)
rcu_read_lock
();
rcu_read_lock
();
for
(
rth
=
rt_hash_table
[
hash
].
chain
;
rth
;
for
(
rth
=
rt_hash_table
[
hash
].
chain
;
rth
;
rth
=
rth
->
u
.
rt_next
)
{
rth
=
rth
->
u
.
rt_next
)
{
read_barrier_depends
();
smp_
read_barrier_depends
();
if
(
rth
->
fl
.
fl4_dst
==
daddr
&&
if
(
rth
->
fl
.
fl4_dst
==
daddr
&&
rth
->
fl
.
fl4_src
==
skeys
[
i
]
&&
rth
->
fl
.
fl4_src
==
skeys
[
i
]
&&
rth
->
rt_dst
==
daddr
&&
rth
->
rt_dst
==
daddr
&&
...
@@ -1740,7 +1751,7 @@ int ip_route_input(struct sk_buff *skb, u32 daddr, u32 saddr,
...
@@ -1740,7 +1751,7 @@ int ip_route_input(struct sk_buff *skb, u32 daddr, u32 saddr,
rcu_read_lock
();
rcu_read_lock
();
for
(
rth
=
rt_hash_table
[
hash
].
chain
;
rth
;
rth
=
rth
->
u
.
rt_next
)
{
for
(
rth
=
rt_hash_table
[
hash
].
chain
;
rth
;
rth
=
rth
->
u
.
rt_next
)
{
read_barrier_depends
();
smp_
read_barrier_depends
();
if
(
rth
->
fl
.
fl4_dst
==
daddr
&&
if
(
rth
->
fl
.
fl4_dst
==
daddr
&&
rth
->
fl
.
fl4_src
==
saddr
&&
rth
->
fl
.
fl4_src
==
saddr
&&
rth
->
fl
.
iif
==
iif
&&
rth
->
fl
.
iif
==
iif
&&
...
@@ -2105,7 +2116,7 @@ int __ip_route_output_key(struct rtable **rp, const struct flowi *flp)
...
@@ -2105,7 +2116,7 @@ int __ip_route_output_key(struct rtable **rp, const struct flowi *flp)
rcu_read_lock
();
rcu_read_lock
();
for
(
rth
=
rt_hash_table
[
hash
].
chain
;
rth
;
rth
=
rth
->
u
.
rt_next
)
{
for
(
rth
=
rt_hash_table
[
hash
].
chain
;
rth
;
rth
=
rth
->
u
.
rt_next
)
{
read_barrier_depends
();
smp_
read_barrier_depends
();
if
(
rth
->
fl
.
fl4_dst
==
flp
->
fl4_dst
&&
if
(
rth
->
fl
.
fl4_dst
==
flp
->
fl4_dst
&&
rth
->
fl
.
fl4_src
==
flp
->
fl4_src
&&
rth
->
fl
.
fl4_src
==
flp
->
fl4_src
&&
rth
->
fl
.
iif
==
0
&&
rth
->
fl
.
iif
==
0
&&
...
@@ -2335,7 +2346,7 @@ int ip_rt_dump(struct sk_buff *skb, struct netlink_callback *cb)
...
@@ -2335,7 +2346,7 @@ int ip_rt_dump(struct sk_buff *skb, struct netlink_callback *cb)
rcu_read_lock
();
rcu_read_lock
();
for
(
rt
=
rt_hash_table
[
h
].
chain
,
idx
=
0
;
rt
;
for
(
rt
=
rt_hash_table
[
h
].
chain
,
idx
=
0
;
rt
;
rt
=
rt
->
u
.
rt_next
,
idx
++
)
{
rt
=
rt
->
u
.
rt_next
,
idx
++
)
{
read_barrier_depends
();
smp_
read_barrier_depends
();
if
(
idx
<
s_idx
)
if
(
idx
<
s_idx
)
continue
;
continue
;
skb
->
dst
=
dst_clone
(
&
rt
->
u
.
dst
);
skb
->
dst
=
dst_clone
(
&
rt
->
u
.
dst
);
...
...
net/ipv6/exthdrs.c
View file @
8f701a3e
...
@@ -402,7 +402,13 @@ static int ipv6_auth_hdr(struct sk_buff **skb_ptr, int nhoff)
...
@@ -402,7 +402,13 @@ static int ipv6_auth_hdr(struct sk_buff **skb_ptr, int nhoff)
if
(
!
pskb_may_pull
(
skb
,
(
skb
->
h
.
raw
-
skb
->
data
)
+
8
))
if
(
!
pskb_may_pull
(
skb
,
(
skb
->
h
.
raw
-
skb
->
data
)
+
8
))
goto
fail
;
goto
fail
;
len
=
(
skb
->
h
.
raw
[
1
]
+
1
)
<<
2
;
/*
* RFC2402 2.2 Payload Length
* The 8-bit field specifies the length of AH in 32-bit words
* (4-byte units), minus "2".
* -- Noriaki Takamiya @USAGI Project
*/
len
=
(
skb
->
h
.
raw
[
1
]
+
2
)
<<
2
;
if
(
len
&
7
)
if
(
len
&
7
)
goto
fail
;
goto
fail
;
...
...
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