Patch "perf jevents: Don't stop at the first matched pmu when searching a events table" has been added to the 6.12-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 jevents: Don't stop at the first matched pmu when searching a events table

to the 6.12-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-jevents-don-t-stop-at-the-first-matched-pmu-whe.patch
and it can be found in the queue-6.12 subdirectory.

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



commit 0ea595ddae0d8f2dab6df445b4d24f6093dabda9
Author: Kan Liang <kan.liang@xxxxxxxxxxxxxxx>
Date:   Mon Sep 30 19:14:31 2024 -0700

    perf jevents: Don't stop at the first matched pmu when searching a events table
    
    [ Upstream commit 8d7f85e323ea402005fa83ddbdf5d00292d77098 ]
    
    The "perf all PMU test" fails on a Coffee Lake machine.
    
    The failure is caused by the below change in the commit e2641db83f18
    ("perf vendor events: Add/update skylake events/metrics").
    
    +    {
    +        "BriefDescription": "This 48-bit fixed counter counts the UCLK cycles",
    +        "Counter": "FIXED",
    +        "EventCode": "0xff",
    +        "EventName": "UNC_CLOCK.SOCKET",
    +        "PerPkg": "1",
    +        "PublicDescription": "This 48-bit fixed counter counts the UCLK cycles.",
    +        "Unit": "cbox_0"
         }
    
    The other cbox events have the unit name "CBOX", while the fixed counter
    has a unit name "cbox_0". So the events_table will maintain separate
    entries for cbox and cbox_0.
    
    The perf_pmus__print_pmu_events() calculates the total number of events,
    allocate an aliases buffer, store all the events into the buffer, sort,
    and print all the aliases one by one.
    
    The problem is that the calculated total number of events doesn't match
    the stored events in the aliases buffer.
    
    The perf_pmu__num_events() is used to calculate the number of events. It
    invokes the pmu_events_table__num_events() to go through the entire
    events_table to find all events. Because of the
    pmu_uncore_alias_match(), the suffix of uncore PMU will be ignored. So
    the events for cbox and cbox_0 are all counted.
    
    When storing events into the aliases buffer, the
    perf_pmu__for_each_event() only process the events for cbox.
    
    Since a bigger buffer was allocated, the last entry are all 0.
    When printing all the aliases, null will be outputted, and trigger the
    failure.
    
    The mismatch was introduced from the commit e3edd6cf6399 ("perf
    pmu-events: Reduce processed events by passing PMU"). The
    pmu_events_table__for_each_event() stops immediately once a pmu is set.
    But for uncore, especially this case, the method is wrong and mismatch
    what perf does in the perf_pmu__num_events().
    
    With the patch,
    $ perf list pmu | grep -A 1 clock.socket
       unc_clock.socket
            [This 48-bit fixed counter counts the UCLK cycles. Unit: uncore_cbox_0
    $ perf test "perf all PMU test"
      107: perf all PMU test                                               : Ok
    
    Reported-by: kernel test robot <oliver.sang@xxxxxxxxx>
    Closes: https://lore.kernel.org/all/202407101021.2c8baddb-oliver.sang@xxxxxxxxx/
    Fixes: e3edd6cf6399 ("perf pmu-events: Reduce processed events by passing PMU")
    Signed-off-by: Kan Liang <kan.liang@xxxxxxxxxxxxxxx>
    Reviewed-by: Ian Rogers <irogers@xxxxxxxxxx>
    Cc: Sandipan Das <sandipan.das@xxxxxxx>
    Cc: Benjamin Gray <bgray@xxxxxxxxxxxxx>
    Cc: Xu Yang <xu.yang_2@xxxxxxx>
    Cc: John Garry <john.g.garry@xxxxxxxxxx>
    Link: https://lore.kernel.org/r/20241001021431.814811-1-irogers@xxxxxxxxxx
    Signed-off-by: Namhyung Kim <namhyung@xxxxxxxxxx>
    Signed-off-by: Sasha Levin <sashal@xxxxxxxxxx>

diff --git a/tools/perf/pmu-events/empty-pmu-events.c b/tools/perf/pmu-events/empty-pmu-events.c
index c592079982fbd..873e9fb2041f0 100644
--- a/tools/perf/pmu-events/empty-pmu-events.c
+++ b/tools/perf/pmu-events/empty-pmu-events.c
@@ -380,7 +380,7 @@ int pmu_events_table__for_each_event(const struct pmu_events_table *table,
                         continue;
 
                 ret = pmu_events_table__for_each_event_pmu(table, table_pmu, fn, data);
-                if (pmu || ret)
+                if (ret)
                         return ret;
         }
         return 0;
diff --git a/tools/perf/pmu-events/jevents.py b/tools/perf/pmu-events/jevents.py
index bb0a5d92df4a1..d46a22fb5573d 100755
--- a/tools/perf/pmu-events/jevents.py
+++ b/tools/perf/pmu-events/jevents.py
@@ -930,7 +930,7 @@ int pmu_events_table__for_each_event(const struct pmu_events_table *table,
                         continue;
 
                 ret = pmu_events_table__for_each_event_pmu(table, table_pmu, fn, data);
-                if (pmu || ret)
+                if (ret)
                         return ret;
         }
         return 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