add proper fuxed-based locking for stdio
[musl] / src / stdio / __fdopen.c
index a010267..07f966a 100644 (file)
@@ -20,8 +20,8 @@ FILE *__fdopen(int fd, const char *mode)
 
        /* Set append mode on fd if opened for append */
        if (*mode == 'a') {
-               int flags = syscall(SYS_fcntl, fd, F_GETFL, 0);
-               syscall(SYS_fcntl, fd, F_SETFL, flags | O_APPEND);
+               int flags = __syscall(SYS_fcntl, fd, F_GETFL);
+               __syscall(SYS_fcntl, fd, F_SETFL, flags | O_APPEND);
        }
 
        f->fd = fd;
@@ -39,11 +39,13 @@ FILE *__fdopen(int fd, const char *mode)
        f->seek = __stdio_seek;
        f->close = __stdio_close;
 
+       if (!libc.threaded) f->lock = -1;
+
        /* Add new FILE to open file list */
        OFLLOCK();
-       f->next = ofl_head;
-       if (ofl_head) ofl_head->prev = f;
-       ofl_head = f;
+       f->next = libc.ofl_head;
+       if (libc.ofl_head) libc.ofl_head->prev = f;
+       libc.ofl_head = f;
        OFLUNLOCK();
 
        return f;