ChangeSet 1.2231.1.163, 2005/03/28 20:01:45-08:00, [EMAIL PROTECTED]

        [PATCH] io_remap_pfn_range: fix some callers for XEN
        
        (from Keir:)
        I have audited the drivers/ and sound/ directories. Most uses of
        remap_pfn_range are okay, but there are a small handful that are
        remapping device memory (mostly AGP and DRM drivers).
        
        Of particular driver is the HPET driver, whose mmap function is broken 
even
        for native (non-Xen) builds.  If nothing else, vmalloc_to_phys should 
be used
        instead of __pa to convert an ioremapped virtual address to a valid 
physical
        address.  The fix in this patch is to remember the original bus address 
as
        probed at boot time and to pass this to io_remap_pfn_range.
        
        Signed-off-by: Keir Fraser <[EMAIL PROTECTED]>
        Signed-off-by: Andrew Morton <[EMAIL PROTECTED]>
        Signed-off-by: Linus Torvalds <[EMAIL PROTECTED]>



 char/agp/frontend.c |    4 ++--
 char/drm/drm_vm.c   |    2 +-
 char/drm/i810_dma.c |    2 +-
 char/drm/i830_dma.c |    2 +-
 char/hpet.c         |    6 ++++--
 sbus/char/flash.c   |    2 +-
 6 files changed, 10 insertions(+), 8 deletions(-)


diff -Nru a/drivers/char/agp/frontend.c b/drivers/char/agp/frontend.c
--- a/drivers/char/agp/frontend.c       2005-03-28 21:42:28 -08:00
+++ b/drivers/char/agp/frontend.c       2005-03-28 21:42:28 -08:00
@@ -628,7 +628,7 @@
                DBG("client vm_ops=%p", kerninfo.vm_ops);
                if (kerninfo.vm_ops) {
                        vma->vm_ops = kerninfo.vm_ops;
-               } else if (remap_pfn_range(vma, vma->vm_start,
+               } else if (io_remap_pfn_range(vma, vma->vm_start,
                                (kerninfo.aper_base + offset) >> PAGE_SHIFT,
                                            size, vma->vm_page_prot)) {
                        goto out_again;
@@ -644,7 +644,7 @@
                DBG("controller vm_ops=%p", kerninfo.vm_ops);
                if (kerninfo.vm_ops) {
                        vma->vm_ops = kerninfo.vm_ops;
-               } else if (remap_pfn_range(vma, vma->vm_start,
+               } else if (io_remap_pfn_range(vma, vma->vm_start,
                                            kerninfo.aper_base >> PAGE_SHIFT,
                                            size, vma->vm_page_prot)) {
                        goto out_again;
diff -Nru a/drivers/char/drm/drm_vm.c b/drivers/char/drm/drm_vm.c
--- a/drivers/char/drm/drm_vm.c 2005-03-28 21:42:28 -08:00
+++ b/drivers/char/drm/drm_vm.c 2005-03-28 21:42:28 -08:00
@@ -630,7 +630,7 @@
                                        vma->vm_end - vma->vm_start,
                                        vma->vm_page_prot))
 #else
-               if (remap_pfn_range(DRM_RPR_ARG(vma) vma->vm_start,
+               if (io_remap_pfn_range(vma, vma->vm_start,
                                     (VM_OFFSET(vma) + offset) >> PAGE_SHIFT,
                                     vma->vm_end - vma->vm_start,
                                     vma->vm_page_prot))
diff -Nru a/drivers/char/drm/i810_dma.c b/drivers/char/drm/i810_dma.c
--- a/drivers/char/drm/i810_dma.c       2005-03-28 21:42:28 -08:00
+++ b/drivers/char/drm/i810_dma.c       2005-03-28 21:42:28 -08:00
@@ -119,7 +119,7 @@
        buf_priv->currently_mapped = I810_BUF_MAPPED;
        unlock_kernel();
 
-       if (remap_pfn_range(DRM_RPR_ARG(vma) vma->vm_start,
+       if (io_remap_pfn_range(vma, vma->vm_start,
                             VM_OFFSET(vma) >> PAGE_SHIFT,
                             vma->vm_end - vma->vm_start,
                             vma->vm_page_prot)) return -EAGAIN;
diff -Nru a/drivers/char/drm/i830_dma.c b/drivers/char/drm/i830_dma.c
--- a/drivers/char/drm/i830_dma.c       2005-03-28 21:42:28 -08:00
+++ b/drivers/char/drm/i830_dma.c       2005-03-28 21:42:28 -08:00
@@ -121,7 +121,7 @@
        buf_priv->currently_mapped = I830_BUF_MAPPED;
        unlock_kernel();
 
-       if (remap_pfn_range(DRM_RPR_ARG(vma) vma->vm_start,
+       if (io_remap_pfn_range(vma, vma->vm_start,
                             VM_OFFSET(vma) >> PAGE_SHIFT,
                             vma->vm_end - vma->vm_start,
                             vma->vm_page_prot)) return -EAGAIN;
diff -Nru a/drivers/char/hpet.c b/drivers/char/hpet.c
--- a/drivers/char/hpet.c       2005-03-28 21:42:28 -08:00
+++ b/drivers/char/hpet.c       2005-03-28 21:42:28 -08:00
@@ -76,6 +76,7 @@
 struct hpets {
        struct hpets *hp_next;
        struct hpet __iomem *hp_hpet;
+       unsigned long hp_hpet_phys;
        struct time_interpolator *hp_interpolator;
        unsigned long hp_period;
        unsigned long hp_delta;
@@ -265,7 +266,7 @@
                return -EINVAL;
 
        devp = file->private_data;
-       addr = (unsigned long)devp->hd_hpet;
+       addr = devp->hd_hpets->hp_hpet_phys;
 
        if (addr & (PAGE_SIZE - 1))
                return -ENOSYS;
@@ -274,7 +275,7 @@
        vma->vm_page_prot = pgprot_noncached(vma->vm_page_prot);
        addr = __pa(addr);
 
-       if (remap_pfn_range(vma, vma->vm_start, addr >> PAGE_SHIFT,
+       if (io_remap_pfn_range(vma, vma->vm_start, addr >> PAGE_SHIFT,
                                        PAGE_SIZE, vma->vm_page_prot)) {
                printk(KERN_ERR "remap_pfn_range failed in hpet.c\n");
                return -EAGAIN;
@@ -795,6 +796,7 @@
 
        hpetp->hp_which = hpet_nhpet++;
        hpetp->hp_hpet = hdp->hd_address;
+       hpetp->hp_hpet_phys = hdp->hd_phys_address;
 
        hpetp->hp_ntimer = hdp->hd_nirqs;
 
diff -Nru a/drivers/sbus/char/flash.c b/drivers/sbus/char/flash.c
--- a/drivers/sbus/char/flash.c 2005-03-28 21:42:28 -08:00
+++ b/drivers/sbus/char/flash.c 2005-03-28 21:42:28 -08:00
@@ -75,7 +75,7 @@
        pgprot_val(vma->vm_page_prot) |= _PAGE_E;
        vma->vm_flags |= (VM_SHM | VM_LOCKED);
 
-       if (remap_pfn_range(vma, vma->vm_start, addr, size, vma->vm_page_prot))
+       if (io_remap_pfn_range(vma, vma->vm_start, addr, size, 
vma->vm_page_prot))
                return -EAGAIN;
                
        return 0;
-
To unsubscribe from this list: send the line "unsubscribe bk-commits-head" in
the body of a message to [EMAIL PROTECTED]
More majordomo info at  http://vger.kernel.org/majordomo-info.html

Reply via email to