Re: [RFC PATCH 0/6] Convert all tasklets to workqueues

From: Stefan Richter
Date: Mon Jun 25 2007 - 19:39:37 EST


Ingo Molnar wrote:
> regarding workqueues - would it be possible for you to test Steve's
> patch and get us performance numbers? Do you have any test with tons of
> tasklet activity that would definitely show the performance impact of
> workqueues?

I can't speak for Kristian, nor do I have test equipment for isochronous
applications, but I know that there are people out there which do data
acquisition on as many FireWire buses as they can stuff boards into
their boxes. There are also FireWire cards with 2 or 4 controllers per
board; and each controller can receive or transmit on several channels.

Depending on the buffering scheme, there may be one (?) interrupt per
channel and isochronopus cycle. Or an interrupt when the buffer is
full. Some application programmers use large buffers; others want small
buffers. An isochronous cycle is 125us.

Asynchronous I/O can even produce much higher interrupt rates. I think
IP over 1394 might indeed cause interrupt rates that are moderately
higher than 1/125us during normal traffic. SBP-2 ( = 1394 storage) is
not as much affected because the bulk of data is transferred without
interrupts. So I suppose some eth1394 bandwidth tests with this patch
series might make sense... alas I'm short of spare time. (Would be
interesting to see whether the old ohci1394 driver is blown to bits with
the patch series; it's an old driver with who-knows what assumptions in
there.)

> Workqueue priority can be set, and your handler should
> probably be SCHED_FIFO.

Does this cooperate nicely with a SCHED_FIFO thread of a userspace data
acquisition program or audio server or the like?
--
Stefan Richter
-=====-=-=== -==- ==-=-
http://arcgraph.de/sr/
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/