aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorrsc <devnull@localhost>2005-02-08 18:01:04 +0000
committerrsc <devnull@localhost>2005-02-08 18:01:04 +0000
commitdc305d03681e150b97acf4631a514868acd4b276 (patch)
tree2452571d92327cb485a4a8371eabf1685d16c7f5
parentdd4afdf4eb411c2899f792cb11380877af065b1d (diff)
downloadplan9port-dc305d03681e150b97acf4631a514868acd4b276.tar.gz
plan9port-dc305d03681e150b97acf4631a514868acd4b276.tar.bz2
plan9port-dc305d03681e150b97acf4631a514868acd4b276.zip
Maybe it will run on SunOS 5.8 now.
-rwxr-xr-xbin/9l13
-rw-r--r--src/cmd/9term/SunOS.c8
2 files changed, 20 insertions, 1 deletions
diff --git a/bin/9l b/bin/9l
index 3fea275c..eadf4d89 100755
--- a/bin/9l
+++ b/bin/9l
@@ -205,6 +205,19 @@ case "$tag" in
;;
esac
done
+ case "${SYSVERSION:-`uname -r`}" in
+ 5.[67])
+ echo do not know how to link right thread library on "$tag" 1>&2
+ ;;
+ 5.8)
+ # Some trickery is needed to force use of
+ # alternate thread lib from /usr/lib/lwp
+ # Likely, this only works with sun cc,
+ # for other compiler/loader we would need other flags.
+ ld="$ld -i"
+ extralibs="$extralibs /usr/lib/lwp/libthread.so -R/usr/lib/lwp:/usr/lib"
+ ;;
+ esac
;;
*)
echo do not know how to link on "$tag" 1>&2
diff --git a/src/cmd/9term/SunOS.c b/src/cmd/9term/SunOS.c
index ba3039a6..97cae2dc 100644
--- a/src/cmd/9term/SunOS.c
+++ b/src/cmd/9term/SunOS.c
@@ -9,8 +9,14 @@
int
getpts(int fd[], char *slave)
{
+ void (*f)(int);
+ int r;
+
fd[1] = open("/dev/ptmx", ORDWR);
- if ((grantpt(fd[1]) < 0) || (unlockpt(fd[1]) < 0))
+ f = signal(SIGCLD, SIG_DFL);
+ r = grantpt(fd[1]);
+ signal(SIGCLD, f);
+ if(r < 0 || unlockpt(fd[1]) < 0)
return -1;
fchmod(fd[1], 0622);