Patch "perf iostat: Fix Segmentation fault from NULL 'struct perf_counts_values *'" has been added to the 5.14-stable tree

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



This is a note to let you know that I've just added the patch titled

    perf iostat: Fix Segmentation fault from NULL 'struct perf_counts_values *'

to the 5.14-stable tree which can be found at:
    http://www.kernel.org/git/?p=linux/kernel/git/stable/stable-queue.git;a=summary

The filename of the patch is:
     perf-iostat-fix-segmentation-fault-from-null-struct-.patch
and it can be found in the queue-5.14 subdirectory.

If you, or anyone else, feels it should not be added to the stable tree,
please let <stable@xxxxxxxxxxxxxxx> know about it.



commit 5585c4d0a8e30d020c17bdbab6f8c071f1c8bc0b
Author: Like Xu <likexu@xxxxxxxxxxx>
Date:   Mon Sep 27 16:11:15 2021 +0800

    perf iostat: Fix Segmentation fault from NULL 'struct perf_counts_values *'
    
    [ Upstream commit 4da8b121884d84476f3d50d46a471471af1aa9df ]
    
    If the 'perf iostat' user specifies two or more iio_root_ports and also
    specifies the cpu(s) by -C which is not *connected to all* the above iio
    ports, the iostat_print_metric() will run into trouble:
    
    For example:
    
      $ perf iostat list
      S0-uncore_iio_0<0000:16>
      S1-uncore_iio_0<0000:97> # <--- CPU 1 is located in the socket S0
    
      $ perf iostat 0000:16,0000:97 -C 1 -- ls
      port  Inbound Read(MB)        Inbound Write(MB)       Outbound Read(MB)       Outbound
      Write(MB) ../perf-iostat: line 12: 104418 Segmentation fault
      (core dumped) perf stat --iostat$DELIMITER$*
    
    The core-dump stack says, in the above corner case, the returned
    (struct perf_counts_values *) count will be NULL, and the caller
    iostat_print_metric() apparently doesn't not handle this case.
    
      433   struct perf_counts_values *count = perf_counts(evsel->counts, die, 0);
      434
      435   if (count->run && count->ena) {
      (gdb) p count
      $1 = (struct perf_counts_values *) 0x0
    
    The deeper reason is that there are actually no statistics from the user
    specified pair "iostat 0000:X, -C (disconnected) Y ", but let's fix it with
    minimum cost by adding a NULL check in the user space.
    
    Fixes: f9ed693e8bc0e7de ("perf stat: Enable iostat mode for x86 platforms")
    Signed-off-by: Like Xu <likexu@xxxxxxxxxxx>
    Cc: Alexander Antonov <alexander.antonov@xxxxxxxxxxxxxxx>
    Cc: Alexander Shishkin <alexander.shishkin@xxxxxxxxxxxxxxx>
    Cc: Ian Rogers <irogers@xxxxxxxxxx>
    Cc: Jiri Olsa <jolsa@xxxxxxxxxx>
    Cc: Mark Rutland <mark.rutland@xxxxxxx>
    Cc: Namhyung Kim <namhyung@xxxxxxxxxx>
    Cc: Peter Zijlstra <peterz@xxxxxxxxxxxxx>
    Cc: Stephane Eranian <eranian@xxxxxxxxxx>
    Link: http://lore.kernel.org/lkml/20210927081115.39568-2-likexu@xxxxxxxxxxx
    Signed-off-by: Arnaldo Carvalho de Melo <acme@xxxxxxxxxx>
    Signed-off-by: Sasha Levin <sashal@xxxxxxxxxx>

diff --git a/tools/perf/arch/x86/util/iostat.c b/tools/perf/arch/x86/util/iostat.c
index eeafe97b8105..792cd75ade33 100644
--- a/tools/perf/arch/x86/util/iostat.c
+++ b/tools/perf/arch/x86/util/iostat.c
@@ -432,7 +432,7 @@ void iostat_print_metric(struct perf_stat_config *config, struct evsel *evsel,
 	u8 die = ((struct iio_root_port *)evsel->priv)->die;
 	struct perf_counts_values *count = perf_counts(evsel->counts, die, 0);
 
-	if (count->run && count->ena) {
+	if (count && count->run && count->ena) {
 		if (evsel->prev_raw_counts && !out->force_header) {
 			struct perf_counts_values *prev_count =
 				perf_counts(evsel->prev_raw_counts, die, 0);



[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[Index of Archives]     [Linux USB Devel]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]

  Powered by Linux