Re: 2.6.12-rc2-mm3

From: Andrew Morton
Date: Tue Apr 12 2005 - 01:28:33 EST


Nick Piggin <nickpiggin@xxxxxxxxxxxx> wrote:
>
> >- The effects of tcq on AS are much less disastrous than I thought they
> > were. Do I have the wrong workload? Memory fails me. Or did we fix the
> > anticipatory scheduler?
> >
> >
>
> Yes, we did fix it ;)
> Quite a long time ago, so maybe you are thinking of something else
> (I haven't been able to work it out).

Steve Pratt's ols2004 presentation made AS look pretty bad. However the
numbers in the proceedings
(http://www.finux.org/proceedings/LinuxSymposium2004_V2.pdf) are much less
stark.

Steve, what's up with that? The slides which you talked to had some awful
numbers. Was it the same set of tests?

Seems that software RAID might have muddied the waters as well.

That was 2.6.5. Do you recall if we did significant AS work after that?

> AS basically does its own TCQ strangulation, which IIRC involves things
> like completing all reads before issuing new writes, and completing all
> reads from one process before reads from another. As well as the
> fundamental way that waiting for a 'dependant read' throttles TCQ.

My (mpt-fusion-based) workstation is still really slow when there's a lot
of writeout happening. Just from a quick test:

> 2.6.12-rc2, as, tcq depth=2: 7.241 seconds
> 2.6.12-rc2, as, tcq depth=64: 12.172 seconds
> 2.6.12-rc2+patch,as, tcq depth=64: 7.199 seconds
> 2.6.12-rc2, cfq2, tcq depth=64: much more than 5 minutes
> 2.6.12-rc2, cfq3, tcq depth=64: much more than 5 minutes

2.6.11-rc4-mm1, as, mpt-f 39.349 seconds

That was really really slow but had a sudden burst of read I/O at the end
which made the thing look better than it really is. I wouldn't have a clue
what tag depth it's using, and it's the only mpt-fusion based machine I
have handy...

> >- as-limit-queue-depth.patch fixes things right up anyway. Seems to be
> > doing the right thing.
> >
> >
>
> Well it depends on what we want to do. If we hard limit the AS queue
> like this, I can remove some of that TCQ throttling logic from AS.
>
> OTOH, the throttling was intended to allow us to sanely use a large
> TCQ depth without getting really bad behaviour. Theoretically a process
> can make use of TCQ if it is doing a lot of writing, or if it is not
> determined to be doing dependant reads.

OK, I'll have a bit more of a poke at the LSI53C1030 driver, see if I can
characterise what's going on.
-
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/