Received: by 2002:a25:1506:0:0:0:0:0 with SMTP id 6csp1586504ybv; Thu, 20 Feb 2020 23:47:48 -0800 (PST) X-Google-Smtp-Source: APXvYqy2S1hdKLPvQzB0HLJOcMJrwtFhio17KkOqbtvhz0ZFFoC7xFqlGAbD9pJU8uj7rNPK7Kou X-Received: by 2002:a9d:68c8:: with SMTP id i8mr27751629oto.34.1582271268837; Thu, 20 Feb 2020 23:47:48 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1582271268; cv=none; d=google.com; s=arc-20160816; b=Y3gfw3AEB9Cr5uSvfmKRpKxs+C/u3ITTlSPL0gMcp6t1Uao09dDesG5Twuusq1R9wK ftuuhHszIChAyfxvbhYye4S00v0C++uuQjK4ABSZlE7QzGDjkiP7J5AXxtjzz7Zen8mj sphU6+mVVZ480j52OFrixZy9/j9GpF6uaL2piC1c+xYG8UNW0dZ5y6zA+GHjQgaKXyYI KCueaKGGzp+pjDq0xobWYcnWgq/h6eApiu0vp7W47up9miK3ZCU439OtNHe/tws9e+hA DV2GplVyFfS+S/pD5z7J00YDunDV2QHctUop9RMXAr1aAVfy/ObZT/3Ws4b2x6e/4n1l E8zg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=+1xa1RPBLSrEAXzJh1szA1WDD3Yb30PfdEtasq9iqdI=; b=ROhsMoiQcQneecJvvSGCA8AU4B0zUjdWwAaNhonygMc+IjjTco726FXA6L9Q5zveL0 KwD+qqHnuFFltko7U9HIb7e+viv9atWTpyczvbllP/It/F0YavuSunZx4Bm4DS1lOeS+ ljAPeWz0WTev6/WUQFdk01RHpYeS5Eu759b9LNeX8JYQCghUUrl8drJ1LVR8qJZRFiN/ LQDpkZQYorR7V1pNhLcnTmizzSD1vU4aeKQ4/ljJ8buTOlbqRhXYMI5pVAfoCELRHWp+ vAOTRUxPCzDhGoRVPbzmTBvfuhaQQ0G9//a3qSK/81YIIrX3qDHv02fhw7+pdSBd6Jw0 J2nQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=behkCGRp; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id p186si406453oih.172.2020.02.20.23.47.36; Thu, 20 Feb 2020 23:47:48 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=behkCGRp; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728844AbgBUHrF (ORCPT + 99 others); Fri, 21 Feb 2020 02:47:05 -0500 Received: from mail.kernel.org ([198.145.29.99]:42740 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728822AbgBUHrA (ORCPT ); Fri, 21 Feb 2020 02:47:00 -0500 Received: from localhost (83-86-89-107.cable.dynamic.v4.ziggo.nl [83.86.89.107]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id ACD96207FD; Fri, 21 Feb 2020 07:46:58 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1582271219; bh=pLJCGtZcjLiobK2gEsIKM9UHD7ehVNhOeVs1OuvPnhQ=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=behkCGRpT507GLEI3ABuIzzSyspSm65UJ4q1lFIvltLtCT5HHG82ZflrxaE6nzw66 BlG5mLmuBgxLR2Y6RJ4lc7j+/QO/bRItTl/XlkjMwKAILFq2vTwE/bqnKRex3wQ1S2 6W46aDXvdb3dZC+d/JYCgYw96BNYcb3ctHM1wZK0= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Luis Henriques , "Steven Rostedt (VMware)" , Sasha Levin Subject: [PATCH 5.5 084/399] tracing: Fix very unlikely race of registering two stat tracers Date: Fri, 21 Feb 2020 08:36:49 +0100 Message-Id: <20200221072410.512550892@linuxfoundation.org> X-Mailer: git-send-email 2.25.1 In-Reply-To: <20200221072402.315346745@linuxfoundation.org> References: <20200221072402.315346745@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Steven Rostedt (VMware) [ Upstream commit dfb6cd1e654315168e36d947471bd2a0ccd834ae ] Looking through old emails in my INBOX, I came across a patch from Luis Henriques that attempted to fix a race of two stat tracers registering the same stat trace (extremely unlikely, as this is done in the kernel, and probably doesn't even exist). The submitted patch wasn't quite right as it needed to deal with clean up a bit better (if two stat tracers were the same, it would have the same files). But to make the code cleaner, all we needed to do is to keep the all_stat_sessions_mutex held for most of the registering function. Link: http://lkml.kernel.org/r/1410299375-20068-1-git-send-email-luis.henriques@canonical.com Fixes: 002bb86d8d42f ("tracing/ftrace: separate events tracing and stats tracing engine") Reported-by: Luis Henriques Signed-off-by: Steven Rostedt (VMware) Signed-off-by: Sasha Levin --- kernel/trace/trace_stat.c | 19 +++++++++---------- 1 file changed, 9 insertions(+), 10 deletions(-) diff --git a/kernel/trace/trace_stat.c b/kernel/trace/trace_stat.c index 2b4d6e674d876..d1fa19773cc8e 100644 --- a/kernel/trace/trace_stat.c +++ b/kernel/trace/trace_stat.c @@ -308,7 +308,7 @@ static int init_stat_file(struct stat_session *session) int register_stat_tracer(struct tracer_stat *trace) { struct stat_session *session, *node; - int ret; + int ret = -EINVAL; if (!trace) return -EINVAL; @@ -319,17 +319,15 @@ int register_stat_tracer(struct tracer_stat *trace) /* Already registered? */ mutex_lock(&all_stat_sessions_mutex); list_for_each_entry(node, &all_stat_sessions, session_list) { - if (node->ts == trace) { - mutex_unlock(&all_stat_sessions_mutex); - return -EINVAL; - } + if (node->ts == trace) + goto out; } - mutex_unlock(&all_stat_sessions_mutex); + ret = -ENOMEM; /* Init the session */ session = kzalloc(sizeof(*session), GFP_KERNEL); if (!session) - return -ENOMEM; + goto out; session->ts = trace; INIT_LIST_HEAD(&session->session_list); @@ -338,15 +336,16 @@ int register_stat_tracer(struct tracer_stat *trace) ret = init_stat_file(session); if (ret) { destroy_session(session); - return ret; + goto out; } + ret = 0; /* Register */ - mutex_lock(&all_stat_sessions_mutex); list_add_tail(&session->session_list, &all_stat_sessions); + out: mutex_unlock(&all_stat_sessions_mutex); - return 0; + return ret; } void unregister_stat_tracer(struct tracer_stat *trace) -- 2.20.1