Commit 994f905e by Michael Tokarev Committed by Daniel Lezcano

host consoles/ttys in containers

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: 's avatarMichael Tokarev <mjt@tls.msk.ru> Signed-off-By: 's avatarDaniel Lezcano <dlezcano@fr.ibm.com>
parent aef4ebcf
...@@ -36,6 +36,7 @@ ...@@ -36,6 +36,7 @@
#include <sys/types.h> #include <sys/types.h>
#include <sys/stat.h> #include <sys/stat.h>
#include <sys/poll.h> #include <sys/poll.h>
#include <sys/ioctl.h>
#include <lxc/error.h> #include <lxc/error.h>
#include <lxc/lxc.h> #include <lxc/lxc.h>
...@@ -74,9 +75,22 @@ Options :\n\ ...@@ -74,9 +75,22 @@ Options :\n\
.ttynum = -1, .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 main(int argc, char *argv[])
{ {
int master = -1;
int wait4q = 0; int wait4q = 0;
int err; int err;
struct termios tios, oldtios; struct termios tios, oldtios;
...@@ -120,6 +134,8 @@ int main(int argc, char *argv[]) ...@@ -120,6 +134,8 @@ int main(int argc, char *argv[])
fprintf(stderr, "\nType <Ctrl+a q> to exit the console\n"); fprintf(stderr, "\nType <Ctrl+a q> to exit the console\n");
setsid(); setsid();
signal(SIGWINCH, sigwinch);
winsz();
err = 0; err = 0;
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment