From patchwork Fri Feb 22 18:04:52 2019 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Will Deacon X-Patchwork-Id: 159045 Delivered-To: patch@linaro.org Received: by 2002:a02:48:0:0:0:0:0 with SMTP id 69csp2024366jaa; Fri, 22 Feb 2019 10:05:04 -0800 (PST) X-Google-Smtp-Source: AHgI3IZOy9G9262M6+vxsec8Q40BcZozqgkzqAmlg0qbdV6/aL3TV8qJmlcbDspA+954Kx1PAYmZ X-Received: by 2002:a62:5385:: with SMTP id h127mr5391816pfb.10.1550858704694; Fri, 22 Feb 2019 10:05:04 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1550858704; cv=none; d=google.com; s=arc-20160816; b=I55H8QbX2sR5swwo7eM3MVjZsYucGP/8ecLd8q3NMdEPreTrSGjlqdW8hQNAdq6w6A TQVYiWZnXl11p0vMPTibBOzdG2i+WZHl477mk1QSeMWpds581hbbPLYfg6M+/4kTS0vl TIwMETf+KMoumkFWYGMvULd6lunDxclS1uN6Wgc92zt1ZA14LE9ximvqYqePX9woYfBC 3iE5zw6XiRylyUJr/00WOFCdMNszjyczIHWlmyfYH4MhKP+hfl/ky9MMyHVd4nF3CpQ9 d4E9JFLXySj4mQX7liv5ytE/O2qWMQBBLpWxtpIm3vY4qBMSUI+9C3tNtcNfYK9yspaZ XK3w== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:cc:to:from; bh=QMKz3vuIBIM6AojhnAMV6y5LVpSvQpMGCecyRKnRWws=; b=GGB7oKPNugJHhE7Dx7FYDSHy/XjjbIEMWv2Al64jkh6hCPOpZTiosuTZti89z/O6N4 Pm2VVLTWY3mVaXI+eQvZ6Zxzg8gjqY45AG7RTGE7a3LnoZ0huOdXEVqu1Rv36umRGH8G w2sKfKo+oOtfPX+k89+EHR5cnYTXmOffQZhKOS0rxBjaraZpflpXfabG9ISvrXrRp+ND ij5P0Z7mjci5342dhZromi/HVmLDcKtY8pmJjyY8QS6nWpy6Hv83uw36fRTPNuS0GiWv ozM5s9xn0dbcvtUJapRg3EWjmG6a/QpOgJJP7tWCX/Caov++b0RHXkQkkUzEZwKtiicA wAHg== ARC-Authentication-Results: i=1; mx.google.com; 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 v23si1894517pgn.542.2019.02.22.10.05.04; Fri, 22 Feb 2019 10:05:04 -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; 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 S1727652AbfBVSFD (ORCPT + 32 others); Fri, 22 Feb 2019 13:05:03 -0500 Received: from usa-sjc-mx-foss1.foss.arm.com ([217.140.101.70]:38156 "EHLO foss.arm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727628AbfBVSFC (ORCPT ); Fri, 22 Feb 2019 13:05:02 -0500 Received: from usa-sjc-imap-foss1.foss.arm.com (unknown [10.72.51.249]) by usa-sjc-mx-foss1.foss.arm.com (Postfix) with ESMTP id 7B479165C; Fri, 22 Feb 2019 10:05:01 -0800 (PST) Received: from fuggles.cambridge.arm.com (usa-sjc-imap-foss1.foss.arm.com [10.72.51.249]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPA id 008523F5C1; Fri, 22 Feb 2019 10:04:59 -0800 (PST) From: Will Deacon To: linux-arch@vger.kernel.org Cc: linux-kernel@vger.kernel.org, andrew.murray@arm.com, arnd@arndb.de, catalin.marinas@arm.com, geert@linux-m68k.org, palmer@sifive.com, Will Deacon Subject: [PATCH v2 1/3] asm-generic/io: Pass result of I/O accessor to __io_[p]ar() Date: Fri, 22 Feb 2019 18:04:52 +0000 Message-Id: <20190222180454.5992-2-will.deacon@arm.com> X-Mailer: git-send-email 2.11.0 In-Reply-To: <20190222180454.5992-1-will.deacon@arm.com> References: <20190222180454.5992-1-will.deacon@arm.com> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org The inX() and readX() I/O accessors must enforce ordering against subsequent calls to the delay() routines, so that a read-back from a device can be used to postpone a subsequent write to the same device. On some architectures, including arm64, this ordering can only be achieved by creating a dependency on the value returned by the I/O accessor operation, so we need to pass the value we read to the __io_par() and __io_ar() macros in these cases. Acked-by: Arnd Bergmann Reported-by: Andrew Murray Signed-off-by: Will Deacon --- include/asm-generic/io.h | 20 ++++++++++---------- 1 file changed, 10 insertions(+), 10 deletions(-) -- 2.11.0 diff --git a/include/asm-generic/io.h b/include/asm-generic/io.h index d356f802945a..303871651f8a 100644 --- a/include/asm-generic/io.h +++ b/include/asm-generic/io.h @@ -32,9 +32,9 @@ /* prevent prefetching of coherent DMA data ahead of a dma-complete */ #ifndef __io_ar #ifdef rmb -#define __io_ar() rmb() +#define __io_ar(v) rmb() #else -#define __io_ar() barrier() +#define __io_ar(v) barrier() #endif #endif @@ -65,7 +65,7 @@ #endif #ifndef __io_par -#define __io_par() __io_ar() +#define __io_par(v) __io_ar(v) #endif @@ -158,7 +158,7 @@ static inline u8 readb(const volatile void __iomem *addr) __io_br(); val = __raw_readb(addr); - __io_ar(); + __io_ar(val); return val; } #endif @@ -171,7 +171,7 @@ static inline u16 readw(const volatile void __iomem *addr) __io_br(); val = __le16_to_cpu(__raw_readw(addr)); - __io_ar(); + __io_ar(val); return val; } #endif @@ -184,7 +184,7 @@ static inline u32 readl(const volatile void __iomem *addr) __io_br(); val = __le32_to_cpu(__raw_readl(addr)); - __io_ar(); + __io_ar(val); return val; } #endif @@ -198,7 +198,7 @@ static inline u64 readq(const volatile void __iomem *addr) __io_br(); val = __le64_to_cpu(__raw_readq(addr)); - __io_ar(); + __io_ar(val); return val; } #endif @@ -471,7 +471,7 @@ static inline u8 inb(unsigned long addr) __io_pbr(); val = __raw_readb(PCI_IOBASE + addr); - __io_par(); + __io_par(val); return val; } #endif @@ -484,7 +484,7 @@ static inline u16 inw(unsigned long addr) __io_pbr(); val = __le16_to_cpu(__raw_readw(PCI_IOBASE + addr)); - __io_par(); + __io_par(val); return val; } #endif @@ -497,7 +497,7 @@ static inline u32 inl(unsigned long addr) __io_pbr(); val = __le32_to_cpu(__raw_readl(PCI_IOBASE + addr)); - __io_par(); + __io_par(val); return val; } #endif