diff options
Diffstat (limited to 'arch')
-rw-r--r-- | arch/arm/include/asm/io.h | 8 | ||||
-rw-r--r-- | arch/arm64/include/asm/io.h | 9 |
2 files changed, 17 insertions, 0 deletions
diff --git a/arch/arm/include/asm/io.h b/arch/arm/include/asm/io.h index d070741b2b37..c45effc18312 100644 --- a/arch/arm/include/asm/io.h +++ b/arch/arm/include/asm/io.h | |||
@@ -24,9 +24,11 @@ | |||
24 | #ifdef __KERNEL__ | 24 | #ifdef __KERNEL__ |
25 | 25 | ||
26 | #include <linux/types.h> | 26 | #include <linux/types.h> |
27 | #include <linux/blk_types.h> | ||
27 | #include <asm/byteorder.h> | 28 | #include <asm/byteorder.h> |
28 | #include <asm/memory.h> | 29 | #include <asm/memory.h> |
29 | #include <asm-generic/pci_iomap.h> | 30 | #include <asm-generic/pci_iomap.h> |
31 | #include <xen/xen.h> | ||
30 | 32 | ||
31 | /* | 33 | /* |
32 | * ISA I/O bus memory addresses are 1:1 with the physical address. | 34 | * ISA I/O bus memory addresses are 1:1 with the physical address. |
@@ -372,6 +374,12 @@ extern void pci_iounmap(struct pci_dev *dev, void __iomem *addr); | |||
372 | #define BIOVEC_MERGEABLE(vec1, vec2) \ | 374 | #define BIOVEC_MERGEABLE(vec1, vec2) \ |
373 | ((bvec_to_phys((vec1)) + (vec1)->bv_len) == bvec_to_phys((vec2))) | 375 | ((bvec_to_phys((vec1)) + (vec1)->bv_len) == bvec_to_phys((vec2))) |
374 | 376 | ||
377 | extern bool xen_biovec_phys_mergeable(const struct bio_vec *vec1, | ||
378 | const struct bio_vec *vec2); | ||
379 | #define BIOVEC_PHYS_MERGEABLE(vec1, vec2) \ | ||
380 | (__BIOVEC_PHYS_MERGEABLE(vec1, vec2) && \ | ||
381 | (!xen_domain() || xen_biovec_phys_mergeable(vec1, vec2))) | ||
382 | |||
375 | #ifdef CONFIG_MMU | 383 | #ifdef CONFIG_MMU |
376 | #define ARCH_HAS_VALID_PHYS_ADDR_RANGE | 384 | #define ARCH_HAS_VALID_PHYS_ADDR_RANGE |
377 | extern int valid_phys_addr_range(phys_addr_t addr, size_t size); | 385 | extern int valid_phys_addr_range(phys_addr_t addr, size_t size); |
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 | ||
269 | extern 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 */ |