From 35fc36a16beca347e746be327a0ccd37238bc31d Mon Sep 17 00:00:00 2001 From: "Richard M. Stallman" Date: Thu, 28 Jan 1999 03:49:39 +0000 Subject: [PATCH] (SETUP_SLAVE_PTY): Use the ptem module if it exists. Don't complain if ttcompat does not exist. --- src/s/ptx4.h | 18 +++++++++++++++++- 1 file changed, 17 insertions(+), 1 deletion(-) diff --git a/src/s/ptx4.h b/src/s/ptx4.h index 8f4db997708..25cf6882986 100644 --- a/src/s/ptx4.h +++ b/src/s/ptx4.h @@ -16,9 +16,25 @@ /* pae@dim.com (Phil Ernhardt) says this correction to the definition in usg5-4.h is needed to prevent all asynchronous subprocesses from exiting right away. */ + +/* James Youngman found that on "DYNIX/ptx ARNIE 4.0 + * V4.4.2 i386", the push of the ttcompat module would fail. It seems + * that PTX 4.4.2 doesn't have that module, so if the push fails we + * don't kill ourselves. While this version lacks ttcompat, it also + * has ptem, but the manual page for ptem indicates that it should + * be pushed onto the slave side before the line discipline module. + * See also the streampty manual page, if you're curious (and have + * a ptx system). + */ + +/* rms: I hope that older versions which do have ttcompat + will not get confused by the code to use ptem. */ + #undef SETUP_SLAVE_PTY #define SETUP_SLAVE_PTY \ + if (ioctl (xforkin, I_PUSH, "ptem") == -1 && errno != EINVAL) \ + fatal ("ioctl I_PUSH ptem", errno); \ if (ioctl (xforkin, I_PUSH, "ldterm") == -1) \ fatal ("ioctl I_PUSH ldterm", errno); \ - if (ioctl (xforkin, I_PUSH, "ttcompat") == -1) \ + if (ioctl (xforkin, I_PUSH, "ttcompat") == -1 && errno != EINVAL) \ fatal ("ioctl I_PUSH ttcompat", errno); -- 2.39.2