summaryrefslogtreecommitdiff
path: root/console-tools
diff options
context:
space:
mode:
Diffstat (limited to 'console-tools')
-rw-r--r--console-tools/Makefile.in1
-rw-r--r--console-tools/config.in1
-rw-r--r--console-tools/openvt.c84
3 files changed, 86 insertions, 0 deletions
diff --git a/console-tools/Makefile.in b/console-tools/Makefile.in
index bc03356..c2c1bad 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 53d5ac6..2ea96ae 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 0000000..3373edd
--- /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:
+*/