mirror of
https://github.com/fluencelabs/musl
synced 2025-06-24 04:01:56 +00:00
previously, stdio used spinlocks, which would be unacceptable if we ever add support for thread priorities, and which yielded pathologically bad performance if an application attempted to use flockfile on a key file as a major/primary locking mechanism. i had held off on making this change for fear that it would hurt performance in the non-threaded case, but actually support for recursive locking had already inflicted that cost. by having the internal locking functions store a flag indicating whether they need to perform unlocking, rather than using the actual recursive lock counter, i was able to combine the conditionals at unlock time, eliminating any additional cost, and also avoid a nasty corner case where a huge number of calls to ftrylockfile could cause deadlock later at the point of internal locking. this commit also fixes some issues with usage of pthread_self conflicting with __attribute__((const)) which resulted in crashes with some compiler versions/optimizations, mainly in flockfile prior to pthread_create.
34 lines
497 B
C
34 lines
497 B
C
#include "stdio_impl.h"
|
|
|
|
off_t __ftello_unlocked(FILE *f)
|
|
{
|
|
off_t pos = f->seek(f, 0, SEEK_CUR);
|
|
if (pos < 0) return pos;
|
|
|
|
/* Adjust for data in buffer. */
|
|
return pos - (f->rend - f->rpos) + (f->wpos - f->wbase);
|
|
}
|
|
|
|
off_t __ftello(FILE *f)
|
|
{
|
|
off_t pos;
|
|
FLOCK(f);
|
|
pos = __ftello_unlocked(f);
|
|
FUNLOCK(f);
|
|
return pos;
|
|
}
|
|
|
|
long ftell(FILE *f)
|
|
{
|
|
off_t pos = __ftello(f);
|
|
if (pos > LONG_MAX) {
|
|
errno = EOVERFLOW;
|
|
return -1;
|
|
}
|
|
return pos;
|
|
}
|
|
|
|
weak_alias(__ftello, ftello);
|
|
|
|
LFS64(ftello);
|