From: Arnaldo Carvalho de Melo Date: Fri, 5 Jun 2026 14:17:03 +0000 (-0300) Subject: perf sched: Use thread__put() in free_idle_threads() X-Git-Tag: v7.2-rc1~60^2~105 X-Git-Url: http://git.ipfire.org/gitweb/?a=commitdiff_plain;h=a99d6394cd48fed75b1d24733d5afe6837a61a3f;p=thirdparty%2Fkernel%2Flinux.git perf sched: Use thread__put() in free_idle_threads() free_idle_threads() calls thread__delete() directly instead of thread__put(), bypassing the reference counting lifecycle. Under REFCNT_CHECKING builds, this leaks the pointer handle since thread__delete() frees the object without going through the refcount wrapper. The idle threads are created via thread__new() (refcount=1) in get_idle_thread(). Callers get additional references via thread__get() which they release with thread__put(). free_idle_threads() drops the base reference — thread__put() is the correct call, matching the thread__new() acquisition. Fixes: 49394a2a24c7 ("perf sched timehist: Introduce timehist command") Reported-by: sashiko-bot Cc: David Ahern Cc: Namhyung Kim Assisted-by: Claude:claude-opus-4.6 Signed-off-by: Arnaldo Carvalho de Melo --- diff --git a/tools/perf/builtin-sched.c b/tools/perf/builtin-sched.c index c0cd3cbb602aa..732c65008a8a5 100644 --- a/tools/perf/builtin-sched.c +++ b/tools/perf/builtin-sched.c @@ -2481,7 +2481,7 @@ static void free_idle_threads(void) if (itr) thread__put(itr->last_thread); - thread__delete(idle); + thread__put(idle); } }