drm/amdgpu: save the setting of VM_CONTEXT_CNTL
authorJack Xiao <Jack.Xiao@amd.com>
Wed, 12 May 2021 07:53:48 +0000 (15:53 +0800)
committerAlex Deucher <alexander.deucher@amd.com>
Wed, 4 May 2022 13:57:22 +0000 (09:57 -0400)
MES firmware needs the setting of VM_CONTEXT_CNTL to perform
vmid switch. Save the initial setting when hub initializing.

Signed-off-by: Jack Xiao <Jack.Xiao@amd.com>
Reviewed-by: Hawking Zhang <Hawking.Zhang@amd.com>
Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
drivers/gpu/drm/amd/amdgpu/amdgpu_gmc.h
drivers/gpu/drm/amd/amdgpu/gfxhub_v2_0.c
drivers/gpu/drm/amd/amdgpu/gfxhub_v2_1.c
drivers/gpu/drm/amd/amdgpu/gfxhub_v3_0.c
drivers/gpu/drm/amd/amdgpu/mmhub_v2_0.c
drivers/gpu/drm/amd/amdgpu/mmhub_v2_3.c
drivers/gpu/drm/amd/amdgpu/mmhub_v3_0.c

index 4be6b657944abbb116e6978511e35b000c314cfe..008eaca271519996a543de508bc361acf2112d1f 100644 (file)
@@ -100,6 +100,7 @@ struct amdgpu_vmhub {
        uint32_t        eng_distance;
        uint32_t        eng_addr_distance; /* include LO32/HI32 */
 
+       uint32_t        vm_cntx_cntl;
        uint32_t        vm_cntx_cntl_vm_fault;
        uint32_t        vm_l2_bank_select_reserved_cid2;
 
index 6e0ace2fbfab14092d7fa7cd413bb6580e562f4c..34513e8e15191668af600ecad4f5bfa9c64c0fa3 100644 (file)
@@ -325,6 +325,8 @@ static void gfxhub_v2_0_setup_vmid_config(struct amdgpu_device *adev)
                                    i * hub->ctx_addr_distance,
                                    upper_32_bits(adev->vm_manager.max_pfn - 1));
        }
+
+       hub->vm_cntx_cntl = tmp;
 }
 
 static void gfxhub_v2_0_program_invalidation(struct amdgpu_device *adev)
index ff738e9725ee8fb15b1e18d6cb0b802c182c5cf5..d8c53158111693de3d07c7e7894c59a2ee19a399 100644 (file)
@@ -334,6 +334,8 @@ static void gfxhub_v2_1_setup_vmid_config(struct amdgpu_device *adev)
                                    i * hub->ctx_addr_distance,
                                    upper_32_bits(adev->vm_manager.max_pfn - 1));
        }
+
+       hub->vm_cntx_cntl = tmp;
 }
 
 static void gfxhub_v2_1_program_invalidation(struct amdgpu_device *adev)
index 47f0e4daa46644a15334c89a8e48386c721a689a..5eccaa2c7ca0ebcdf45f22686a90463c31f91efa 100644 (file)
@@ -335,6 +335,8 @@ static void gfxhub_v3_0_setup_vmid_config(struct amdgpu_device *adev)
                                    i * hub->ctx_addr_distance,
                                    upper_32_bits(adev->vm_manager.max_pfn - 1));
        }
+
+       hub->vm_cntx_cntl = tmp;
 }
 
 static void gfxhub_v3_0_program_invalidation(struct amdgpu_device *adev)
index 636abd8556865ed71743ebcae18bee3ceafd584a..4d304f22889e4c62d2178ad3facd632dd7a61481 100644 (file)
@@ -408,6 +408,8 @@ static void mmhub_v2_0_setup_vmid_config(struct amdgpu_device *adev)
                                    i * hub->ctx_addr_distance,
                                    upper_32_bits(adev->vm_manager.max_pfn - 1));
        }
+
+       hub->vm_cntx_cntl = tmp;
 }
 
 static void mmhub_v2_0_program_invalidation(struct amdgpu_device *adev)
index ff44c5364a8cd87922336da343de96c072b9624d..1b027d069ab4042c294890bbd7cdd4cb449bffc2 100644 (file)
@@ -324,6 +324,8 @@ static void mmhub_v2_3_setup_vmid_config(struct amdgpu_device *adev)
                                    i * hub->ctx_addr_distance,
                                    upper_32_bits(adev->vm_manager.max_pfn - 1));
        }
+
+       hub->vm_cntx_cntl = tmp;
 }
 
 static void mmhub_v2_3_program_invalidation(struct amdgpu_device *adev)
index 74b5b2f2dfd3f2bff595107f1f92466eafba1f3c..08a85a0cd334524a2105a3e04e538ca44952a3f3 100644 (file)
@@ -361,6 +361,8 @@ static void mmhub_v3_0_setup_vmid_config(struct amdgpu_device *adev)
                                    i * hub->ctx_addr_distance,
                                    upper_32_bits(adev->vm_manager.max_pfn - 1));
        }
+
+       hub->vm_cntx_cntl = tmp;
 }
 
 static void mmhub_v3_0_program_invalidation(struct amdgpu_device *adev)