Memory controller: make charging gfp mask aware
Nick Piggin pointed out that swap cache and page cache addition routines could be called from non GFP_KERNEL contexts. This patch makes the charging routine aware of the gfp context. Charging might fail if the cgroup is over it's limit, in which case a suitable error is returned. This patch was tested on a Powerpc box. I am still looking at being able to test the path, through which allocations happen in non GFP_KERNEL contexts. [kamezawa.hiroyu@jp.fujitsu.com: problem with ZONE_MOVABLE] Signed-off-by:Balbir Singh <balbir@linux.vnet.ibm.com> Cc: Pavel Emelianov <xemul@openvz.org> Cc: Paul Menage <menage@google.com> Cc: Peter Zijlstra <a.p.zijlstra@chello.nl> Cc: "Eric W. Biederman" <ebiederm@xmission.com> Cc: Nick Piggin <nickpiggin@yahoo.com.au> Cc: Kirill Korotaev <dev@sw.ru> Cc: Herbert Poetzl <herbert@13thfloor.at> Cc: David Rientjes <rientjes@google.com> Cc: Vaidyanathan Srinivasan <svaidy@linux.vnet.ibm.com> Signed-off-by:
KAMEZAWA Hiroyuki <kamezawa.hiroyu@jp.fujitsu.com> Signed-off-by:
Andrew Morton <akpm@linux-foundation.org> Signed-off-by:
Linus Torvalds <torvalds@linux-foundation.org>
Showing
- include/linux/memcontrol.h 8 additions, 4 deletionsinclude/linux/memcontrol.h
- include/linux/swap.h 2 additions, 1 deletioninclude/linux/swap.h
- mm/filemap.c 1 addition, 1 deletionmm/filemap.c
- mm/memcontrol.c 17 additions, 7 deletionsmm/memcontrol.c
- mm/memory.c 5 additions, 5 deletionsmm/memory.c
- mm/migrate.c 1 addition, 1 deletionmm/migrate.c
- mm/swap_state.c 1 addition, 1 deletionmm/swap_state.c
- mm/swapfile.c 1 addition, 1 deletionmm/swapfile.c
- mm/vmscan.c 5 additions, 9 deletionsmm/vmscan.c
Loading
Please register or sign in to comment