perf intel-pt: Fix divide by zero when TSC is not available
authorAdrian Hunter <adrian.hunter@intel.com>
Fri, 1 Mar 2019 10:35:36 +0000 (12:35 +0200)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Sat, 23 Mar 2019 13:35:29 +0000 (14:35 +0100)
commit 076333870c2f5bdd9b6d31e7ca1909cf0c84cbfa upstream.

When TSC is not available, "timeless" decoding is used but a divide by
zero occurs if perf_time_to_tsc() is called.

Ensure the divisor is not zero.

Signed-off-by: Adrian Hunter <adrian.hunter@intel.com>
Cc: Jiri Olsa <jolsa@redhat.com>
Cc: stable@vger.kernel.org # v4.9+
Link: https://lkml.kernel.org/n/tip-1i4j0wqoc8vlbkcizqqxpsf4@git.kernel.org
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
tools/perf/util/intel-pt.c

index 3b118fa9da89bee1680b5662497854b49320905e..e8e05e7838b26501ae76e5930a7b5cbc41b94a57 100644 (file)
@@ -2545,6 +2545,8 @@ int intel_pt_process_auxtrace_info(union perf_event *event,
        }
 
        pt->timeless_decoding = intel_pt_timeless_decoding(pt);
+       if (pt->timeless_decoding && !pt->tc.time_mult)
+               pt->tc.time_mult = 1;
        pt->have_tsc = intel_pt_have_tsc(pt);
        pt->sampling_mode = false;
        pt->est_tsc = !pt->timeless_decoding;