diff options
author | Denys Vlasenko <vda.linux@googlemail.com> | 2020-10-01 21:52:16 +0200 |
---|---|---|
committer | Denys Vlasenko <vda.linux@googlemail.com> | 2020-10-01 21:52:16 +0200 |
commit | 689d0650ab63425adaea26afe347015a204958ee (patch) | |
tree | 9c2e10b952cad6804359bc10ccc963ff138fc3d4 /modutils/modprobe.c | |
parent | 3c3928fc658bddacd4e540589868bc28a8e4ca0a (diff) | |
download | busybox-w32-689d0650ab63425adaea26afe347015a204958ee.tar.gz busybox-w32-689d0650ab63425adaea26afe347015a204958ee.tar.bz2 busybox-w32-689d0650ab63425adaea26afe347015a204958ee.zip |
libbb: shrink recursive_action() by reducing memory pressure
function old new delta
recursive_action1 - 316 +316
file_action_grep 161 164 +3
add_to_prg_cache_if_socket 202 205 +3
depmod_main 509 511 +2
writeFileToTarball 488 489 +1
parse_module 281 282 +1
fileAction 207 208 +1
act 189 190 +1
add_to_dirlist 65 64 -1
writeTarFile 196 194 -2
uuidcache_init 47 45 -2
uuidcache_check_device 109 107 -2
true_action 8 6 -2
run_parts_main 310 308 -2
netstat_main 534 532 -2
lsusb_main 29 27 -2
lspci_main 45 43 -2
initial_scan 138 136 -2
grep_main 845 843 -2
find_main 482 480 -2
config_file_action 437 435 -2
chmod_main 142 140 -2
dirAction 14 10 -4
diff_main 1544 1540 -4
chown_main 154 148 -6
skip_dir 136 129 -7
dir_act 191 184 -7
recursive_action 453 69 -384
------------------------------------------------------------------------------
(add/remove: 1/0 grow/shrink: 7/20 up/down: 328/-439) Total: -111 bytes
Signed-off-by: Denys Vlasenko <vda.linux@googlemail.com>
Diffstat (limited to 'modutils/modprobe.c')
-rw-r--r-- | modutils/modprobe.c | 14 |
1 files changed, 6 insertions, 8 deletions
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) |