Igor Pylypiv
a0c66ac8b7
Revert "module, async: async_synchronize_full() on module init iff async is used"
...
[ Upstream commit 67d6212afda218d564890d1674bab28e8612170f ]
This reverts commit 774a1221e8 .
We need to finish all async code before the module init sequence is
done. In the reverted commit the PF_USED_ASYNC flag was added to mark a
thread that called async_schedule(). Then the PF_USED_ASYNC flag was
used to determine whether or not async_synchronize_full() needs to be
invoked. This works when modprobe thread is calling async_schedule(),
but it does not work if module dispatches init code to a worker thread
which then calls async_schedule().
For example, PCI driver probing is invoked from a worker thread based on
a node where device is attached:
if (cpu < nr_cpu_ids)
error = work_on_cpu(cpu, local_pci_probe, &ddi);
else
error = local_pci_probe(&ddi);
We end up in a situation where a worker thread gets the PF_USED_ASYNC
flag set instead of the modprobe thread. As a result,
async_synchronize_full() is not invoked and modprobe completes without
waiting for the async code to finish.
The issue was discovered while loading the pm80xx driver:
(scsi_mod.scan=async)
modprobe pm80xx worker
...
do_init_module()
...
pci_call_probe()
work_on_cpu(local_pci_probe)
local_pci_probe()
pm8001_pci_probe()
scsi_scan_host()
async_schedule()
worker->flags |= PF_USED_ASYNC;
...
< return from worker >
...
if (current->flags & PF_USED_ASYNC) <--- false
async_synchronize_full();
Commit 21c3c5d280 ("block: don't request module during elevator init")
fixed the deadlock issue which the reverted commit 774a1221e8
("module, async: async_synchronize_full() on module init iff async is
used") tried to fix.
Since commit 0fdff3ec6d ("async, kmod: warn on synchronous
request_module() from async workers") synchronous module loading from
async is not allowed.
Given that the original deadlock issue is fixed and it is no longer
allowed to call synchronous request_module() from async we can remove
PF_USED_ASYNC flag to make module init consistently invoke
async_synchronize_full() unless async module probe is requested.
Signed-off-by: Igor Pylypiv <ipylypiv@google.com >
Reviewed-by: Changyuan Lyu <changyuanl@google.com >
Reviewed-by: Luis Chamberlain <mcgrof@kernel.org >
Acked-by: Tejun Heo <tj@kernel.org >
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org >
Signed-off-by: Sasha Levin <sashal@kernel.org >
2022-02-23 11:58:38 +01:00
..
2019-12-13 08:51:18 +01:00
2019-01-22 21:40:33 +01:00
2021-03-17 16:43:42 +01:00
2020-04-02 15:28:16 +02:00
2018-09-30 08:49:55 -07:00
2019-12-05 09:20:15 +01:00
2020-04-29 16:31:24 +02:00
2020-01-27 14:50:42 +01:00
2021-08-08 08:54:28 +02:00
2021-06-16 11:55:01 +02:00
2021-04-14 08:22:36 +02:00
2020-10-01 13:14:28 +02:00
2020-11-05 11:08:34 +01:00
2021-03-30 14:37:02 +02:00
2018-10-12 15:25:17 +01:00
2020-01-27 14:51:19 +01:00
2021-09-22 11:47:49 +02:00
2020-06-30 23:17:12 -04:00
2020-01-23 08:21:39 +01:00
2021-12-08 08:50:11 +01:00
2021-05-22 10:59:30 +02:00
2021-09-22 11:47:47 +02:00
2021-08-12 13:19:42 +02:00
2021-05-07 10:49:25 +02:00
2020-01-09 10:19:01 +01:00
2019-12-13 08:52:59 +01:00
2021-08-08 08:54:29 +02:00
2021-08-08 08:54:29 +02:00
2019-05-31 06:46:00 -07:00
2020-08-19 08:15:05 +02:00
2019-12-01 09:17:07 +01:00
2020-06-25 15:33:02 +02:00
2019-04-17 08:38:51 +02:00
2019-10-05 13:10:03 +02:00
2021-03-04 09:39:30 +01:00
2020-04-29 16:31:17 +02:00
2021-09-22 11:47:59 +02:00
2019-07-03 13:14:48 +02:00
2021-03-30 14:37:02 +02:00
2020-04-23 10:30:12 +02:00
2019-10-05 13:09:54 +02:00
2020-12-30 11:25:39 +01:00
2020-09-09 19:04:31 +02:00
2021-09-26 13:39:48 +02:00
2019-08-16 10:12:38 +02:00
2020-07-22 09:32:00 +02:00
2020-07-22 09:32:00 +02:00
2019-04-05 22:33:03 +02:00
2019-08-06 19:06:52 +02:00
2019-08-06 19:06:52 +02:00
2021-01-30 13:32:11 +01:00
2021-03-24 11:07:31 +01:00
2020-12-30 11:25:40 +01:00
2021-01-23 15:49:55 +01:00
2019-02-27 10:08:53 +01:00
2021-10-06 15:31:17 +02:00
2021-05-26 11:48:35 +02:00
2021-11-26 11:36:02 +01:00
2019-11-12 19:21:38 +01:00
2019-11-20 18:47:11 +01:00
2019-12-31 16:36:22 +01:00
2021-08-08 08:54:30 +02:00
2019-11-24 08:20:07 +01:00
2021-10-06 15:31:28 +02:00
2020-11-05 11:08:35 +01:00
2020-10-01 13:14:28 +02:00
2020-04-17 10:48:45 +02:00
2021-03-04 09:39:57 +01:00
2021-08-26 08:36:41 -04:00
2021-01-23 15:49:55 +01:00
2019-12-13 08:51:54 +01:00
2020-02-24 08:34:44 +01:00
2019-06-04 08:02:34 +02:00
2019-11-20 18:47:40 +01:00
2021-03-11 14:05:02 +01:00
2020-09-03 11:24:23 +02:00
2019-05-16 19:41:17 +02:00
2021-10-27 09:53:13 +02:00
2020-06-25 15:33:02 +02:00
2020-02-11 04:34:08 -08:00
2021-04-07 12:48:50 +02:00
2019-04-05 22:32:59 +02:00
2019-11-24 08:19:14 +01:00
2021-12-08 08:50:13 +01:00
2021-11-26 11:35:59 +01:00
2020-10-14 10:31:21 +02:00
2021-12-08 08:50:13 +01:00
2018-12-17 09:24:38 +01:00
2021-09-22 11:47:56 +02:00
2021-09-22 11:47:56 +02:00
2020-11-05 11:08:35 +01:00
2019-11-20 18:45:55 +01:00
2018-12-01 09:37:31 +01:00
2018-12-05 19:32:10 +01:00
2021-01-30 13:32:12 +01:00
2019-12-05 09:21:03 +01:00
2021-03-11 14:04:59 +01:00
2019-02-12 19:47:14 +01:00
2019-11-10 11:27:40 +01:00
2019-09-10 10:33:44 +01:00
2019-03-23 20:10:08 +01:00
2018-11-13 11:08:54 -08:00
2019-02-12 19:47:24 +01:00
2018-12-05 19:32:13 +01:00
2022-01-27 09:04:25 +01:00
2020-11-05 11:08:54 +01:00
2019-01-13 09:51:04 +01:00
2019-07-31 07:26:59 +02:00
2020-01-04 19:13:32 +01:00
2021-07-11 12:49:27 +02:00
2021-09-22 11:48:09 +02:00
2019-10-17 13:45:42 -07:00
2020-08-11 15:32:33 +02:00
2020-09-23 12:10:59 +02:00
2021-05-22 10:59:40 +02:00
2018-11-21 09:19:20 +01:00
2021-03-04 09:39:59 +01:00
2019-12-05 09:19:39 +01:00
2020-05-10 10:30:12 +02:00
2019-03-05 17:58:51 +01:00
2020-01-12 12:17:25 +01:00
2021-03-30 14:37:00 +02:00
2019-08-09 17:52:34 +02:00
2020-07-22 09:32:00 +02:00
2020-03-18 07:14:11 +01:00
2021-08-26 08:36:39 -04:00
2021-02-03 23:23:26 +01:00
2020-02-28 16:38:59 +01:00
2020-07-29 10:16:57 +02:00
2020-05-10 10:30:11 +02:00
2020-04-17 10:48:41 +02:00
2021-05-22 10:59:50 +02:00
2019-08-04 09:30:54 +02:00
2021-12-08 08:50:11 +01:00
2019-12-31 16:35:23 +01:00
2021-03-04 09:39:59 +01:00
2021-08-26 08:36:40 -04:00
2019-04-05 22:33:09 +02:00
2020-02-28 16:38:50 +01:00
2019-12-13 08:52:43 +01:00
2019-06-04 08:02:34 +02:00
2019-06-04 08:02:34 +02:00
2020-07-16 08:17:26 +02:00
2019-04-20 09:15:59 +02:00
2021-01-09 13:43:48 +01:00
2019-07-21 09:03:11 +02:00
2019-12-13 08:52:43 +01:00
2021-03-04 09:39:42 +01:00
2020-04-23 10:30:24 +02:00
2021-03-04 09:39:44 +01:00
2020-06-22 09:05:15 +02:00
2020-10-14 10:31:26 +02:00
2021-12-08 08:50:12 +01:00
2021-02-07 14:48:38 +01:00
2021-09-26 13:39:46 +02:00
2020-04-29 16:31:19 +02:00
2021-11-26 11:35:57 +01:00
2020-01-04 19:13:15 +01:00
2019-06-09 09:17:19 +02:00
2020-02-24 08:34:46 +01:00
2021-09-22 11:47:57 +02:00
2020-09-09 19:04:28 +02:00
2019-09-06 10:22:19 +02:00
2021-11-26 11:35:56 +01:00
2021-04-28 13:16:51 +02:00
2018-12-29 13:37:59 +01:00
2021-10-09 14:11:03 +02:00
2020-02-11 04:34:18 -08:00
2019-04-17 08:38:51 +02:00
2021-09-22 11:48:12 +02:00
2020-01-29 16:43:27 +01:00
2019-01-13 09:51:04 +01:00
2019-12-31 16:35:38 +01:00
2019-11-12 19:20:36 +01:00
2021-07-11 12:49:28 +02:00
2021-07-11 12:49:26 +02:00
2020-10-07 08:00:08 +02:00
2020-07-29 10:16:52 +02:00
2021-05-22 10:59:23 +02:00
2019-05-31 06:46:05 -07:00
2021-08-26 08:36:41 -04:00
2021-03-30 14:37:02 +02:00
2018-12-05 19:31:59 +01:00
2021-06-30 08:48:18 -04:00
2021-07-20 16:16:01 +02:00
2022-02-08 18:23:08 +01:00
2019-06-04 08:02:34 +02:00
2020-11-18 19:18:44 +01:00
2020-11-18 19:18:44 +01:00
2020-12-02 08:48:07 +01:00
2018-09-23 21:55:24 -07:00
2021-07-20 16:16:11 +02:00
2020-10-01 13:14:41 +02:00
2019-09-06 10:22:23 +02:00
2018-11-21 09:19:20 +01:00
2020-10-07 08:00:08 +02:00
2020-04-13 10:45:06 +02:00
2020-04-17 10:48:45 +02:00
2018-11-13 11:08:24 -08:00
2021-12-08 08:50:11 +01:00
2021-01-06 14:45:00 +01:00
2021-09-03 09:58:00 +02:00
2020-10-29 09:55:15 +01:00
2020-10-30 10:38:20 +01:00
2021-08-08 08:54:30 +02:00
2020-03-25 08:06:13 +01:00
2021-07-11 12:49:30 +02:00
2020-06-22 09:05:25 +02:00
2020-04-17 10:48:46 +02:00
2021-11-26 11:36:19 +01:00
2020-04-23 10:30:20 +02:00
2020-02-11 04:34:11 -08:00
2021-06-10 13:24:08 +02:00
2018-12-01 09:37:34 +01:00
2020-03-18 07:14:17 +01:00
2019-05-04 09:20:11 +02:00
2020-01-27 14:50:26 +01:00
2020-05-20 08:18:45 +02:00
2020-01-17 19:46:55 +01:00
2020-01-04 19:13:35 +01:00
2021-07-20 16:15:46 +02:00
2020-07-22 09:32:13 +02:00
2021-01-12 20:10:17 +01:00
2019-03-23 20:10:04 +01:00
2019-06-11 12:20:52 +02:00
2021-06-30 08:48:19 -04:00
2019-01-09 17:38:33 +01:00
2018-12-05 19:32:03 +01:00
2019-06-15 11:54:10 +02:00
2019-12-13 08:52:28 +01:00
2020-01-04 19:12:53 +01:00
2019-12-17 20:35:17 +01:00
2020-08-07 09:36:21 +02:00
2020-02-24 08:34:46 +01:00
2019-07-26 09:14:07 +02:00
2019-04-05 22:32:56 +02:00
2019-12-05 09:19:38 +01:00
2019-04-05 22:32:56 +02:00
2021-07-11 12:49:28 +02:00
2021-11-26 11:36:14 +01:00
2020-01-27 14:50:37 +01:00
2021-12-14 10:18:04 +01:00
2022-02-23 11:58:38 +01:00
2021-11-26 11:35:56 +01:00
2020-04-02 15:28:22 +02:00
2020-12-30 11:26:01 +01:00
2020-10-01 13:14:30 +02:00
2019-12-05 09:20:25 +01:00
2019-12-13 08:51:07 +01:00
2018-10-02 14:38:02 -07:00
2020-06-22 09:05:03 +02:00
2020-01-27 14:51:05 +01:00
2021-12-08 08:50:13 +01:00
2021-09-22 11:48:11 +02:00
2019-04-03 06:26:28 +02:00
2021-05-22 10:59:39 +02:00
2019-05-31 06:46:16 -07:00
2021-06-30 08:48:18 -04:00
2019-03-13 14:02:35 -07:00
2021-03-17 16:43:51 +01:00
2021-02-13 13:51:15 +01:00
2018-10-12 12:35:02 +02:00
2020-04-17 10:48:43 +02:00
2019-12-05 09:20:57 +01:00
2020-04-23 10:30:19 +02:00
2020-01-27 14:50:22 +01:00
2021-03-07 12:19:01 +01:00
2018-12-29 13:37:55 +01:00
2018-11-13 11:08:51 -08:00
2020-07-31 18:37:48 +02:00
2022-01-05 12:34:57 +01:00
2021-03-24 11:07:37 +01:00
2020-11-18 19:18:40 +01:00
2019-12-21 10:57:17 +01:00
2019-11-20 18:45:24 +01:00
2021-10-09 14:11:04 +02:00
2020-01-23 08:21:32 +01:00
2019-12-05 09:19:49 +01:00
2020-12-30 11:26:01 +01:00
2018-10-17 15:35:29 -04:00
2021-07-20 16:15:42 +02:00
2021-05-22 10:59:31 +02:00
2020-12-11 13:25:01 +01:00
2021-03-30 14:36:58 +02:00
2020-09-09 19:04:29 +02:00
2021-03-24 11:07:34 +01:00
2019-05-08 07:21:44 +02:00
2021-12-29 12:20:44 +01:00
2019-04-17 08:38:52 +02:00
2020-10-07 08:00:05 +02:00
2020-04-29 16:31:27 +02:00
2019-07-14 08:11:21 +02:00
2020-04-02 15:28:23 +02:00
2021-12-14 10:18:06 +01:00
2020-08-11 15:32:34 +02:00
2021-03-07 12:19:01 +01:00