Received: by 10.213.65.68 with SMTP id h4csp502517imn; Tue, 20 Mar 2018 08:22:14 -0700 (PDT) X-Google-Smtp-Source: AG47ELth5XSjngZ0rF7f7ZStYg+j7peQFVV5jw4zLcsDFlYkVIqDNVVizuI6m2vO8RMUCvdkpGG9 X-Received: by 10.99.2.202 with SMTP id 193mr2964463pgc.117.1521559334197; Tue, 20 Mar 2018 08:22:14 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1521559334; cv=none; d=google.com; s=arc-20160816; b=uoWghBvF9iJX+vk8D6mr7ejggTr6Lgmd3E4vg9kdSqCGqxJJ7oQIQe9h0HqLv5Kdtp KNHC/MfldP62eWcW61/n9Ltd80q67zAGvbAhwHt3qoHO7FJ4iwLRM1OlIEyF33TnAAI8 PXw8jCVcwJleaIu/LDUWlUcfeIzMkNDDitT8EPFoZ4eGBGTxbUcIXvuNovmL3KaM8H04 2OvMMNLNIp7CkXDfRpjlIPGb9XDbmhfe4aEd8RbQuZVegfEcEC1db4G1L565ovKqVjrm oktAzz8mw+w6KIWlraktXVU6n/w4fiuDoBscnSV9sNJoIkLZNO/JYxqXEPxw/zyd6Boy XP4w== 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:arc-authentication-results; bh=DOast0PiIs3WLZpDFGfN81gRVN/50a1+qtej77X4+4g=; b=VNWSsth2L4ibJAx4xN06bEFhKzsXrt18OlucdPvIINz1uUUNRmsoD+seGymM+M+G42 Ep6ult+qPThAvqGaAd7MXz77hhDhwoYlLPNZdP3cMUBX6eYgnYcmOs/ffz3n72cAmzJP et34/hYv9U4aw8ayjngH3eXHTKvnG6pCqMRwqBEYZXoBsQNfZVR/FTqZiysnIcXCdEuw Qr+LcUUpfdWUbUujy/5Wr4thnEBbLTlFyzkdjvcp019sVOx4UID7x93OEPk0tqSo9MWm 1sz/UDSWq7zMFtCbJZ7E+z4pkpD9CLl9TENsqW8xkiJCNWhdXasosf+uhdPQpMQKL7CN 289A== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@ziepe.ca header.s=google header.b=KoRdBO/s; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id p3-v6si1752902plo.746.2018.03.20.08.22.00; Tue, 20 Mar 2018 08:22:14 -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=@ziepe.ca header.s=google header.b=KoRdBO/s; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751718AbeCTPUw (ORCPT + 99 others); Tue, 20 Mar 2018 11:20:52 -0400 Received: from mail-wm0-f68.google.com ([74.125.82.68]:55821 "EHLO mail-wm0-f68.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751552AbeCTPUu (ORCPT ); Tue, 20 Mar 2018 11:20:50 -0400 Received: by mail-wm0-f68.google.com with SMTP id t7so4201944wmh.5 for ; Tue, 20 Mar 2018 08:20:49 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=ziepe.ca; s=google; h=date:from:to:cc:subject:message-id:references:mime-version :content-disposition:in-reply-to:user-agent; bh=DOast0PiIs3WLZpDFGfN81gRVN/50a1+qtej77X4+4g=; b=KoRdBO/sd2so0JC9vfW7LoaoOHx8hDHBTelIOyerrK5v5YNeXHiNnWYJoh5N1hc8mj NoV9ouV8FQR/3yWURqdkCjAfyf0LMpu/LuvdtvoBcjjldkEXyURcpu7ysN0+OEWQymU2 10DbHygQlWoX3tshzuAjWtiyT8sL1h+owRwhnz7Q+Osavi7E3n59RvfzD3gaITRbyEQF bqQqYe176CXjgCM50yKUnah+tOfGZy7jLcL1XiGMYIxDAM0kruwRebsJrZWB7Z1GmNNy yyT8lM01cl41LbTcItN9Lb3iunQK/Ny9FD+xQIWea074a8172s1VqAgs+CpR6eb8aem1 qSMA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:date:from:to:cc:subject:message-id:references :mime-version:content-disposition:in-reply-to:user-agent; bh=DOast0PiIs3WLZpDFGfN81gRVN/50a1+qtej77X4+4g=; b=tDQusqrCDEJc97nfVwoskEjr938inEUfXBTD5OMtqyKzTyiHY30v4FpeTx42ij4z8y fE9mVV2uIwul+S7VjmNL3rKUWrsr7iG1HPCreF5e8pVcqAtcS7FW9IEWW4LgmAnGSaRd FKshMVgn3D1/xL5Ae8LJrg0yzMmH2RRdP6d75xykQkb3tjLuNX7byMgIFKCbIe/WUPJl r4c6E5BcYE7Iu9+XbIGzuPAzUf/igJytBbM4E5AGaa+8h/R2OX0MsgEyC0IXJVCog6I4 UCaoDlyc1sxtjFDxOKyOxxa+agLqaeFiVail8kzskXRZPJYfYESFpkiK5WyaLDk7K3uY I/+w== X-Gm-Message-State: AElRT7HmbuMy3/yo6PGot8RbxMk/I67GrLjqPJKkjUmrRbEr9VFJqdFw nPbF/wqVbTHdHCFShhS+CuFlMQ== X-Received: by 10.28.113.212 with SMTP id d81mr39447wmi.88.1521559249084; Tue, 20 Mar 2018 08:20:49 -0700 (PDT) Received: from ziepe.ca (S010614cc2056d97f.ed.shawcable.net. [174.3.196.123]) by smtp.gmail.com with ESMTPSA id o12sm1928020wrf.93.2018.03.20.08.20.48 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Tue, 20 Mar 2018 08:20:48 -0700 (PDT) Received: from jgg by mlx.ziepe.ca with local (Exim 4.86_2) (envelope-from ) id 1eyJ47-0006To-Tq; Tue, 20 Mar 2018 09:20:43 -0600 Date: Tue, 20 Mar 2018 09:20:43 -0600 From: Jason Gunthorpe To: Sinan Kaya Cc: linux-rdma@vger.kernel.org, timur@codeaurora.org, sulrich@codeaurora.org, linux-arm-msm@vger.kernel.org, linux-arm-kernel@lists.infradead.org, Selvin Xavier , Devesh Sharma , Somnath Kotur , Sriharsha Basavapatna , Doug Ledford , linux-kernel@vger.kernel.org Subject: Re: [PATCH v4 1/6] RDMA/bnxt_re: Eliminate duplicate barriers on weakly-ordered archs Message-ID: <20180320152043.GK19744@ziepe.ca> References: <1521514068-8856-1-git-send-email-okaya@codeaurora.org> <1521514068-8856-2-git-send-email-okaya@codeaurora.org> <20180320144801.GE19744@ziepe.ca> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: User-Agent: Mutt/1.5.24 (2015-08-30) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Tue, Mar 20, 2018 at 10:00:49AM -0500, Sinan Kaya wrote: > On 3/20/2018 9:48 AM, Jason Gunthorpe wrote: > > On Mon, Mar 19, 2018 at 10:47:43PM -0400, Sinan Kaya wrote: > >> Code includes wmb() followed by writel(). writel() already has a barrier on > >> some architectures like arm64. > >> > >> This ends up CPU observing two barriers back to back before executing the > >> register write. > >> > >> Since code already has an explicit barrier call, changing writel() to > >> writel_relaxed(). > >> > >> Signed-off-by: Sinan Kaya > >> drivers/infiniband/hw/bnxt_re/qplib_rcfw.c | 8 ++++---- > >> 1 file changed, 4 insertions(+), 4 deletions(-) > >> > >> diff --git a/drivers/infiniband/hw/bnxt_re/qplib_rcfw.c b/drivers/infiniband/hw/bnxt_re/qplib_rcfw.c > >> index 8329ec6..4a6b981 100644 > >> +++ b/drivers/infiniband/hw/bnxt_re/qplib_rcfw.c > >> @@ -181,10 +181,10 @@ static int __send_message(struct bnxt_qplib_rcfw *rcfw, struct cmdq_base *req, > >> > >> /* ring CMDQ DB */ > >> wmb(); > >> - writel(cmdq_prod, rcfw->cmdq_bar_reg_iomem + > >> - rcfw->cmdq_bar_reg_prod_off); > >> - writel(RCFW_CMDQ_TRIG_VAL, rcfw->cmdq_bar_reg_iomem + > >> - rcfw->cmdq_bar_reg_trig_off); > >> + writel_relaxed(cmdq_prod, rcfw->cmdq_bar_reg_iomem + > >> + rcfw->cmdq_bar_reg_prod_off); > >> + writel_relaxed(RCFW_CMDQ_TRIG_VAL, rcfw->cmdq_bar_reg_iomem + > >> + rcfw->cmdq_bar_reg_trig_off); > > > > Woah, this may not be safe.. > > > > The definition of writel_relaxed() is that it is fully unordered, so > > the above two writes may change order now. Broadcom guys would have to > > ack if that it is OK or not for their hardware. > > > > In general this is not an OK approach for a mechanical > > conversion.. Only the first writel can be convereted. > > > > You need to check all your patches to make sure there are no > > subsequent writel's in the places touched. > > I paid special attention to this one and went to check the barriers > document. According to the document, writes (whether it is relaxed or not) > are always observed by the HW inorder with respect to each other. Oh interesting, that document got revised to make writel_relaxed less relaxed a few years ago, didn't know that. Thanks. However, this is still not OK, the full code is: /* ring CMDQ DB */ wmb(); writel(cmdq_prod, rcfw->cmdq_bar_reg_iomem + rcfw->cmdq_bar_reg_prod_off); writel(RCFW_CMDQ_TRIG_VAL, rcfw->cmdq_bar_reg_iomem + rcfw->cmdq_bar_reg_trig_off); done: spin_unlock_irqrestore(&cmdq->lock, flags); And the definition of _relaxed allows the writes to order outside the spinlock region, which is very likely to be wrong in this driver. I'm not sure adding a mmiowb() just to use a writel_relaxed is any sort of win though? Jason