public inbox for linux-kernel@vger.kernel.org
 help / color / mirror / Atom feed
* [PATCH] pid: remove unnecessary idr_preload()
@ 2025-12-15 20:15 Tycho Andersen
  2025-12-16  9:39 ` Oleg Nesterov
  2025-12-16  9:44 ` Oleg Nesterov
  0 siblings, 2 replies; 6+ messages in thread
From: Tycho Andersen @ 2025-12-15 20:15 UTC (permalink / raw)
  To: Christian Brauner, Oleg Nesterov; +Cc: linux-kernel, Tycho Andersen (AMD)

From: "Tycho Andersen (AMD)" <tycho@kernel.org>

As near as I can tell, nothing in the second pidmap_lock critical section
actually allocates an id, so there is no need to do idr_preload().
idr_replace() does not, nor does pidfs_add_pid().

I boot tested this and built a kernel on a $large core system, so hopefully
that would have caught any errors.

Signed-off-by: Tycho Andersen (AMD) <tycho@kernel.org>
---
 kernel/pid.c | 3 ---
 1 file changed, 3 deletions(-)

diff --git a/kernel/pid.c b/kernel/pid.c
index a31771bc89c1..b0fefeb0a1ec 100644
--- a/kernel/pid.c
+++ b/kernel/pid.c
@@ -270,7 +270,6 @@ struct pid *alloc_pid(struct pid_namespace *ns, pid_t *set_tid,
 	INIT_HLIST_HEAD(&pid->inodes);
 
 	upid = pid->numbers + ns->level;
-	idr_preload(GFP_KERNEL);
 	spin_lock(&pidmap_lock);
 	if (!(ns->pid_allocated & PIDNS_ADDING))
 		goto out_unlock;
@@ -281,14 +280,12 @@ struct pid *alloc_pid(struct pid_namespace *ns, pid_t *set_tid,
 		upid->ns->pid_allocated++;
 	}
 	spin_unlock(&pidmap_lock);
-	idr_preload_end();
 	ns_ref_active_get(ns);
 
 	return pid;
 
 out_unlock:
 	spin_unlock(&pidmap_lock);
-	idr_preload_end();
 	put_pid_ns(ns);
 
 out_free:

base-commit: 8f0b4cce4481fb22653697cced8d0d04027cb1e8
-- 
2.52.0


^ permalink raw reply related	[flat|nested] 6+ messages in thread

end of thread, other threads:[~2025-12-16 15:36 UTC | newest]

Thread overview: 6+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2025-12-15 20:15 [PATCH] pid: remove unnecessary idr_preload() Tycho Andersen
2025-12-16  9:39 ` Oleg Nesterov
2025-12-16 15:35   ` Tycho Andersen
2025-12-16  9:44 ` Oleg Nesterov
2025-12-16 10:02   ` Mateusz Guzik
2025-12-16 15:36     ` Tycho Andersen

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox