Received: by 2002:a25:8b91:0:0:0:0:0 with SMTP id j17csp5161103ybl; Tue, 4 Feb 2020 08:47:22 -0800 (PST) X-Google-Smtp-Source: APXvYqzyv4hHzLCOnSlnYgdXiP6TOaL+OzAcafiVlUFSgBu2/Ty3h/tAzr/sOZjb3KkGERm+76/L X-Received: by 2002:aca:dd05:: with SMTP id u5mr4065715oig.91.1580834842030; Tue, 04 Feb 2020 08:47:22 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1580834842; cv=none; d=google.com; s=arc-20160816; b=Ub/GlVjOPy1wUhjAPqqHX0meSxodVfD5ICXtjXA6n9yxuOAFyDsujpWpEHFKi2uHIO 4M9qPiL/0EMPqF2pMyBV6YxZ+4Y0QO1zhx16MBFfiHJVlsoz8THlGU6Q7cXVuPFSCewI eXuIcvTnbSmEAFJ8bwNnviH2ttAzDWJNyxpdc0CPf1ar5Zuv5Z7RBKcyxLu4R0oJR8Gm WO+nBXWDy0OhYNaeHl9W7PTHIz6wthstM2bylg37CsGdHIOvmX1yi/WCc2gMZ1J0O/IF yXpIps2TBJBblp0eTwRESUHQKVli20UKdRLTVk1xEtPdWFxRBhvnkoOhl9lWjiqBy3KV 0MXw== 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 :message-id:date:subject:cc:to:from:dkim-signature; bh=LvcrkfGVaVyqYp3PxmtymjbwEQgZobmEwUEZg9FpGaA=; b=DnGJrB61HiTlQaoYeQr4wClSFxP0GKM3y/keihsYMx4oVYyNd+xPTKVAPbpYe/1FDF zs41ePje6YNRhhCSMcKzFQMGePOWqxnAJ1xoo31CzvetjeF+KrKTLktP+hRJgIcOwvWb 5/MvVBsMEWbOWhZVo2A4Y9j2MPsplmNE8qPMQ6KoYho/klPj6LiKwUpWAQOQnpLpBWW9 WuhSl/92Fvll2eofyUSYTuV2EbRWQD30uF1GdlAtw4aNGUN39pZuwvqhDIa7wR3YWQXH a5mUKt+Vht9CZemj0hp9phrZv1PzQf4+v5guDx0wOq0y4mWyIMnZQ5dC9Nc0t7OO75iq IX7w== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=amxR0ufk; 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; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id l6si11859265otk.134.2020.02.04.08.47.08; Tue, 04 Feb 2020 08:47:22 -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=@gmail.com header.s=20161025 header.b=amxR0ufk; 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; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727386AbgBDQpF (ORCPT + 99 others); Tue, 4 Feb 2020 11:45:05 -0500 Received: from mail-pj1-f67.google.com ([209.85.216.67]:39722 "EHLO mail-pj1-f67.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727330AbgBDQpF (ORCPT ); Tue, 4 Feb 2020 11:45:05 -0500 Received: by mail-pj1-f67.google.com with SMTP id e9so1620566pjr.4 for ; Tue, 04 Feb 2020 08:45:05 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=from:to:cc:subject:date:message-id:mime-version :content-transfer-encoding; bh=LvcrkfGVaVyqYp3PxmtymjbwEQgZobmEwUEZg9FpGaA=; b=amxR0ufkthyJ0qvUGfISZjnp12D/UvujELNV7hj5l8NXTqN820SVKf/An6xueYxnsH WdsRKO/8Td+kLoM3zPJDXTvoRbt4DG7nobx+aEgd/navqMRUTcHZzXTJyrtr7tjICBWZ bS+5PzBtocw+xfxt65j0iA19ssjA0oXicVwyqvlyTqKgHocHNHMF0Kd+kd7wUk1/6NM5 OBO8KU5gmYe4Ppnh3t+x/3uobPYNAlXP0cgafOUYmLtu6o/YytKdTeGjRbliY7DT+HUa oV0cwktplTjylwHI4Wuzu4vXKWW1wvaXzvqbjqZ+w3Cj4qw8gD6yG8A+4QeCxzBGIMbx WaUw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:mime-version :content-transfer-encoding; bh=LvcrkfGVaVyqYp3PxmtymjbwEQgZobmEwUEZg9FpGaA=; b=eZEc+DrPUrNLIdE9qulTF63onKSWFdgHHZZflkGjG2krSkKsRMVabiZSwwtMPbppJL rwuWavt3h0zC2C7mmB6/fXQeceS6u0R4ZV73nzxYKb1sWzgBZDIkKqaPQukoVXVONyxq dZjj0da7CYJVCopVqNbk9qW3SBEhkXbeOl0Ibxn+B2TUPufcdr1nggBobO13KT8yI/bI 3jdrAVgpDsMN1TLwmDnrPfHPGFMoygBnC3nYhVkF4pw9YpxV5UKaudYdXD6/E7K+/QKU TZrtDa0cCcQJisT2Rla2ybw7XScW9F0sX93VzA3D4+oIFgxeHGBwfyDbb/ZlblkdkPh/ PLLQ== X-Gm-Message-State: APjAAAUlIkfiddyvBeNkhWTpWY8nNykxrrDWi4NY1KhU2M7f3cJV3mij +Kb5qMSffLVMOcIxCG68eDE= X-Received: by 2002:a17:902:7406:: with SMTP id g6mr30734580pll.103.1580834704599; Tue, 04 Feb 2020 08:45:04 -0800 (PST) Received: from localhost.localdomain ([146.196.37.61]) by smtp.googlemail.com with ESMTPSA id ci5sm4266173pjb.5.2020.02.04.08.45.01 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 04 Feb 2020 08:45:04 -0800 (PST) From: Amol Grover To: Steven Rostedt , Ingo Molnar Cc: linux-kernel@vger.kernel.org, linux-kernel-mentees@lists.linuxfoundation.org, Joel Fernandes , Madhuparna Bhowmik , "Paul E . McKenney" , Amol Grover Subject: [PATCH v2] tracing: Annotate ftrace_graph_hash pointer with __rcu Date: Tue, 4 Feb 2020 22:13:01 +0530 Message-Id: <20200204164300.15297-1-frextrite@gmail.com> X-Mailer: git-send-email 2.24.1 MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Fix following instances of sparse error kernel/trace/ftrace.c:5664:29: error: incompatible types in comparison kernel/trace/ftrace.c:5785:21: error: incompatible types in comparison kernel/trace/ftrace.c:5864:36: error: incompatible types in comparison kernel/trace/ftrace.c:5866:25: error: incompatible types in comparison Use rcu_dereference_sched to dereference the __rcu annotated pointer. Signed-off-by: Amol Grover --- v2: - Use rcu_dereference_sched instead of rcu_dereference_protected kernel/trace/ftrace.c | 2 +- kernel/trace/trace.h | 9 ++++++--- 2 files changed, 7 insertions(+), 4 deletions(-) diff --git a/kernel/trace/ftrace.c b/kernel/trace/ftrace.c index 9bf1f2cd515e..959ded08dc13 100644 --- a/kernel/trace/ftrace.c +++ b/kernel/trace/ftrace.c @@ -5596,7 +5596,7 @@ static const struct file_operations ftrace_notrace_fops = { static DEFINE_MUTEX(graph_lock); -struct ftrace_hash *ftrace_graph_hash = EMPTY_HASH; +struct ftrace_hash __rcu *ftrace_graph_hash = EMPTY_HASH; struct ftrace_hash *ftrace_graph_notrace_hash = EMPTY_HASH; enum graph_filter_type { diff --git a/kernel/trace/trace.h b/kernel/trace/trace.h index 63bf60f79398..7253e8251f50 100644 --- a/kernel/trace/trace.h +++ b/kernel/trace/trace.h @@ -950,22 +950,25 @@ extern void __trace_graph_return(struct trace_array *tr, unsigned long flags, int pc); #ifdef CONFIG_DYNAMIC_FTRACE -extern struct ftrace_hash *ftrace_graph_hash; +extern struct ftrace_hash __rcu *ftrace_graph_hash; extern struct ftrace_hash *ftrace_graph_notrace_hash; static inline int ftrace_graph_addr(struct ftrace_graph_ent *trace) { unsigned long addr = trace->func; int ret = 0; + struct ftrace_hash *hash; preempt_disable_notrace(); - if (ftrace_hash_empty(ftrace_graph_hash)) { + hash = rcu_dereference_sched(ftrace_graph_hash); + + if (ftrace_hash_empty(hash)) { ret = 1; goto out; } - if (ftrace_lookup_ip(ftrace_graph_hash, addr)) { + if (ftrace_lookup_ip(hash, addr)) { /* * This needs to be cleared on the return functions -- 2.24.1