diff options
Diffstat (limited to 'modutils')
-rw-r--r-- | modutils/depmod.c | 12 | ||||
-rw-r--r-- | modutils/modprobe-small.c | 3 | ||||
-rw-r--r-- | modutils/modprobe.c | 14 |
3 files changed, 14 insertions, 15 deletions
diff --git a/modutils/depmod.c b/modutils/depmod.c index 318e7cdc7..bb42bbefe 100644 --- a/modutils/depmod.c +++ b/modutils/depmod.c | |||
@@ -32,10 +32,11 @@ | |||
32 | * for each depends, look through our list of full paths and emit if found | 32 | * for each depends, look through our list of full paths and emit if found |
33 | */ | 33 | */ |
34 | 34 | ||
35 | static int FAST_FUNC parse_module(const char *fname, struct stat *sb UNUSED_PARAM, | 35 | static int FAST_FUNC parse_module(struct recursive_state *state, |
36 | void *data, int depth UNUSED_PARAM) | 36 | const char *fname, |
37 | struct stat *sb UNUSED_PARAM) | ||
37 | { | 38 | { |
38 | module_db *modules = data; | 39 | module_db *modules = state->userData; |
39 | char *image, *ptr; | 40 | char *image, *ptr; |
40 | module_entry *e; | 41 | module_entry *e; |
41 | 42 | ||
@@ -201,11 +202,12 @@ int depmod_main(int argc UNUSED_PARAM, char **argv) | |||
201 | memset(&modules, 0, sizeof(modules)); | 202 | memset(&modules, 0, sizeof(modules)); |
202 | if (*argv) { | 203 | if (*argv) { |
203 | do { | 204 | do { |
204 | parse_module(*argv, /*sb (unused):*/ NULL, &modules, 0); | 205 | recursive_action(*argv, 0 /* no ACTION_RECURSE! */, |
206 | parse_module, NULL, &modules); | ||
205 | } while (*++argv); | 207 | } while (*++argv); |
206 | } else { | 208 | } else { |
207 | recursive_action(".", ACTION_RECURSE, | 209 | recursive_action(".", ACTION_RECURSE, |
208 | parse_module, NULL, &modules, 0); | 210 | parse_module, NULL, &modules); |
209 | } | 211 | } |
210 | 212 | ||
211 | /* Generate dependency and alias files */ | 213 | /* Generate dependency and alias files */ |
diff --git a/modutils/modprobe-small.c b/modutils/modprobe-small.c index a94b0b9a6..18cfac481 100644 --- a/modutils/modprobe-small.c +++ b/modutils/modprobe-small.c | |||
@@ -751,8 +751,7 @@ static int process_module(char *name, const char *cmdline_options) | |||
751 | ACTION_RECURSE, /* flags */ | 751 | ACTION_RECURSE, /* flags */ |
752 | fileAction, /* file action */ | 752 | fileAction, /* file action */ |
753 | NULL, /* dir action */ | 753 | NULL, /* dir action */ |
754 | name, /* user data */ | 754 | name /* user data */ |
755 | 0 /* depth */ | ||
756 | ); | 755 | ); |
757 | dbg1_error_msg("dirscan complete"); | 756 | dbg1_error_msg("dirscan complete"); |
758 | /* Module was not found, or load failed, or is_remove */ | 757 | /* Module was not found, or load failed, or is_remove */ |
diff --git a/modutils/modprobe.c b/modutils/modprobe.c index 70c45903a..eeeff7609 100644 --- a/modutils/modprobe.c +++ b/modutils/modprobe.c | |||
@@ -235,10 +235,9 @@ static void add_probe(const char *name) | |||
235 | } | 235 | } |
236 | } | 236 | } |
237 | 237 | ||
238 | static int FAST_FUNC config_file_action(const char *filename, | 238 | static int FAST_FUNC config_file_action(struct recursive_state *state, |
239 | struct stat *statbuf UNUSED_PARAM, | 239 | const char *filename, |
240 | void *userdata UNUSED_PARAM, | 240 | struct stat *statbuf UNUSED_PARAM) |
241 | int depth) | ||
242 | { | 241 | { |
243 | char *tokens[3]; | 242 | char *tokens[3]; |
244 | parser_t *p; | 243 | parser_t *p; |
@@ -255,7 +254,7 @@ static int FAST_FUNC config_file_action(const char *filename, | |||
255 | * that we shouldn't recurse into /etc/modprobe.d/dir/ | 254 | * that we shouldn't recurse into /etc/modprobe.d/dir/ |
256 | * _subdirectories_: | 255 | * _subdirectories_: |
257 | */ | 256 | */ |
258 | if (depth > 1) | 257 | if (state->depth > 1) |
259 | return SKIP; /* stop recursing */ | 258 | return SKIP; /* stop recursing */ |
260 | //TODO: instead, can use dirAction in recursive_action() to SKIP dirs | 259 | //TODO: instead, can use dirAction in recursive_action() to SKIP dirs |
261 | //on depth == 1 level. But that's more code... | 260 | //on depth == 1 level. But that's more code... |
@@ -264,7 +263,7 @@ static int FAST_FUNC config_file_action(const char *filename, | |||
264 | * depth==0: read_config("modules.{symbols,alias}") must work, | 263 | * depth==0: read_config("modules.{symbols,alias}") must work, |
265 | * "include FILE_NOT_ENDING_IN_CONF" must work too. | 264 | * "include FILE_NOT_ENDING_IN_CONF" must work too. |
266 | */ | 265 | */ |
267 | if (depth != 0) { | 266 | if (state->depth != 0) { |
268 | if (!is_suffixed_with(base, ".conf")) | 267 | if (!is_suffixed_with(base, ".conf")) |
269 | goto error; | 268 | goto error; |
270 | } | 269 | } |
@@ -329,8 +328,7 @@ static int FAST_FUNC config_file_action(const char *filename, | |||
329 | static int read_config(const char *path) | 328 | static int read_config(const char *path) |
330 | { | 329 | { |
331 | return recursive_action(path, ACTION_RECURSE | ACTION_QUIET, | 330 | return recursive_action(path, ACTION_RECURSE | ACTION_QUIET, |
332 | config_file_action, NULL, NULL, | 331 | config_file_action, NULL, NULL); |
333 | /*depth:*/ 0); | ||
334 | } | 332 | } |
335 | 333 | ||
336 | static const char *humanly_readable_name(struct module_entry *m) | 334 | static const char *humanly_readable_name(struct module_entry *m) |