]> git.ipfire.org Git - thirdparty/lxc.git/commitdiff
host consoles/ttys in containers
authorMichael Tokarev <mjt@tls.msk.ru>
Tue, 17 Nov 2009 09:56:24 +0000 (10:56 +0100)
committerDaniel Lezcano <dlezcano@fr.ibm.com>
Tue, 17 Nov 2009 09:56:24 +0000 (10:56 +0100)
I noticed that container's consoles aren't quite useable
(be it lxc-console or lxc-start with getty bound to /dev/console).
The main problem is a complete lack of window resizing support:
when I resize an xterm window with lxc-start or lxc-console, the
"guest" does not know about that and continues to think that the
terminal is 80x25 still.

Is it just a lack of functionality (missing implementation) or
something problematic?

Ok, the attached patch fixes this.

It moves the 'master' variable out of main function so it's
accessible from the signal handler, sets up SIGWINCH handler
to call a (newly created) winsz() function that gets the
current tty size using TIOCGWINSZ ioctl and if that works,
sets up the pty size using TIOCSWINSZ.  That same function
is called at the start as well, when setting up the signal
handler.

Signed-off-By: Michael Tokarev <mjt@tls.msk.ru>
Signed-off-By: Daniel Lezcano <dlezcano@fr.ibm.com>
src/lxc/lxc_console.c

index cff208f6bc37049dc8ffaebb17e95a409bea84a2..8bdf6b12f8139ba7b47635b7d4c8063b75b25de2 100644 (file)
@@ -36,6 +36,7 @@
 #include <sys/types.h>
 #include <sys/stat.h>
 #include <sys/poll.h>
+#include <sys/ioctl.h>
 
 #include <lxc/error.h>
 #include <lxc/lxc.h>
@@ -74,9 +75,22 @@ Options :\n\
        .ttynum = -1,
 };
 
+static int master = -1;
+
+static void winsz(void)
+{
+       struct winsize wsz;
+       if (ioctl(0, TIOCGWINSZ, &wsz) == 0)
+               ioctl(master, TIOCSWINSZ, &wsz);
+}
+
+static void sigwinch(int sig)
+{
+       winsz();
+}
+
 int main(int argc, char *argv[])
 {
-       int master = -1;
        int wait4q = 0;
        int err;
        struct termios tios, oldtios;
@@ -120,6 +134,8 @@ int main(int argc, char *argv[])
        fprintf(stderr, "\nType <Ctrl+a q> to exit the console\n");
 
        setsid();
+       signal(SIGWINCH, sigwinch);
+       winsz();
 
        err = 0;