]> www.infradead.org Git - users/hch/misc.git/commitdiff
drm/amdgpu: stop reserving VMIDs to enforce isolation
authorChristian König <christian.koenig@amd.com>
Mon, 27 Jan 2025 15:27:51 +0000 (16:27 +0100)
committerAlex Deucher <alexander.deucher@amd.com>
Fri, 21 Mar 2025 16:16:34 +0000 (12:16 -0400)
That was quite troublesome for gang submit. Completely drop this
approach and enforce the isolation separately.

Signed-off-by: Christian König <christian.koenig@amd.com>
Acked-by: Srinivasan Shanmugam <srinivasan.shanmugam@amd.com>
Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
drivers/gpu/drm/amd/amdgpu/amdgpu_cs.c
drivers/gpu/drm/amd/amdgpu/amdgpu_gfx.c
drivers/gpu/drm/amd/amdgpu/amdgpu_ids.c
drivers/gpu/drm/amd/amdgpu/amdgpu_ids.h

index 4a5b406601fa20c789edc9095ca1813aa78081c1..82df06a72ee025d5dc22fb0b954d38f394fb5c5e 100644 (file)
@@ -1111,7 +1111,7 @@ static int amdgpu_cs_vm_handling(struct amdgpu_cs_parser *p)
                        struct drm_gpu_scheduler *sched = entity->rq->sched;
                        struct amdgpu_ring *ring = to_amdgpu_ring(sched);
 
-                       if (amdgpu_vmid_uses_reserved(adev, vm, ring->vm_hub))
+                       if (amdgpu_vmid_uses_reserved(vm, ring->vm_hub))
                                return -EINVAL;
                }
        }
index 4beb0609e703434e4db3635236d134a4636c7e97..72af5e5a894a29dcaa368be52ada491438725b84 100644 (file)
@@ -1665,15 +1665,8 @@ static ssize_t amdgpu_gfx_set_enforce_isolation(struct device *dev,
        }
 
        mutex_lock(&adev->enforce_isolation_mutex);
-       for (i = 0; i < num_partitions; i++) {
-               if (adev->enforce_isolation[i] && !partition_values[i])
-                       /* Going from enabled to disabled */
-                       amdgpu_vmid_free_reserved(adev, AMDGPU_GFXHUB(i));
-               else if (!adev->enforce_isolation[i] && partition_values[i])
-                       /* Going from disabled to enabled */
-                       amdgpu_vmid_alloc_reserved(adev, AMDGPU_GFXHUB(i));
+       for (i = 0; i < num_partitions; i++)
                adev->enforce_isolation[i] = partition_values[i];
-       }
        mutex_unlock(&adev->enforce_isolation_mutex);
 
        amdgpu_mes_update_enforce_isolation(adev);
index 92ab821afc06ae561929cfed74c72ad0ac8d87b2..4c4e087230ac51450ecdc3083328094be2bde9e2 100644 (file)
@@ -411,7 +411,7 @@ int amdgpu_vmid_grab(struct amdgpu_vm *vm, struct amdgpu_ring *ring,
        if (r || !idle)
                goto error;
 
-       if (amdgpu_vmid_uses_reserved(adev, vm, vmhub)) {
+       if (amdgpu_vmid_uses_reserved(vm, vmhub)) {
                r = amdgpu_vmid_grab_reserved(vm, ring, job, &id, fence);
                if (r || !id)
                        goto error;
@@ -464,19 +464,14 @@ error:
 
 /*
  * amdgpu_vmid_uses_reserved - check if a VM will use a reserved VMID
- * @adev: amdgpu_device pointer
  * @vm: the VM to check
  * @vmhub: the VMHUB which will be used
  *
  * Returns: True if the VM will use a reserved VMID.
  */
-bool amdgpu_vmid_uses_reserved(struct amdgpu_device *adev,
-                              struct amdgpu_vm *vm, unsigned int vmhub)
+bool amdgpu_vmid_uses_reserved(struct amdgpu_vm *vm, unsigned int vmhub)
 {
-       return vm->reserved_vmid[vmhub] ||
-               (adev->enforce_isolation[(vm->root.bo->xcp_id != AMDGPU_XCP_NO_PARTITION) ?
-                                        vm->root.bo->xcp_id : 0] &&
-                AMDGPU_IS_GFXHUB(vmhub));
+       return vm->reserved_vmid[vmhub];
 }
 
 int amdgpu_vmid_alloc_reserved(struct amdgpu_device *adev,
index 4012fb2dd08a59960ebea95cafdbfa503de170c3..240fa675126029a0050a44cd4d5065eefcf70bef 100644 (file)
@@ -78,8 +78,7 @@ void amdgpu_pasid_free_delayed(struct dma_resv *resv,
 
 bool amdgpu_vmid_had_gpu_reset(struct amdgpu_device *adev,
                               struct amdgpu_vmid *id);
-bool amdgpu_vmid_uses_reserved(struct amdgpu_device *adev,
-                              struct amdgpu_vm *vm, unsigned int vmhub);
+bool amdgpu_vmid_uses_reserved(struct amdgpu_vm *vm, unsigned int vmhub);
 int amdgpu_vmid_alloc_reserved(struct amdgpu_device *adev,
                                unsigned vmhub);
 void amdgpu_vmid_free_reserved(struct amdgpu_device *adev,