[<prev] [next>] [thread-next>] [day] [month] [year] [list]
Message-ID: <06dc7df0afd344fc9aa656896e761d37@AcuMS.aculab.com>
Date: Mon, 9 May 2022 16:55:13 +0000
From: David Laight <David.Laight@...LAB.COM>
To: netdev <netdev@...r.kernel.org>
CC: "David S . Miller" <davem@...emloft.net>,
Jakub Kicinski <kuba@...nel.org>,
'Eric Dumazet' <edumazet@...gle.com>
Subject: High packet rate udp receive
I'm testing some high channel count RTP (UDP audio).
When I get much over 250000 receive packets/second the
network receive softint processing seems to overload
one cpu and then packets are silently discarded somewhere.
I (probably) can see all the packets in /sys/class/net/em2/statistics/rx_packets
but the counts from 'netstat -s' are a lot lower.
The packets are destined for a lot of UDP sockets - each gets 50/sec.
These can't be 'connected' because the source address is allowed to change.
For testing the source IP is pretty fixed.
But I've not tried to look for the actual bottleneck.
Are we stuck with one cpu doing all the ethernet, IP and UDP
receive processing?
(and the end of transmit reaping).
Or is there a way to get another cpu to do some of the work?
Since this is UDP things like gro can't help.
We do have to handle very large numbers of packets.
Would a multi-queue ethernet adapter help?
This system has a BCM5720 (tg3 driver) which I don't think is multi-Q.
OTOH I've also had issues with a similar packet rate on an intel
nic that would be multi-q because the interrupt mitigation logic
is completely broken for high packet rates.
Only increasing the ring size to 4096 stopped it dropping packets.
David
-
Registered Address Lakeside, Bramley Road, Mount Farm, Milton Keynes, MK1 1PT, UK
Registration No: 1397386 (Wales)
Powered by blists - more mailing lists