about summary refs log tree commit diff
path: root/src/internal/libc.h
diff options
context:
space:
mode:
authorRich Felker <dalias@aerifal.cx>2011-04-17 16:53:54 -0400
committerRich Felker <dalias@aerifal.cx>2011-04-17 16:53:54 -0400
commit9080cc153cc2b09881c3245becbd68534db18d7c (patch)
treeddbc5aef325120e000b8e7d852f26322791deb55 /src/internal/libc.h
parenteb0e8fa0b1960cff4bd65ebefc798f70273b0bc9 (diff)
downloadmusl-9080cc153cc2b09881c3245becbd68534db18d7c.tar.gz
musl-9080cc153cc2b09881c3245becbd68534db18d7c.tar.xz
musl-9080cc153cc2b09881c3245becbd68534db18d7c.zip
clean up handling of thread/nothread mode, locking
Diffstat (limited to 'src/internal/libc.h')
-rw-r--r--src/internal/libc.h7
1 files changed, 3 insertions, 4 deletions
diff --git a/src/internal/libc.h b/src/internal/libc.h
index d6df93d0..06ba73e7 100644
--- a/src/internal/libc.h
+++ b/src/internal/libc.h
@@ -7,8 +7,8 @@
 struct __libc {
 	int *(*errno_location)(void);
 	void (*testcancel)(void);
-	void (*lock)(volatile int *);
-	void (*lockfile)(FILE *);
+	int threaded;
+	int canceldisable;
 	void (*fork_handler)(int);
 	int (*atexit)(void (*)(void));
 	void (*fini)(void);
@@ -16,7 +16,6 @@ struct __libc {
 	volatile int threads_minus_1;
 	int ofl_lock;
 	FILE *ofl_head;
-	int canceldisable;
 };
 
 
@@ -40,7 +39,7 @@ extern struct __libc *__libc_loc(void) __attribute__((const));
 void __lock(volatile int *);
 void __lockfile(FILE *);
 #define LOCK(x) (libc.threads_minus_1 ? (__lock(x),1) : ((void)(x),1))
-#define UNLOCK(x) (*(x)=0)
+#define UNLOCK(x) (*(volatile int *)(x)=0)
 
 int __rsyscall(int, long, long, long, long, long, long);