bin/146205: df(1) fails to display total space on a
100PB filesystem correctly
Alexander Best
arundel at freebsd.org
Tue Mar 22 12:27:19 UTC 2011
On Tue Mar 22 11, Alexander Best wrote:
> On Mon Mar 21 11, Xin LI wrote:
> > -----BEGIN PGP SIGNED MESSAGE-----
> > Hash: SHA256
> >
> > Revised version, I have mistakenly understood the old code, which only
> > keeps one digit after the dot.
>
> with this patch running my example code with
>
> int64_t bytes = 6007692009979824 * 1024;
>
> returns "8E". with
>
> int64_t bytes = 2007692009979824 * 1024;
>
> however it returns "9E. this doesn't seem quite right.
i haven't checked whether this behavior was introduced by your patch or poses
another genuine humanzie_number(3) bug.
cheers.
alex
>
> >
> > Cheers,
> > - --
> > Xin LI <delphij at delphij.net> http://www.delphij.net/
> > FreeBSD - The Power to Serve! Live free or die
> > -----BEGIN PGP SIGNATURE-----
> > Version: GnuPG v2.0.17 (FreeBSD)
> >
> > iQEcBAEBCAAGBQJNh/D6AAoJEATO+BI/yjfBbDoH/25nmc7rQ914Rgfp2iVTBTCo
> > 0J6D29V1tRfqFnzg62zYH23tsoQfcYI/gesx5TyegdCOpR1nOAEUl7T/UA4CmUuh
> > CN54KNQ631WUT/V5Rndf5ikIcAnu7L5IP14RNGUWH5CJhi70OmrbWt3d2XKvLMvO
> > Uhtq+Uhl/NyoGaq2tE9/WyGyeb70Ribzd4zE6hMVSSY9rPKASpCj3oSpAn7ioSms
> > X9MvcUCM/eOQxLMYtq1PN6Dz5GPqewiBfmoOWNGssbYnhqotYpIKNUAkDeKUuFop
> > P940nVkhhiSmsZPGD4W67fgKwXhxzj7Ukw7ru+XOp0z3afK6xxkkUQAvAfGop4g=
> > =mx5z
> > -----END PGP SIGNATURE-----
>
> > Index: humanize_number.c
> > ===================================================================
> > --- humanize_number.c (revision 219842)
> > +++ humanize_number.c (working copy)
> > @@ -47,8 +47,9 @@
> > const char *suffix, int scale, int flags)
> > {
> > const char *prefixes, *sep;
> > - int b, i, r, maxscale, s1, s2, sign;
> > + int i, r, maxscale, s1, s2, sign;
> > int64_t divisor, max;
> > + int64_t quotient = bytes, reminder = 0;
> > size_t baselen;
> >
> > assert(buf != NULL);
> > @@ -88,11 +89,10 @@
> > buf[0] = '\0';
> > if (bytes < 0) {
> > sign = -1;
> > - bytes *= -100;
> > + quotient = -quotient;
> > baselen = 3; /* sign, digit, prefix */
> > } else {
> > sign = 1;
> > - bytes *= 100;
> > baselen = 2; /* digit, prefix */
> > }
> > if (flags & HN_NOSPACE)
> > @@ -109,7 +109,7 @@
> >
> > if (scale & (HN_AUTOSCALE | HN_GETSCALE)) {
> > /* See if there is additional columns can be used. */
> > - for (max = 100, i = len - baselen; i-- > 0;)
> > + for (max = 1, i = len - baselen; i-- > 0;)
> > max *= 10;
> >
> > /*
> > @@ -117,29 +117,33 @@
> > * If there will be an overflow by the rounding below,
> > * divide once more.
> > */
> > - for (i = 0; bytes >= max - 50 && i < maxscale; i++)
> > - bytes /= divisor;
> > + for (i = 0; quotient > max && i < maxscale; i++) {
> > + reminder = quotient % divisor;
> > + quotient /= divisor;
> > + }
> >
> > if (scale & HN_GETSCALE)
> > return (i);
> > - } else
> > - for (i = 0; i < scale && i < maxscale; i++)
> > - bytes /= divisor;
> > + } else {
> > + for (i = 0; i < scale && i < maxscale; i++) {
> > + reminder = quotient % divisor;
> > + quotient /= divisor;
> > + }
> > + }
> >
> > /* If a value <= 9.9 after rounding and ... */
> > - if (bytes < 995 && i > 0 && flags & HN_DECIMAL) {
> > + if (quotient == 9 && reminder < 950 && i > 0 && flags & HN_DECIMAL) {
> > /* baselen + \0 + .N */
> > if (len < baselen + 1 + 2)
> > return (-1);
> > - b = ((int)bytes + 5) / 10;
> > - s1 = b / 10;
> > - s2 = b % 10;
> > + s1 = (int)quotient + (((int)reminder + 50) / 100);
> > + s2 = (((int)reminder + 50) / 10) % 10;
> > r = snprintf(buf, len, "%d%s%d%s%s%s",
> > sign * s1, localeconv()->decimal_point, s2,
> > sep, SCALE2PREFIX(i), suffix);
> > } else
> > r = snprintf(buf, len, "%" PRId64 "%s%s%s",
> > - sign * ((bytes + 50) / 100),
> > + sign * (quotient + (reminder + 50) / 100),
> > sep, SCALE2PREFIX(i), suffix);
> >
> > return (r);
>
>
> --
> a13x
--
a13x
More information about the freebsd-bugs
mailing list