xen: introduce xen_remap, use it instead of ioremap
authorStefano Stabellini <stefano.stabellini@eu.citrix.com>
Tue, 19 Feb 2013 13:59:19 +0000 (13:59 +0000)
committerKonrad Rzeszutek Wilk <konrad.wilk@oracle.com>
Wed, 20 Feb 2013 03:02:34 +0000 (22:02 -0500)
ioremap can't be used to map ring pages on ARM because it uses device
memory caching attributes (MT_DEVICE*).

Introduce a Xen specific abstraction to map ring pages, called
xen_remap, that is defined as ioremap on x86 (no behavioral changes).
On ARM it explicitly calls __arm_ioremap with the right caching
attributes: MT_MEMORY.

Signed-off-by: Stefano Stabellini <stefano.stabellini@eu.citrix.com>
Signed-off-by: Konrad Rzeszutek Wilk <konrad.wilk@oracle.com>
arch/arm/include/asm/xen/page.h
arch/x86/include/asm/xen/page.h
drivers/tty/hvc/hvc_xen.c
drivers/xen/grant-table.c
drivers/xen/xenbus/xenbus_probe.c

index c6b9096cef9593fe6508f13768802e1fba98d64c..30cdacb675af149e41a113450a7b59a3eb5ef0a2 100644 (file)
@@ -1,6 +1,7 @@
 #ifndef _ASM_ARM_XEN_PAGE_H
 #define _ASM_ARM_XEN_PAGE_H
 
+#include <asm/mach/map.h>
 #include <asm/page.h>
 #include <asm/pgtable.h>
 
@@ -86,4 +87,7 @@ static inline bool set_phys_to_machine(unsigned long pfn, unsigned long mfn)
 {
        return __set_phys_to_machine(pfn, mfn);
 }
+
+#define xen_remap(cookie, size) __arm_ioremap((cookie), (size), MT_MEMORY);
+
 #endif /* _ASM_ARM_XEN_PAGE_H */
index 472b9b783019a2e2f7c7b273ab7b13b96ec257b9..6aef9fbc09b7a48ec82c13e04b1f8c761dc34661 100644 (file)
@@ -212,4 +212,6 @@ unsigned long arbitrary_virt_to_mfn(void *vaddr);
 void make_lowmem_page_readonly(void *vaddr);
 void make_lowmem_page_readwrite(void *vaddr);
 
+#define xen_remap(cookie, size) ioremap((cookie), (size));
+
 #endif /* _ASM_X86_XEN_PAGE_H */
index 19843ec3f80aca3f467d80df57307a09a439bf80..682210d778bd05ae9dafd7779a0f189919e5f9f0 100644 (file)
@@ -230,7 +230,7 @@ static int xen_hvm_console_init(void)
        if (r < 0 || v == 0)
                goto err;
        mfn = v;
-       info->intf = ioremap(mfn << PAGE_SHIFT, PAGE_SIZE);
+       info->intf = xen_remap(mfn << PAGE_SHIFT, PAGE_SIZE);
        if (info->intf == NULL)
                goto err;
        info->vtermno = HVC_COOKIE;
index 157c0ccda3efdce0e8a3c4b9ab0937ade1d932ec..04c1b2d9b77514ca89ef1cf74d6263f5ebb93a29 100644 (file)
@@ -1147,7 +1147,7 @@ static int gnttab_setup(void)
                return gnttab_map(0, nr_grant_frames - 1);
 
        if (gnttab_shared.addr == NULL) {
-               gnttab_shared.addr = ioremap(xen_hvm_resume_frames,
+               gnttab_shared.addr = xen_remap(xen_hvm_resume_frames,
                                                PAGE_SIZE * max_nr_gframes);
                if (gnttab_shared.addr == NULL) {
                        printk(KERN_WARNING
index 038b71dbf03c980fd9024284f2e5cca1bfb3db95..3325884c693f8f1db3d94e43be43a622b857af2d 100644 (file)
@@ -769,7 +769,7 @@ static int __init xenbus_init(void)
                        goto out_error;
                xen_store_mfn = (unsigned long)v;
                xen_store_interface =
-                       ioremap(xen_store_mfn << PAGE_SHIFT, PAGE_SIZE);
+                       xen_remap(xen_store_mfn << PAGE_SHIFT, PAGE_SIZE);
                break;
        default:
                pr_warn("Xenstore state unknown\n");