Received: by 2002:a25:6193:0:0:0:0:0 with SMTP id v141csp9142ybb; Tue, 31 Mar 2020 15:57:02 -0700 (PDT) X-Google-Smtp-Source: APiQypJuHveaQWkKCDt7IC6upO+6f+jYs3w5WTl6in0ouh5Y+fIU2ztCKkBgJNNZjXLcev3n8vYI X-Received: by 2002:a54:4416:: with SMTP id k22mr927675oiw.34.1585695421651; Tue, 31 Mar 2020 15:57:01 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1585695421; cv=none; d=google.com; s=arc-20160816; b=efz6u2FFEjm7LmNElqEAtCzBQupo0Mld48opKDUhe0qOsqV0mocZOD3dY3ILoOUqTa lmouq6BBNl+mncor3JlZGi0wHUeBbPIyKxdD3s0iINeAFXZPyge7eyGxmHbQz87UZ13z +40oSSj07B3s0jpP91MoGyoAXIRnzJF+9Ndf2P+pGz81Kw+ev93o2JtGYvPjkdbZADl1 5C5mgUwu9sAcdRdwSFgs08kONSR6RCQkAzIrLiB1+PKqQFPMB5TrS9D3/Z1LBOWYahN8 Y9oYKv3W5UVyCA6Mr73xgqUjny3bQZpxnczuakUdkdOnoOrw5xW9Uccm54lWws8YyDoG vn6A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-disposition:mime-version:references:reply-to:message-id :subject:cc:to:from:date:dkim-signature; bh=lYg8gNXt5ClnOyxIU7EsBTAYczICzaib9zDIlyXepu4=; b=tNPwUbZ6ySTHnQFQ5mkeA9C/LnTOvS+oCBecIA4MOHdryJJwb9ZI6OqIUcKZsgbQEu Dv7kP/bMOea5O7cgHDHANqbSrgTVV1c1O5e2kUSUjWfCFtA6C31848tAqFrHzQjnKFOz HVTOL6t8Prppt/w8XCNwQH1KMMC13wZmiSRpdu16FJmiB5DYN5nFACAUrvxWDk8tLku/ e54H6eNUoVYcaYyci3zPX7Li7Xmvl7YNZlYJFe1utQFHqkHpCxVZoT4yS7MgbD1Fdfta GUug89txEoAcMYLMq0/sZgKgAxsXpioe0HbKEK6rEYEUKiRqlhsPP2e5YGakGGf2u9sZ maTQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b="mphGjb/g"; 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=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id f46si5967otf.146.2020.03.31.15.56.46; Tue, 31 Mar 2020 15:57:01 -0700 (PDT) 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="mphGjb/g"; 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=NONE dis=NONE) header.from=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1731424AbgCaWz4 (ORCPT + 99 others); Tue, 31 Mar 2020 18:55:56 -0400 Received: from mail.kernel.org ([198.145.29.99]:38030 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1729647AbgCaWz4 (ORCPT ); Tue, 31 Mar 2020 18:55:56 -0400 Received: from paulmck-ThinkPad-P72.home (50-39-105-78.bvtn.or.frontiernet.net [50.39.105.78]) (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 2DA78206DB; Tue, 31 Mar 2020 22:55:55 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1585695355; bh=Hgz8pxepgCf9r4NaWuQuFrYbzsS9dEwa9nTPm+PnFJ4=; h=Date:From:To:Cc:Subject:Reply-To:References:In-Reply-To:From; b=mphGjb/gwWL9k4bNSKEo1yguKtZKHSNoMaZ9Ipu6Y9VuB+6N84nNjTrqkqxsULwVL OE5vpZ6VQI6XiuBUpl8e4R5IV5DkyUdRFM5JXswMNoIllXKK4Jm8KXkC67adRIWagy QzaTnkxonk+XexJDqazhdfu3LEn3khJgVA8Pzz4Y= Received: by paulmck-ThinkPad-P72.home (Postfix, from userid 1000) id 05B7A352279F; Tue, 31 Mar 2020 15:55:55 -0700 (PDT) Date: Tue, 31 Mar 2020 15:55:55 -0700 From: "Paul E. McKenney" To: Marco Elver Cc: dvyukov@google.com, glider@google.com, andreyknvl@google.com, cai@lca.pw, kasan-dev@googlegroups.com, linux-kernel@vger.kernel.org Subject: Re: [PATCH 1/2] kcsan: Move kcsan_{disable,enable}_current() to kcsan-checks.h Message-ID: <20200331225554.GA28283@paulmck-ThinkPad-P72> Reply-To: paulmck@kernel.org References: <20200331193233.15180-1-elver@google.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20200331193233.15180-1-elver@google.com> User-Agent: Mutt/1.9.4 (2018-02-28) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Tue, Mar 31, 2020 at 09:32:32PM +0200, Marco Elver wrote: > Both affect access checks, and should therefore be in kcsan-checks.h. > This is in preparation to use these in compiler.h. > > Signed-off-by: Marco Elver The two of these do indeed make data_race() act more like one would expect, thank you! I have queued them for further testing and review. Thanx, Paul > --- > include/linux/kcsan-checks.h | 16 ++++++++++++++++ > include/linux/kcsan.h | 16 ---------------- > 2 files changed, 16 insertions(+), 16 deletions(-) > > diff --git a/include/linux/kcsan-checks.h b/include/linux/kcsan-checks.h > index 101df7f46d89..ef95ddc49182 100644 > --- a/include/linux/kcsan-checks.h > +++ b/include/linux/kcsan-checks.h > @@ -36,6 +36,20 @@ > */ > void __kcsan_check_access(const volatile void *ptr, size_t size, int type); > > +/** > + * kcsan_disable_current - disable KCSAN for the current context > + * > + * Supports nesting. > + */ > +void kcsan_disable_current(void); > + > +/** > + * kcsan_enable_current - re-enable KCSAN for the current context > + * > + * Supports nesting. > + */ > +void kcsan_enable_current(void); > + > /** > * kcsan_nestable_atomic_begin - begin nestable atomic region > * > @@ -133,6 +147,8 @@ void kcsan_end_scoped_access(struct kcsan_scoped_access *sa); > static inline void __kcsan_check_access(const volatile void *ptr, size_t size, > int type) { } > > +static inline void kcsan_disable_current(void) { } > +static inline void kcsan_enable_current(void) { } > static inline void kcsan_nestable_atomic_begin(void) { } > static inline void kcsan_nestable_atomic_end(void) { } > static inline void kcsan_flat_atomic_begin(void) { } > diff --git a/include/linux/kcsan.h b/include/linux/kcsan.h > index 17ae59e4b685..53340d8789f9 100644 > --- a/include/linux/kcsan.h > +++ b/include/linux/kcsan.h > @@ -50,25 +50,9 @@ struct kcsan_ctx { > */ > void kcsan_init(void); > > -/** > - * kcsan_disable_current - disable KCSAN for the current context > - * > - * Supports nesting. > - */ > -void kcsan_disable_current(void); > - > -/** > - * kcsan_enable_current - re-enable KCSAN for the current context > - * > - * Supports nesting. > - */ > -void kcsan_enable_current(void); > - > #else /* CONFIG_KCSAN */ > > static inline void kcsan_init(void) { } > -static inline void kcsan_disable_current(void) { } > -static inline void kcsan_enable_current(void) { } > > #endif /* CONFIG_KCSAN */ > > -- > 2.26.0.rc2.310.g2932bb562d-goog >