There is no specific use-once handling for buffers so what happens is
touch_buffer->SetPageReferenced
causes all referenced buffer pages to be moved lazilly from the
inactive to active queue and unused readahead buffers to be dropped
quickly. It would be better if there were use-once handling for
buffers too, so that your dd doesn't fill up memory and cause a (still
mysterious to me) chain of events that ends up in swapping.
> I tried other more experimental patches, too:
> o_direct-10 and blkdev-pagecache-5. There was a one-liner
> reject in mm/vmscan.c after applying blkdev-pagecache-5.
>
> I fixed this and booted this new kernel, I tried the same.
> This time the page cache started to fill up but
> no swapping occured. Hm...
>
> During 'dd' starting new (I mean: not yet in the page cache)
> programs were slow as hell. Starting them second time was
> fast as expected.
The blkdev-pagecache patch is highly relevant to the discussion because
it moves the dd resource load from buffers to the page cache, changing
the behaviour of the system a great deal as you saw. I think what is
happening is, use-once makes a lot more inactive pages available from
the dd so the system sees no need to go into swap (good). But we also
lose the scanning behaviour that used to throttle the dd process. It
now picks up new IO pages so quickly that it usually wins the
competition for IO bandwidth. (N.B., this is a *theory*, measurements
needed. If it's correct then we have to look at ways to be fairer
about IO, something that's been needed for a long time anyway.)
> I tried glade with a large project file,
> loading it / looking into directories was slow at first,
> was fast second time. Since ext2 directories are in the
> page cache, this is perfectly understandable.
Yes, there is also no use-once handling for ext2 directories so the
default behaviour is to lazily activate them. Since directory pages
are never treated as use-once, and they get a default boost in priority
vs file IO. It's probably ok to just leave it that way.
> So it seems that the used-once patch works.
> The only comments is that I didn't expect it
> to start swapping with the stock pre3.
> I supposed it frees the "used-once" pages more quickly.
> Anyway I am not a VM expert and don't flame me about
> my non relevant comments. 2.4.8 seems promising :-)
A little bit of digging should answer the swapping question. Adding
use-once handling to buffers should be a one-liner, after moving the
check_used_once into a header. I'll try it first before making any
claims ;-)
-- Daniel - 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/