Commit 4853cbcd authored by Felix Kuehling's avatar Felix Kuehling Committed by Alex Deucher

drm/amdkfd: Don't split unchanged SVM ranges

If an existing SVM range overlaps an svm_range_set_attr call, we would
normally split it in order to update only the overlapping part.
However, if the attributes of the existing range would not be changed
splitting it is unnecessary.
Signed-off-by: default avatarFelix Kuehling <Felix.Kuehling@amd.com>
Reviewed-by: default avatarPhilip Yang <Philip.Yang@amd.com>
Signed-off-by: default avatarAlex Deucher <alexander.deucher@amd.com>
parent f864df76
...@@ -1855,18 +1855,24 @@ svm_range_add(struct kfd_process *p, uint64_t start, uint64_t size, ...@@ -1855,18 +1855,24 @@ svm_range_add(struct kfd_process *p, uint64_t start, uint64_t size,
node = interval_tree_iter_first(&svms->objects, start, last); node = interval_tree_iter_first(&svms->objects, start, last);
while (node) { while (node) {
struct interval_tree_node *next; struct interval_tree_node *next;
struct svm_range *old;
unsigned long next_start; unsigned long next_start;
pr_debug("found overlap node [0x%lx 0x%lx]\n", node->start, pr_debug("found overlap node [0x%lx 0x%lx]\n", node->start,
node->last); node->last);
old = container_of(node, struct svm_range, it_node); prange = container_of(node, struct svm_range, it_node);
next = interval_tree_iter_next(node, start, last); next = interval_tree_iter_next(node, start, last);
next_start = min(node->last, last) + 1; next_start = min(node->last, last) + 1;
if (node->start < start || node->last > last) { if (svm_range_is_same_attrs(p, prange, nattr, attrs)) {
/* node intersects the updated range, clone+split it */ /* nothing to do */
} else if (node->start < start || node->last > last) {
/* node intersects the update range and its attributes
* will change. Clone and split it, apply updates only
* to the overlapping part
*/
struct svm_range *old = prange;
prange = svm_range_clone(old); prange = svm_range_clone(old);
if (!prange) { if (!prange) {
r = -ENOMEM; r = -ENOMEM;
...@@ -1875,6 +1881,7 @@ svm_range_add(struct kfd_process *p, uint64_t start, uint64_t size, ...@@ -1875,6 +1881,7 @@ svm_range_add(struct kfd_process *p, uint64_t start, uint64_t size,
list_add(&old->remove_list, remove_list); list_add(&old->remove_list, remove_list);
list_add(&prange->insert_list, insert_list); list_add(&prange->insert_list, insert_list);
list_add(&prange->update_list, update_list);
if (node->start < start) { if (node->start < start) {
pr_debug("change old range start\n"); pr_debug("change old range start\n");
...@@ -1894,16 +1901,12 @@ svm_range_add(struct kfd_process *p, uint64_t start, uint64_t size, ...@@ -1894,16 +1901,12 @@ svm_range_add(struct kfd_process *p, uint64_t start, uint64_t size,
/* The node is contained within start..last, /* The node is contained within start..last,
* just update it * just update it
*/ */
prange = old;
}
if (!svm_range_is_same_attrs(p, prange, nattr, attrs))
list_add(&prange->update_list, update_list); list_add(&prange->update_list, update_list);
}
/* insert a new node if needed */ /* insert a new node if needed */
if (node->start > start) { if (node->start > start) {
prange = svm_range_new(prange->svms, start, prange = svm_range_new(svms, start, node->start - 1);
node->start - 1);
if (!prange) { if (!prange) {
r = -ENOMEM; r = -ENOMEM;
goto out; goto out;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment