Re: [VM PATCH 2.6.6-rc3-bk5] Dirty balancing in the presence ofmapped pages

From: Andrew Morton
Date: Tue May 04 2004 - 21:59:25 EST


Nick Piggin <nickpiggin@xxxxxxxxxxxx> wrote:
>
> Andrew Morton wrote:
> > Shantanu Goel <sgoel01@xxxxxxxxx> wrote:
> >
> >>Presently the kernel does not collection information
> >>about the percentage of memory that processes have
> >>dirtied via mmap until reclamation. Nothing analogous
> >>to balance_dirty_pages() is being done for mmap'ed
> >>pages. The attached patch adds collection of dirty
> >>page information during kswapd() scans and initiation
> >>of background writeback by waking up bdflush.
> >
> >
> > And what were the effects of this patch?
> >
>
> I havea modified patch from Nikita that does the
> if (ptep_test_and_clear_dirty) set_page_dirty from
> page_referenced, under the page_table_lock.

Dude. I have lots of patches too. The question is: what use are they?

In this case, given that we have an actively mapped MAP_SHARED pagecache
page, marking it dirty will cause it to be written by pdflush. Even though
we're not about to reclaim it, and even though the process which is mapping
the page may well modify it again. This patch will cause additional I/O.

So we need to understand why it was written, and what effects were
observed, with what workload, and all that good stuff.

> It doesn't do the wakeup_bdflush thing, but that sounds
> like a good idea. What does wakeup_bdflush(-1) mean?

It appears that it will cause pdflush to write out down to
dirty_background_ratio.
-
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/