diff options
author | Denis Vlasenko <vda.linux@googlemail.com> | 2007-04-09 03:11:58 +0000 |
---|---|---|
committer | Denis Vlasenko <vda.linux@googlemail.com> | 2007-04-09 03:11:58 +0000 |
commit | c44ab01b75aba758fe0aff4b34b25d733e370dc2 (patch) | |
tree | 7aaff270868ae6e6ff78fb5c42d42f5645a6a67a /include/libbb.h | |
parent | 95cb3263ae8f9afda0f6af3f777739506a0dfc62 (diff) | |
download | busybox-w32-c44ab01b75aba758fe0aff4b34b25d733e370dc2.tar.gz busybox-w32-c44ab01b75aba758fe0aff4b34b25d733e370dc2.tar.bz2 busybox-w32-c44ab01b75aba758fe0aff4b34b25d733e370dc2.zip |
Improve STANDALONE_SHELL. "safe" applets are renamed NOEXEC applets
and now this fact is recorded in applets.h, not ash.c.
Several fixes to "--help + STANDALONE_SHELL" scenarios.
function old new delta
run_current_applet_and_exit - 355 +355
arith 2064 2073 +9
refresh 1148 1156 +8
getopt32 1068 1073 +5
telnet_main 1510 1514 +4
md5_sha1_sum_main 565 566 +1
xstrtoul_range_sfx 255 251 -4
packed_usage 22523 22514 -9
tryexec 255 203 -52
static.safe_applets 152 - -152
.rodata 131320 131128 -192
run_applet_by_name 869 506 -363
------------------------------------------------------------------------------
(add/remove: 1/1 grow/shrink: 5/5 up/down: 382/-772) Total: -390 bytes
./busybox ash -c 'i=20000; while test $i != 0; do touch z; i=$((i-1)); done'
runs more than twice as fast with STANDALONE_SHELL versus without.
Diffstat (limited to 'include/libbb.h')
-rw-r--r-- | include/libbb.h | 5 |
1 files changed, 4 insertions, 1 deletions
diff --git a/include/libbb.h b/include/libbb.h index 8f43aeafc..4fc5d183f 100644 --- a/include/libbb.h +++ b/include/libbb.h | |||
@@ -662,9 +662,11 @@ const struct hwtype *get_hwntype(int type); | |||
662 | 662 | ||
663 | 663 | ||
664 | #ifndef BUILD_INDIVIDUAL | 664 | #ifndef BUILD_INDIVIDUAL |
665 | extern struct BB_applet *find_applet_by_name(const char *name); | 665 | struct BB_applet; |
666 | extern const struct BB_applet *find_applet_by_name(const char *name); | ||
666 | /* Returns only if applet is not found. */ | 667 | /* Returns only if applet is not found. */ |
667 | extern void run_applet_by_name(const char *name, int argc, char **argv); | 668 | extern void run_applet_by_name(const char *name, int argc, char **argv); |
669 | extern void run_current_applet_and_exit(int argc, char **argv) ATTRIBUTE_NORETURN; | ||
668 | #endif | 670 | #endif |
669 | 671 | ||
670 | extern int match_fstype(const struct mntent *mt, const char *fstypes); | 672 | extern int match_fstype(const struct mntent *mt, const char *fstypes); |
@@ -870,6 +872,7 @@ enum { /* DO NOT CHANGE THESE VALUES! cp.c, mv.c, install.c depend on them. */ | |||
870 | }; | 872 | }; |
871 | 873 | ||
872 | #define FILEUTILS_CP_OPTSTR "pdRfils" USE_SELINUX("c") | 874 | #define FILEUTILS_CP_OPTSTR "pdRfils" USE_SELINUX("c") |
875 | extern const struct BB_applet *current_applet; | ||
873 | extern const char *applet_name; | 876 | extern const char *applet_name; |
874 | extern const char BB_BANNER[]; | 877 | extern const char BB_BANNER[]; |
875 | 878 | ||