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 /util-linux | |
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 'util-linux')
-rw-r--r-- | util-linux/lspci.c | 11 | ||||
-rw-r--r-- | util-linux/lsusb.c | 10 | ||||
-rw-r--r-- | util-linux/mdev.c | 20 | ||||
-rw-r--r-- | util-linux/volume_id/get_devname.c | 14 |
4 files changed, 24 insertions, 31 deletions
diff --git a/util-linux/lspci.c b/util-linux/lspci.c index 2f0b5fab9..c22cbcc1e 100644 --- a/util-linux/lspci.c +++ b/util-linux/lspci.c | |||
@@ -37,11 +37,9 @@ enum { | |||
37 | /* | 37 | /* |
38 | * PCI_SLOT_NAME PCI_CLASS: PCI_VID:PCI_DID [PCI_SUBSYS_VID:PCI_SUBSYS_DID] [DRIVER] | 38 | * PCI_SLOT_NAME PCI_CLASS: PCI_VID:PCI_DID [PCI_SUBSYS_VID:PCI_SUBSYS_DID] [DRIVER] |
39 | */ | 39 | */ |
40 | static int FAST_FUNC fileAction( | 40 | static int FAST_FUNC fileAction(struct recursive_state *state UNUSED_PARAM, |
41 | const char *fileName, | 41 | const char *fileName, |
42 | struct stat *statbuf UNUSED_PARAM, | 42 | struct stat *statbuf UNUSED_PARAM) |
43 | void *userData UNUSED_PARAM, | ||
44 | int depth UNUSED_PARAM) | ||
45 | { | 43 | { |
46 | parser_t *parser; | 44 | parser_t *parser; |
47 | char *tokens[3]; | 45 | char *tokens[3]; |
@@ -117,8 +115,7 @@ int lspci_main(int argc UNUSED_PARAM, char **argv) | |||
117 | ACTION_RECURSE, | 115 | ACTION_RECURSE, |
118 | fileAction, | 116 | fileAction, |
119 | NULL, /* dirAction */ | 117 | NULL, /* dirAction */ |
120 | NULL, /* userData */ | 118 | NULL /* userData */ |
121 | 0 /* depth */); | 119 | ); |
122 | |||
123 | return EXIT_SUCCESS; | 120 | return EXIT_SUCCESS; |
124 | } | 121 | } |
diff --git a/util-linux/lsusb.c b/util-linux/lsusb.c index 64a00eee2..9abb748ce 100644 --- a/util-linux/lsusb.c +++ b/util-linux/lsusb.c | |||
@@ -24,11 +24,9 @@ | |||
24 | 24 | ||
25 | #include "libbb.h" | 25 | #include "libbb.h" |
26 | 26 | ||
27 | static int FAST_FUNC fileAction( | 27 | static int FAST_FUNC fileAction(struct recursive_state *state UNUSED_PARAM, |
28 | const char *fileName, | 28 | const char *fileName, |
29 | struct stat *statbuf UNUSED_PARAM, | 29 | struct stat *statbuf UNUSED_PARAM) |
30 | void *userData UNUSED_PARAM, | ||
31 | int depth UNUSED_PARAM) | ||
32 | { | 30 | { |
33 | parser_t *parser; | 31 | parser_t *parser; |
34 | char *tokens[4]; | 32 | char *tokens[4]; |
@@ -80,8 +78,8 @@ int lsusb_main(int argc UNUSED_PARAM, char **argv UNUSED_PARAM) | |||
80 | ACTION_RECURSE, | 78 | ACTION_RECURSE, |
81 | fileAction, | 79 | fileAction, |
82 | NULL, /* dirAction */ | 80 | NULL, /* dirAction */ |
83 | NULL, /* userData */ | 81 | NULL /* userData */ |
84 | 0 /* depth */); | 82 | ); |
85 | 83 | ||
86 | return EXIT_SUCCESS; | 84 | return EXIT_SUCCESS; |
87 | } | 85 | } |
diff --git a/util-linux/mdev.c b/util-linux/mdev.c index f42bebc20..59dbcf0cd 100644 --- a/util-linux/mdev.c +++ b/util-linux/mdev.c | |||
@@ -845,13 +845,12 @@ static ssize_t readlink2(char *buf, size_t bufsize) | |||
845 | /* File callback for /sys/ traversal. | 845 | /* File callback for /sys/ traversal. |
846 | * We act only on "/sys/.../dev" (pseudo)file | 846 | * We act only on "/sys/.../dev" (pseudo)file |
847 | */ | 847 | */ |
848 | static int FAST_FUNC fileAction(const char *fileName, | 848 | static int FAST_FUNC fileAction(struct recursive_state *state, |
849 | struct stat *statbuf UNUSED_PARAM, | 849 | const char *fileName, |
850 | void *userData, | 850 | struct stat *statbuf UNUSED_PARAM) |
851 | int depth UNUSED_PARAM) | ||
852 | { | 851 | { |
853 | size_t len = strlen(fileName) - 4; /* can't underflow */ | 852 | size_t len = strlen(fileName) - 4; /* can't underflow */ |
854 | char *path = userData; /* char array[PATH_MAX + SCRATCH_SIZE] */ | 853 | char *path = state->userData; /* char array[PATH_MAX + SCRATCH_SIZE] */ |
855 | char subsys[PATH_MAX]; | 854 | char subsys[PATH_MAX]; |
856 | int res; | 855 | int res; |
857 | 856 | ||
@@ -888,12 +887,11 @@ static int FAST_FUNC fileAction(const char *fileName, | |||
888 | } | 887 | } |
889 | 888 | ||
890 | /* Directory callback for /sys/ traversal */ | 889 | /* Directory callback for /sys/ traversal */ |
891 | static int FAST_FUNC dirAction(const char *fileName UNUSED_PARAM, | 890 | static int FAST_FUNC dirAction(struct recursive_state *state, |
892 | struct stat *statbuf UNUSED_PARAM, | 891 | const char *fileName UNUSED_PARAM, |
893 | void *userData UNUSED_PARAM, | 892 | struct stat *statbuf UNUSED_PARAM) |
894 | int depth) | ||
895 | { | 893 | { |
896 | return (depth >= MAX_SYSFS_DEPTH ? SKIP : TRUE); | 894 | return (state->depth >= MAX_SYSFS_DEPTH ? SKIP : TRUE); |
897 | } | 895 | } |
898 | 896 | ||
899 | /* For the full gory details, see linux/Documentation/firmware_class/README | 897 | /* For the full gory details, see linux/Documentation/firmware_class/README |
@@ -1149,7 +1147,7 @@ static void initial_scan(char *temp) | |||
1149 | /* Create all devices from /sys/dev hierarchy */ | 1147 | /* Create all devices from /sys/dev hierarchy */ |
1150 | recursive_action("/sys/dev", | 1148 | recursive_action("/sys/dev", |
1151 | ACTION_RECURSE | ACTION_FOLLOWLINKS, | 1149 | ACTION_RECURSE | ACTION_FOLLOWLINKS, |
1152 | fileAction, dirAction, temp, 0); | 1150 | fileAction, dirAction, temp); |
1153 | } | 1151 | } |
1154 | 1152 | ||
1155 | #if ENABLE_FEATURE_MDEV_DAEMON | 1153 | #if ENABLE_FEATURE_MDEV_DAEMON |
diff --git a/util-linux/volume_id/get_devname.c b/util-linux/volume_id/get_devname.c index 34f5d119f..00cfb2826 100644 --- a/util-linux/volume_id/get_devname.c +++ b/util-linux/volume_id/get_devname.c | |||
@@ -102,10 +102,9 @@ uuidcache_addentry(char *device, /*int major, int minor,*/ char *label, char *uu | |||
102 | * add a cache entry for this device. | 102 | * add a cache entry for this device. |
103 | * If device node does not exist, it will be temporarily created. */ | 103 | * If device node does not exist, it will be temporarily created. */ |
104 | static int FAST_FUNC | 104 | static int FAST_FUNC |
105 | uuidcache_check_device(const char *device, | 105 | uuidcache_check_device(struct recursive_state *state UNUSED_PARAM, |
106 | struct stat *statbuf, | 106 | const char *device, |
107 | void *userData UNUSED_PARAM, | 107 | struct stat *statbuf) |
108 | int depth UNUSED_PARAM) | ||
109 | { | 108 | { |
110 | /* note: this check rejects links to devices, among other nodes */ | 109 | /* note: this check rejects links to devices, among other nodes */ |
111 | if (!S_ISBLK(statbuf->st_mode) | 110 | if (!S_ISBLK(statbuf->st_mode) |
@@ -145,12 +144,13 @@ uuidcache_init(int scan_devices) | |||
145 | * This is unacceptably complex. Let's just scan /dev. | 144 | * This is unacceptably complex. Let's just scan /dev. |
146 | * (Maybe add scanning of /sys/block/XXX/dev for devices | 145 | * (Maybe add scanning of /sys/block/XXX/dev for devices |
147 | * somehow not having their /dev/XXX entries created?) */ | 146 | * somehow not having their /dev/XXX entries created?) */ |
148 | if (scan_devices) | 147 | if (scan_devices) { |
149 | recursive_action("/dev", ACTION_RECURSE, | 148 | recursive_action("/dev", ACTION_RECURSE, |
150 | uuidcache_check_device, /* file_action */ | 149 | uuidcache_check_device, /* file_action */ |
151 | NULL, /* dir_action */ | 150 | NULL, /* dir_action */ |
152 | NULL, /* userData */ | 151 | NULL /* userData */ |
153 | 0 /* depth */); | 152 | ); |
153 | } | ||
154 | 154 | ||
155 | return uuidCache; | 155 | return uuidCache; |
156 | } | 156 | } |