summaryrefslogtreecommitdiff
path: root/emu
diff options
context:
space:
mode:
Diffstat (limited to 'emu')
-rw-r--r--emu/port/devfs-posix.c37
-rw-r--r--emu/port/kproc-pthreads.c11
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))