perf/arm-cmn: Validate cycles events fully
authorRobin Murphy <robin.murphy@arm.com>
Mon, 3 Apr 2023 11:49:05 +0000 (12:49 +0100)
committerWill Deacon <will@kernel.org>
Thu, 6 Apr 2023 15:07:51 +0000 (16:07 +0100)
DTC cycle count events don't have anything to validate or initialise in
themselves, but we should not forget to still validate their whole group
context. Otherwise, we may fail to correctly reject a contrived group
containing an impossible number of cycles events.

Signed-off-by: Robin Murphy <robin.murphy@arm.com>
Link: https://lore.kernel.org/r/3124e8c276a1f513c1a415dc839ca4181b3c8bc8.1680522545.git.robin.murphy@arm.com
Signed-off-by: Will Deacon <will@kernel.org>
drivers/perf/arm-cmn.c

index 9f2edc28d16ef46dacdac1fc3571cd5ff94342a5..5a57c3f10d27b22d9008e744cbc5b5a2a28d7f2a 100644 (file)
@@ -1546,7 +1546,7 @@ static int arm_cmn_event_init(struct perf_event *event)
        type = CMN_EVENT_TYPE(event);
        /* DTC events (i.e. cycles) already have everything they need */
        if (type == CMN_TYPE_DTC)
-               return 0;
+               return arm_cmn_validate_group(cmn, event);
 
        eventid = CMN_EVENT_EVENTID(event);
        /* For watchpoints we need the actual XP node here */