* lib/fsusage.c (PROPAGATE_ALL_ONES): Don't assume uintmax_t is
authorPaul Eggert <eggert@cs.ucla.edu>
Mon, 16 Oct 2006 23:39:20 +0000 (23:39 +0000)
committerPaul Eggert <eggert@cs.ucla.edu>
Mon, 16 Oct 2006 23:39:20 +0000 (23:39 +0000)
at least as wide as intmax_t.

ChangeLog
lib/fsusage.c

index addf6ef..9a5beab 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,8 @@
+2006-10-16  Paul Eggert  <eggert@cs.ucla.edu>
+
+       * lib/fsusage.c (PROPAGATE_ALL_ONES): Don't assume uintmax_t is
+       at least as wide as intmax_t.
+
 2006-10-16  Alexandre Duret-Lutz  <adl@gnu.org>
 
        (Imported from Automake.)
index c9721ca..7d84a9f 100644 (file)
    a uintmax_t value that is all 1 bits if X is all 1 bits, even if X
    is unsigned and narrower than uintmax_t.  */
 #define PROPAGATE_ALL_ONES(x) \
-  ((sizeof (x) < sizeof (uintmax_t) \
+  ((sizeof (x) != sizeof (uintmax_t) \
     && (~ (x) == (sizeof (x) < sizeof (int) \
                  ? - (1 << (sizeof (x) * CHAR_BIT)) \
                  : 0))) \
-   ? UINTMAX_MAX : (x))
+   ? UINTMAX_MAX : (uintmax_t) (x))
 
 /* Extract the top bit of X as an uintmax_t value.  */
 #define EXTRACT_TOP_BIT(x) ((x) \