aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--drivers/gpu/drm/amd/amdkfd/kfd_process.c8
1 files changed, 7 insertions, 1 deletions
diff --git a/drivers/gpu/drm/amd/amdkfd/kfd_process.c b/drivers/gpu/drm/amd/amdkfd/kfd_process.c
index a22fb0710f15..4ff5f0fe6db8 100644
--- a/drivers/gpu/drm/amd/amdkfd/kfd_process.c
+++ b/drivers/gpu/drm/amd/amdkfd/kfd_process.c
@@ -461,7 +461,8 @@ int kfd_bind_processes_to_device(struct kfd_dev *dev)
461 hash_for_each_rcu(kfd_processes_table, temp, p, kfd_processes) { 461 hash_for_each_rcu(kfd_processes_table, temp, p, kfd_processes) {
462 mutex_lock(&p->mutex); 462 mutex_lock(&p->mutex);
463 pdd = kfd_get_process_device_data(dev, p); 463 pdd = kfd_get_process_device_data(dev, p);
464 if (pdd->bound != PDD_BOUND_SUSPENDED) { 464
465 if (WARN_ON(!pdd) || pdd->bound != PDD_BOUND_SUSPENDED) {
465 mutex_unlock(&p->mutex); 466 mutex_unlock(&p->mutex);
466 continue; 467 continue;
467 } 468 }
@@ -501,6 +502,11 @@ void kfd_unbind_processes_from_device(struct kfd_dev *dev)
501 mutex_lock(&p->mutex); 502 mutex_lock(&p->mutex);
502 pdd = kfd_get_process_device_data(dev, p); 503 pdd = kfd_get_process_device_data(dev, p);
503 504
505 if (WARN_ON(!pdd)) {
506 mutex_unlock(&p->mutex);
507 continue;
508 }
509
504 if (pdd->bound == PDD_BOUND) 510 if (pdd->bound == PDD_BOUND)
505 pdd->bound = PDD_BOUND_SUSPENDED; 511 pdd->bound = PDD_BOUND_SUSPENDED;
506 mutex_unlock(&p->mutex); 512 mutex_unlock(&p->mutex);