summaryrefslogtreecommitdiff
path: root/drivers/gpu/drm/amd/amdkfd/kfd_svm.c
diff options
context:
space:
mode:
authorAlex Sierra <alex.sierra@amd.com>2023-05-30 00:01:37 +0300
committerAlex Deucher <alexander.deucher@amd.com>2023-06-09 19:32:25 +0300
commitc22b044070971e474dd0ff81a9830df93751f726 (patch)
treeca897bf93fc474e8bbc25ae787b6fd21961afcfc /drivers/gpu/drm/amd/amdkfd/kfd_svm.c
parentc6a64ad9b7f7182b5e2439a740574300b2e61951 (diff)
downloadlinux-c22b044070971e474dd0ff81a9830df93751f726.tar.xz
drm/amdkfd: flag added to handle errors from svm validate and map
If a return error is raised during validation and mapping of a prange, this flag is set. It is a rare occurrence, but it could happen when `amdgpu_hmm_range_get_pages_done` returns true. In such cases, the caller should retry. However, it is important to ensure that the prange is updated correctly during the retry. Signed-off-by: Alex Sierra <alex.sierra@amd.com> Reviewed-by: Felix Kuehling <Felix.Kuehling@amd.com> Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
Diffstat (limited to 'drivers/gpu/drm/amd/amdkfd/kfd_svm.c')
-rw-r--r--drivers/gpu/drm/amd/amdkfd/kfd_svm.c3
1 files changed, 2 insertions, 1 deletions
diff --git a/drivers/gpu/drm/amd/amdkfd/kfd_svm.c b/drivers/gpu/drm/amd/amdkfd/kfd_svm.c
index ee16130ddc75..9c88d6e90c3b 100644
--- a/drivers/gpu/drm/amd/amdkfd/kfd_svm.c
+++ b/drivers/gpu/drm/amd/amdkfd/kfd_svm.c
@@ -809,7 +809,7 @@ svm_range_is_same_attrs(struct kfd_process *p, struct svm_range *prange,
}
}
- return true;
+ return !prange->is_error_flag;
}
/**
@@ -1691,6 +1691,7 @@ unlock_out:
unreserve_out:
svm_range_unreserve_bos(ctx);
+ prange->is_error_flag = !!r;
if (!r)
prange->validate_timestamp = ktime_get_boottime();