With this bug MTYPE_UC 0x3 can not update to MTYPE_RW 0x1.

Set AMDGPU_PTE_EXECUTABLE flag if mapping flag set, but should not
clear it if mapping flag is not set, to only update mtype.

Signed-off-by: Philip Yang <[email protected]>
---
 drivers/gpu/drm/amd/amdgpu/gmc_v9_0.c | 10 ++++------
 1 file changed, 4 insertions(+), 6 deletions(-)

diff --git a/drivers/gpu/drm/amd/amdgpu/gmc_v9_0.c 
b/drivers/gpu/drm/amd/amdgpu/gmc_v9_0.c
index 97a04e3171f2..d2e8b96c0372 100644
--- a/drivers/gpu/drm/amd/amdgpu/gmc_v9_0.c
+++ b/drivers/gpu/drm/amd/amdgpu/gmc_v9_0.c
@@ -1194,8 +1194,6 @@ static void gmc_v9_0_get_vm_pte(struct amdgpu_device 
*adev,
 {
        if (vm_flags & AMDGPU_VM_PAGE_EXECUTABLE)
                *flags |= AMDGPU_PTE_EXECUTABLE;
-       else
-               *flags &= ~AMDGPU_PTE_EXECUTABLE;
 
        switch (vm_flags & AMDGPU_VM_MTYPE_MASK) {
        case AMDGPU_VM_MTYPE_DEFAULT:
@@ -1204,16 +1202,16 @@ static void gmc_v9_0_get_vm_pte(struct amdgpu_device 
*adev,
                *flags = AMDGPU_PTE_MTYPE_VG10(*flags, MTYPE_NC);
                break;
        case AMDGPU_VM_MTYPE_WC:
-               *flags |= AMDGPU_PTE_MTYPE_VG10(*flags, MTYPE_WC);
+               *flags = AMDGPU_PTE_MTYPE_VG10(*flags, MTYPE_WC);
                break;
        case AMDGPU_VM_MTYPE_RW:
-               *flags |= AMDGPU_PTE_MTYPE_VG10(*flags, MTYPE_RW);
+               *flags = AMDGPU_PTE_MTYPE_VG10(*flags, MTYPE_RW);
                break;
        case AMDGPU_VM_MTYPE_CC:
-               *flags |= AMDGPU_PTE_MTYPE_VG10(*flags, MTYPE_CC);
+               *flags = AMDGPU_PTE_MTYPE_VG10(*flags, MTYPE_CC);
                break;
        case AMDGPU_VM_MTYPE_UC:
-               *flags |= AMDGPU_PTE_MTYPE_VG10(*flags, MTYPE_UC);
+               *flags = AMDGPU_PTE_MTYPE_VG10(*flags, MTYPE_UC);
                break;
        }
 
-- 
2.50.1

Reply via email to