Re: userspace irq balancer

Andrea Arcangeli (andrea@suse.de)
Tue, 27 May 2003 03:09:03 +0200


On Mon, May 26, 2003 at 05:48:41PM -0700, David S. Miller wrote:
> From: Andrea Arcangeli <andrea@suse.de>
> Date: Tue, 27 May 2003 02:41:15 +0200
>
> In 2.4 normally the softirq (of course w/o NAPI) are
> served in irq context so we didn't face this yet.
>
> Andrea, whether ksoftirqd processes the softirq work or not has
> nothing to do with what I'm talking about.
>
> It is all about what does a hardware IRQ mean in terms of work
> processed. And it can mean anything from 1 to 1000 packets worth
> of work.
>
> Therefore, any usage of hardware IRQ activity to determine "load" in
> any sense is totally inaccurate.
>
> So I'm asking you, again, how are you going to measure softirq load in
> making hardware IRQ load balancing decisions? Watching the scheduling

rdtsc could do it very well, irqs and softirqs can't be rescheduled so
you can tick measure how long you take in each cpu, same goes for each
task before migrating to another cpu (I'm only assuming this is SMP and
not AMT, still if the difference between cpu frequency among cpus isn't
huge it could stil work with AMT, a multiplicator could be applied with
AMT). This "non idle" load could be accounted in a per-cpu array.

I'm not going to implement the above in 2.4, that sounds a 2.5 thing,
but my point is that by just ignoring ksoftirqd in the idle selection
should avoid the biggest of the NAPI issues. I'm approximating, i.e.
better than nothing approch (either that or nothing). I never claimed
that to be a final golden algorihm, just obviously better than the
total-trashing one and even w/o the ksoftirqd and HT last bits, numbers
confirmed that.

And for 2.5 there are many doors open for further optimizations of
course.

> But deciding how to intepret these measurements and what to do in
> response is a userlevel policy decision. This also coincides with
> how cpufreq works.

you mean you can have slightly different modes selectable by sysctl
right? or do you really want to generate a reschedule per second with
tlb flush and microkernel API between user and kernel in turn total
waste of resources just to avoid admitting irq balancing belongs to the
kernel?

Andrea
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/