On Fri, Oct 23, 2009 at 12:59 AM, Eric W. Biederman <ebiederm@xxxxxxxxxxxx> wrote: > David Daney <ddaney@xxxxxxxxxxxxxxxxxx> writes: >> Certainly this is one mode of operation that should be supported, but I would >> also like to be able to go for raw throughput and have as many cores as possible >> reading from a single queue (like I currently have). > > I believe will detect false packet drops and ask for unnecessary > retransmits if you have multiple cores processing a single queue, > because you are processing the packets out of order. So, the way the default linux kernel configures today's many core server systems is to leave the affinity mask by default at 0xffffffff, and most current Intel hardware based on 5000 (older core cpus), or 5500 chipset (used with Core i7 processors) that I have seen will allow for round robin interrupts by default. This kind of sucks for the above unless you run irqbalance or set smp_affinity by hand. Yes, I know Arjan and others will say you should always run irqbalance, but some people don't and some distros don't ship it enabled by default (or their version doesn't work for one reason or another) The question is should the kernel work better by default *without* irqbalance loaded, or does it not matter? I don't believe we should re-enable the kernel irq balancer, but should we consider only setting a single bit in each new interrupt's irq affinity? Doing it with a random spread for the initial affinity would be better than setting them all to one.