Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/sys/external/bsd/drm2/dist/drm/radeon Fix little arithmetic ...



details:   https://anonhg.NetBSD.org/src/rev/b27e2b562ffc
branches:  trunk
changeset: 797733:b27e2b562ffc
user:      riastradh <riastradh%NetBSD.org@localhost>
date:      Sat Jul 26 05:23:11 2014 +0000

description:
Fix little arithmetic mistakes in radeon_gart.c.

Unlikely to fix the failing ring tests on boot, though.

diffstat:

 sys/external/bsd/drm2/dist/drm/radeon/radeon_gart.c |  22 +++++++++++++++-----
 1 files changed, 16 insertions(+), 6 deletions(-)

diffs (55 lines):

diff -r 0e0e92af3b18 -r b27e2b562ffc sys/external/bsd/drm2/dist/drm/radeon/radeon_gart.c
--- a/sys/external/bsd/drm2/dist/drm/radeon/radeon_gart.c       Sat Jul 26 04:54:20 2014 +0000
+++ b/sys/external/bsd/drm2/dist/drm/radeon/radeon_gart.c       Sat Jul 26 05:23:11 2014 +0000
@@ -262,9 +262,14 @@
     unsigned gpu_npages)
 {
 
-       if (rdev->gart.rg_table_map != NULL)
+       if (rdev->gart.rg_table_map != NULL) {
+               const unsigned entsize =
+                   rdev->gart.table_size / rdev->gart.num_gpu_pages;
+
                bus_dmamap_sync(rdev->ddev->dmat, rdev->gart.rg_table_map,
-                   gpu_pgstart*4, gpu_npages*4, BUS_DMASYNC_PREWRITE);
+                   gpu_pgstart*entsize, gpu_npages*entsize,
+                   BUS_DMASYNC_PREWRITE);
+       }
 }
 
 static void
@@ -273,9 +278,14 @@
 {
 
        membar_sync();          /* XXX overkill */
-       if (rdev->gart.rg_table_map != NULL)
+       if (rdev->gart.rg_table_map != NULL) {
+               const unsigned entsize =
+                   rdev->gart.table_size / rdev->gart.num_gpu_pages;
+
                bus_dmamap_sync(rdev->ddev->dmat, rdev->gart.rg_table_map,
-                   gpu_pgstart*4, gpu_npages*4, BUS_DMASYNC_POSTWRITE);
+                   gpu_pgstart*entsize, gpu_npages*entsize,
+                   BUS_DMASYNC_POSTWRITE);
+       }
        radeon_gart_tlb_flush(rdev);
 }
 #endif
@@ -289,7 +299,7 @@
     unsigned npages)
 {
        const unsigned gpu_per_cpu = (PAGE_SIZE / RADEON_GPU_PAGE_SIZE);
-       const unsigned gpu_npages = (npages / gpu_per_cpu);
+       const unsigned gpu_npages = (npages * gpu_per_cpu);
        const unsigned gpu_pgstart = (gpu_start / RADEON_GPU_PAGE_SIZE);
        const unsigned pgstart = (gpu_pgstart / gpu_per_cpu);
        unsigned pgno, gpu_pgno;
@@ -367,7 +377,7 @@
     unsigned npages, struct page **pages, bus_dmamap_t dmamap)
 {
        const unsigned gpu_per_cpu = (PAGE_SIZE / RADEON_GPU_PAGE_SIZE);
-       const unsigned gpu_npages = (npages / gpu_per_cpu);
+       const unsigned gpu_npages = (npages * gpu_per_cpu);
        const unsigned gpu_pgstart = (gpu_start / RADEON_GPU_PAGE_SIZE);
        const unsigned pgstart = (gpu_pgstart / gpu_per_cpu);
        unsigned pgno, gpu_pgno;



Home | Main Index | Thread Index | Old Index