On Tue, Jun 07, 2011 at 03:38:35PM -0400, Vivek Goyal wrote: > On Fri, Jun 03, 2011 at 09:12:17AM -0700, Greg Thelen wrote: > > When the system is under background dirty memory threshold but a cgroup > > is over its background dirty memory threshold, then only writeback > > inodes associated with the over-limit cgroup(s). > > > > [..] > > -static inline bool over_bground_thresh(void) > > +static inline bool over_bground_thresh(struct bdi_writeback *wb, > > + struct writeback_control *wbc) > > { > > unsigned long background_thresh, dirty_thresh; > > > > global_dirty_limits(&background_thresh, &dirty_thresh); > > > > - return (global_page_state(NR_FILE_DIRTY) + > > - global_page_state(NR_UNSTABLE_NFS) > background_thresh); > > + if (global_page_state(NR_FILE_DIRTY) + > > + global_page_state(NR_UNSTABLE_NFS) > background_thresh) { > > + wbc->for_cgroup = 0; > > + return true; > > + } > > + > > + wbc->for_cgroup = 1; > > + wbc->shared_inodes = 1; > > + return mem_cgroups_over_bground_dirty_thresh(); > > } > > Hi Greg, > > So all the logic of writeout from mem cgroup works only if system is > below background limit. The moment we cross background limit, looks > like we will fall back to existing way of writting inodes? If yes, then from design point of view it is little odd that as long as we are below background limit, we share the bdi between different cgroups. The moment we are above background limit, we fall back to algorithm of sharing the disk among individual inodes and forget about memory cgroups. Kind of awkward. Thanks Vivek -- To unsubscribe from this list: send the line "unsubscribe linux-fsdevel" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html