Loading
drivers/perf: hisi: hns3: Fix out-of-bound access when valid event group
mainline inclusion from mainline-v6.9-rc1 commit 81bdd60a3d1d3b05e6cc6674845afb1694dd3a0e category: bugfix bugzilla: https://gitee.com/openeuler/kernel/issues/I9HCSA CVE: NA Reference: https://git.kernel.org/pub/scm/linux/kernel/git/will/linux.git/commit/?h=for-next/perf&id=81bdd60a3d1d3b05e6cc6674845afb1694dd3a0e ------------------------------------------------------------------------ The perf tool allows users to create event groups through following cmd [1], but the driver does not check whether the array index is out of bounds when writing data to the event_group array. If the number of events in an event_group is greater than HNS3_PMU_MAX_HW_EVENTS, the memory write overflow of event_group array occurs. Add array index check to fix the possible array out of bounds violation, and return directly when write new events are written to array bounds. There are 9 different events in an event_group. [1] perf stat -e '{pmu/event1/, ... ,pmu/event9/} Fixes: 66637ab1 ("drivers/perf: hisi: add driver for HNS3 PMU") Signed-off-by:Junhao He <hejunhao3@huawei.com> Signed-off-by:
Hao Chen <chenhao418@huawei.com> Acked-by:
Jonathan Cameron <Jonathan.Cameron@huawei.com> Reviewed-by:
Jijie Shao <shaojijie@huawei.com> Link: https://lore.kernel.org/r/20240425124627.13764-3-hejunhao3@huawei.com Signed-off-by:
Will Deacon <will@kernel.org> Signed-off-by:
Slim6882 <yangjunshuo@huawei.com>