about summary refs log tree commit diff
path: root/src/stdio
diff options
context:
space:
mode:
authorRich Felker <dalias@aerifal.cx>2018-10-17 23:38:29 -0400
committerRich Felker <dalias@aerifal.cx>2018-10-17 23:38:29 -0400
commitd664061adb4d7f6647ab2059bc351daa394bf5da (patch)
treef27a25137efcd548a1b48b44ff3a72d73d8f2d6c /src/stdio
parentdd8f02b7dce53d6b1c4282439f1636a2d63bee01 (diff)
downloadmusl-d664061adb4d7f6647ab2059bc351daa394bf5da.tar.gz
musl-d664061adb4d7f6647ab2059bc351daa394bf5da.tar.xz
musl-d664061adb4d7f6647ab2059bc351daa394bf5da.zip
optimize hot paths of putc with manual shrink-wrapping
this is the analog of commit dd8f02b7dce53d6b1c4282439f1636a2d63bee01,
but for putc.
Diffstat (limited to 'src/stdio')
-rw-r--r--src/stdio/fputc.c9
-rw-r--r--src/stdio/putc.c9
-rw-r--r--src/stdio/putchar.c3
3 files changed, 8 insertions, 13 deletions
diff --git a/src/stdio/fputc.c b/src/stdio/fputc.c
index 92762c98..f364ed38 100644
--- a/src/stdio/fputc.c
+++ b/src/stdio/fputc.c
@@ -1,10 +1,7 @@
-#include "stdio_impl.h"
+#include <stdio.h>
+#include "putc.h"
 
 int fputc(int c, FILE *f)
 {
-	if (f->lock < 0 || !__lockfile(f))
-		return putc_unlocked(c, f);
-	c = putc_unlocked(c, f);
-	__unlockfile(f);
-	return c;
+	return do_putc(c, f);
 }
diff --git a/src/stdio/putc.c b/src/stdio/putc.c
index fa893496..4744d978 100644
--- a/src/stdio/putc.c
+++ b/src/stdio/putc.c
@@ -1,12 +1,9 @@
-#include "stdio_impl.h"
+#include <stdio.h>
+#include "putc.h"
 
 int putc(int c, FILE *f)
 {
-	if (f->lock < 0 || !__lockfile(f))
-		return putc_unlocked(c, f);
-	c = putc_unlocked(c, f);
-	__unlockfile(f);
-	return c;
+	return do_putc(c, f);
 }
 
 weak_alias(putc, _IO_putc);
diff --git a/src/stdio/putchar.c b/src/stdio/putchar.c
index 945636d5..f044f169 100644
--- a/src/stdio/putchar.c
+++ b/src/stdio/putchar.c
@@ -1,6 +1,7 @@
 #include <stdio.h>
+#include "putc.h"
 
 int putchar(int c)
 {
-	return fputc(c, stdout);
+	return do_putc(c, stdout);
 }