aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rwxr-xr-xbin/g2
-rwxr-xr-xbin/slay2
-rw-r--r--include/libc.h1
-rw-r--r--src/cmd/9term/rcstart.c1
-rw-r--r--src/cmd/mkfile2
-rw-r--r--src/cmd/samterm/io.c9
-rw-r--r--src/cmd/samterm/main.c10
-rw-r--r--src/cmd/samterm/plan9.c2
-rw-r--r--src/lib9/open.c4
-rw-r--r--src/libmach/SunOS.c0
-rw-r--r--src/libmach/mkfile2
11 files changed, 28 insertions, 7 deletions
diff --git a/bin/g b/bin/g
index c9e8b929..26d065e1 100755
--- a/bin/g
+++ b/bin/g
@@ -1,4 +1,4 @@
-#!/usr/local/plan9/bin/rc
+#!/mit/rsc/plan9/bin/rc
flags=()
while(! ~ $#* 1 && ~ $1 -*){
diff --git a/bin/slay b/bin/slay
index c3a99332..e1aaf714 100755
--- a/bin/slay
+++ b/bin/slay
@@ -1,3 +1,3 @@
#!/bin/sh
-exec /usr/local/plan9/bin/kill -9 "$@"
+exec $PLAN9/bin/kill -9 "$@"
diff --git a/include/libc.h b/include/libc.h
index d9074681..b84e34b1 100644
--- a/include/libc.h
+++ b/include/libc.h
@@ -590,6 +590,7 @@ extern void freenetconninfo(NetConnInfo*);
#define OCEXEC 32 /* or'ed in, close on exec */
#define ORCLOSE 64 /* or'ed in, remove on close */
#define ODIRECT 128 /* or'ed in, direct access */
+#define ONONBLOCK 256 /* or'ed in, non-blocking call */
#define OEXCL 0x1000 /* or'ed in, exclusive use (create only) */
#define OLOCK 0x2000 /* or'ed in, lock after opening */
diff --git a/src/cmd/9term/rcstart.c b/src/cmd/9term/rcstart.c
index 1aa46dce..edf161c2 100644
--- a/src/cmd/9term/rcstart.c
+++ b/src/cmd/9term/rcstart.c
@@ -24,6 +24,7 @@ sys(char *buf, int devnull)
_exit(2);
default:
waitpid();
+fprint(2, "done waiting\n");
}
}
diff --git a/src/cmd/mkfile b/src/cmd/mkfile
index 51e6ed6f..ea036ac9 100644
--- a/src/cmd/mkfile
+++ b/src/cmd/mkfile
@@ -4,7 +4,7 @@ TARG=`ls *.[cy] | grep -v "\.tab\.c$" | sed 's/\.[cy]//'`
<$PLAN9/src/mkmany
-BUGGERED='CVS|faces|factotum|mailfs|page|scat|upas|venti|vncv|postscript|mnihongo|mpm|index'
+BUGGERED='CVS|acid|db|faces|factotum|mailfs|page|scat|upas|venti|vncv|postscript|mnihongo|mpm|index'
DIRS=lex `ls -l |sed -n 's/^d.* //p' |egrep -v "^($BUGGERED)$"|egrep -v '^lex$'`
<$PLAN9/src/mkdirs
diff --git a/src/cmd/samterm/io.c b/src/cmd/samterm/io.c
index 30a707a0..d9cf2e83 100644
--- a/src/cmd/samterm/io.c
+++ b/src/cmd/samterm/io.c
@@ -33,20 +33,27 @@ void
initio(void)
{
threadsetname("main");
+ if(protodebug) print("mouse\n");
mousectl = initmouse(nil, display->image);
if(mousectl == nil){
fprint(2, "samterm: mouse init failed: %r\n");
threadexitsall("mouse");
}
mousep = &mousectl->m;
+ if(protodebug) print("kbd\n");
keyboardctl = initkeyboard(nil);
if(keyboardctl == nil){
fprint(2, "samterm: keyboard init failed: %r\n");
threadexitsall("kbd");
}
+ if(protodebug) print("hoststart\n");
hoststart();
- if(plumbstart() < 0)
+ if(protodebug) print("plumbstart\n");
+ if(plumbstart() < 0){
+ if(protodebug) print("extstart\n");
extstart();
+ }
+ if(protodebug) print("initio done\n");
}
void
diff --git a/src/cmd/samterm/main.c b/src/cmd/samterm/main.c
index 9a485b51..c56ea5f8 100644
--- a/src/cmd/samterm/main.c
+++ b/src/cmd/samterm/main.c
@@ -44,15 +44,22 @@ threadmain(int argc, char *argv[])
close(0);
close(1);
open("/dev/null", OREAD);
- dup(2, 1);
+ if(open("/dev/tty", OWRITE) < 0)
+ open("/dev/null", OWRITE);
+dup(2, 1);
+ if(protodebug) print("getscreen\n");
getscreen(argc, argv);
+ if(protodebug) print("iconinit\n");
iconinit();
+ if(protodebug) print("initio\n");
initio();
+ if(protodebug) print("scratch\n");
scratch = alloc(100*RUNESIZE);
nscralloc = 100;
r = screen->r;
r.max.y = r.min.y+Dy(r)/5;
+ if(protodebug) print("flstart\n");
flstart(screen->clipr);
rinit(&cmd.rasp);
flnew(&cmd.l[0], gettext, 1, &cmd);
@@ -64,6 +71,7 @@ threadmain(int argc, char *argv[])
startnewfile(Tstartcmdfile, &cmd);
got = 0;
+ if(protodebug) print("loop\n");
for(;;got = waitforio()){
if(hasunlocked && RESIZED())
resize();
diff --git a/src/cmd/samterm/plan9.c b/src/cmd/samterm/plan9.c
index e860ea58..5f5c33d0 100644
--- a/src/cmd/samterm/plan9.c
+++ b/src/cmd/samterm/plan9.c
@@ -158,7 +158,7 @@ extstart(void)
}
}
- fd = open(exname, OREAD|O_NONBLOCK);
+ fd = open(exname, OREAD|ONONBLOCK);
if(fd == -1){
removeextern();
return;
diff --git a/src/lib9/open.c b/src/lib9/open.c
index 896ca528..e76aabe3 100644
--- a/src/lib9/open.c
+++ b/src/lib9/open.c
@@ -28,6 +28,10 @@ p9open(char *name, int mode)
umode |= O_DIRECT;
mode ^= ODIRECT;
}
+ if(mode&ONONBLOCK){
+ umode |= O_NONBLOCK;
+ mode ^= ONONBLOCK;
+ }
if(mode){
werrstr("mode 0x%x not supported", mode);
return -1;
diff --git a/src/libmach/SunOS.c b/src/libmach/SunOS.c
new file mode 100644
index 00000000..e69de29b
--- /dev/null
+++ b/src/libmach/SunOS.c
diff --git a/src/libmach/mkfile b/src/libmach/mkfile
index 53d1af99..25a3a877 100644
--- a/src/libmach/mkfile
+++ b/src/libmach/mkfile
@@ -67,7 +67,7 @@ elfnm: elfnm.o $LIBDIR/$LIB
$LD -o $target $prereq -l9
-SunOS.$O: nosys.c
+#SunOS.$O: nosys.c
Darwin.$O: nosys.c
OpenBSD.$O: nosys.c
NetBSD.$O: nosys.c