aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--console-tools/Makefile.in1
-rw-r--r--console-tools/config.in1
-rw-r--r--console-tools/openvt.c84
-rw-r--r--include/applets.h3
-rw-r--r--include/usage.h7
5 files changed, 96 insertions, 0 deletions
diff --git a/console-tools/Makefile.in b/console-tools/Makefile.in
index bc0335643..c2c1bad6a 100644
--- a/console-tools/Makefile.in
+++ b/console-tools/Makefile.in
@@ -30,6 +30,7 @@ CONSOLETOOLS_DIR-$(CONFIG_DUMPKMAP) += dumpkmap.o
CONSOLETOOLS_DIR-$(CONFIG_LOADACM) += loadacm.o
CONSOLETOOLS_DIR-$(CONFIG_LOADFONT) += loadfont.o
CONSOLETOOLS_DIR-$(CONFIG_LOADKMAP) += loadkmap.o
+CONSOLETOOLS_DIR-$(CONFIG_OPENVT) += openvt.o
CONSOLETOOLS_DIR-$(CONFIG_RESET) += reset.o
CONSOLETOOLS_DIR-$(CONFIG_SETKEYCODES) += setkeycodes.o
diff --git a/console-tools/config.in b/console-tools/config.in
index 53d5ac6b4..2ea96aec4 100644
--- a/console-tools/config.in
+++ b/console-tools/config.in
@@ -12,6 +12,7 @@ bool 'dumpkmap' CONFIG_DUMPKMAP
bool 'loadacm' CONFIG_LOADACM
bool 'loadfont' CONFIG_LOADFONT
bool 'loadkmap' CONFIG_LOADKMAP
+bool 'openvt' CONFIG_OPENVT
bool 'reset' CONFIG_RESET
bool 'setkeycodes' CONFIG_SETKEYCODES
diff --git a/console-tools/openvt.c b/console-tools/openvt.c
new file mode 100644
index 000000000..3373edd29
--- /dev/null
+++ b/console-tools/openvt.c
@@ -0,0 +1,84 @@
+/* vi: set sw=4 ts=4: */
+
+/*
+ * openvt.c - open a vt to run a command.
+ *
+ * busyboxed by Quy Tonthat <quy@signal3.com>
+ */
+
+/* getopt not needed */
+
+#include <stdio.h>
+#include <stdlib.h>
+#include <unistd.h>
+#include <fcntl.h>
+#include <string.h>
+#include <sys/types.h>
+#include "busybox.h"
+
+#define VTNAME "/dev/tty%d"
+
+int openvt_main(int argc, char **argv)
+{
+ int pid;
+ int fd;
+ int vtno;
+ char vtname[sizeof VTNAME + 2];
+ char * cmd = NULL;
+ char * cmd_args = NULL;
+
+ if (argc < 3)
+ show_usage();
+
+ if (!isdigit(argv[1][0]))
+ show_usage();
+
+ vtno = (int) atol(argv[1]);
+
+ /* if (vtno <= 0 || vtno > 63) */
+ if (vtno <= 0 || vtno > 12)
+ error_msg_and_die("Illegal vt number (%d)", vtno);
+
+ sprintf(vtname, VTNAME, vtno);
+
+ cmd = argv[2];
+ cmd_args = xmalloc(80);
+ cmd_args[0] = '\0';
+
+ if((pid = fork()) == 0) {
+ /* leave current vt */
+
+#ifdef ESIX_5_3_2_D
+ if (setpgrp() < 0) {
+#else
+ if (setsid() < 0) {
+#endif
+
+ perror_msg_and_die("Unable to set new session");
+ }
+ close(0); /* so that new vt becomes stdin */
+
+ /* and grab new one */
+ if ((fd = open(vtname, O_RDWR)) == -1)
+ perror_msg_and_die("could not open %s", vtname);
+
+ /* Reassign stdout and sterr */
+ close(1);
+ close(2);
+ dup(fd);
+ dup(fd);
+
+ execvp(cmd, &argv[2]);
+ /*execlp(cmd, cmd_args);*/
+ _exit(1);
+ }
+ return EXIT_SUCCESS;
+}
+
+/*
+Local Variables:
+c-file-style: "linux"
+c-basic-offset: 4
+tab-width: 4
+End:
+*/
diff --git a/include/applets.h b/include/applets.h
index 9117880ad..38d75344f 100644
--- a/include/applets.h
+++ b/include/applets.h
@@ -341,6 +341,9 @@
#ifdef CONFIG_OD
APPLET(od, od_main, _BB_DIR_USR_BIN, _BB_SUID_NEVER)
#endif
+#ifdef CONFIG_OPENVT
+ APPLET(openvt, openvt_main, _BB_DIR_USR_BIN, _BB_SUID_NEVER)
+#endif
#ifdef CONFIG_PASSWD
APPLET(passwd, passwd_main, _BB_DIR_USR_BIN, _BB_SUID_ALWAYS)
#endif
diff --git a/include/usage.h b/include/usage.h
index 9e16a085f..98b81cf1d 100644
--- a/include/usage.h
+++ b/include/usage.h
@@ -1347,6 +1347,13 @@
"Write an unambiguous representation, octal bytes by default, of FILE\n"\
"to standard output. With no FILE, or when FILE is -, read standard input."
+#define openvt_trivial_usage \
+ "<vtnum> <COMMAND> [ARGS...]"
+#define openvt_full_usage \
+ "Start a command on a new virtual terminal"
+#define openvt_example_usage \
+ "openvt 2 /bin/ash\n"
+
#ifdef CONFIG_FEATURE_SHA1_PASSWORDS
#define PASSWORD_ALG_TYPES(a) a
#else