mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/kdave/btrfs-progs.git
synced 2024-11-16 08:44:31 +08:00
pretty_sizes() returns incorrect values
pretty_sizes() returns incorrect values if the argument is < 1024. pretty_sizes(0) -> 0.00 OK pretty_sizes(102) -> 0.10 WRONG pretty_sizes(1023) -> 1.00 WRONG pretty_sizes(1024) -> 1.00KB OK Signed-off-by: Goffredo Baroncelli <kreijack@inwind.it> Signed-off-by: Chris Mason <chris.mason@fusionio.com>
This commit is contained in:
parent
e86f7198d9
commit
29db8b12cd
30
utils.c
30
utils.c
@ -1091,25 +1091,27 @@ char *pretty_sizes(u64 size)
|
||||
{
|
||||
int num_divs = 0;
|
||||
int pretty_len = 16;
|
||||
u64 last_size = size;
|
||||
u64 fract_size = size;
|
||||
float fraction;
|
||||
char *pretty;
|
||||
|
||||
while(size > 0) {
|
||||
fract_size = last_size;
|
||||
last_size = size;
|
||||
size /= 1024;
|
||||
num_divs++;
|
||||
}
|
||||
if (num_divs == 0)
|
||||
num_divs = 1;
|
||||
if (num_divs > ARRAY_SIZE(size_strs))
|
||||
return NULL;
|
||||
if( size < 1024 ){
|
||||
fraction = size;
|
||||
num_divs = 0;
|
||||
} else {
|
||||
u64 last_size = size;
|
||||
num_divs = 0;
|
||||
while(size >= 1024){
|
||||
last_size = size;
|
||||
size /= 1024;
|
||||
num_divs ++;
|
||||
}
|
||||
|
||||
fraction = (float)fract_size / 1024;
|
||||
if (num_divs > ARRAY_SIZE(size_strs))
|
||||
return NULL;
|
||||
fraction = (float)last_size / 1024;
|
||||
}
|
||||
pretty = malloc(pretty_len);
|
||||
snprintf(pretty, pretty_len, "%.2f%s", fraction, size_strs[num_divs-1]);
|
||||
snprintf(pretty, pretty_len, "%.2f%s", fraction, size_strs[num_divs]);
|
||||
return pretty;
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user