summarylogtreecommitdiffstats
path: root/0004-kernel-4.19-depmod-disable-for-packaging.patch
blob: ed42baa9c25e892fb8a8d8f53db56559469c47b1 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
https://bbs.archlinux.org/viewtopic.php?pid=2191292

2024-08-22 Arch Linux changed the default module folder
from /lib/modules to /usr/lib/modules. Unfortunately there
are a lot of scripts and makefiles that use one or the
other and contain a lot of hacks to add or remove /usr as
necessary. Changing the default in depmod breaks various
scripts which aren't yet written to handle both folder
names. DEPMOD is needed for make install. It is not needed
for packaging where an alpm hook runs DEPMOD. Until the
scripts are fixed, running DEPMOD for packaging is crashing
packages like zfs that build kernel modules in make
module_install.

Linux 6.6 and 6.10 have fixed the problem and eliminated
the wasted time by disabling DEPMOD with
DEPMOD=/doesnt/exist. Here we disable DEPMOD for anything
except "sudo make install."

According to make help, the default for INSTALL_MOD_PATH is
"/". If it can be blank, this won't work right. This has
been tested with "make install DESTDIR=..." for the kernel
and packages. This has not been tested with "make install."
This patch will break distros that don't have a depmod
hook.

Alas, this blanket fix will leave all those scripts and
makefiles with their buggy hacks unfixed.

For 4.19 I originally patched out $(call cmd,depmod) in
_modinst_post kernel compile and _emodinst_post for a
package that includes a kernel module like zfs. However I
decided that silently dropping DEPMOD obfuscates what we're
doing leading to bugs that noone knows how to report. This
patch shows it on the screen so where it is wrong, bug
reports can be filed with the appropriate distros.

A good patch would probably include an override to force
the DEPMOD.

CJS severach@aur

diff -pNaru5 a/Makefile b/Makefile
--- a/Makefile	2024-08-22 13:26:56.242300916 -0400
+++ b/Makefile	2024-08-22 13:28:37.493383948 -0400
@@ -1749,13 +1749,18 @@ quiet_cmd_rmdirs = $(if $(wildcard $(rm-
 
 quiet_cmd_rmfiles = $(if $(wildcard $(rm-files)),CLEAN   $(wildcard $(rm-files)))
       cmd_rmfiles = rm -f $(rm-files)
 
 # Run depmod only if we have System.map and depmod is executable
+ifeq ($(INSTALL_MOD_PATH),/)
 quiet_cmd_depmod = DEPMOD  $(KERNELRELEASE)
       cmd_depmod = $(CONFIG_SHELL) $(srctree)/scripts/depmod.sh $(DEPMOD) \
                    $(KERNELRELEASE)
+else
+quiet_cmd_depmod = DEPMOD  $(KERNELRELEASE) skipped for packaging to $(INSTALL_MOD_PATH)
+      cmd_depmod = true depmod $(KERNELRELEASE) skipped for packaging to $(INSTALL_MOD_PATH)
+endif
 
 # Create temporary dir for module support files
 # clean it up only when building all modules
 cmd_crmodverdir = $(Q)mkdir -p $(MODVERDIR) \
                   $(if $(KBUILD_MODULES),; rm -f $(MODVERDIR)/*)