1 This patch changes 'modprobe' & co. so they honor the 'LINUX_MODULE_DIRECTORY'
2 environment variable, rather than looking for modules exclusively in
5 Original patch by David Guibert, from Nixpkgs; adjusted to use
6 'LINUX_MODULE_DIRECTORY' rather than 'MODULE_DIR' as the variable name.
8 diff --git a/depmod.c b/depmod.c
9 index a1d2f8c..ff579c7 100644
17 -#define MODULE_DIR "/lib/modules/"
20 #ifndef MODULE_BUILTIN_KEY
21 #define MODULE_BUILTIN_KEY "built-in"
22 @@ -1516,6 +1513,7 @@ static int parse_config_file(const char *filename,
24 unsigned int linenum = 0;
28 cfile = fopen(filename, "r");
30 @@ -1525,6 +1523,10 @@ static int parse_config_file(const char *filename,
34 + if((module_dir = getenv("LINUX_MODULE_DIRECTORY")) == NULL) {
35 + module_dir = "/lib/modules";
38 while ((line = getline_wrapped(cfile, &linenum)) != NULL) {
41 @@ -1549,8 +1551,8 @@ static int parse_config_file(const char *filename,
45 - nofail_asprintf(&dirname, "%s%s%s/%s", basedir,
46 - MODULE_DIR, kernelversion, search_path);
47 + nofail_asprintf(&dirname, "%s%s/%s/%s", basedir,
48 + module_dir, kernelversion, search_path);
49 len = strlen(dirname);
50 *search = add_search(dirname, len, *search);
52 @@ -1564,8 +1566,8 @@ static int parse_config_file(const char *filename,
53 if (!regex_match(kernelversion, (const char *)version))
56 - nofail_asprintf(&pathname, "%s%s%s/%s/%s.ko", basedir,
57 - MODULE_DIR, kernelversion, subdir, modname);
58 + nofail_asprintf(&pathname, "%s%s/%s/%s/%s.ko", basedir,
59 + module_dir, kernelversion, subdir, modname);
61 *overrides = add_override(pathname, *overrides);
63 @@ -1737,6 +1739,7 @@ int main(int argc, char *argv[])
64 char *basedir = "", *dirname, *version;
65 char *system_map = NULL, *module_symvers = NULL;
68 const char *config = NULL;
70 if (native_endianness() == 0)
71 @@ -1832,7 +1835,11 @@ int main(int argc, char *argv[])
75 - nofail_asprintf(&dirname, "%s%s%s", basedir, MODULE_DIR, version);
76 + if((module_dir = getenv("LINUX_MODULE_DIRECTORY")) == NULL) {
77 + module_dir = "/lib/modules";
80 + nofail_asprintf(&dirname, "%s%s/%s", basedir, module_dir, version);
83 if (!doing_stdout && !depfile_out_of_date(dirname))
84 @@ -1849,8 +1856,8 @@ int main(int argc, char *argv[])
88 - nofail_asprintf(&dirname, "%s%s%s/updates", basedir,
89 - MODULE_DIR, version);
90 + nofail_asprintf(&dirname, "%s%s/%s/updates", basedir,
91 + module_dir, version);
92 len = strlen(dirname);
93 search = add_search(dirname, len, search);
95 diff --git a/modinfo.c b/modinfo.c
96 index 1dd8469..6a1865b 100644
100 #include "zlibsupport.h"
104 -#define MODULE_DIR "/lib/modules"
109 @@ -193,6 +190,11 @@ static struct elf_file *grab_module(const char *name,
111 char *depname, *p, *moddir;
112 struct elf_file *module;
115 + if((module_dir = getenv("LINUX_MODULE_DIRECTORY")) == NULL) {
116 + module_dir = "/lib/modules";
119 if (strchr(name, '.') || strchr(name, '/')) {
120 module = grab_elf_file(name);
121 @@ -207,9 +209,9 @@ static struct elf_file *grab_module(const char *name,
122 kernel = buf.release;
125 - nofail_asprintf(&moddir, "%s/%s/%s", basedir, MODULE_DIR, kernel);
126 + nofail_asprintf(&moddir, "%s/%s/%s", basedir, module_dir, kernel);
128 - nofail_asprintf(&moddir, "%s/%s", MODULE_DIR, kernel);
129 + nofail_asprintf(&moddir, "%s/%s", module_dir, kernel);
131 /* Search for it in modules.dep. */
132 nofail_asprintf(&depname, "%s/%s", moddir, "modules.dep");
133 diff --git a/modprobe.c b/modprobe.c
134 index 5464f45..cb57917 100644
137 @@ -86,10 +86,6 @@ typedef enum
142 -#define MODULE_DIR "/lib/modules"
146 * print_usage - output the prefered program usage
148 @@ -2136,6 +2132,7 @@ int main(int argc, char *argv[])
149 struct modprobe_conf conf = {};
152 + char *module_dir = NULL;
154 /* Prepend options from environment. */
155 argv = merge_args(getenv("MODPROBE_OPTIONS"), argv, &argc);
156 @@ -2233,7 +2230,11 @@ int main(int argc, char *argv[])
157 if (argc < optind + 1 && !dump_config && !list_only)
158 print_usage(argv[0]);
160 - nofail_asprintf(&dirname, "%s%s/%s", basedir, MODULE_DIR, buf.release);
161 + if((module_dir = getenv("LINUX_MODULE_DIRECTORY")) == NULL) {
162 + module_dir = "/lib/modules";
165 + nofail_asprintf(&dirname, "%s%s/%s", basedir, module_dir, buf.release);
167 /* Old-style -t xxx wildcard? Only with -l. */