Module Name: src Committed By: riastradh Date: Mon Aug 27 13:56:09 UTC 2018
Modified Files: src/sys/external/bsd/drm2/dist/drm/radeon: radeon_gart.c Log Message: GART might not be mapped with bus_dma. Still need membar and tlb flush in that case. To generate a diff of this commit: cvs rdiff -u -r1.8 -r1.9 \ src/sys/external/bsd/drm2/dist/drm/radeon/radeon_gart.c Please note that diffs are not public domain; they are subject to the copyright notices on the relevant files.
Modified files: Index: src/sys/external/bsd/drm2/dist/drm/radeon/radeon_gart.c diff -u src/sys/external/bsd/drm2/dist/drm/radeon/radeon_gart.c:1.8 src/sys/external/bsd/drm2/dist/drm/radeon/radeon_gart.c:1.9 --- src/sys/external/bsd/drm2/dist/drm/radeon/radeon_gart.c:1.8 Mon Aug 27 06:37:00 2018 +++ src/sys/external/bsd/drm2/dist/drm/radeon/radeon_gart.c Mon Aug 27 13:56:09 2018 @@ -1,4 +1,4 @@ -/* $NetBSD: radeon_gart.c,v 1.8 2018/08/27 06:37:00 riastradh Exp $ */ +/* $NetBSD: radeon_gart.c,v 1.9 2018/08/27 13:56:09 riastradh Exp $ */ /* * Copyright 2008 Advanced Micro Devices, Inc. @@ -28,7 +28,7 @@ * Jerome Glisse */ #include <sys/cdefs.h> -__KERNEL_RCSID(0, "$NetBSD: radeon_gart.c,v 1.8 2018/08/27 06:37:00 riastradh Exp $"); +__KERNEL_RCSID(0, "$NetBSD: radeon_gart.c,v 1.9 2018/08/27 13:56:09 riastradh Exp $"); #include <drm/drmP.h> #include <drm/radeon_drm.h> @@ -280,11 +280,10 @@ radeon_gart_pre_update(struct radeon_dev unsigned gpu_npages) { - if (rdev->gart.ptr != NULL) { + if (rdev->gart.rg_table_map != NULL) { const unsigned entsize = rdev->gart.table_size / rdev->gart.num_gpu_pages; - KASSERT(rdev->gart.rg_table_map != NULL); bus_dmamap_sync(rdev->ddev->dmat, rdev->gart.rg_table_map, gpu_pgstart*entsize, gpu_npages*entsize, BUS_DMASYNC_PREWRITE); @@ -296,15 +295,16 @@ radeon_gart_post_update(struct radeon_de unsigned gpu_npages) { - if (rdev->gart.ptr != NULL) { + if (rdev->gart.rg_table_map != NULL) { const unsigned entsize = rdev->gart.table_size / rdev->gart.num_gpu_pages; - KASSERT(rdev->gart.rg_table_map != NULL); - membar_sync(); /* XXX overkill */ bus_dmamap_sync(rdev->ddev->dmat, rdev->gart.rg_table_map, gpu_pgstart*entsize, gpu_npages*entsize, BUS_DMASYNC_POSTWRITE); + } + if (rdev->gart.ptr != NULL) { + membar_sync(); /* XXX overkill */ radeon_gart_tlb_flush(rdev); } }