GNU bug report logs -
#9279
df -h should use human_round_to_nearest in human_output_opts for more accurate results
Previous Next
To add a comment to this bug, you must first unarchive it, by sending
a message to control AT debbugs.gnu.org, with unarchive 9279 in the body.
You can then email your comments to 9279 AT debbugs.gnu.org in the normal way.
Toggle the display of automated, internal messages from the tracker.
Report forwarded
to
owner <at> debbugs.gnu.org, bug-coreutils <at> gnu.org
:
bug#9279
; Package
coreutils
.
(Thu, 11 Aug 2011 06:31:02 GMT)
Full text and
rfc822 format available.
Acknowledgement sent
to
Sabuj Pattanayek <sabujp <at> gmail.com>
:
New bug report received and forwarded. Copy sent to
bug-coreutils <at> gnu.org
.
(Thu, 11 Aug 2011 06:31:03 GMT)
Full text and
rfc822 format available.
Message #5 received at submit <at> debbugs.gnu.org (full text, mbox):
Hi,
We have a 37TB filesystem that shows up in the output of df -h as 38TB :
Filesystem Size Used Avail Use% Mounted on
blue:/sas2fs03/ 38T 24T 14T 63% /blue/sas2
df -k shows :
Filesystem 1K-blocks Used Available Use% Mounted on
blue:/sas2fs03/ 39741816832 25020650784 14721166048 63% /blue/sas2
39741816832 is definitely much closer to 37TB than to 38TB :
% echo "39741816832 / (1024^3)" | bc -l
37.01245117187500000000
38TB would be :
echo "38*1024^3" | bc -l
40802189312 (in 1K-blocks) which is >> 39741816832 (difference of 1060372480)
With my suggested patch (below), I get correct output :
coreutils-8.9/src% ./df -h /blue/sas2
Filesystem Size Used Avail Use% Mounted on
blue:/sas2fs03/ 37T 23T 14T 63% /blue/sas2
Here's my suggested patch against the 8.9 release :
--- df.c.old 2011-08-11 00:45:02.697289000 -0500
+++ df.c 2011-08-11 00:45:45.884017000 -0500
@@ -794,7 +794,7 @@
inode_format = true;
break;
case 'h':
- human_output_opts = human_autoscale | human_SI | human_base_1024;
+ human_output_opts = human_round_to_nearest |
human_autoscale | human_SI | human_base_1024;
output_block_size = 1;
break;
case 'H':
Thanks,
Sabuj Pattanayek
Information forwarded
to
owner <at> debbugs.gnu.org, bug-coreutils <at> gnu.org
:
bug#9279
; Package
coreutils
.
(Thu, 11 Aug 2011 15:22:02 GMT)
Full text and
rfc822 format available.
Message #8 received at 9279 <at> debbugs.gnu.org (full text, mbox):
tag 9279 notabug
thanks
Thanks, but df always rounds up. POSIX requires this for formats it specifies;
see <http://pubs.opengroup.org/onlinepubs/9699919799/utilities/df.html>
and look for "rounded". for other formats, I thought it better to be
consistent.
Reply sent
to
Jim Meyering <jim <at> meyering.net>
:
You have taken responsibility.
(Thu, 11 Aug 2011 15:52:01 GMT)
Full text and
rfc822 format available.
Notification sent
to
Sabuj Pattanayek <sabujp <at> gmail.com>
:
bug acknowledged by developer.
(Thu, 11 Aug 2011 15:52:02 GMT)
Full text and
rfc822 format available.
Message #13 received at 9279-done <at> debbugs.gnu.org (full text, mbox):
Paul Eggert wrote:
> Thanks, but df always rounds up. POSIX requires this for formats it specifies;
> see <http://pubs.opengroup.org/onlinepubs/9699919799/utilities/df.html>
> and look for "rounded". for other formats, I thought it better to be
> consistent.
Thanks for the patch.
Note that the consistency argument applies not just to df, but also to
du and ls. All of those tools are documented to round block counts up.
If you feel ambitious, an alternative may be to extend human.c so that
setting the BLOCK_SIZE envvar to say, "human-readable-round-to-nearest",
makes all of those tools do what you propose. The "Block size" section
of "info coreutils" describes how the BLOCK_SIZE envvar works.
I'm closing this issue.
If you propose to change gnulib's human.c,
please start a new thread with an appropriate subject.
bug archived.
Request was from
Debbugs Internal Request <help-debbugs <at> gnu.org>
to
internal_control <at> debbugs.gnu.org
.
(Fri, 09 Sep 2011 11:24:03 GMT)
Full text and
rfc822 format available.
This bug report was last modified 14 years and 6 days ago.
Previous Next
GNU bug tracking system
Copyright (C) 1999 Darren O. Benham,
1997,2003 nCipher Corporation Ltd,
1994-97 Ian Jackson.