testdisplay: only set terminal attributes when in foreground process group
authorThomas Wood <thomas.wood@intel.com>
Thu, 24 Jul 2014 16:45:48 +0000 (17:45 +0100)
committerThomas Wood <thomas.wood@intel.com>
Fri, 25 Jul 2014 13:46:51 +0000 (14:46 +0100)
The Piglit test runner for intel-gpu-tools creates a new process group
for the test processes, so attempting to set terminal attributes causes
the process to receive SIGTTOU and be stopped. Since the test is not run
interactively in this case, the issue can be avoided by not setting
terminal attributes if the process is not in the foreground process
group.

Signed-off-by: Thomas Wood <thomas.wood@intel.com>
tests/testdisplay.c

index 6d8fe3a..f60e66d 100644 (file)
@@ -725,6 +725,11 @@ static void set_termio_mode(void)
 {
        struct termios tio;
 
+       /* don't attempt to set terminal attributes if not in the foreground
+        * process group */
+       if (getpgrp() != tcgetpgrp(STDOUT_FILENO))
+               return;
+
        tio_fd = dup(STDIN_FILENO);
        tcgetattr(tio_fd, &saved_tio);
        igt_install_exit_handler(restore_termio_mode);