diff options
author | Shawn Bohrer <sbohrer@rgmadvisors.com> | 2013-10-07 12:01:40 -0400 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2013-10-08 16:27:33 -0400 |
commit | fbf8866d65d5de84f75563eb0edd7fc27dbe9a90 (patch) | |
tree | 150188e64b62233edb22aefe9e57ed90196388da /net/ipv4/udp.c | |
parent | 421b3885bf6d56391297844f43fb7154a6396e12 (diff) |
net: ipv4 only populate IP_PKTINFO when needed
The since the removal of the routing cache computing
fib_compute_spec_dst() does a fib_table lookup for each UDP multicast
packet received. This has introduced a performance regression for some
UDP workloads.
This change skips populating the packet info for sockets that do not have
IP_PKTINFO set.
Benchmark results from a netperf UDP_RR test:
Before 89789.68 transactions/s
After 90587.62 transactions/s
Benchmark results from a fio 1 byte UDP multicast pingpong test
(Multicast one way unicast response):
Before 12.63us RTT
After 12.48us RTT
Signed-off-by: Shawn Bohrer <sbohrer@rgmadvisors.com>
Acked-by: Eric Dumazet <edumazet@google.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/ipv4/udp.c')
-rw-r--r-- | net/ipv4/udp.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/net/ipv4/udp.c b/net/ipv4/udp.c index 262ea3929da6..4226c53daaed 100644 --- a/net/ipv4/udp.c +++ b/net/ipv4/udp.c | |||
@@ -1544,7 +1544,7 @@ int udp_queue_rcv_skb(struct sock *sk, struct sk_buff *skb) | |||
1544 | 1544 | ||
1545 | rc = 0; | 1545 | rc = 0; |
1546 | 1546 | ||
1547 | ipv4_pktinfo_prepare(skb); | 1547 | ipv4_pktinfo_prepare(sk, skb); |
1548 | bh_lock_sock(sk); | 1548 | bh_lock_sock(sk); |
1549 | if (!sock_owned_by_user(sk)) | 1549 | if (!sock_owned_by_user(sk)) |
1550 | rc = __udp_queue_rcv_skb(sk, skb); | 1550 | rc = __udp_queue_rcv_skb(sk, skb); |