|
Prev: [PATCH] quota: Don't call sync_fs() from vfs_quota_off() when there's no quota turn off
Next: x86: e820 unification: Extract common functions
From: KOSAKI Motohiro on 6 May 2008 07:10 on heavy workload, call_usermodehelper() may failure because it use kzmalloc(GFP_ATOMIC). but userland want receive release notificcation even heavy workload. thus, We should retry if -ENOMEM happend. Signed-off-by: KOSAKI Motohiro <kosaki.motohiro(a)jp.fujitsu.com> CC: "Paul Menage" <menage(a)google.com> CC: Li Zefan <lizf(a)cn.fujitsu.com> --- kernel/cgroup.c | 10 +++++++++- 1 file changed, 9 insertions(+), 1 deletion(-) Index: b/kernel/cgroup.c =================================================================== --- a/kernel/cgroup.c 2008-04-29 18:00:53.000000000 +0900 +++ b/kernel/cgroup.c 2008-05-06 20:28:23.000000000 +0900 @@ -3072,6 +3072,8 @@ void __css_put(struct cgroup_subsys_stat */ static void cgroup_release_agent(struct work_struct *work) { + int err; + BUG_ON(work != &release_agent_work); mutex_lock(&cgroup_mutex); spin_lock(&release_list_lock); @@ -3111,7 +3113,13 @@ static void cgroup_release_agent(struct * since the exec could involve hitting disk and hence * be a slow process */ mutex_unlock(&cgroup_mutex); - call_usermodehelper(argv[0], argv, envp, UMH_WAIT_EXEC); + +retry: + err = call_usermodehelper(argv[0], argv, envp, UMH_WAIT_EXEC); + if (err == -ENOMEM) { + schedule(); + goto retry; + } kfree(pathbuf); mutex_lock(&cgroup_mutex); spin_lock(&release_list_lock); -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo(a)vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/ |