aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorUlrich Drepper <drepper@redhat.com>2008-08-06 02:09:47 +0000
committerUlrich Drepper <drepper@redhat.com>2008-08-06 02:09:47 +0000
commit9c0cb1504e3883e788da79375e4fd8e3f424cddf (patch)
treeb6acad6b60f29d703cd75a29c2137e715ee5a8ca
parent46aea5cb2fe83c36fa3cf4182aaba29d8f3b3077 (diff)
downloadglibc-9c0cb1504e3883e788da79375e4fd8e3f424cddf.tar
glibc-9c0cb1504e3883e788da79375e4fd8e3f424cddf.tar.gz
glibc-9c0cb1504e3883e788da79375e4fd8e3f424cddf.tar.bz2
glibc-9c0cb1504e3883e788da79375e4fd8e3f424cddf.zip
* scripts/gen-as-const.awk: Use 32-bit values on 32-bit platforms.
-rw-r--r--ChangeLog2
-rw-r--r--scripts/gen-as-const.awk14
2 files changed, 13 insertions, 3 deletions
diff --git a/ChangeLog b/ChangeLog
index d379de5138..c94308ff80 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,5 +1,7 @@
2008-08-05 Ulrich Drepper <drepper@redhat.com>
+ * scripts/gen-as-const.awk: Use 32-bit values on 32-bit platforms.
+
[BZ #5794]
* sysdeps/i386/fpu/s_expm1l.S: Simply use exp implementation for large
parameters.
diff --git a/scripts/gen-as-const.awk b/scripts/gen-as-const.awk
index 23f2f2bc9b..20d18c12af 100644
--- a/scripts/gen-as-const.awk
+++ b/scripts/gen-as-const.awk
@@ -16,12 +16,20 @@ NF >= 1 && !started {
if (test) {
print "\n#include <inttypes.h>";
print "\n#include <stdio.h>";
+ print "\n#if __WORDSIZE__ == 64";
+ print "\ntypedef uint64_t c_t;";
print "\n#define U(n) UINT64_C (n)";
+ print "\n#define PRI PRId64";
+ print "\n#else";
+ print "\ntypedef uint32_t c_t;";
+ print "\n#define U(n) UINT32_C (n)";
+ print "\n#define PRI PRId32";
+ print "\n#endif";
print "\nstatic int do_test (void)\n{\n int bad = 0, good = 0;\n";
print "#define TEST(name, source, expr) \\\n" \
- " if (U (asconst_##name) != (uint64_t) (expr)) { ++bad;" \
- " fprintf (stderr, \"%s: %s is %\" PRId64 \" but %s is %\"PRId64 \"\\n\"," \
- " source, #name, U (asconst_##name), #expr, (uint64_t) (expr));" \
+ " if (U (asconst_##name) != (c_t) (expr)) { ++bad;" \
+ " fprintf (stderr, \"%s: %s is %\" PRI \" but %s is %\"PRI \"\\n\"," \
+ " source, #name, U (asconst_##name), #expr, (c_t) (expr));" \
" } else ++good;\n";
}
else