diff options
author | Ahmad Fatoum <a.fatoum@pengutronix.de> | 2021-02-16 21:02:08 +0100 |
---|---|---|
committer | Sascha Hauer <s.hauer@pengutronix.de> | 2021-02-19 08:42:32 +0100 |
commit | 129e3317a6b283cb7bb10eb8cb0f531b603893c0 (patch) | |
tree | 511e2cf2cbb0ed316feb61c11bb92b93711c5aee /lib | |
parent | f53b916b01e26ed200718b9ed736fea18605ce9c (diff) | |
download | barebox-129e3317a6b283cb7bb10eb8cb0f531b603893c0.tar.gz barebox-129e3317a6b283cb7bb10eb8cb0f531b603893c0.tar.xz |
copy_file: fix progress bar for files larger than 2G
Files larger than 2G cause the benign bug, that the progress bar is no
longer accurate. Use loff_t to fix this.
Note that printed % HASHES_PER_LINE in show_progress implies a 64-bit
division. A previous commit changed the constant divisor to a power of
two, so a division shouldn't be generated. The original multiplication
and modulo operations are left as is for clarity.
Signed-off-by: Ahmad Fatoum <a.fatoum@pengutronix.de>
Signed-off-by: Sascha Hauer <s.hauer@pengutronix.de>
Diffstat (limited to 'lib')
-rw-r--r-- | lib/libfile.c | 2 | ||||
-rw-r--r-- | lib/show_progress.c | 17 |
2 files changed, 9 insertions, 10 deletions
diff --git a/lib/libfile.c b/lib/libfile.c index 20bb689a79..4ab8db11ad 100644 --- a/lib/libfile.c +++ b/lib/libfile.c @@ -332,7 +332,7 @@ int copy_file(const char *src, const char *dst, int verbose) int r, s; int ret = 1, err1 = 0; int mode; - int total = 0; + loff_t total = 0; struct stat srcstat, dststat; rw_buf = xmalloc(RW_BUF_SIZE); diff --git a/lib/show_progress.c b/lib/show_progress.c index d797ec28d8..1be06ea780 100644 --- a/lib/show_progress.c +++ b/lib/show_progress.c @@ -17,15 +17,15 @@ #include <common.h> #include <fs.h> #include <progress.h> -#include <asm-generic/div64.h> +#include <linux/math64.h> #define HASHES_PER_LINE 64 -static int printed; -static int progress_max; -static int spin; +static loff_t printed; +static loff_t progress_max; +static unsigned spin; -void show_progress(int now) +void show_progress(loff_t now) { char spinchr[] = "\\|/-"; @@ -35,9 +35,8 @@ void show_progress(int now) } if (progress_max && progress_max != FILESIZE_MAX) { - uint64_t tmp = (int64_t)now * HASHES_PER_LINE; - do_div(tmp, progress_max); - now = tmp; + uint64_t tmp = now * HASHES_PER_LINE; + now = div64_u64(tmp, progress_max); } while (printed < now) { @@ -48,7 +47,7 @@ void show_progress(int now) } } -void init_progression_bar(int max) +void init_progression_bar(loff_t max) { printed = 0; progress_max = max; |