[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <354820e8-939c-781a-0d76-c1574c43b7f3@redhat.com>
Date: Mon, 14 Nov 2022 12:13:15 +0100
From: Javier Martinez Canillas <javierm@...hat.com>
To: Greg Kroah-Hartman <gregkh@...uxfoundation.org>
Cc: linux-kernel@...r.kernel.org,
Saravana Kannan <saravanak@...gle.com>,
Peter Robinson <pbrobinson@...hat.com>,
Steev Klimaszewski <steev@...i.org>,
Rob Herring <robh@...nel.org>,
Sergio Lopez Pascual <slp@...hat.com>,
Enric Balletbo i Serra <eballetbo@...hat.com>,
John Stultz <jstultz@...gle.com>,
"Rafael J. Wysocki" <rafael@...nel.org>
Subject: Re: [PATCH] driver core: Disable driver deferred probe timeout by
default
Hello Greg,
Thanks a lot for your feedback.
On 11/14/22 11:54, Greg Kroah-Hartman wrote:
[...]
>>
>> This default value of 0 was reverted again by commit f516d01b9df2 ("Revert
>> "driver core: Set default deferred_probe_timeout back to 0."") and set to
>> 10 seconds instead. Which was still less than the 30 seconds that was set
>> at some point to allow systems with drivers built as modules and loaded by
>> user-land to probe drivers that were previously deferred.
>>
>> The 10 seconds timeout isn't enough for the mentioned systems, for example
>> general purpose distributions attempt to build all the possible drivers as
>> a module to keep the Linux kernel image small. But that means that in very
>> likely that the probe deferral mechanism will timeout and drivers won't be
>> probed correctly.
>
> What specific "mentioned systems" have deferred probe drivers that are
The "mentioned systems" are the ones mentioned in the paragraph above:
"to allow systems with drivers built as modules and loaded by user-land to
probe drivers that were previously deferred."
I even gave an example about general purpose distributions that build as
much as possible as a module. What more info do you think that is missing?
> failing on the current value? What drivers are causing the long delay
> here? No one should be having to wait 10 seconds for a deferred delay
> on a real system as that feels really wrong.
>
Not really, it depends if the drivers are built-in, built as modules, in
the initramfs or in the rootfs. A 10 seconds might not be enough if these
modules are in the root partition and need to wait for this to be mounted
and udev to load the modules, etc.
Also, it may even be that the module alias is not correct and then users
have to load them by explicitly have /etc/modules-load.d/ configs and so
on.
> Why not fix the drivers that are causing this delay and maybe move them
> to be async so as to not slow down the whole boot process?
>
Yes, these drivers could be fixed to report a proper module alias or the
dependencies can be built-in or added to the initramfs and that does not
change the fact that by default the kernel shouldn't make assumptions
about when is safe to just timeout instead of -EPROBE_DEFER.
Because with modules the kernel has no way to know when all the modules
have been already been loaded by user-space or more drivers are going to
be registered in the future.
Also, that's how probe deferral always worked since the mechanism was
introduced. It's just recently that the behavior was changed to timeout.
A nice feature of the probe deferral mechanism is that it was simple and
reliable. Adding a timeout makes it non-deterministic and more fragile IMO.
--
Best regards,
Javier Martinez Canillas
Core Platforms
Red Hat
Powered by blists - more mailing lists