From: Will Deacon <will.deacon@arm.com>
To: Brian Norris <computersforpeace@gmail.com>
Cc: "linux-arch@vger.kernel.org" <linux-arch@vger.kernel.org>,
"linux-kernel@vger.kernel.org" <linux-kernel@vger.kernel.org>
Subject: Re: [PATCH 16/18] x86: io: implement dummy relaxed accessor macros for writes
Date: Wed, 21 May 2014 10:22:40 +0100 [thread overview]
Message-ID: <20140521092240.GD11932@arm.com> (raw)
In-Reply-To: <20140521015327.GF22233@ld-irv-0074>
On Wed, May 21, 2014 at 02:53:27AM +0100, Brian Norris wrote:
> Hi Will,
Hello,
> On Tue, Apr 22, 2014 at 05:08:21PM +0100, Will Deacon wrote:
> > On Thu, Apr 17, 2014 at 02:44:19PM +0100, Will Deacon wrote:
> > > write{b,w,l,q}_relaxed are implemented by some architectures in order to
> > > permit memory-mapped I/O accesses with weaker barrier semantics than the
> > > non-relaxed variants.
> > >
> > > This patch adds dummy macros for the write accessors to x86, in the
> > > same vein as the dummy definitions for the relaxed read accessors.
> [...]
> > > --- a/arch/x86/include/asm/io.h
> > > +++ b/arch/x86/include/asm/io.h
> > > @@ -74,6 +74,9 @@ build_mmio_write(__writel, "l", unsigned int, "r", )
> > > #define __raw_readw __readw
> > > #define __raw_readl __readl
> > >
> > > +#define writeb_relaxed(v, a) __writeb(v, a)
> > > +#define writew_relaxed(v, a) __writew(v, a)
> > > +#define writel_relaxed(v, a) __writel(v, a)
> > > #define __raw_writeb __writeb
> > > #define __raw_writew __writew
> > > #define __raw_writel __writel
> [...]
> >
> > Actually, I should be using the regular (i.e. without the double underscore
> > prefix) accessors for the relaxed variants, including the existing read
> > flavours here. The proposed semantics are that the accessors are ordered
> > with respect to each other, which necessitates a compiler barrier.
>
> Are you planning on resubmitting this series? I've run into several
> situations in which I can't compile-test a driver on a different ARCH
> just because of this issue.
Yeah, I was just hoping for some input from Ben on the semantics I proposed.
I have a fix for the x86 patch, so I guess that justifies a v2. I'll post
something later on.
Cheers,
Will
next prev parent reply other threads:[~2014-05-21 9:22 UTC|newest]
Thread overview: 41+ messages / expand[flat|nested] mbox.gz Atom feed top
2014-04-17 13:44 [PATCH 00/18] Cross-architecture definitions of relaxed MMIO accessors Will Deacon
2014-04-17 13:44 ` [PATCH 01/18] asm-generic: io: implement relaxed accessor macros as conditional wrappers Will Deacon
2014-04-17 13:44 ` [PATCH 02/18] microblaze: io: remove dummy relaxed accessor macros Will Deacon
2014-04-22 13:53 ` Michal Simek
2014-04-17 13:44 ` [PATCH 03/18] s390: io: remove dummy relaxed accessor macros for reads Will Deacon
2014-04-17 13:44 ` [PATCH 04/18] xtensa: " Will Deacon
2014-04-17 13:44 ` [PATCH 05/18] alpha: io: implement relaxed accessor macros for writes Will Deacon
2014-04-17 13:44 ` [PATCH 06/18] frv: io: implement dummy " Will Deacon
2014-04-17 13:44 ` [PATCH 07/18] cris: " Will Deacon
2014-04-22 13:47 ` Jesper Nilsson
2014-04-17 13:44 ` [PATCH 08/18] ia64: " Will Deacon
2014-04-17 13:44 ` [PATCH 09/18] m32r: " Will Deacon
2014-04-17 13:44 ` [PATCH 10/18] m68k: " Will Deacon
2014-04-17 16:07 ` Geert Uytterhoeven
2014-04-17 13:44 ` [PATCH 11/18] mn10300: " Will Deacon
2014-04-17 13:44 ` [PATCH 12/18] parisc: " Will Deacon
2014-04-17 13:44 ` [PATCH 13/18] powerpc: " Will Deacon
2014-04-17 13:44 ` [PATCH 14/18] sparc: " Will Deacon
2014-04-17 13:44 ` [PATCH 15/18] tile: " Will Deacon
2014-04-17 14:52 ` Chris Metcalf
2014-04-17 14:52 ` Chris Metcalf
2014-04-17 13:44 ` [PATCH 16/18] x86: " Will Deacon
2014-04-22 16:08 ` Will Deacon
2014-05-21 1:53 ` Brian Norris
2014-05-21 9:22 ` Will Deacon [this message]
2014-04-17 13:44 ` [PATCH 17/18] documentation: memory-barriers: clarify relaxed io accessor semantics Will Deacon
2014-04-17 13:44 ` [PATCH 18/18] asm-generic: io: define relaxed accessor macros unconditionally Will Deacon
2014-04-22 14:09 ` Michal Simek
2014-04-22 15:18 ` Will Deacon
2014-04-23 7:12 ` Michal Simek
2014-04-23 7:23 ` Sam Ravnborg
2014-04-23 7:36 ` Michal Simek
2014-04-17 14:00 ` [PATCH 00/18] Cross-architecture definitions of relaxed MMIO accessors Peter Zijlstra
2014-04-17 14:15 ` Will Deacon
2014-04-17 21:36 ` Benjamin Herrenschmidt
2014-05-01 11:10 ` Will Deacon
2014-04-17 15:36 ` Sam Ravnborg
2014-04-17 15:47 ` Will Deacon
2014-04-17 19:15 ` Sam Ravnborg
2014-04-22 13:43 ` Will Deacon
2014-04-22 14:30 ` Sam Ravnborg
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20140521092240.GD11932@arm.com \
--to=will.deacon@arm.com \
--cc=computersforpeace@gmail.com \
--cc=linux-arch@vger.kernel.org \
--cc=linux-kernel@vger.kernel.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.