selftests/bpf: make veristat emit all stats in CSV mode by default
authorAndrii Nakryiko <andrii@kernel.org>
Thu, 3 Nov 2022 05:53:01 +0000 (22:53 -0700)
committerAlexei Starovoitov <ast@kernel.org>
Fri, 4 Nov 2022 04:54:13 +0000 (21:54 -0700)
Make veristat distinguish between table and CSV output formats and use
different default set of stats (columns) that are emitted. While for
human-readable table output it doesn't make sense to output all known
stats, it is very useful for CSV mode to record all possible data, so
that it can later be queried and filtered in replay or comparison mode.

Signed-off-by: Andrii Nakryiko <andrii@kernel.org>
Link: https://lore.kernel.org/r/20221103055304.2904589-8-andrii@kernel.org
Signed-off-by: Alexei Starovoitov <ast@kernel.org>
tools/testing/selftests/bpf/veristat.c

index 37e512d233a7003cc2c602e07776898ffd373f41..ec1a8ba7791c732db7cdebf4392a5a3c465d2a70 100644 (file)
@@ -501,6 +501,15 @@ static const struct stat_specs default_output_spec = {
        },
 };
 
+static const struct stat_specs default_csv_output_spec = {
+       .spec_cnt = 9,
+       .ids = {
+               FILE_NAME, PROG_NAME, VERDICT, DURATION,
+               TOTAL_INSNS, TOTAL_STATES, PEAK_STATES,
+               MAX_STATES_PER_INSN, MARK_READ_MAX_LEN,
+       },
+};
+
 static const struct stat_specs default_sort_spec = {
        .spec_cnt = 2,
        .ids = {
@@ -1561,8 +1570,12 @@ int main(int argc, char **argv)
        if (env.verbose && env.log_level == 0)
                env.log_level = 1;
 
-       if (env.output_spec.spec_cnt == 0)
-               env.output_spec = default_output_spec;
+       if (env.output_spec.spec_cnt == 0) {
+               if (env.out_fmt == RESFMT_CSV)
+                       env.output_spec = default_csv_output_spec;
+               else
+                       env.output_spec = default_output_spec;
+       }
        if (env.sort_spec.spec_cnt == 0)
                env.sort_spec = default_sort_spec;