-
Notifications
You must be signed in to change notification settings - Fork 29
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
deferred-probe-empty test failures on Intel-based Chromebooks #218
Comments
@hardboprobot I was testing this to make sure if it still fails as someone pointed this out on buganizer as well. I see that the tests are passing now. |
@crazoes which kernel config did you use for that test run? |
Is it expected kernel behaviour to be pending on a deferred probe when the driver is not even registered? There's always some implicit kernel config requirements to boot on any given type of hardware, but in this case it seems to be a grey area as one could argue the kernel should be able to deal with this more gracefully. Maybe the parent driver waiting for the deferred probe shouldn't have probed itself if it's missing a dependency. @hardboprobot Could you please list the extra configs you had to enable to make the deferred probe issue go away? |
@gctucker About the deferred probe semantics and the kernel handling this more gracefully, I agree. AFAIK the deferred probe mechanism doesn't really enforce anything and each driver is free to use it in the way it feels more appropriate, so gray areas are expected, I think. From a testing point of view, a more elaborated solution for this could be done, in theory, by checking the kernel config and discarding a certain deferred probe failure if the key config option is missing, but that wouldn't be practical at all: it's not trivial to match the error messages to the config options and it'd be incredibly painful to maintain. So fixing the configs, even if it's overkill to add more options than necessary, could be the most reasonable workaround here. The full config file was linked above: https://people.collabora.com/~rcn/kernel_config_snd_modules.config, most of the differences have to do with soundcard support:
|
OK thanks @hardboprobot, so we can treat this as "suboptimal design" in the kernel and compensate by adding config options in KernelCI to suppress the deferred probe warnings. Maybe a longer-term improvement in the kernel side of things would be to solve dependency between drivers and probed devices as I think that's always been a weakness, but I don't think it's realistic. Or maybe some small parts could be improved, like only for ACPI or only for device tree platforms we could catch things earlier if we can tell some devices will never probe at runtime or add more checks at build time. Well that's just me brain storming here :p |
@hardboprobot here is the config file for your reference. Also, I tested this on regressions happening in chrome-platform/for-kernelci. I just followed the usual way through Here are the lava jobs for it. |
@crazoes What changed between the builds from your tests and this one for instance? The kernel versions are supposed to be the same: chrome-platform/for-kernelci v6.5-rc1-1-ga6edd5f5d9cc and the config is supposed to be the same as well: x86_64_defconfig+x86-chromebook The last test runs for this using KernelCI builds still fail. |
@hardboprobot that's the weird thing about it which I cannot figure out why it started to work now. I checked the x86-chromebook config options and there have been no recent additions to it related to sound. There were only some config options added by Laura which were related to Video Codec. Also, @nfraprado added the deferred probe timeout = 60s but I think was already being used by these devices and I could see it in the logs for it. |
@hardboprobot can you verify this on your side as well to confirm if I am not doing anything wrong here while building the kernel? |
@gctucker can we add the config options for now in KernelCI to resolve the warnings for now? If yes, then will this go as fragments in |
One issue with adding lots of config options is that it makes the build further away from the base defconfig. So the kernel may start showing different results than the same tests run on other platforms without the fragment, which makes comparisons a bit harder to make. Other than that, if this is to be added to the |
I understand the problem and that is why I was trying to narrow down the config options but it is very complicated to find the exact config options needed by these devices, especially when there are multiple devices failing due to missing codec configs. I was only able to identify the config options for
But they don't work for other hp and asus devices. |
Old issue. (also we are not tracking kernel test failure/issues through GitHub anymore) |
@gctucker @nuclearcat Not a kernel bug but something to fix in the KernelCI kernel builds instead.
There are a lot of bootrr
deferred-probe-empty
tests failing on almost all Intel-based Chromebooks since forever. Example: https://linux.kernelci.org/test/case/id/64810f3a4b727ea9fd30618b/Depending on the board there might be different deferred drivers:
hatch
andvolteer
:sona
andoctopus
:zork
anddalboz
:I haven't seen these on
grunt
orsarien
.This seems related to the kernel config. I could reproduce the problem easily with the kernel configuration from one of the failing tests: https://lava.collabora.dev/scheduler/job/10685806 (config = x86_64_defconfig+x86-chromebook)
and then I checked that it doesn't fail with a kernel configured with a custom config that enables most soundcard drivers and codecs: https://lava.collabora.dev/scheduler/job/11007480
Fixing this would clean up the test result logs and reports considerably.
The text was updated successfully, but these errors were encountered: