Welcome to mirror list, hosted at ThFree Co, Russian Federation.

git.busybox.net/busybox.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDenys Vlasenko <vda.linux@googlemail.com>2023-07-10 11:52:41 +0300
committerDenys Vlasenko <vda.linux@googlemail.com>2023-07-10 11:53:23 +0300
commit5e0411a7fb510b9aecda0a850c76bdd62c50efa4 (patch)
treed3698f53c76998c940131e18aca0cf5e025c6605
parent6ce1dc2e91398145633ceaff7a6fecc786826277 (diff)
ash: disable sleep as builtin, closes 15619
Has a few annoying problems: * sleepcmd() -> sleep_main(), the parsing of bad arguments exits the shell. * sleep_for_duration() in sleep_main() has to be interruptible for ^C traps to work, which may be a problem for other users of sleep_for_duration(). * BUT, if sleep_for_duration() is interruptible, then SIGCHLD interrupts it as well (try "/bin/sleep 1 & sleep 10"). * sleep_main() must not allocate anything as ^C in ash longjmp's. (currently, allocations are only on error paths, in message printing). Signed-off-by: Denys Vlasenko <vda.linux@googlemail.com>
-rw-r--r--include/libbb.h2
-rw-r--r--shell/ash.c22
2 files changed, 19 insertions, 5 deletions
diff --git a/include/libbb.h b/include/libbb.h
index 18336da23..640fa3988 100644
--- a/include/libbb.h
+++ b/include/libbb.h
@@ -1513,6 +1513,8 @@ int hush_main(int argc, char** argv) IF_SHELL_HUSH(MAIN_EXTERNALLY_VISIBLE);
/* If shell needs them, they exist even if not enabled as applets */
int echo_main(int argc, char** argv) IF_ECHO(MAIN_EXTERNALLY_VISIBLE);
int sleep_main(int argc, char **argv) IF_SLEEP(MAIN_EXTERNALLY_VISIBLE);
+/* See disabled "config ASH_SLEEP" in ash.c */
+#define ENABLE_ASH_SLEEP 0
int printf_main(int argc, char **argv) IF_PRINTF(MAIN_EXTERNALLY_VISIBLE);
int test_main(int argc, char **argv)
#if ENABLE_TEST || ENABLE_TEST1 || ENABLE_TEST2
diff --git a/shell/ash.c b/shell/ash.c
index e91566994..e154cc6cc 100644
--- a/shell/ash.c
+++ b/shell/ash.c
@@ -134,11 +134,23 @@
//config: default y
//config: depends on SHELL_ASH
//config:
-//config:config ASH_SLEEP
-//config: bool "sleep builtin"
-//config: default y
-//config: depends on SHELL_ASH
-//config:
+//
+////config:config ASH_SLEEP
+////config: bool "sleep builtin"
+////config: default y
+////config: depends on SHELL_ASH
+////config:
+//^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
+//Disabled for now. Has a few annoying problems:
+// * sleepcmd() -> sleep_main(), the parsing of bad arguments exits the shell.
+// * sleep_for_duration() in sleep_main() has to be interruptible for
+// ^C traps to work, which may be a problem for other users
+// of sleep_for_duration().
+// * BUT, if sleep_for_duration() is interruptible, then SIGCHLD interrupts it
+// as well (try "/bin/sleep 1 & sleep 10").
+// * sleep_main() must not allocate anything as ^C in ash longjmp's.
+// (currently, allocations are only on error paths, in message printing).
+//
//config:config ASH_HELP
//config: bool "help builtin"
//config: default y