aboutsummaryrefslogtreecommitdiffstats
path: root/arch/arm64/include/asm/io.h
diff options
context:
space:
mode:
authorStefano Stabellini <stefano.stabellini@eu.citrix.com>2013-10-25 06:33:26 -0400
committerStefano Stabellini <stefano.stabellini@eu.citrix.com>2013-10-25 06:33:26 -0400
commit3d1975b57097820c131c692d2e0d075641370369 (patch)
tree92784190b99b6b9e1a665a29dc2f1efb60623ff6 /arch/arm64/include/asm/io.h
parent783d0281043b9a1111d81d11ed0610b83d8857ed (diff)
arm,arm64: do not always merge biovec if we are running on Xen
This is similar to what it is done on X86: biovecs are prevented from merging otherwise every dma requests would be forced to bounce on the swiotlb buffer. Signed-off-by: Stefano Stabellini <stefano.stabellini@eu.citrix.com> Acked-by: Catalin Marinas <catalin.marinas@arm.com> Changes in v7: - remove the extra autotranslate check in biomerge.c.
Diffstat (limited to 'arch/arm64/include/asm/io.h')
-rw-r--r--arch/arm64/include/asm/io.h9
1 files changed, 9 insertions, 0 deletions
diff --git a/arch/arm64/include/asm/io.h b/arch/arm64/include/asm/io.h
index 1d12f89140ba..c163287b9871 100644
--- a/arch/arm64/include/asm/io.h
+++ b/arch/arm64/include/asm/io.h
@@ -22,11 +22,14 @@
22#ifdef __KERNEL__ 22#ifdef __KERNEL__
23 23
24#include <linux/types.h> 24#include <linux/types.h>
25#include <linux/blk_types.h>
25 26
26#include <asm/byteorder.h> 27#include <asm/byteorder.h>
27#include <asm/barrier.h> 28#include <asm/barrier.h>
28#include <asm/pgtable.h> 29#include <asm/pgtable.h>
29 30
31#include <xen/xen.h>
32
30/* 33/*
31 * Generic IO read/write. These perform native-endian accesses. 34 * Generic IO read/write. These perform native-endian accesses.
32 */ 35 */
@@ -263,5 +266,11 @@ extern int devmem_is_allowed(unsigned long pfn);
263 */ 266 */
264#define xlate_dev_kmem_ptr(p) p 267#define xlate_dev_kmem_ptr(p) p
265 268
269extern bool xen_biovec_phys_mergeable(const struct bio_vec *vec1,
270 const struct bio_vec *vec2);
271#define BIOVEC_PHYS_MERGEABLE(vec1, vec2) \
272 (__BIOVEC_PHYS_MERGEABLE(vec1, vec2) && \
273 (!xen_domain() || xen_biovec_phys_mergeable(vec1, vec2)))
274
266#endif /* __KERNEL__ */ 275#endif /* __KERNEL__ */
267#endif /* __ASM_IO_H */ 276#endif /* __ASM_IO_H */