]> www.infradead.org Git - users/jedix/linux-maple.git/commitdiff
drm/xe/guc: move guc_fini over to devm
authorMatthew Auld <matthew.auld@intel.com>
Wed, 22 May 2024 10:21:47 +0000 (11:21 +0100)
committerMatthew Auld <matthew.auld@intel.com>
Wed, 22 May 2024 12:22:39 +0000 (13:22 +0100)
Make sure to actually call this when the device is removed. Currently we
only trigger it when the driver instance goes away, but that doesn't
work too well with hotunplug, since device can be removed and re-probed
with a new driver instance, where the guc_fini() is called too late.
Move the fini over to devm to ensure this is called when device is
removed.

References: https://gitlab.freedesktop.org/drm/xe/kernel/-/issues/1717
Signed-off-by: Matthew Auld <matthew.auld@intel.com>
Cc: Rodrigo Vivi <rodrigo.vivi@intel.com>
Reviewed-by: Andrzej Hajda <andrzej.hajda@intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20240522102143.128069-22-matthew.auld@intel.com
drivers/gpu/drm/xe/xe_guc.c

index cec709a908c3d316837bc154a55b2de8af980e35..3ac821438b60b3cabb682b2a09cba9ae5ed2e05a 100644 (file)
@@ -241,7 +241,7 @@ static void guc_write_params(struct xe_guc *guc)
                xe_mmio_write32(gt, SOFT_SCRATCH(1 + i), guc->params[i]);
 }
 
-static void guc_fini(struct drm_device *drm, void *arg)
+static void guc_fini(void *arg)
 {
        struct xe_guc *guc = arg;
        struct xe_gt *gt = guc_to_gt(guc);
@@ -349,7 +349,7 @@ int xe_guc_init(struct xe_guc *guc)
        if (ret)
                goto out;
 
-       ret = drmm_add_action_or_reset(&xe->drm, guc_fini, guc);
+       ret = devm_add_action_or_reset(xe->drm.dev, guc_fini, guc);
        if (ret)
                goto out;