From: Vasiliy Kulikov Date: Wed, 3 Aug 2011 18:28:26 +0000 (+0400) Subject: shm: optimize exit_shm() X-Git-Tag: firefly_0821_release~3680^2~4736 X-Git-Url: http://demsky.eecs.uci.edu/git/?a=commitdiff_plain;h=298507d4d2cf;p=firefly-linux-kernel-4.4.55.git shm: optimize exit_shm() We may optimistically check .in_use == 0 without holding the rw_mutex: it's the common case, and if it's zero, there certainly won't be any segments associated with us. After taking the lock, the idr_for_each() will do the right thing, so we could now drop the re-check inside the lock without any real cost. But it won't hurt. Signed-off-by: Vasiliy Kulikov Signed-off-by: Linus Torvalds --- diff --git a/ipc/shm.c b/ipc/shm.c index 7efff043ffbf..b5bae9d945b6 100644 --- a/ipc/shm.c +++ b/ipc/shm.c @@ -304,6 +304,9 @@ void exit_shm(struct task_struct *task) { struct ipc_namespace *ns = task->nsproxy->ipc_ns; + if (shm_ids(ns).in_use == 0) + return; + /* Destroy all already created segments, but not mapped yet */ down_write(&shm_ids(ns).rw_mutex); if (shm_ids(ns).in_use)