Hi,
Upstream kernel commit 88a686728b37 ("kbuild: simplify access to the kernel's version") [0] extended the Makefile to add the following defines to the linux/version.h file: #define LINUX_VERSION_MAJOR $(VERSION) #define LINUX_VERSION_PATCHLEVEL $(PATCHLEVEL) #define LINUX_VERSION_SUBLEVEL $(SUBLEVEL)
I would like to have these defines especially LINUX_VERSION_SUBLEVEL also in older stable kernel versions to make it easier for out of tree kernel code to detect which version it is compiling against.
In the Linux drivers backports project [1] we backport the current wifi driver to older Linux versions, so someone with an old kernel can use current wifi drivers. To make this work we have to know which kernel version it is being compiled against. The Makefile has access to the SUBLEVEL variable and can also forward it to the C code, but this does not work when someone compiles some other driver against the mac80211 subsystem provided by backports for example.
I tried to cherry-pick commit 88a686728b37 to kernel 4.9, but it did not apply cleanly. Would it get accepted when I just port the changes in the main Makefile to the currently supported LTS kernel versions?
Hauke
[0]: https://git.kernel.org/linus/88a686728b3739d3598851e729c0e81f194e5c53 [1]: https://backports.wiki.kernel.org/index.php/Main_Page
Here would be my suggestion for kernel 4.9, I haven't tested this yet: --- a/Makefile +++ b/Makefile @@ -1142,7 +1142,10 @@ endef define filechk_version.h (echo #define LINUX_VERSION_CODE $(shell \ expr $(VERSION) * 65536 + 0$(PATCHLEVEL) * 256 + 255); \ - echo '#define KERNEL_VERSION(a,b,c) (((a) << 16) + ((b) << 8) + (c))';) + echo '#define KERNEL_VERSION(a,b,c) (((a) << 16) + ((b) << 8) + (c))';) \ + echo #define LINUX_VERSION_MAJOR $(VERSION); \ + echo #define LINUX_VERSION_PATCHLEVEL $(PATCHLEVEL); \ + echo #define LINUX_VERSION_SUBLEVEL $(SUBLEVEL) endef
$(version_h): $(srctree)/Makefile FORCE