Received: by 2002:a25:7ec1:0:0:0:0:0 with SMTP id z184csp3505852ybc; Thu, 14 Nov 2019 10:06:58 -0800 (PST) X-Google-Smtp-Source: APXvYqxGW4bdyWXWr0VAI2T+JZV4oyIoBSWuFG8eomSrphxL3sUQipTJVpqAG5u9mMUzH5AlliT8 X-Received: by 2002:a7b:c1ca:: with SMTP id a10mr9865404wmj.161.1573754818681; Thu, 14 Nov 2019 10:06:58 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1573754818; cv=none; d=google.com; s=arc-20160816; b=pOQVaPw5see43TD2aQXPeWPMMJveMd+u0ycP1kGM4t4BxlpMJX/KZG39Nds/Rlrp4i Cmyi/vllK9laaf4an3360MetJ3o4cld8XoJrjQ0JVB+cW3vFlKJx/T/jJaneadk+aDkW G5923vjrN6COTjCte/PFcq6hBDwxVOlpPVPlfCtTpsd8HHm4Xq6odre2ZIxWVTvxpLOJ GW3DjNL6fWPZcTyMIoBHpLKOzc5RCDSGXULizTCREhX057V8zaE48FXxlMNwlQefbJQc 0eIuCy8t0mTWPekRF2H/7p476BBG5c4N//sJlfxO9wFcdzVcoG7co2Rw6N9scXnZrI3s NyQw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:cc:to:from:subject:references :mime-version:message-id:in-reply-to:date:dkim-signature; bh=c5ZdhZ0YGUmz1p5pK6AEd80tJtC02zu3w0ESO5REMCw=; b=BToGU1EdDF9fbTShcTXGuLqaUJU4auqyOm/uafvBOrLfZu5auNaMzKzJVYXuYwdg9U 1pb71zOuRDGcikYIVQDEBBrPMvcP6xcYXA7AQhmVm3Gpceiiz1bXWUa4ZSXHPSe43zT5 H3Jv9xsyBjCXieCz0aDEQsGjSZIRtnZWFEXuLViWBULbxCb+zth54Wc31faIxKvPaG9R EANMRu2NCWxNeixVgYNP7H6NUHbeasvnhJVPHi4rXkJo5Ny1Cw5T3uPw1qN+2rI/RdOW QPxTzXMm5+mya70QrWRdUEc1YUDOTCiZS47OKEVFTz89graIjTWnwLjM4V+Xg/Bah4fI usRg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@google.com header.s=20161025 header.b=HvmXn12w; 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=REJECT sp=REJECT dis=NONE) header.from=google.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id r7si2752578edc.451.2019.11.14.10.06.33; Thu, 14 Nov 2019 10:06:58 -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=@google.com header.s=20161025 header.b=HvmXn12w; 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=REJECT sp=REJECT dis=NONE) header.from=google.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727296AbfKNSEH (ORCPT + 99 others); Thu, 14 Nov 2019 13:04:07 -0500 Received: from mail-qk1-f202.google.com ([209.85.222.202]:42143 "EHLO mail-qk1-f202.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727146AbfKNSEG (ORCPT ); Thu, 14 Nov 2019 13:04:06 -0500 Received: by mail-qk1-f202.google.com with SMTP id p68so4505420qkf.9 for ; Thu, 14 Nov 2019 10:04:04 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=20161025; h=date:in-reply-to:message-id:mime-version:references:subject:from:to :cc; bh=c5ZdhZ0YGUmz1p5pK6AEd80tJtC02zu3w0ESO5REMCw=; b=HvmXn12wl0qX/E3Rsy6XqFvz7iTSNFZJIf1ZuTbKx3Tf8RzcRepEE5HIoqTt7DRQTD BhA9D84TWAiMyyFx8ULMX+Dm3fgOaUFKhbkkAo23XPCj17yXfdvGlxXC3T5hbr6vY+2E /+LOp1OCb1YMNQGDPTs/kvDX3vj+tn43TQfV5DRowqaLe3Rsy0CJONrwytkRB963xQt2 RhDiCzHw1wa4bGdIbJDAOtNuLIelDK4ow+jKCLXn6s6/F6/Dqiq3o5xn1VqYsLMdgaay aADxdgs93rup9XUu0H6SUFQRc26NJEOqN8mzXO6Y75vGKv4cuA3T/r8IkQiHZQ5uN5h2 exoA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:date:in-reply-to:message-id:mime-version :references:subject:from:to:cc; bh=c5ZdhZ0YGUmz1p5pK6AEd80tJtC02zu3w0ESO5REMCw=; b=prsZpGfAC9HmKDYDzaVBwOfajjXQv1DQ6R2vOA4XuedNm3kzW4Qt4Gz/ChE11w3183 oe/bDWE9sv2qzAsvKu54/xtAtKuPraUu5HjYFY4jHCxsfHfl4GEByw4drEm+DRmbIfBN 52nmbG//Ml873CxZt6SpsGcj6Bx+4YpGZQjR5hgw5Izfiq4erxWDMk33H6V3VMz0ujeB Yykgf7GuMO+FF2VB8OnqJevS6yD22Wc1ZJLgcPs1eJyMt8UlcIt7Z/FIZSf4blnw/8W1 uSj/ADkmwZNIRmlU1yLsB2kdTY/GMd1gMTZWDhx9efzyZ/KPp3GrlKie1R3Hsld3EELI GpDA== X-Gm-Message-State: APjAAAW304cA4QopHzn8vHZ1+z6HFV1aktDlcmsec3gjz3/nqowHdCOA XUJJKG2uo9xkOL1PB3E8s65MNHfKpQ== X-Received: by 2002:a05:6214:1332:: with SMTP id c18mr7908552qvv.213.1573754643719; Thu, 14 Nov 2019 10:04:03 -0800 (PST) Date: Thu, 14 Nov 2019 19:02:55 +0100 In-Reply-To: <20191114180303.66955-1-elver@google.com> Message-Id: <20191114180303.66955-3-elver@google.com> Mime-Version: 1.0 References: <20191114180303.66955-1-elver@google.com> X-Mailer: git-send-email 2.24.0.rc1.363.gb1bccd3e3d-goog Subject: [PATCH v4 02/10] include/linux/compiler.h: Introduce data_race(expr) macro From: Marco Elver To: elver@google.com Cc: akiyks@gmail.com, stern@rowland.harvard.edu, glider@google.com, parri.andrea@gmail.com, andreyknvl@google.com, luto@kernel.org, ard.biesheuvel@linaro.org, arnd@arndb.de, boqun.feng@gmail.com, bp@alien8.de, dja@axtens.net, dlustig@nvidia.com, dave.hansen@linux.intel.com, dhowells@redhat.com, dvyukov@google.com, hpa@zytor.com, mingo@redhat.com, j.alglave@ucl.ac.uk, joel@joelfernandes.org, corbet@lwn.net, jpoimboe@redhat.com, luc.maranget@inria.fr, mark.rutland@arm.com, npiggin@gmail.com, paulmck@kernel.org, peterz@infradead.org, tglx@linutronix.de, will@kernel.org, edumazet@google.com, kasan-dev@googlegroups.com, linux-arch@vger.kernel.org, linux-doc@vger.kernel.org, linux-efi@vger.kernel.org, linux-kbuild@vger.kernel.org, linux-kernel@vger.kernel.org, linux-mm@kvack.org, x86@kernel.org, Linus Torvalds Content-Type: text/plain; charset="UTF-8" Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org This introduces the data_race(expr) macro, which can be used to annotate expressions for purposes of (1) documenting, and (2) giving tooling such as KCSAN information about which data races are deemed "safe". More context: http://lkml.kernel.org/r/CAHk-=wg5CkOEF8DTez1Qu0XTEFw_oHhxN98bDnFqbY7HL5AB2g@mail.gmail.com Signed-off-by: Marco Elver Cc: Alan Stern Cc: Eric Dumazet Cc: Linus Torvalds Cc: Paul E. McKenney --- v4: * Introduce this patch to KCSAN series. --- include/linux/compiler.h | 20 ++++++++++++++++++++ 1 file changed, 20 insertions(+) diff --git a/include/linux/compiler.h b/include/linux/compiler.h index c42fa83f23fb..7d3e77781578 100644 --- a/include/linux/compiler.h +++ b/include/linux/compiler.h @@ -310,6 +310,26 @@ unsigned long read_word_at_a_time(const void *addr) __u.__val; \ }) +#include + +/* + * data_race: macro to document that accesses in an expression may conflict with + * other concurrent accesses resulting in data races, but the resulting + * behaviour is deemed safe regardless. + * + * This macro *does not* affect normal code generation, but is a hint to tooling + * that data races here should be ignored. + */ +#define data_race(expr) \ + ({ \ + typeof(({ expr; })) __val; \ + kcsan_nestable_atomic_begin(); \ + __val = ({ expr; }); \ + kcsan_nestable_atomic_end(); \ + __val; \ + }) +#else + #endif /* __KERNEL__ */ /* -- 2.24.0.rc1.363.gb1bccd3e3d-goog