io-64-nonatomic: Add relaxed accessor variants
authorRobin Murphy <robin.murphy@arm.com>
Tue, 26 Apr 2016 10:38:20 +0000 (11:38 +0100)
committerWill Deacon <will.deacon@arm.com>
Tue, 3 May 2016 17:23:02 +0000 (18:23 +0100)
commite511267bc25e18926826e7cccdf7872bcbb4776a
treeae8d3be2bee8b89cfaa309a88ebd229f76b5f95c
parentf0cfffc48cac516e37711786227f6808491913a5
io-64-nonatomic: Add relaxed accessor variants

Whilst commit 9439eb3ab9d1 ("asm-generic: io: implement relaxed
accessor macros as conditional wrappers") makes the *_relaxed forms of
I/O accessors universally available to drivers, in cases where writeq()
is implemented via the io-64-nonatomic helpers, writeq_relaxed() will
end up falling back to writel() regardless of whether writel_relaxed()
is available (identically for s/write/read/).

Add corresponding relaxed forms of the nonatomic helpers to delegate
to the equivalent 32-bit accessors as appropriate. We also need to fix
io.h to avoid defining default relaxed variants if the basic accessors
themselves don't exist.

CC: Christoph Hellwig <hch@lst.de>
CC: Darren Hart <dvhart@linux.intel.com>
CC: Hitoshi Mitake <mitake.hitoshi@lab.ntt.co.jp>
Acked-by: Arnd Bergmann <arnd@arndb.de>
Signed-off-by: Robin Murphy <robin.murphy@arm.com>
Signed-off-by: Will Deacon <will.deacon@arm.com>
include/asm-generic/io.h
include/linux/io-64-nonatomic-hi-lo.h
include/linux/io-64-nonatomic-lo-hi.h