mirror of
https://github.com/fluencelabs/musl
synced 2025-06-26 05:02:02 +00:00
simplify and optimize FILE lock handling
This commit is contained in:
@ -3,17 +3,18 @@
|
||||
|
||||
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;
|
||||
}
|
||||
|
@ -3,16 +3,16 @@
|
||||
|
||||
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;
|
||||
}
|
||||
|
@ -17,7 +17,7 @@ int vsnprintf(char *s, size_t n, const char *fmt, va_list ap)
|
||||
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;
|
||||
|
@ -32,7 +32,7 @@ int vswprintf(wchar_t *s, size_t n, const wchar_t *fmt, va_list ap)
|
||||
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;
|
||||
|
Reference in New Issue
Block a user