Received: by 2002:a25:6193:0:0:0:0:0 with SMTP id v141csp378026ybb; Wed, 1 Apr 2020 01:39:13 -0700 (PDT) X-Google-Smtp-Source: APiQypK+12in4dvKJ/Kr20j7oZcyxsKwIpwJ4+bRInBGhV+mNiM6jK02qD8Pg+7PwN68hpv/+orZ X-Received: by 2002:a54:4f0a:: with SMTP id e10mr2028268oiy.127.1585730353061; Wed, 01 Apr 2020 01:39:13 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1585730353; cv=none; d=google.com; s=arc-20160816; b=IoMuVMpMuwSUkbwC8R2QvQcl7/GGJowg2HQhgVXoSS34XqNNMKjOECKOVzXkUyORZQ PxYdrGJTUwjfd1OvuujuVZzEBmvktEFQPKFXpJ/FYv725OamTsQezeZ/R/8VS6vNT5t3 leNMkZzY7AnXVBNhSPj50IeD5sHg836/+m7WRcCmz839LSe/l4vo4/WBQ4Bd3oopb8PT CV4Kc+s/ikYG7WXJriIVKt3ZYdjr93XsI5mI4Ay2nZDW17mEwTY3Q9qVdZ+1cNQNVkek UYrB6mQb6N8MPFUJZyBLf9RuwWMxrUi7zuHYa26XGBi0CqzMg6Gjfd2JFfcTFtx2ynIy ya9w== 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:message-id:subject:cc :to:from:date:dkim-signature; bh=Iq34dYwT2pFM9ChNu170uX954yMTayyUFQS9IB63uVc=; b=lrf0QH2IEFQbe0jzDrIrtYkRkZO3ISGxeC8RO7uLvKrYaleGRsD+HQHT3A6XOxjoo+ mDXhK1qtvT6mmvDVMGaYxOSb5Cn12qquOtn3EpV1joa5u0uD/7redsjSz7m0d+qZknlm h6dUdyjQM57Q74Fq6Cpyjxs89zkQizUsukibwDPaUhr7fCGXcOhBxkj+c9obMU9gfIZ2 2A7SNvPWJnep8BgUOj1LkkbG1GUpOmIMHaahp0pl9wEnQqThHkZLf5i/fzQgsLbcKC5/ mSH4391cgTW96wQy4tibu0BI+dxMPeAt+FL6wesIUTnhYAMz0hzjP7LzaUybCGF9/7B3 XgDw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=J2s9ykdX; 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 w129si590143oia.232.2020.04.01.01.39.00; Wed, 01 Apr 2020 01:39:13 -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=J2s9ykdX; 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 S1730821AbgDAIiY (ORCPT + 99 others); Wed, 1 Apr 2020 04:38:24 -0400 Received: from mail.kernel.org ([198.145.29.99]:48210 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726536AbgDAIiY (ORCPT ); Wed, 1 Apr 2020 04:38:24 -0400 Received: from willie-the-truck (236.31.169.217.in-addr.arpa [217.169.31.236]) (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 75CF82073B; Wed, 1 Apr 2020 08:38:22 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1585730303; bh=Bvhmmc0BPGknPaf0rghM2JRllR9P2T5itF8OtzXxVa4=; h=Date:From:To:Cc:Subject:References:In-Reply-To:From; b=J2s9ykdXJR83vU5mD6OAAenGxi5Bw2B/QKskuClc1jza0jHl4blJXrDruApIoiNgN IVIMXXI/VarPS8bmC4RFYcQJu2Rrc+i/0nIrN6/uGlt54YRZuGI5y5XylmsEd0mchJ tqvVb/cwwDMpD1Q1wXn+9j0WTJFPOWJGSOUsbJ7o= Date: Wed, 1 Apr 2020 09:38:19 +0100 From: Will Deacon To: Marco Elver Cc: paulmck@kernel.org, dvyukov@google.com, glider@google.com, andreyknvl@google.com, cai@lca.pw, kasan-dev@googlegroups.com, linux-kernel@vger.kernel.org Subject: Re: [PATCH 2/2] kcsan: Change data_race() to no longer require marking racing accesses Message-ID: <20200401083818.GA16446@willie-the-truck> References: <20200331193233.15180-1-elver@google.com> <20200331193233.15180-2-elver@google.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20200331193233.15180-2-elver@google.com> User-Agent: Mutt/1.10.1 (2018-07-13) 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:33PM +0200, Marco Elver wrote: > Thus far, accesses marked with data_race() would still require the > racing access to be marked in some way (be it with READ_ONCE(), > WRITE_ONCE(), or data_race() itself), as otherwise KCSAN would still > report a data race. This requirement, however, seems to be unintuitive, > and some valid use-cases demand *not* marking other accesses, as it > might hide more serious bugs (e.g. diagnostic reads). > > Therefore, this commit changes data_race() to no longer require marking > racing accesses (although it's still recommended if possible). > > The alternative would have been introducing another variant of > data_race(), however, since usage of data_race() already needs to be > carefully reasoned about, distinguishing between these cases likely adds > more complexity in the wrong place. Just a thought, but perhaps worth extending scripts/checkpatch.pl to check for use of data_race() without a comment? We already have that for memory barriers, so should be easy enough to extend with any luck. > Link: https://lkml.kernel.org/r/20200331131002.GA30975@willie-the-truck > Signed-off-by: Marco Elver > Cc: Paul E. McKenney > Cc: Will Deacon > Cc: Qian Cai > --- > include/linux/compiler.h | 4 ++-- > 1 file changed, 2 insertions(+), 2 deletions(-) > > diff --git a/include/linux/compiler.h b/include/linux/compiler.h > index f504edebd5d7..1729bd17e9b7 100644 > --- a/include/linux/compiler.h > +++ b/include/linux/compiler.h > @@ -326,9 +326,9 @@ unsigned long read_word_at_a_time(const void *addr) > #define data_race(expr) \ > ({ \ > typeof(({ expr; })) __val; \ > - kcsan_nestable_atomic_begin(); \ > + kcsan_disable_current(); \ > __val = ({ expr; }); \ > - kcsan_nestable_atomic_end(); \ > + kcsan_enable_current(); \ > __val; \ > }) > #else Acked-by: Will Deacon Will