Commit 83775e15 authored by Ben Skeggs's avatar Ben Skeggs Committed by Karol Herbst

drm/nouveau/nvkm: fini object children in reverse order

Turns out, we're currently tearing down the disp core channel *before*
the satellite channels (wndw, etc) during suspend.

This makes RM return NV_ERR_NOT_SUPPORTED on attempting to reallocate
the core channel on resume for some reason, but we probably shouldn't
be doing it on HW either.

Tear down children in the reverse of allocation order instead.
Signed-off-by: default avatarBen Skeggs <bskeggs@redhat.com>
Reviewed-by: default avatarKarol Herbst <kherbst@redhat.com>
Reviewed-by: default avatarLyude Paul <lyude@redhat.com>
Signed-off-by: default avatarKarol Herbst <kherbst@redhat.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20230525003106.3853741-1-skeggsb@gmail.com
parent c69f9d92
...@@ -185,7 +185,7 @@ nvkm_object_fini(struct nvkm_object *object, bool suspend) ...@@ -185,7 +185,7 @@ nvkm_object_fini(struct nvkm_object *object, bool suspend)
nvif_debug(object, "%s children...\n", action); nvif_debug(object, "%s children...\n", action);
time = ktime_to_us(ktime_get()); time = ktime_to_us(ktime_get());
list_for_each_entry(child, &object->tree, head) { list_for_each_entry_reverse(child, &object->tree, head) {
ret = nvkm_object_fini(child, suspend); ret = nvkm_object_fini(child, suspend);
if (ret && suspend) if (ret && suspend)
goto fail_child; goto fail_child;
......
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