add proper fuxed-based locking for stdio
authorRich Felker <dalias@aerifal.cx>
Sat, 30 Jul 2011 12:02:14 +0000 (08:02 -0400)
committerRich Felker <dalias@aerifal.cx>
Sat, 30 Jul 2011 12:02:14 +0000 (08:02 -0400)
commitdba68bf98fc708cea4c478278c889fc7ad802b00
treeb90a55aaa51c72475cdb69efca7b9ddd37e50b2e
parent7683fceedebd98dda19b1a379b92406b64ce7f92
add proper fuxed-based locking for stdio

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.
20 files changed:
src/internal/libc.h
src/internal/pthread_impl.h
src/internal/stdio_impl.h
src/stdio/__fdopen.c
src/stdio/__lockfile.c
src/stdio/fclose.c
src/stdio/fflush.c
src/stdio/fgetc.c
src/stdio/fgetwc.c
src/stdio/flockfile.c
src/stdio/fputc.c
src/stdio/ftell.c
src/stdio/ftrylockfile.c
src/stdio/funlockfile.c
src/stdio/stderr.c
src/stdio/stdin.c
src/stdio/stdout.c
src/thread/pthread_create.c
src/thread/pthread_key_create.c
src/thread/pthread_self.c