aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--include/thread.h2
-rw-r--r--src/cmd/ls.C2
-rw-r--r--src/cmd/rc/plan9ish.c2
-rw-r--r--src/cmd/time.c7
-rw-r--r--src/lib9/notify.c15
-rw-r--r--src/libthread/386.c13
-rw-r--r--src/libthread/PowerMacintosh.c2
-rw-r--r--src/libthread/create.c1
-rw-r--r--src/libthread/fdwait.c25
-rw-r--r--src/libthread/main.c12
-rw-r--r--src/libthread/mkfile1
-rw-r--r--src/libthread/sched.c15
-rw-r--r--src/libthread/sun4u.c2
-rw-r--r--src/libthread/threadimpl.h6
14 files changed, 71 insertions, 34 deletions
diff --git a/include/thread.h b/include/thread.h
index 356d7b62..2721fb4e 100644
--- a/include/thread.h
+++ b/include/thread.h
@@ -121,7 +121,7 @@ Channel* threadwaitchan(void);
int tprivalloc(void);
void tprivfree(int);
void **tprivaddr(int);
-void yield(void);
+int yield(void);
long threadstack(void);
diff --git a/src/cmd/ls.C b/src/cmd/ls.C
index de2bee94..8bdeab61 100644
--- a/src/cmd/ls.C
+++ b/src/cmd/ls.C
@@ -101,6 +101,8 @@ ls(char *s, int multi)
return 1;
}
if(db->qid.type&QTDIR && dflag==0){
+ free(db);
+ db = nil;
output();
fd = open(s, OREAD);
if(fd == -1)
diff --git a/src/cmd/rc/plan9ish.c b/src/cmd/rc/plan9ish.c
index 2b9011cc..6644778c 100644
--- a/src/cmd/rc/plan9ish.c
+++ b/src/cmd/rc/plan9ish.c
@@ -71,7 +71,7 @@ void Vinit(void){
for(s=*env;*s && *s!='(' && *s!='=';s++);
switch(*s){
case '\0':
- pfmt(err, "rc: odd environment %q?\n", *env);
+ // pfmt(err, "rc: odd environment %q?\n", *env);
break;
case '=':
*s='\0';
diff --git a/src/cmd/time.c b/src/cmd/time.c
index d82eaa94..3b52216b 100644
--- a/src/cmd/time.c
+++ b/src/cmd/time.c
@@ -11,6 +11,7 @@ main(int argc, char *argv[])
{
int i;
Waitmsg *w;
+ vlong t0, t1;
long l;
char *p;
char err[ERRMAX];
@@ -20,6 +21,7 @@ main(int argc, char *argv[])
exits("usage");
}
+ t0 = nsec();
switch(fork()){
case -1:
error("fork");
@@ -37,8 +39,9 @@ main(int argc, char *argv[])
loop:
w = wait();
+ t1 = nsec();
if(w == nil){
- errstr(err, sizeof err);
+ rerrstr(err, sizeof err);
if(strcmp(err, "interrupted") == 0)
goto loop;
error("wait");
@@ -47,7 +50,7 @@ main(int argc, char *argv[])
add("%ld.%.2ldu", l/1000, (l%1000)/10);
l = w->time[1];
add("%ld.%.2lds", l/1000, (l%1000)/10);
- l = w->time[2];
+ l = (t1-t0)/1000000;
add("%ld.%.2ldr", l/1000, (l%1000)/10);
add("\t");
for(i=1; i<argc; i++){
diff --git a/src/lib9/notify.c b/src/lib9/notify.c
index 79a5e621..26487bab 100644
--- a/src/lib9/notify.c
+++ b/src/lib9/notify.c
@@ -66,7 +66,7 @@ int
notify(void (*f)(void*, char*))
{
int i;
- struct sigaction sa;
+ struct sigaction sa, osa;
_p9uproc(0);
memset(&sa, 0, sizeof sa);
@@ -77,11 +77,22 @@ notify(void (*f)(void*, char*))
sa.sa_handler = notifysigf;
}
for(i=0; i<nelem(sigs); i++){
+ /*
+ * If someone has already installed a handler,
+ * It's probably some ld preload nonsense,
+ * like pct (a SIGVTALRM-based profiler).
+ * Leave it alone.
+ */
+ sigaction(sigs[i].sig, nil, &osa);
+ if(osa.sa_handler != SIG_DFL)
+ continue;
+ sigemptyset(&sa.sa_mask);
+ sigaddset(&sa.sa_mask, i);
if(sigs[i].restart)
sa.sa_flags |= SA_RESTART;
else
sa.sa_flags &= ~SA_RESTART;
- sigaction(sigs[i].sig, &sa, 0);
+ sigaction(sigs[i].sig, &sa, nil);
}
return 0;
}
diff --git a/src/libthread/386.c b/src/libthread/386.c
index d8052f09..2c611e45 100644
--- a/src/libthread/386.c
+++ b/src/libthread/386.c
@@ -15,7 +15,7 @@ launcher386(void (*f)(void *arg), void *arg)
p = _threadgetproc();
t = p->thread;
- _threadstacklimit(t->stk);
+ _threadstacklimit(t->stk, t->stk+t->stksize);
(*f)(arg);
threadexits(nil);
@@ -39,18 +39,19 @@ _threadinswitch(int enter)
USED(enter);
#ifdef USEVALGRIND
if(enter)
- VALGRIND_SET_STACK_LIMIT(0, 0, 1);
- else
VALGRIND_SET_STACK_LIMIT(0, 0, 0);
+ else
+ VALGRIND_SET_STACK_LIMIT(0, 0, 1);
#endif
}
void
-_threadstacklimit(void *addr)
+_threadstacklimit(void *bottom, void *top)
{
- USED(addr);
+ USED(bottom);
+ USED(top);
#ifdef USEVALGRIND
- VALGRIND_SET_STACK_LIMIT(1, addr, 0);
+ VALGRIND_SET_STACK_LIMIT(1, bottom, top);
#endif
}
diff --git a/src/libthread/PowerMacintosh.c b/src/libthread/PowerMacintosh.c
index 21f6041d..94d4db9a 100644
--- a/src/libthread/PowerMacintosh.c
+++ b/src/libthread/PowerMacintosh.c
@@ -32,7 +32,7 @@ _threadinswitch(int enter)
}
void
-_threadstacklimit(void *addr)
+_threadstacklimit(void *addr, void *addr2)
{
USED(addr);
}
diff --git a/src/libthread/create.c b/src/libthread/create.c
index b63fee44..f5f0d6c0 100644
--- a/src/libthread/create.c
+++ b/src/libthread/create.c
@@ -24,6 +24,7 @@ newthread(Proc *p, void (*f)(void *arg), void *arg, uint stacksize, char *name,
if(stacksize < 32)
sysfatal("bad stacksize %d", stacksize);
t = _threadmalloc(sizeof(Thread), 1);
+ t->lastfd = -1;
s = _threadmalloc(stacksize, 0);
t->stk = (uchar*)s;
t->stksize = stacksize;
diff --git a/src/libthread/fdwait.c b/src/libthread/fdwait.c
index 927fc64f..a6890332 100644
--- a/src/libthread/fdwait.c
+++ b/src/libthread/fdwait.c
@@ -2,12 +2,13 @@
#include <u.h>
#include <libc.h>
#include <thread.h>
-
+#include "threadimpl.h"
#include <errno.h>
#include <unistd.h>
#include <fcntl.h>
#define debugpoll 0
+static int noblocked[4096/32];
#ifdef __APPLE__
#include <sys/time.h>
@@ -174,11 +175,15 @@ _threadfdwait(int fd, int rw, ulong pc)
struct {
Channel c;
+ Alt *qentry[2];
ulong x;
} s;
threadfdwaitsetup();
chaninit(&s.c, sizeof(ulong), 1);
+ s.c.qentry = (volatile Alt**)s.qentry;
+ s.c.nentry = 2;
+ memset(s.qentry, 0, sizeof s.qentry);
for(i=0; i<npoll; i++)
if(pfd[i].fd == -1)
break;
@@ -223,7 +228,25 @@ threadsleep(int ms)
void
threadfdnoblock(int fd)
{
+ Thread *t;
+
+ if(fd<0)
+ return;
+ if(fd < 8*sizeof(int)*nelem(noblocked)
+ && (noblocked[fd/(8*sizeof(int))] & (1<<(fd%(8*sizeof(int))))))
+ return;
+ t = _threadgetproc()->thread;
+ if(t && t->lastfd == fd)
+ return;
fcntl(fd, F_SETFL, fcntl(fd, F_GETFL, 0)|O_NONBLOCK);
+ if(t)
+ t->lastfd = fd;
+
+ /* We could lock this but we're probably single-threaded
+ * and the worst that will happen is we'll run fcntl
+ * a few more times.
+ */
+ noblocked[fd/(8*sizeof(int))] |= 1<<(fd%(8*sizeof(int)));
}
long
diff --git a/src/libthread/main.c b/src/libthread/main.c
index 04e6cd9f..bc7ad0f8 100644
--- a/src/libthread/main.c
+++ b/src/libthread/main.c
@@ -32,24 +32,12 @@ _threaddie(int x)
exit(_threadexitsallstatus[0] ? 1 : 0);
}
-static void
-_nop(int x)
-{
- USED(x);
-}
-
int
main(int argc, char **argv)
{
Mainarg *a;
Proc *p;
- signal(SIGTERM, _threaddie);
- signal(SIGCHLD, _nop);
- signal(SIGALRM, _nop);
-// signal(SIGINFO, _threadstatus);
-// rfork(RFREND);
-
//_threaddebuglevel = (DBGSCHED|DBGCHAN|DBGREND)^~0;
_systhreadinit();
_qlockinit(_threadrendezvous);
diff --git a/src/libthread/mkfile b/src/libthread/mkfile
index 1ced9021..f8ec8e80 100644
--- a/src/libthread/mkfile
+++ b/src/libthread/mkfile
@@ -59,6 +59,7 @@ asm-OpenBSD-386.$O: asm-FreeBSD-386.s
# sorry
VG=`test -d /home/rsc/pub/valgrind-debian && echo -DUSEVALGRIND`
+# VG=
CFLAGS=$CFLAGS $VG
diff --git a/src/libthread/sched.c b/src/libthread/sched.c
index 9ad7298b..bdb9ad6b 100644
--- a/src/libthread/sched.c
+++ b/src/libthread/sched.c
@@ -171,7 +171,7 @@ needstack(int howmuch)
}
}
-void
+int
_sched(void)
{
Proc *p;
@@ -186,8 +186,8 @@ Resched:
// psstate(t->state), &t->sched, &p->sched);
if(_setlabel(&t->sched)==0)
_gotolabel(&p->sched);
- _threadstacklimit(t->stk);
- return;
+ _threadstacklimit(t->stk, t->stk+t->stksize);
+ return p->nsched++;
}else{
t = runthread(p);
if(t == nil){
@@ -277,10 +277,15 @@ _threadidle(void)
unlock(&p->readylock);
}
-void
+int
yield(void)
{
- _sched();
+ Proc *p;
+ int nsched;
+
+ p = _threadgetproc();
+ nsched = p->nsched;
+ return _sched() - nsched;
}
void
diff --git a/src/libthread/sun4u.c b/src/libthread/sun4u.c
index 6312dac9..0d2d8d24 100644
--- a/src/libthread/sun4u.c
+++ b/src/libthread/sun4u.c
@@ -46,7 +46,7 @@ _threadinswitch(int enter)
}
void
-_threadstacklimit(void *addr)
+_threadstacklimit(void *addr, void *addr2)
{
USED(addr);
}
diff --git a/src/libthread/threadimpl.h b/src/libthread/threadimpl.h
index 373164ad..7e44e646 100644
--- a/src/libthread/threadimpl.h
+++ b/src/libthread/threadimpl.h
@@ -99,6 +99,7 @@ struct Thread
ulong userpc;
void* udata[NPRIV]; /* User per-thread data pointer */
+ int lastfd;
};
struct Execargs
@@ -143,6 +144,7 @@ struct Proc
Waitmsg *waitmsg;
void* udata; /* User per-proc data pointer */
+ int nsched;
};
struct Pqueue { /* Proc queue */
@@ -169,7 +171,7 @@ void _freeproc(Proc*);
Proc* _newproc(void(*)(void*), void*, uint, char*, int, int);
int _procsplhi(void);
void _procsplx(int);
-void _sched(void);
+int _sched(void);
int _schedexec(Execargs*);
void _schedexecwait(void);
void _schedexit(Proc*);
@@ -219,4 +221,4 @@ extern int _threadgetpid(void);
extern void _threadmemset(void*, int, int);
extern void _threaddebugmemset(void*, int, int);
extern int _threadprocs;
-extern void _threadstacklimit(void*);
+extern void _threadstacklimit(void*, void*);