Re: [PATCH 3/6] memcg: make throttle_vm_writeout() memcg aware

From: KAMEZAWA Hiroyuki
Date: Mon Nov 15 2010 - 23:03:14 EST


On Fri, 12 Nov 2010 12:39:35 -0800
Greg Thelen <gthelen@xxxxxxxxxx> wrote:

> > Odd branch ordering, but I may be OCDing again.
> >
> > if (mem_cgroup && memcg_dirty_info())
> > do_mem_cgroup_stuff()
> > else
> > do_global_stuff()
> >
> > would be more natural, IMO.
>
> I agree. I will resubmit this series with your improved branch ordering.
>

Hmm. I think this patch is troublesome.

This patch will make memcg's pageout routine _not_ throttoled even when the whole
system vmscan's pageout is throttoled.

So, one idea is....

Make this change
==
+++ b/mm/vmscan.c
@@ -1844,7 +1844,7 @@ static void shrink_zone(int priority, struct zone *zone,
if (inactive_anon_is_low(zone, sc))
shrink_active_list(SWAP_CLUSTER_MAX, zone, sc, priority, 0);

- throttle_vm_writeout(sc->gfp_mask);
+ throttle_vm_writeout(sc->gfp_mask, sc->mem_cgroup);
}
==
as

==

if (!sc->mem_cgroup || throttle_vm_writeout(sc->gfp_mask, sc->mem_cgroup) == not throttled)
throttole_vm_writeout(sc->gfp_mask, NULL);

Then, both of memcg and global dirty thresh will be checked.


-Kame

--
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/