]> ruderich.org/simon Gitweb - coloredstderr/coloredstderr.git/commitdiff
Fix save/restore of errno for isatty().
authorSimon Ruderich <simon@ruderich.org>
Mon, 10 Jun 2013 04:19:00 +0000 (06:19 +0200)
committerSimon Ruderich <simon@ruderich.org>
Mon, 10 Jun 2013 12:05:51 +0000 (14:05 +0200)
src/coloredstderr.c
src/hookmacros.h

index 72a881fb866ab12e0e92188c58456e4e2979c1a7..727c580895b7814d18bba43ec832e905ba7ff6b4 100644 (file)
@@ -64,6 +64,19 @@ static int force_write_to_non_tty;
 /* See hookmacros.h for the decision if a function call is colored. */
 
 
+/* Prevent inlining into hook functions because it may increase the number of
+ * spilled registers unnecessarily. As it's not called very often accept the
+ * additional call. */
+static int isatty_noinline(int fd) __noinline;
+static int isatty_noinline(int fd) {
+    int saved_errno = errno;
+    int result = isatty(fd);
+    errno = saved_errno;
+
+    return result;
+}
+
+
 static void dup_fd(int oldfd, int newfd) {
 #ifdef DEBUG
     debug("%3d -> %3d\t\t\t[%d]\n", oldfd, newfd, getpid());
index 0eb47cd67abd45451dc85b02e0573a7e04119ced..6b52293495eb166120294356637f674d7afda9cc 100644 (file)
@@ -38,7 +38,7 @@
  *         if (force_write_to_non_tty) {
  *             handle = 1;
  *         } else {
- *             handle = isatty(<fd>);
+ *             handle = isatty_noinline(<fd>);
  *         }
  *     } else {
  *         handle = 0;
@@ -72,7 +72,7 @@
             if (unlikely(force_write_to_non_tty)) { \
                 handle = 1; \
             } else { \
-                handle = isatty(fd); \
+                handle = isatty_noinline(fd); \
             } \
         } else { \
             handle = 0; \
@@ -87,7 +87,7 @@
             if (unlikely(force_write_to_non_tty)) { \
                 handle = 1; \
             } else { \
-                handle = isatty(fileno(file)); \
+                handle = isatty_noinline(fileno(file)); \
             } \
         } else { \
             handle = 0; \