Re: ixgbe question
From: Eric Dumazet <hidden>
Date: 2009-11-23 14:05:27
Eric Dumazet a écrit :
Waskiewicz Jr, Peter P a écrit :quoted
On Mon, 23 Nov 2009, Eric Dumazet wrote:quoted
Hi Peter I tried a pktgen stress on 82599EB card and could not split RX load on multiple cpus. Setup is : One 82599 card with fiber0 looped to fiber1, 10Gb link mode. machine is a HPDL380 G6 with dual quadcore E5530 @2.4GHz (16 logical cpus)Can you specify kernel version and driver version?Well, I forgot to mention I am only working with net-next-2.6 tree. Ubuntu 9.10 kernel (Fedora Core 12 installer was not able to recognize disks on this machine :( ) ixgbe: Intel(R) 10 Gigabit PCI Express Network Driver - version 2.0.44-k2
I tried with several pktgen threads, no success so far. Only one cpu handles all interrupts and ksoftirq enters a mode with no escape to splitted mode. To get real multi queue and uncontended handling, I had to force : echo 1 >`echo /proc/irq/*/fiber1-TxRx-0/../smp_affinity` echo 2 >`echo /proc/irq/*/fiber1-TxRx-1/../smp_affinity` echo 4 >`echo /proc/irq/*/fiber1-TxRx-2/../smp_affinity` echo 8 >`echo /proc/irq/*/fiber1-TxRx-3/../smp_affinity` echo 10 >`echo /proc/irq/*/fiber1-TxRx-4/../smp_affinity` echo 20 >`echo /proc/irq/*/fiber1-TxRx-5/../smp_affinity` echo 40 >`echo /proc/irq/*/fiber1-TxRx-6/../smp_affinity` echo 80 >`echo /proc/irq/*/fiber1-TxRx-7/../smp_affinity` echo 100 >`echo /proc/irq/*/fiber1-TxRx-8/../smp_affinity` echo 200 >`echo /proc/irq/*/fiber1-TxRx-9/../smp_affinity` echo 400 >`echo /proc/irq/*/fiber1-TxRx-10/../smp_affinity` echo 800 >`echo /proc/irq/*/fiber1-TxRx-11/../smp_affinity` echo 1000 >`echo /proc/irq/*/fiber1-TxRx-12/../smp_affinity` echo 2000 >`echo /proc/irq/*/fiber1-TxRx-13/../smp_affinity` echo 4000 >`echo /proc/irq/*/fiber1-TxRx-14/../smp_affinity` echo 8000 >`echo /proc/irq/*/fiber1-TxRx-15/../smp_affinity` Probably problem comes from fact that when ksoftirqd runs and RX queues are not depleted, no hardware interrupts is sent, and NAPI contexts stay sticked on one cpu forever ?