mirror of
https://github.com/fluencelabs/musl
synced 2025-05-21 11:41:29 +00:00
for now this is just a tiny optimization, but later if we support cancellation from __stdio_read and __stdio_write, it will be necessary for the recusrive lock count to be zero in order for these functions to know they are responsible for unlocking the FILE on cancellation.
19 lines
346 B
C
19 lines
346 B
C
#include "stdio_impl.h"
|
|
#include "pthread_impl.h"
|
|
|
|
int __lockfile(FILE *f)
|
|
{
|
|
int owner, tid = __pthread_self()->tid;
|
|
if (f->lock == tid)
|
|
return 0;
|
|
while ((owner = a_cas(&f->lock, 0, tid)))
|
|
__wait(&f->lock, &f->waiters, owner, 1);
|
|
return 1;
|
|
}
|
|
|
|
void __unlockfile(FILE *f)
|
|
{
|
|
a_store(&f->lock, 0);
|
|
if (f->waiters) __wake(&f->lock, 1, 1);
|
|
}
|