drm/amdgpu: abstract set_vm_fault_masks function to refine the programming
authorHuang Rui <ray.huang@amd.com>
Tue, 21 Jul 2020 06:57:02 +0000 (14:57 +0800)
committerAlex Deucher <alexander.deucher@amd.com>
Wed, 22 Jul 2020 22:42:49 +0000 (18:42 -0400)
This patch is to add set_vm_fault_masks helper to amdgpu_gmc to refine the
original programming.

Signed-off-by: Huang Rui <ray.huang@amd.com>
Reviewed-by: Alex Deucher <alexander.deucher@amd.com>
Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
drivers/gpu/drm/amd/amdgpu/amdgpu_gmc.c
drivers/gpu/drm/amd/amdgpu/amdgpu_gmc.h
drivers/gpu/drm/amd/amdgpu/gmc_v10_0.c

index 34cbd6f6a56b7864f95eb1ad62cf1112b3e51d1e..21d2c8543f852377fa42c44c11a5e6a24a4a56bd 100644 (file)
@@ -411,3 +411,23 @@ void amdgpu_gmc_tmz_set(struct amdgpu_device *adev)
                break;
        }
 }
+
+void amdgpu_gmc_set_vm_fault_masks(struct amdgpu_device *adev, int hub_type,
+                                  bool enable)
+{
+       struct amdgpu_vmhub *hub;
+       u32 tmp, reg, i;
+
+       hub = &adev->vmhub[hub_type];
+       for (i = 0; i < 16; i++) {
+               reg = hub->vm_context0_cntl + hub->ctx_distance * i;
+
+               tmp = RREG32(reg);
+               if (enable)
+                       tmp |= hub->vm_cntx_cntl_vm_fault;
+               else
+                       tmp &= ~hub->vm_cntx_cntl_vm_fault;
+
+               WREG32(reg, tmp);
+       }
+}
index e11c21a639fdbfd01223b71fe866288f61c44d31..1785a0e378df1fd811006ffaf584d5282aa47cbf 100644 (file)
@@ -291,4 +291,8 @@ int amdgpu_gmc_allocate_vm_inv_eng(struct amdgpu_device *adev);
 
 extern void amdgpu_gmc_tmz_set(struct amdgpu_device *adev);
 
+extern void
+amdgpu_gmc_set_vm_fault_masks(struct amdgpu_device *adev, int hub_type,
+                             bool enable);
+
 #endif
index ec90c62078d96ec21b4a895e5f025ea27f8b1868..e6c8526f0093b56ba83f52d18cea71a93d5654fc 100644 (file)
@@ -62,63 +62,18 @@ gmc_v10_0_vm_fault_interrupt_state(struct amdgpu_device *adev,
                                   struct amdgpu_irq_src *src, unsigned type,
                                   enum amdgpu_interrupt_state state)
 {
-       struct amdgpu_vmhub *hub;
-       u32 tmp, reg, bits[AMDGPU_MAX_VMHUBS], i;
-
-       bits[AMDGPU_GFXHUB_0] = GCVM_CONTEXT1_CNTL__RANGE_PROTECTION_FAULT_ENABLE_INTERRUPT_MASK |
-               GCVM_CONTEXT1_CNTL__DUMMY_PAGE_PROTECTION_FAULT_ENABLE_INTERRUPT_MASK |
-               GCVM_CONTEXT1_CNTL__PDE0_PROTECTION_FAULT_ENABLE_INTERRUPT_MASK |
-               GCVM_CONTEXT1_CNTL__VALID_PROTECTION_FAULT_ENABLE_INTERRUPT_MASK |
-               GCVM_CONTEXT1_CNTL__READ_PROTECTION_FAULT_ENABLE_INTERRUPT_MASK |
-               GCVM_CONTEXT1_CNTL__WRITE_PROTECTION_FAULT_ENABLE_INTERRUPT_MASK |
-               GCVM_CONTEXT1_CNTL__EXECUTE_PROTECTION_FAULT_ENABLE_INTERRUPT_MASK;
-
-       bits[AMDGPU_MMHUB_0] = MMVM_CONTEXT1_CNTL__RANGE_PROTECTION_FAULT_ENABLE_INTERRUPT_MASK |
-               MMVM_CONTEXT1_CNTL__DUMMY_PAGE_PROTECTION_FAULT_ENABLE_INTERRUPT_MASK |
-               MMVM_CONTEXT1_CNTL__PDE0_PROTECTION_FAULT_ENABLE_INTERRUPT_MASK |
-               MMVM_CONTEXT1_CNTL__VALID_PROTECTION_FAULT_ENABLE_INTERRUPT_MASK |
-               MMVM_CONTEXT1_CNTL__READ_PROTECTION_FAULT_ENABLE_INTERRUPT_MASK |
-               MMVM_CONTEXT1_CNTL__WRITE_PROTECTION_FAULT_ENABLE_INTERRUPT_MASK |
-               MMVM_CONTEXT1_CNTL__EXECUTE_PROTECTION_FAULT_ENABLE_INTERRUPT_MASK;
-
        switch (state) {
        case AMDGPU_IRQ_STATE_DISABLE:
                /* MM HUB */
-               hub = &adev->vmhub[AMDGPU_MMHUB_0];
-               for (i = 0; i < 16; i++) {
-                       reg = hub->vm_context0_cntl + hub->ctx_distance * i;
-                       tmp = RREG32(reg);
-                       tmp &= ~bits[AMDGPU_MMHUB_0];
-                       WREG32(reg, tmp);
-               }
-
+               amdgpu_gmc_set_vm_fault_masks(adev, AMDGPU_MMHUB_0, false);
                /* GFX HUB */
-               hub = &adev->vmhub[AMDGPU_GFXHUB_0];
-               for (i = 0; i < 16; i++) {
-                       reg = hub->vm_context0_cntl + hub->ctx_distance * i;
-                       tmp = RREG32(reg);
-                       tmp &= ~bits[AMDGPU_GFXHUB_0];
-                       WREG32(reg, tmp);
-               }
+               amdgpu_gmc_set_vm_fault_masks(adev, AMDGPU_GFXHUB_0, false);
                break;
        case AMDGPU_IRQ_STATE_ENABLE:
                /* MM HUB */
-               hub = &adev->vmhub[AMDGPU_MMHUB_0];
-               for (i = 0; i < 16; i++) {
-                       reg = hub->vm_context0_cntl + hub->ctx_distance * i;
-                       tmp = RREG32(reg);
-                       tmp |= bits[AMDGPU_MMHUB_0];
-                       WREG32(reg, tmp);
-               }
-
+               amdgpu_gmc_set_vm_fault_masks(adev, AMDGPU_MMHUB_0, true);
                /* GFX HUB */
-               hub = &adev->vmhub[AMDGPU_GFXHUB_0];
-               for (i = 0; i < 16; i++) {
-                       reg = hub->vm_context0_cntl + hub->ctx_distance * i;
-                       tmp = RREG32(reg);
-                       tmp |= bits[AMDGPU_GFXHUB_0];
-                       WREG32(reg, tmp);
-               }
+               amdgpu_gmc_set_vm_fault_masks(adev, AMDGPU_GFXHUB_0, true);
                break;
        default:
                break;