]> git.ipfire.org Git - thirdparty/linux.git/commitdiff
driver core: Guard deferred probe timeout extension with delayed_work_pending()
authorDanilo Krummrich <dakr@kernel.org>
Mon, 25 May 2026 01:23:22 +0000 (03:23 +0200)
committerDanilo Krummrich <dakr@kernel.org>
Tue, 26 May 2026 14:51:08 +0000 (16:51 +0200)
mod_delayed_work() unconditionally queues the work even when it wasn't
previously pending, which can fire the timeout prematurely or restart it
after it already fired. Add a delayed_work_pending() guard to restore
the originally intended semantics.

Premature firing calls fw_devlink_drivers_done() before all built-in
drivers have registered, causing fw_devlink to prematurely relax device
links for suppliers whose drivers haven't loaded yet.

Fixes: 1137838865bf ("driver core: Use mod_delayed_work to prevent lost deferred probe work")
Tested-by: Geert Uytterhoeven <geert+renesas@glider.be>
Reviewed-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Link: https://patch.msgid.link/20260525012340.3860581-2-dakr@kernel.org
Signed-off-by: Danilo Krummrich <dakr@kernel.org>
drivers/base/dd.c

index bebb43acc132752503b4e4094aea19f4753bcac4..905269ecef9b4b596ea3e707ea20ad4f45f1794e 100644 (file)
@@ -323,7 +323,8 @@ void deferred_probe_extend_timeout(void)
         * If the work hasn't been queued yet or if the work expired, don't
         * start a new one.
         */
-       if (mod_delayed_work(system_wq, &deferred_probe_timeout_work,
+       if (delayed_work_pending(&deferred_probe_timeout_work) &&
+           mod_delayed_work(system_wq, &deferred_probe_timeout_work,
                             secs_to_jiffies(driver_deferred_probe_timeout)))
                pr_debug("Extended deferred probe timeout by %d secs\n",
                                        driver_deferred_probe_timeout);