diff options
author | Richard M. Stallman <[email protected]> | 1994-08-11 03:42:57 +0000 |
---|---|---|
committer | Richard M. Stallman <[email protected]> | 1994-08-11 03:42:57 +0000 |
commit | c764f95fab66ee945b884d8a609347f2a6574208 (patch) | |
tree | f29f45bb793e6dfc3cf86a7db7a9aa464aa223a2 /src/s/sol2-3.h | |
parent | 8d40872b18967a419df4bc10df422928d6e057e1 (diff) |
(POSIX_SIGNALS): Define it.
(PTY_TTY_NAME_SPRINTF): New overriding definition.
(sigsetmask): Add #undefs.
Diffstat (limited to 'src/s/sol2-3.h')
-rw-r--r-- | src/s/sol2-3.h | 32 |
1 files changed, 32 insertions, 0 deletions
diff --git a/src/s/sol2-3.h b/src/s/sol2-3.h index d17ec1851b..2e5d068d19 100644 --- a/src/s/sol2-3.h +++ b/src/s/sol2-3.h @@ -16,3 +16,35 @@ #define LD_SWITCH_SYSTEM -L /usr/ccs/lib \ `./prefix-args -Xlinker LD_SWITCH_X_SITE_AUX` #endif /* GCC */ + +/* Info from [email protected] suggests this is appropriate. */ +#define POSIX_SIGNALS + +/* We don't need the definition from usg5-3.h with POSIX_SIGNALS. */ +#undef sigsetmask + +/* This is the same definition as in usg5-4.h, but with sigblock/sigunblock + rather than sighold/sigrelse, which appear to be BSD4.1 specific and won't + work if POSIX_SIGNALS is defined. It may also be appropriate for SVR4.x + (x<2) but I'm not sure. [email protected] */ +/* This sets the name of the slave side of the PTY. On SysVr4, + grantpt(3) forks a subprocess, so keep sigchld_handler() from + intercepting that death. If any child but grantpt's should die + within, it should be caught after sigrelse(2). */ + +#undef PTY_TTY_NAME_SPRINTF +#define PTY_TTY_NAME_SPRINTF \ + { \ + char *ptsname(), *ptyname; \ + \ + sigblock(sigmask(SIGCLD)); \ + if (grantpt(fd) == -1) \ + fatal("could not grant slave pty"); \ + sigunblock(sigmask(SIGCLD)); \ + if (unlockpt(fd) == -1) \ + fatal("could not unlock slave pty"); \ + if (!(ptyname = ptsname(fd))) \ + fatal ("could not enable slave pty"); \ + strncpy(pty_name, ptyname, sizeof(pty_name)); \ + pty_name[sizeof(pty_name) - 1] = 0; \ + } |