selftests/bpf: Fix massive output from test_maps
authorJesper Dangaard Brouer <brouer@redhat.com>
Wed, 26 Aug 2020 08:17:36 +0000 (10:17 +0200)
committerDaniel Borkmann <daniel@iogearbox.net>
Fri, 28 Aug 2020 11:58:19 +0000 (13:58 +0200)
When stdout output from the selftests tool 'test_maps' gets redirected
into e.g file or pipe, then the output lines increase a lot (from 21
to 33949 lines).  This is caused by the printf that happens before the
fork() call, and there are user-space buffered printf data that seems
to be duplicated into the forked process.

To fix this fflush() stdout before the fork loop in __run_parallel().

Fixes: 1a97cf1fe503 ("selftests/bpf: speedup test_maps")
Signed-off-by: Jesper Dangaard Brouer <brouer@redhat.com>
Signed-off-by: Daniel Borkmann <daniel@iogearbox.net>
Link: https://lore.kernel.org/bpf/159842985651.1050885.2154399297503372406.stgit@firesoul
tools/testing/selftests/bpf/test_maps.c

index 754cf611723ee53f759bcf7a88f989033431ae1a..0d92ebcb335d1b7637641c07594c99cf3312b9fb 100644 (file)
@@ -1274,6 +1274,8 @@ static void __run_parallel(unsigned int tasks,
        pid_t pid[tasks];
        int i;
 
        pid_t pid[tasks];
        int i;
 
+       fflush(stdout);
+
        for (i = 0; i < tasks; i++) {
                pid[i] = fork();
                if (pid[i] == 0) {
        for (i = 0; i < tasks; i++) {
                pid[i] = fork();
                if (pid[i] == 0) {