Received: by 2002:a25:6193:0:0:0:0:0 with SMTP id v141csp2938237ybb; Mon, 30 Mar 2020 16:31:00 -0700 (PDT) X-Google-Smtp-Source: ADFU+vv4YXaXbkz86cbp2YUyunk1YAm/kdr6ptMSW6MFjWR6fd+zMc3vkAbPW8Z1bkqmYNr0n5c4 X-Received: by 2002:a4a:674f:: with SMTP id j15mr11595082oof.41.1585611060616; Mon, 30 Mar 2020 16:31:00 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1585611060; cv=none; d=google.com; s=arc-20160816; b=IBPkjIlktzxD/U5Et6afEvsM+btHoxFb2w1s6zy6kkMmCSV8pcEXtZRPQAngBKPFbu w+PXGI6/P3wHHXWi8+ATVf27oCyVAf44zASS6WuxfN1iWqEqGJnUs0V494BJ6yATnL2w 5awiOHMshgIHKA9qqYYxawsBgmC57loLr2dv1AqqmXJraf7y7AY/+IvYVnSkAb6lvey1 PRUYyjeRCCwZexlOHBuChmyx3lseRXUK7GzXYVCxJ5MyS2QHvPdOiimNmAmWw9tNe63o exH7/ZA0fCP9CLtdbVqH1HqgE3ZBGNuk9sT+mMtUJVKppB6bKuAiyKub6aV6sRJzXbgR lwVg== 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=RYEq35+shaNbI4+s/BVsMw50O7zERj/gEWTj5M95MIA=; b=Xqcm2brwMPmBN1cvgubra7wB5a+FgN/Sk2MDpX7F4gP36t8k6WbL5Km9KizmSY2UDy WFswDt6Pqsfbu2jAi7zzbTG3bUhpH2Uy25sTGs79hYo2uYlA0kqhj09cQQfOs0boV5e+ OLj89KBdEh/1NfdPVqhiiZ/BlvfTBM87CSwSetEQhiWLWSTQLGQjKaHzImiAuRUy73zp imxCxe1EpX2sT6TXs5P4FvwhLHQ/12cnOpgE3FuHa4+JJNT2pz83t/cUkuBgUYzeuim7 lSmk7ns1r7UNBWOz72siWxjvkQm6j5J3g0qFjA7bVYNjBs8JeL84iJlHzatwov0p1w5w J/lA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=ds1bkViW; 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 l22si5019126otd.53.2020.03.30.16.30.46; Mon, 30 Mar 2020 16:31:00 -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=ds1bkViW; 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 S1729060AbgC3XaV (ORCPT + 99 others); Mon, 30 Mar 2020 19:30:21 -0400 Received: from mail.kernel.org ([198.145.29.99]:37872 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728537AbgC3XaV (ORCPT ); Mon, 30 Mar 2020 19:30:21 -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 C926D20771; Mon, 30 Mar 2020 23:30:20 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1585611020; bh=Y7ER3dlZBrPi+ataV+7Z5F/+VEyWcrrMDkj9J6vpEeU=; h=Date:From:To:Cc:Subject:Reply-To:References:In-Reply-To:From; b=ds1bkViWG00jIm0WOighGk47cdO0TnLYGidI+AR+O21BLBm/VPEqpAxTjktw+sJlH x9QL3QfVErtrrCYvtfJbYmhb7l4+qbGZQlYkAKeVMOYTlGdCfEw/EJHQMuE7u+0zwj XFmg4lmF+NaXqODR3IIMw7HO9ZOSFLW4iSwVvajY= Received: by paulmck-ThinkPad-P72.home (Postfix, from userid 1000) id A1C903523140; Mon, 30 Mar 2020 16:30:20 -0700 (PDT) Date: Mon, 30 Mar 2020 16:30:20 -0700 From: "Paul E. McKenney" To: Will Deacon Cc: linux-kernel@vger.kernel.org, Eric Dumazet , Jann Horn , Kees Cook , Maddie Stone , Marco Elver , Peter Zijlstra , Thomas Gleixner , kernel-team@android.com, kernel-hardening@lists.openwall.com Subject: Re: [RFC PATCH 09/21] list: Remove unnecessary WRITE_ONCE() from hlist_bl_add_before() Message-ID: <20200330233020.GF19865@paulmck-ThinkPad-P72> Reply-To: paulmck@kernel.org References: <20200324153643.15527-1-will@kernel.org> <20200324153643.15527-10-will@kernel.org> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20200324153643.15527-10-will@kernel.org> 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 24, 2020 at 03:36:31PM +0000, Will Deacon wrote: > There is no need to use WRITE_ONCE() when inserting into a non-RCU > protected list. > > Cc: Paul E. McKenney > Cc: Peter Zijlstra > Signed-off-by: Will Deacon OK, I will bite... Why "unsigned long" instead of "uintptr_t"? Not that it matters in the context of the Linux kernel, so: Reviewed-by: Paul E. McKenney Thanx, Paul > --- > include/linux/list_bl.h | 6 +++--- > 1 file changed, 3 insertions(+), 3 deletions(-) > > diff --git a/include/linux/list_bl.h b/include/linux/list_bl.h > index 1804fdb84dda..c93e7e3aa8fc 100644 > --- a/include/linux/list_bl.h > +++ b/include/linux/list_bl.h > @@ -91,15 +91,15 @@ static inline void hlist_bl_add_before(struct hlist_bl_node *n, > struct hlist_bl_node *next) > { > struct hlist_bl_node **pprev = next->pprev; > + unsigned long val; > > n->pprev = pprev; > n->next = next; > next->pprev = &n->next; > > /* pprev may be `first`, so be careful not to lose the lock bit */ > - WRITE_ONCE(*pprev, > - (struct hlist_bl_node *) > - ((uintptr_t)n | ((uintptr_t)*pprev & LIST_BL_LOCKMASK))); > + val = (unsigned long)n | ((unsigned long)*pprev & LIST_BL_LOCKMASK); > + *pprev = (struct hlist_bl_node *)val; > } > > static inline void hlist_bl_add_behind(struct hlist_bl_node *n, > -- > 2.20.1 >