summaryrefslogtreecommitdiff
path: root/libc
diff options
context:
space:
mode:
Diffstat (limited to 'libc')
-rw-r--r--libc/stdio/printf.c12
-rw-r--r--libc/stdio/scanf.c4
2 files changed, 16 insertions, 0 deletions
diff --git a/libc/stdio/printf.c b/libc/stdio/printf.c
index 9654cda90..5bdec7ae4 100644
--- a/libc/stdio/printf.c
+++ b/libc/stdio/printf.c
@@ -1265,6 +1265,10 @@ int vsnprintf(char *__restrict buf, size_t size,
f.filedes = -2; /* for debugging */
f.modeflags = (__FLAG_NARROW|__FLAG_WRITEONLY|__FLAG_WRITING);
+#ifdef __STDIO_THREADSAFE
+ __stdio_init_mutex(&f.lock);
+#endif
+
rv = vfprintf(&f, format, arg);
if (size) {
if (f.bufwpos == f.bufend) {
@@ -1335,6 +1339,10 @@ int vsnprintf(char *__restrict buf, size_t size,
f.filedes = -1; /* For debugging. */
f.modeflags = (__FLAG_NARROW|__FLAG_WRITEONLY|__FLAG_WRITING);
+#ifdef __STDIO_THREADSAFE
+ __stdio_init_mutex(&f.lock);
+#endif
+
rv = vfprintf(&f, format, arg);
return rv;
@@ -1373,6 +1381,10 @@ int vdprintf(int filedes, const char * __restrict format, va_list arg)
f.filedes = filedes;
f.modeflags = (__FLAG_NARROW|__FLAG_WRITEONLY|__FLAG_WRITING);
+#ifdef __STDIO_THREADSAFE
+ __stdio_init_mutex(&f.lock);
+#endif
+
rv = vfprintf(&f, format, arg);
return fflush(&f) ? -1 : rv;
diff --git a/libc/stdio/scanf.c b/libc/stdio/scanf.c
index 07e74d9ae..a5e0d412c 100644
--- a/libc/stdio/scanf.c
+++ b/libc/stdio/scanf.c
@@ -127,6 +127,10 @@ int vsscanf(__const char *sp, __const char *fmt, va_list ap)
string->bufstart = string->bufrpos = (unsigned char *) ((void *) sp);
string->bufgetc = (char *) ((unsigned) -1);
+#ifdef __STDIO_THREADSAFE
+ __stdio_init_mutex(&string->lock);
+#endif
+
return vfscanf(string, fmt, ap);
}
#else /* __STDIO_BUFFERS */