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
Kirill Smelkov
linux
Commits
575f5a13
Commit
575f5a13
authored
Oct 27, 2002
by
Nivedita Singhvi
Committed by
David S. Miller
Oct 27, 2002
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
[IPV{4,6}]: Clean up SNMP counter bumping.
parent
0a68b031
Changes
8
Hide whitespace changes
Inline
Side-by-side
Showing
8 changed files
with
20 additions
and
25 deletions
+20
-25
net/ipv4/ip_input.c
net/ipv4/ip_input.c
+9
-3
net/ipv4/raw.c
net/ipv4/raw.c
+1
-2
net/ipv4/tcp_ipv4.c
net/ipv4/tcp_ipv4.c
+0
-2
net/ipv4/udp.c
net/ipv4/udp.c
+0
-6
net/ipv6/ip6_input.c
net/ipv6/ip6_input.c
+6
-2
net/ipv6/raw.c
net/ipv6/raw.c
+4
-5
net/ipv6/tcp_ipv6.c
net/ipv6/tcp_ipv6.c
+0
-2
net/ipv6/udp.c
net/ipv6/udp.c
+0
-3
No files found.
net/ipv4/ip_input.c
View file @
575f5a13
...
@@ -237,11 +237,13 @@ static inline int ip_local_deliver_finish(struct sk_buff *skb)
...
@@ -237,11 +237,13 @@ static inline int ip_local_deliver_finish(struct sk_buff *skb)
protocol
=
-
ret
;
protocol
=
-
ret
;
goto
resubmit
;
goto
resubmit
;
}
}
IP_INC_STATS_BH
(
IpInDelivers
);
}
else
{
}
else
{
if
(
!
raw_sk
)
{
if
(
!
raw_sk
)
{
icmp_send
(
skb
,
ICMP_DEST_UNREACH
,
icmp_send
(
skb
,
ICMP_DEST_UNREACH
,
ICMP_PROT_UNREACH
,
0
);
ICMP_PROT_UNREACH
,
0
);
}
}
else
IP_INC_STATS_BH
(
IpInDelivers
);
kfree_skb
(
skb
);
kfree_skb
(
skb
);
}
}
}
}
...
@@ -304,8 +306,10 @@ static inline int ip_rcv_finish(struct sk_buff *skb)
...
@@ -304,8 +306,10 @@ static inline int ip_rcv_finish(struct sk_buff *skb)
--ANK (980813)
--ANK (980813)
*/
*/
if
(
skb_cow
(
skb
,
skb_headroom
(
skb
)))
if
(
skb_cow
(
skb
,
skb_headroom
(
skb
)))
{
IP_INC_STATS_BH
(
IpInDiscards
);
goto
drop
;
goto
drop
;
}
iph
=
skb
->
nh
.
iph
;
iph
=
skb
->
nh
.
iph
;
if
(
ip_options_compile
(
NULL
,
skb
))
if
(
ip_options_compile
(
NULL
,
skb
))
...
@@ -353,8 +357,10 @@ int ip_rcv(struct sk_buff *skb, struct net_device *dev, struct packet_type *pt)
...
@@ -353,8 +357,10 @@ int ip_rcv(struct sk_buff *skb, struct net_device *dev, struct packet_type *pt)
IP_INC_STATS_BH
(
IpInReceives
);
IP_INC_STATS_BH
(
IpInReceives
);
if
((
skb
=
skb_share_check
(
skb
,
GFP_ATOMIC
))
==
NULL
)
if
((
skb
=
skb_share_check
(
skb
,
GFP_ATOMIC
))
==
NULL
)
{
IP_INC_STATS_BH
(
IpInDiscards
);
goto
out
;
goto
out
;
}
if
(
!
pskb_may_pull
(
skb
,
sizeof
(
struct
iphdr
)))
if
(
!
pskb_may_pull
(
skb
,
sizeof
(
struct
iphdr
)))
goto
inhdr_error
;
goto
inhdr_error
;
...
...
net/ipv4/raw.c
View file @
575f5a13
...
@@ -227,12 +227,11 @@ static int raw_rcv_skb(struct sock * sk, struct sk_buff * skb)
...
@@ -227,12 +227,11 @@ static int raw_rcv_skb(struct sock * sk, struct sk_buff * skb)
/* Charge it to the socket. */
/* Charge it to the socket. */
if
(
sock_queue_rcv_skb
(
sk
,
skb
)
<
0
)
{
if
(
sock_queue_rcv_skb
(
sk
,
skb
)
<
0
)
{
IP_INC_STATS
(
IpInDiscards
);
/* FIXME: increment a raw drops counter here */
kfree_skb
(
skb
);
kfree_skb
(
skb
);
return
NET_RX_DROP
;
return
NET_RX_DROP
;
}
}
IP_INC_STATS
(
IpInDelivers
);
return
NET_RX_SUCCESS
;
return
NET_RX_SUCCESS
;
}
}
...
...
net/ipv4/tcp_ipv4.c
View file @
575f5a13
...
@@ -1700,8 +1700,6 @@ int tcp_v4_do_rcv(struct sock *sk, struct sk_buff *skb)
...
@@ -1700,8 +1700,6 @@ int tcp_v4_do_rcv(struct sock *sk, struct sk_buff *skb)
goto
discard
;
goto
discard
;
#endif
/* CONFIG_FILTER */
#endif
/* CONFIG_FILTER */
IP_INC_STATS_BH
(
IpInDelivers
);
if
(
sk
->
state
==
TCP_ESTABLISHED
)
{
/* Fast path */
if
(
sk
->
state
==
TCP_ESTABLISHED
)
{
/* Fast path */
TCP_CHECK_TIMER
(
sk
);
TCP_CHECK_TIMER
(
sk
);
if
(
tcp_rcv_established
(
sk
,
skb
,
skb
->
h
.
th
,
skb
->
len
))
if
(
tcp_rcv_established
(
sk
,
skb
,
skb
->
h
.
th
,
skb
->
len
))
...
...
net/ipv4/udp.c
View file @
575f5a13
...
@@ -951,8 +951,6 @@ static int udp_queue_rcv_skb(struct sock * sk, struct sk_buff *skb)
...
@@ -951,8 +951,6 @@ static int udp_queue_rcv_skb(struct sock * sk, struct sk_buff *skb)
if
(
sk
->
filter
&&
skb
->
ip_summed
!=
CHECKSUM_UNNECESSARY
)
{
if
(
sk
->
filter
&&
skb
->
ip_summed
!=
CHECKSUM_UNNECESSARY
)
{
if
(
__udp_checksum_complete
(
skb
))
{
if
(
__udp_checksum_complete
(
skb
))
{
UDP_INC_STATS_BH
(
UdpInErrors
);
UDP_INC_STATS_BH
(
UdpInErrors
);
IP_INC_STATS_BH
(
IpInDiscards
);
ip_statistics
[
smp_processor_id
()
*
2
].
IpInDelivers
--
;
kfree_skb
(
skb
);
kfree_skb
(
skb
);
return
-
1
;
return
-
1
;
}
}
...
@@ -962,8 +960,6 @@ static int udp_queue_rcv_skb(struct sock * sk, struct sk_buff *skb)
...
@@ -962,8 +960,6 @@ static int udp_queue_rcv_skb(struct sock * sk, struct sk_buff *skb)
if
(
sock_queue_rcv_skb
(
sk
,
skb
)
<
0
)
{
if
(
sock_queue_rcv_skb
(
sk
,
skb
)
<
0
)
{
UDP_INC_STATS_BH
(
UdpInErrors
);
UDP_INC_STATS_BH
(
UdpInErrors
);
IP_INC_STATS_BH
(
IpInDiscards
);
ip_statistics
[
smp_processor_id
()
*
2
].
IpInDelivers
--
;
kfree_skb
(
skb
);
kfree_skb
(
skb
);
return
-
1
;
return
-
1
;
}
}
...
@@ -1047,8 +1043,6 @@ int udp_rcv(struct sk_buff *skb)
...
@@ -1047,8 +1043,6 @@ int udp_rcv(struct sk_buff *skb)
u32
daddr
=
skb
->
nh
.
iph
->
daddr
;
u32
daddr
=
skb
->
nh
.
iph
->
daddr
;
int
len
=
skb
->
len
;
int
len
=
skb
->
len
;
IP_INC_STATS_BH
(
IpInDelivers
);
/*
/*
* Validate the packet and the UDP length.
* Validate the packet and the UDP length.
*/
*/
...
...
net/ipv6/ip6_input.c
View file @
575f5a13
...
@@ -60,8 +60,10 @@ int ipv6_rcv(struct sk_buff *skb, struct net_device *dev, struct packet_type *pt
...
@@ -60,8 +60,10 @@ int ipv6_rcv(struct sk_buff *skb, struct net_device *dev, struct packet_type *pt
IP6_INC_STATS_BH
(
Ip6InReceives
);
IP6_INC_STATS_BH
(
Ip6InReceives
);
if
((
skb
=
skb_share_check
(
skb
,
GFP_ATOMIC
))
==
NULL
)
if
((
skb
=
skb_share_check
(
skb
,
GFP_ATOMIC
))
==
NULL
)
{
IP6_INC_STATS_BH
(
Ip6InDiscards
);
goto
out
;
goto
out
;
}
/* Store incoming device index. When the packet will
/* Store incoming device index. When the packet will
be queued, we cannot refer to skb->dev anymore.
be queued, we cannot refer to skb->dev anymore.
...
@@ -175,11 +177,13 @@ static inline int ip6_input_finish(struct sk_buff *skb)
...
@@ -175,11 +177,13 @@ static inline int ip6_input_finish(struct sk_buff *skb)
nexthdr
=
-
ret
;
nexthdr
=
-
ret
;
goto
resubmit
;
goto
resubmit
;
}
}
IP6_INC_STATS_BH
(
Ip6InDelivers
);
}
else
{
}
else
{
if
(
!
raw_sk
)
{
if
(
!
raw_sk
)
{
IP6_INC_STATS_BH
(
Ip6InUnknownProtos
);
IP6_INC_STATS_BH
(
Ip6InUnknownProtos
);
icmpv6_param_prob
(
skb
,
ICMPV6_UNK_NEXTHDR
,
nhoff
);
icmpv6_param_prob
(
skb
,
ICMPV6_UNK_NEXTHDR
,
nhoff
);
}
}
else
IP6_INC_STATS_BH
(
Ip6InDelivers
);
kfree_skb
(
skb
);
kfree_skb
(
skb
);
}
}
...
...
net/ipv6/raw.c
View file @
575f5a13
...
@@ -275,7 +275,7 @@ static inline int rawv6_rcv_skb(struct sock * sk, struct sk_buff * skb)
...
@@ -275,7 +275,7 @@ static inline int rawv6_rcv_skb(struct sock * sk, struct sk_buff * skb)
#if defined(CONFIG_FILTER)
#if defined(CONFIG_FILTER)
if
(
sk
->
filter
&&
skb
->
ip_summed
!=
CHECKSUM_UNNECESSARY
)
{
if
(
sk
->
filter
&&
skb
->
ip_summed
!=
CHECKSUM_UNNECESSARY
)
{
if
((
unsigned
short
)
csum_fold
(
skb_checksum
(
skb
,
0
,
skb
->
len
,
skb
->
csum
)))
{
if
((
unsigned
short
)
csum_fold
(
skb_checksum
(
skb
,
0
,
skb
->
len
,
skb
->
csum
)))
{
IP6_INC_STATS_BH
(
Ip6InDiscards
);
/* FIXME: increment a raw6 drops counter here */
kfree_skb
(
skb
);
kfree_skb
(
skb
);
return
0
;
return
0
;
}
}
...
@@ -284,12 +284,11 @@ static inline int rawv6_rcv_skb(struct sock * sk, struct sk_buff * skb)
...
@@ -284,12 +284,11 @@ static inline int rawv6_rcv_skb(struct sock * sk, struct sk_buff * skb)
#endif
#endif
/* Charge it to the socket. */
/* Charge it to the socket. */
if
(
sock_queue_rcv_skb
(
sk
,
skb
)
<
0
)
{
if
(
sock_queue_rcv_skb
(
sk
,
skb
)
<
0
)
{
IP6_INC_STATS_BH
(
Ip6InDiscards
);
/* FIXME: increment a raw6 drops counter here */
kfree_skb
(
skb
);
kfree_skb
(
skb
);
return
0
;
return
0
;
}
}
IP6_INC_STATS_BH
(
Ip6InDelivers
);
return
0
;
return
0
;
}
}
...
@@ -327,7 +326,7 @@ int rawv6_rcv(struct sock *sk, struct sk_buff *skb)
...
@@ -327,7 +326,7 @@ int rawv6_rcv(struct sock *sk, struct sk_buff *skb)
if
(
inet
->
hdrincl
)
{
if
(
inet
->
hdrincl
)
{
if
(
skb
->
ip_summed
!=
CHECKSUM_UNNECESSARY
&&
if
(
skb
->
ip_summed
!=
CHECKSUM_UNNECESSARY
&&
(
unsigned
short
)
csum_fold
(
skb_checksum
(
skb
,
0
,
skb
->
len
,
skb
->
csum
)))
{
(
unsigned
short
)
csum_fold
(
skb_checksum
(
skb
,
0
,
skb
->
len
,
skb
->
csum
)))
{
IP6_INC_STATS_BH
(
Ip6InDiscards
);
/* FIXME: increment a raw6 drops counter here */
kfree_skb
(
skb
);
kfree_skb
(
skb
);
return
0
;
return
0
;
}
}
...
@@ -427,7 +426,7 @@ static int rawv6_recvmsg(struct kiocb *iocb, struct sock *sk, struct msghdr *msg
...
@@ -427,7 +426,7 @@ static int rawv6_recvmsg(struct kiocb *iocb, struct sock *sk, struct msghdr *msg
as some normal condition.
as some normal condition.
*/
*/
err
=
(
flags
&
MSG_DONTWAIT
)
?
-
EAGAIN
:
-
EHOSTUNREACH
;
err
=
(
flags
&
MSG_DONTWAIT
)
?
-
EAGAIN
:
-
EHOSTUNREACH
;
IP6_INC_STATS_USER
(
Ip6InDiscards
);
/* FIXME: increment a raw6 drops counter here */
goto
out_free
;
goto
out_free
;
}
}
...
...
net/ipv6/tcp_ipv6.c
View file @
575f5a13
...
@@ -1497,8 +1497,6 @@ static int tcp_v6_do_rcv(struct sock *sk, struct sk_buff *skb)
...
@@ -1497,8 +1497,6 @@ static int tcp_v6_do_rcv(struct sock *sk, struct sk_buff *skb)
* is currently called with bh processing disabled.
* is currently called with bh processing disabled.
*/
*/
IP6_INC_STATS_BH
(
Ip6InDelivers
);
/* Do Stevens' IPV6_PKTOPTIONS.
/* Do Stevens' IPV6_PKTOPTIONS.
Yes, guys, it is the only place in our code, where we
Yes, guys, it is the only place in our code, where we
...
...
net/ipv6/udp.c
View file @
575f5a13
...
@@ -545,7 +545,6 @@ static inline int udpv6_queue_rcv_skb(struct sock * sk, struct sk_buff *skb)
...
@@ -545,7 +545,6 @@ static inline int udpv6_queue_rcv_skb(struct sock * sk, struct sk_buff *skb)
if
(
sk
->
filter
&&
skb
->
ip_summed
!=
CHECKSUM_UNNECESSARY
)
{
if
(
sk
->
filter
&&
skb
->
ip_summed
!=
CHECKSUM_UNNECESSARY
)
{
if
((
unsigned
short
)
csum_fold
(
skb_checksum
(
skb
,
0
,
skb
->
len
,
skb
->
csum
)))
{
if
((
unsigned
short
)
csum_fold
(
skb_checksum
(
skb
,
0
,
skb
->
len
,
skb
->
csum
)))
{
UDP6_INC_STATS_BH
(
UdpInErrors
);
UDP6_INC_STATS_BH
(
UdpInErrors
);
IP6_INC_STATS_BH
(
Ip6InDiscards
);
kfree_skb
(
skb
);
kfree_skb
(
skb
);
return
0
;
return
0
;
}
}
...
@@ -554,11 +553,9 @@ static inline int udpv6_queue_rcv_skb(struct sock * sk, struct sk_buff *skb)
...
@@ -554,11 +553,9 @@ static inline int udpv6_queue_rcv_skb(struct sock * sk, struct sk_buff *skb)
#endif
#endif
if
(
sock_queue_rcv_skb
(
sk
,
skb
)
<
0
)
{
if
(
sock_queue_rcv_skb
(
sk
,
skb
)
<
0
)
{
UDP6_INC_STATS_BH
(
UdpInErrors
);
UDP6_INC_STATS_BH
(
UdpInErrors
);
IP6_INC_STATS_BH
(
Ip6InDiscards
);
kfree_skb
(
skb
);
kfree_skb
(
skb
);
return
0
;
return
0
;
}
}
IP6_INC_STATS_BH
(
Ip6InDelivers
);
UDP6_INC_STATS_BH
(
UdpInDatagrams
);
UDP6_INC_STATS_BH
(
UdpInDatagrams
);
return
0
;
return
0
;
}
}
...
...
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