diff options
| author | Rich Felker <dalias@aerifal.cx> | 2011-03-12 21:55:45 -0500 | 
|---|---|---|
| committer | Rich Felker <dalias@aerifal.cx> | 2011-03-12 21:55:45 -0500 | 
| commit | 5eb0d33ec0f08b123c5c10877d6258d05fa9453a (patch) | |
| tree | 85ff7f5397424685d89af8176ff7ce6d6f46f6e2 /src/stdio | |
| parent | d8d19f4d46284d5b6124710a5235b6fe090c013f (diff) | |
| download | musl-5eb0d33ec0f08b123c5c10877d6258d05fa9453a.tar.gz | |
implement flockfile api, rework stdio locking
Diffstat (limited to 'src/stdio')
| -rw-r--r-- | src/stdio/__lockfile.c | 19 | ||||
| -rw-r--r-- | src/stdio/__ofl.c | 3 | ||||
| -rw-r--r-- | src/stdio/flockfile.c | 9 | ||||
| -rw-r--r-- | src/stdio/ftrylockfile.c | 18 | ||||
| -rw-r--r-- | src/stdio/funlockfile.c | 7 | ||||
| -rw-r--r-- | src/stdio/vsnprintf.c | 1 | 
6 files changed, 54 insertions, 3 deletions
| diff --git a/src/stdio/__lockfile.c b/src/stdio/__lockfile.c new file mode 100644 index 00000000..82f50b42 --- /dev/null +++ b/src/stdio/__lockfile.c @@ -0,0 +1,19 @@ +#include "stdio_impl.h" +#include "pthread_impl.h" + +void __lockfile(FILE *f) +{ +	int spins; +	if (f->owner < 0) return; +	if (f->owner && f->owner == __pthread_self()->tid) { +		while (f->lockcount == INT_MAX); +		f->lockcount++; +		return; +	} +	spins = 100000; +	while (a_swap(&f->lock, 1)) +		if (spins) spins--, a_spin(); +		else syscall0(__NR_sched_yield); +	f->owner = __pthread_self()->tid; +	f->lockcount = 1; +} diff --git a/src/stdio/__ofl.c b/src/stdio/__ofl.c deleted file mode 100644 index 7d9652c8..00000000 --- a/src/stdio/__ofl.c +++ /dev/null @@ -1,3 +0,0 @@ -#include "stdio_impl.h" - -struct ofl __ofl; diff --git a/src/stdio/flockfile.c b/src/stdio/flockfile.c new file mode 100644 index 00000000..1b6ef580 --- /dev/null +++ b/src/stdio/flockfile.c @@ -0,0 +1,9 @@ +#include "stdio_impl.h" +#include "pthread_impl.h" + +void flockfile(FILE *f) +{ +	pthread_self(); +	libc.lockfile = __lockfile; +	__lockfile(f); +} diff --git a/src/stdio/ftrylockfile.c b/src/stdio/ftrylockfile.c new file mode 100644 index 00000000..725b66e7 --- /dev/null +++ b/src/stdio/ftrylockfile.c @@ -0,0 +1,18 @@ +#include "stdio_impl.h" +#include "pthread_impl.h" + +int ftrylockfile(FILE *f) +{ +	libc.lockfile = __lockfile; +	if (f->owner && f->owner == pthread_self()->tid) { +		if (f->lockcount == INT_MAX) +			return -1; +		f->lockcount++; +		return 0; +	} +	if (a_swap(&f->lock, 1)) +		return -1; +	f->owner = pthread_self()->tid; +	f->lockcount = 1; +	return 0; +} diff --git a/src/stdio/funlockfile.c b/src/stdio/funlockfile.c new file mode 100644 index 00000000..d69f68ee --- /dev/null +++ b/src/stdio/funlockfile.c @@ -0,0 +1,7 @@ +#include "stdio_impl.h" +#include "pthread_impl.h" + +void funlockfile(FILE *f) +{ +	FUNLOCK(f); +} diff --git a/src/stdio/vsnprintf.c b/src/stdio/vsnprintf.c index bda6b49b..ff792e17 100644 --- a/src/stdio/vsnprintf.c +++ b/src/stdio/vsnprintf.c @@ -17,6 +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;  	if (n > INT_MAX) {  		errno = EOVERFLOW;  		return -1; | 
