On Wed, Nov 22, 2023 at 10:15 AM Linux regression tracking (Thorsten Leemhuis) <regressions@xxxxxxxxxxxxx> wrote: > > On 12.11.23 19:10, Borislav Petkov wrote: > > On Sun, Nov 12, 2023 at 04:03:32PM +0100, Linux regression tracking (Thorsten Leemhuis) wrote: > >> That's because dracut until the recent commit > >> https://github.com/dracutdevs/dracut/commit/6c80408c8644a0add1907b0593eb83f90d6247b1 > >> looked for CONFIG_MICROCODE_AMD and CONFIG_MICROCODE_INTEL in the config > >> file to decide what to include or not. > > > > They've been told a bunch of times already that grepping .config for > > specific symbols is not how one should check whether one should add > > microcode blobs to the initrd or not because Kconfig symbols are not an > > ABI. > > Maybe, but you know how Linus sees things like this: what's considered > an ABI/API or not is nearly[1] irrelevant - if a change breaks something > that used to work then it needs to be fixed. > > [1] unless you fiddle with things obviously internal; not sure if this > case would qualify for him, but somehow I doubt it -- but I might be > wrong there. > Thorsten, I think you are wrong here in this case. We are talking about the kernel build configuration options and their names and these are certainly not stable and never have been. Some indication to show that the rate of change we are generally talking about without anyone considering this stable ABI/API: You can run "find . -name Kconfig* | xargs grep -h -E '^(menu)config ' | sort | uniq" on each kernel release. Then diff those lists of configs with increasing kernel config versions. If this would be stable, then only config options should appear and little should disappear, but that is not the case. And if something disappears, it should relate to a driver/feature that was removed, but that is also not always the case. Here are some quick numbers: v6.0 to v6.1: 43 removals v6.1 to v6.2: 40 removals v6.2 to v6.3: 350 removals v6.3 to v6.4: 86 removals v6.4 to v6.5: 73 removals v6.5 to v6.6: 61 removals * Removals can also be potentially a renaming. So, these config names are certainly not stable ABI/API. We can investigate a bit deeper on which changes are due to driver removals, which due to config removal but making a feature default and which are simply a config renaming, but in the past, hardly any kernel developer has considered this interface to be a special stable ABI/API. Further, to my knowledge looking at kernel discussions and the repository, there are currently no tools out there that would assist in updating a kernel build configuration from one version to the next. So, we are talking about roughly more than 50 removals to kernel config options every release, and now there was this one special case in one release, where a tool incorrectly relies on this one config option to be stable. That is not a regression of a stable ABI/API, that is a misuse of an internal non-stable ABI/API. Lukas