diff options
Diffstat (limited to 'emu')
| -rw-r--r-- | emu/port/devfs-posix.c | 37 | ||||
| -rw-r--r-- | emu/port/kproc-pthreads.c | 11 |
2 files changed, 20 insertions, 28 deletions
diff --git a/emu/port/devfs-posix.c b/emu/port/devfs-posix.c index c4aa3d9a..763694d1 100644 --- a/emu/port/devfs-posix.c +++ b/emu/port/devfs-posix.c @@ -632,45 +632,28 @@ fswstat(Chan *c, uchar *buf, int nb) return nb; } -#define QDEVBITS 4 /* 16 devices should be plenty */ -#define MAXDEV (1<<QDEVBITS) -#define QDEVSHIFT (64-QDEVBITS) -#define QINOMASK (((uvlong)1<<QDEVSHIFT)-1) -#define QPATH(d,i) (((uvlong)(d)<<QDEVSHIFT)|((uvlong)(i)&QINOMASK)) - static Qid fsqid(struct stat *st) { Qid q; - ulong dev; - int idev; - static int nqdev = 0; - static ulong qdev[MAXDEV]; - static Lock l; + u16int dev; q.type = QTFILE; if(S_ISDIR(st->st_mode)) q.type = QTDIR; - dev = st->st_dev; - lock(&l); - for(idev = 0; idev < nqdev; idev++) - if(qdev[idev] == dev) - break; - if(idev == nqdev) { - if(nqdev == MAXDEV) { - unlock(&l); - error("too many devices"); + dev = (u16int)st->st_dev; + if(dev & 0x8000){ + static int aware; + if(aware==0){ + aware = 1; + fprint(2, "fs: fsqid: top-bit dev: %#4.4ux\n", dev); } - qdev[nqdev++] = dev; + dev ^= 0x8080; } - unlock(&l); - - if(0) /* we'll just let it be masked off */ - if((uvlong)st->st_ino & ~QINOMASK) - error("inode number too large"); - q.path = QPATH(idev, st->st_ino); + q.path = (uvlong)dev<<48; + q.path ^= st->st_ino; q.vers = st->st_mtime; return q; diff --git a/emu/port/kproc-pthreads.c b/emu/port/kproc-pthreads.c index b48a00bb..32053794 100644 --- a/emu/port/kproc-pthreads.c +++ b/emu/port/kproc-pthreads.c @@ -8,6 +8,7 @@ #include <unistd.h> #include <signal.h> #include <pthread.h> +#include <limits.h> #include <errno.h> #include <semaphore.h> @@ -81,6 +82,14 @@ tramp(void *arg) os->self = pthread_self(); if(pthread_setspecific(prdakey, arg)) panic("set specific data failed in tramp\n"); + if(0){ + pthread_attr_t attr; + memset(&attr, 0, sizeof(attr)); + pthread_getattr_np(pthread_self(), &attr); + size_t s; + pthread_attr_getstacksize(&attr, &s); + print("stack size = %d\n", s); + } p->func(p->arg); pexit("{Tramp}", 0); return nil; @@ -150,7 +159,7 @@ kproc(char *name, void (*func)(void*), void *arg, int flags) if(flags & KPX11) pthread_attr_setstacksize(&attr, 512*1024); /* could be a parameter */ else if(KSTACK > 0) - pthread_attr_setstacksize(&attr, KSTACK); + pthread_attr_setstacksize(&attr, (KSTACK < PTHREAD_STACK_MIN? PTHREAD_STACK_MIN: KSTACK)+1024); pthread_attr_setinheritsched(&attr, PTHREAD_INHERIT_SCHED); pthread_attr_setdetachstate(&attr, PTHREAD_CREATE_DETACHED); if(pthread_create(&thread, &attr, tramp, p)) |
