#define UNGET 4
-#define FLOCK(f) ((libc.lockfile && (f)->owner>=0) ? (libc.lockfile((f)),0) : 0)
-#define FUNLOCK(f) ((f)->lockcount && (--(f)->lockcount || ((f)->owner=(f)->lock=0)))
+#define FLOCK(f) ((libc.lockfile && (f)->lock>=0) ? (libc.lockfile((f)),0) : 0)
+#define FUNLOCK(f) ((f)->lockcount && (--(f)->lockcount || ((f)->lock=0)))
#define F_PERM 1
#define F_NORD 4
off_t (*seek)(FILE *, off_t, int);
int mode;
int (*close)(FILE *);
- int owner;
};
size_t __stdio_read(FILE *, unsigned char *, size_t);
void __lockfile(FILE *f)
{
- int spins;
- if (f->owner < 0) return;
- if (f->owner && f->owner == __pthread_self()->tid) {
+ int spins=100000;
+ int tid;
+
+ if (f->lock < 0) return;
+ tid = __pthread_self()->tid;
+ if (f->lock == tid) {
while (f->lockcount == INT_MAX);
f->lockcount++;
return;
}
- spins = 100000;
- while (a_swap(&f->lock, 1))
+ while (f->lock || a_cas(&f->lock, 0, tid))
if (spins) spins--, a_spin();
else syscall(SYS_sched_yield);
- f->owner = __pthread_self()->tid;
f->lockcount = 1;
}
int ftrylockfile(FILE *f)
{
+ int tid = pthread_self()->tid;
if (!libc.lockfile) libc.lockfile = __lockfile;
- if (f->owner && f->owner == pthread_self()->tid) {
+ if (f->lock == tid) {
if (f->lockcount == INT_MAX)
return -1;
f->lockcount++;
return 0;
}
- if (a_swap(&f->lock, 1))
+ if (f->lock || a_cas(&f->lock, 0, tid))
return -1;
- f->owner = pthread_self()->tid;
f->lockcount = 1;
return 0;
}
f.write = sn_write;
f.buf_size = 1;
f.buf = buf;
- f.owner = -1;
+ f.lock = -1;
if (n > INT_MAX) {
errno = EOVERFLOW;
return -1;
f.write = sw_write;
f.buf_size = sizeof buf;
f.buf = buf;
- f.owner = -1;
+ f.lock = -1;
f.cookie = &c;
if (!n) {
return -1;