aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/gpu/drm/amd/amdgpu/amdgpu_ttm.c
diff options
context:
space:
mode:
authorChristian König <christian.koenig@amd.com>2017-03-29 05:16:05 -0400
committerAlex Deucher <alexander.deucher@amd.com>2017-04-06 13:26:45 -0400
commit9bbdcc0fbc392e1fa6b4d1497f9d9454df70466f (patch)
tree811bd9a195b384e934005607094158d66c130978 /drivers/gpu/drm/amd/amdgpu/amdgpu_ttm.c
parent89bb5752c054e971fd453456792cb3db3d738f75 (diff)
drm/amdgpu: handle CPU access for split VRAM buffers (v2)
This avoids merging them together on page fault. v2: squash in 64-bit division fix Signed-off-by: Christian König <christian.koenig@amd.com> Acked-by: Michel Dänzer <michel.daenzer@amd.com> Reviewed-by: Nicolai Hähnle <nicolai.haehnle@amd.com> Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
Diffstat (limited to 'drivers/gpu/drm/amd/amdgpu/amdgpu_ttm.c')
-rw-r--r--drivers/gpu/drm/amd/amdgpu/amdgpu_ttm.c16
1 files changed, 12 insertions, 4 deletions
diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_ttm.c b/drivers/gpu/drm/amd/amdgpu/amdgpu_ttm.c
index 83f4930f870c..e3008d55ec77 100644
--- a/drivers/gpu/drm/amd/amdgpu/amdgpu_ttm.c
+++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_ttm.c
@@ -529,9 +529,6 @@ static int amdgpu_ttm_io_mem_reserve(struct ttm_bo_device *bdev, struct ttm_mem_
529 case TTM_PL_TT: 529 case TTM_PL_TT:
530 break; 530 break;
531 case TTM_PL_VRAM: 531 case TTM_PL_VRAM:
532 if (mem->start == AMDGPU_BO_INVALID_OFFSET)
533 return -EINVAL;
534
535 mem->bus.offset = mem->start << PAGE_SHIFT; 532 mem->bus.offset = mem->start << PAGE_SHIFT;
536 /* check if it's visible */ 533 /* check if it's visible */
537 if ((mem->bus.offset + mem->bus.size) > adev->mc.visible_vram_size) 534 if ((mem->bus.offset + mem->bus.size) > adev->mc.visible_vram_size)
@@ -549,6 +546,17 @@ static void amdgpu_ttm_io_mem_free(struct ttm_bo_device *bdev, struct ttm_mem_re
549{ 546{
550} 547}
551 548
549static unsigned long amdgpu_ttm_io_mem_pfn(struct ttm_buffer_object *bo,
550 unsigned long page_offset)
551{
552 struct drm_mm_node *mm = bo->mem.mm_node;
553 uint64_t size = mm->size;
554 unsigned long offset = page_offset;
555
556 page_offset = do_div(offset, size);
557 return (bo->mem.bus.base >> PAGE_SHIFT) + mm->start + page_offset;
558}
559
552/* 560/*
553 * TTM backend functions. 561 * TTM backend functions.
554 */ 562 */
@@ -1064,7 +1072,7 @@ static struct ttm_bo_driver amdgpu_bo_driver = {
1064 .fault_reserve_notify = &amdgpu_bo_fault_reserve_notify, 1072 .fault_reserve_notify = &amdgpu_bo_fault_reserve_notify,
1065 .io_mem_reserve = &amdgpu_ttm_io_mem_reserve, 1073 .io_mem_reserve = &amdgpu_ttm_io_mem_reserve,
1066 .io_mem_free = &amdgpu_ttm_io_mem_free, 1074 .io_mem_free = &amdgpu_ttm_io_mem_free,
1067 .io_mem_pfn = ttm_bo_default_io_mem_pfn, 1075 .io_mem_pfn = amdgpu_ttm_io_mem_pfn,
1068}; 1076};
1069 1077
1070int amdgpu_ttm_init(struct amdgpu_device *adev) 1078int amdgpu_ttm_init(struct amdgpu_device *adev)