perf tools: Fix copyfile_offset update of output offset
authorJiri Olsa <[email protected]>
Tue, 9 Jan 2018 13:39:23 +0000 (14:39 +0100)
committerArnaldo Carvalho de Melo <[email protected]>
Fri, 12 Jan 2018 19:57:16 +0000 (16:57 -0300)
We need to increase output offset in each iteration, not decrease it as
we currently do.

I guess we were lucky to finish in most cases in first iteration, so the
bug never showed. However it shows a lot when working with big (~4GB)
size data.

Signed-off-by: Jiri Olsa <[email protected]>
Cc: Alexander Shishkin <[email protected]>
Cc: Andi Kleen <[email protected]>
Cc: David Ahern <[email protected]>
Cc: Namhyung Kim <[email protected]>
Cc: Peter Zijlstra <[email protected]>
Fixes: 9c9f5a2f1944 ("perf tools: Introduce copyfile_offset() function")
Link: http://lkml.kernel.org/r/[email protected]
Signed-off-by: Arnaldo Carvalho de Melo <[email protected]>
tools/perf/util/util.c

index a789f952b3e9b8d84c6999f5486fb25d5a3676ba..443892dabedbe319d8f1f582c3a255c03da5d748 100644 (file)
@@ -210,7 +210,7 @@ static int copyfile_offset(int ifd, loff_t off_in, int ofd, loff_t off_out, u64
 
                size -= ret;
                off_in += ret;
-               off_out -= ret;
+               off_out += ret;
        }
        munmap(ptr, off_in + size);