diff options
Diffstat (limited to 'meta-amdfalconx86/recipes-kernel/linux/linux-yocto/0448-drm-amdgpu-remove-VI-hw-bug-workaround-v3.patch')
-rw-r--r-- | meta-amdfalconx86/recipes-kernel/linux/linux-yocto/0448-drm-amdgpu-remove-VI-hw-bug-workaround-v3.patch | 64 |
1 files changed, 64 insertions, 0 deletions
diff --git a/meta-amdfalconx86/recipes-kernel/linux/linux-yocto/0448-drm-amdgpu-remove-VI-hw-bug-workaround-v3.patch b/meta-amdfalconx86/recipes-kernel/linux/linux-yocto/0448-drm-amdgpu-remove-VI-hw-bug-workaround-v3.patch new file mode 100644 index 00000000..610688f7 --- /dev/null +++ b/meta-amdfalconx86/recipes-kernel/linux/linux-yocto/0448-drm-amdgpu-remove-VI-hw-bug-workaround-v3.patch @@ -0,0 +1,64 @@ +From c548b345d15092bf46469a0339d41ae3e106987d Mon Sep 17 00:00:00 2001 +From: =?UTF-8?q?Christian=20K=C3=B6nig?= <christian.koenig@amd.com> +Date: Fri, 7 Aug 2015 20:22:40 +0200 +Subject: [PATCH 0448/1050] drm/amdgpu: remove VI hw bug workaround v3 +MIME-Version: 1.0 +Content-Type: text/plain; charset=UTF-8 +Content-Transfer-Encoding: 8bit + +The workaround simply doesn't work because VM mappings +are controlled by userspace not the kernel. + +Additional to that this is just a performance problem +which happens if you have holes in your VM mapping. + +v2: adjust virtual addr alignment as well. +v3: fix trivial warning + +Signed-off-by: Christian König <christian.koenig@amd.com> +Reviewed-by: Monk Liu <monk.liu@amd.com> (v1) +Reviewed-by: Jammy Zhou <Jammy.Zhou@amd.com> (v2) +--- + drivers/gpu/drm/amd/amdgpu/amdgpu_kms.c | 2 +- + drivers/gpu/drm/amd/amdgpu/amdgpu_object.c | 12 ------------ + 2 files changed, 1 insertion(+), 13 deletions(-) + +diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_kms.c b/drivers/gpu/drm/amd/amdgpu/amdgpu_kms.c +index 7226def..87da6b1 100644 +--- a/drivers/gpu/drm/amd/amdgpu/amdgpu_kms.c ++++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_kms.c +@@ -455,7 +455,7 @@ static int amdgpu_info_ioctl(struct drm_device *dev, void *data, struct drm_file + dev_info.ids_flags |= AMDGPU_IDS_FLAGS_FUSION; + dev_info.virtual_address_offset = AMDGPU_VA_RESERVED_SIZE; + dev_info.virtual_address_max = (uint64_t)adev->vm_manager.max_pfn * AMDGPU_GPU_PAGE_SIZE; +- dev_info.virtual_address_alignment = max(PAGE_SIZE, 0x10000UL); ++ dev_info.virtual_address_alignment = max((int)PAGE_SIZE, AMDGPU_GPU_PAGE_SIZE); + dev_info.pte_fragment_size = (1 << AMDGPU_LOG2_PAGES_PER_FRAG) * + AMDGPU_GPU_PAGE_SIZE; + dev_info.gart_page_size = AMDGPU_GPU_PAGE_SIZE; +diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_object.c b/drivers/gpu/drm/amd/amdgpu/amdgpu_object.c +index 87d67f8..f1f1b67 100644 +--- a/drivers/gpu/drm/amd/amdgpu/amdgpu_object.c ++++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_object.c +@@ -223,18 +223,6 @@ int amdgpu_bo_create_restricted(struct amdgpu_device *adev, + size_t acc_size; + int r; + +- /* VI has a hw bug where VM PTEs have to be allocated in groups of 8. +- * do this as a temporary workaround +- */ +- if (!(domain & (AMDGPU_GEM_DOMAIN_GDS | AMDGPU_GEM_DOMAIN_GWS | AMDGPU_GEM_DOMAIN_OA))) { +- if ((adev->asic_type >= CHIP_TOPAZ) && (adev->asic_type != CHIP_FIJI)) { +- if (byte_align & 0x7fff) +- byte_align = ALIGN(byte_align, 0x8000); +- if (size & 0x7fff) +- size = ALIGN(size, 0x8000); +- } +- } +- + page_align = roundup(byte_align, PAGE_SIZE) >> PAGE_SHIFT; + size = ALIGN(size, PAGE_SIZE); + +-- +1.9.1 + |