diff options
author | Rich Felker <dalias@aerifal.cx> | 2011-09-05 22:23:06 -0400 |
---|---|---|
committer | Rich Felker <dalias@aerifal.cx> | 2011-09-05 22:23:06 -0400 |
commit | 96cea94ad258be262ecf15b33d13cf775e59720d (patch) | |
tree | 533a76158ab9473da5d0017d73e28105680f663e /src/stdlib/strtoull.c | |
parent | 5989dde3459b2ccd304f89e3e875136e5608b8ff (diff) | |
download | musl-96cea94ad258be262ecf15b33d13cf775e59720d.tar.gz musl-96cea94ad258be262ecf15b33d13cf775e59720d.tar.bz2 musl-96cea94ad258be262ecf15b33d13cf775e59720d.tar.xz musl-96cea94ad258be262ecf15b33d13cf775e59720d.zip |
fix incorrect overflow errors on strtoul, etc.
Diffstat (limited to 'src/stdlib/strtoull.c')
-rw-r--r-- | src/stdlib/strtoull.c | 7 |
1 files changed, 5 insertions, 2 deletions
diff --git a/src/stdlib/strtoull.c b/src/stdlib/strtoull.c index 20aa7bde..5d1c4ee5 100644 --- a/src/stdlib/strtoull.c +++ b/src/stdlib/strtoull.c @@ -5,8 +5,11 @@ unsigned long long strtoull(const char *s, char **p, int base) { - uintmax_t x = strtoumax(s, p, base); - if (x > ULLONG_MAX) { + intmax_t x; + if (sizeof(intmax_t) == sizeof(long long)) + return strtoumax(s, p, base); + x = strtoimax(s, p, base); + if (-x > ULLONG_MAX || x > ULLONG_MAX) { errno = ERANGE; return ULLONG_MAX; } |