summaryrefslogtreecommitdiffstats
path: root/lib
diff options
context:
space:
mode:
authorAhmad Fatoum <a.fatoum@pengutronix.de>2021-02-16 21:02:08 +0100
committerSascha Hauer <s.hauer@pengutronix.de>2021-02-19 08:42:32 +0100
commit129e3317a6b283cb7bb10eb8cb0f531b603893c0 (patch)
tree511e2cf2cbb0ed316feb61c11bb92b93711c5aee /lib
parentf53b916b01e26ed200718b9ed736fea18605ce9c (diff)
downloadbarebox-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.c2
-rw-r--r--lib/show_progress.c17
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;