X-Git-Url: http://nsz.repo.hu/git/?a=blobdiff_plain;f=src%2Finternal%2Fstdio_impl.h;h=13e5cfd9019c946057450a5481f898121c579a67;hb=5eb0d33ec0f08b123c5c10877d6258d05fa9453a;hp=1e9159f6f2443bd0eba52598c76159d1de840ec0;hpb=0b44a0315b47dd8eced9f3b7f31580cf14bbfc01;p=musl diff --git a/src/internal/stdio_impl.h b/src/internal/stdio_impl.h index 1e9159f6..13e5cfd9 100644 --- a/src/internal/stdio_impl.h +++ b/src/internal/stdio_impl.h @@ -23,8 +23,8 @@ #define UNGET 4 -#define FLOCK(f) LOCK(&f->lock) -#define FUNLOCK(f) UNLOCK(&f->lock) +#define FLOCK(f) ((libc.lockfile && (f)->owner>=0) ? (libc.lockfile((f)),0) : 0) +#define FUNLOCK(f) ((f)->lockcount && (--(f)->lockcount || ((f)->owner=(f)->lock=0))) #define F_PERM 1 #define F_NORD 4 @@ -50,7 +50,7 @@ struct __FILE_s { signed char lbf; int lock; int lockcount; - void *owner; + void *dummy5; off_t off; int (*flush)(FILE *); void **wide_data; /* must be NULL */ @@ -59,6 +59,7 @@ struct __FILE_s { off_t (*seek)(FILE *, off_t, int); int mode; int (*close)(FILE *); + int owner; }; size_t __stdio_read(FILE *, unsigned char *, size_t); @@ -80,15 +81,9 @@ int __putc_unlocked(int, FILE *); FILE *__fdopen(int, const char *); -extern struct ofl -{ - FILE *head; - int lock; -} __ofl; - -#define OFLLOCK() LOCK(&__ofl.lock) -#define OFLUNLOCK() UNLOCK(&__ofl.lock) -#define ofl_head (__ofl.head) +#define OFLLOCK() LOCK(&libc.ofl_lock) +#define OFLUNLOCK() UNLOCK(&libc.ofl_lock) +#define ofl_head (libc.ofl_head) #define feof(f) ((f)->flags & F_EOF) #define ferror(f) ((f)->flags & F_ERR)