projects
/
platform
/
kernel
/
linux-starfive.git
/ commitdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
| commitdiff |
tree
raw
|
patch
| inline |
side by side
(parent:
33835e8
)
perf/arm-cmn: Fix filter_sel lookup
author
Robin Murphy
<robin.murphy@arm.com>
Tue, 10 May 2022 21:23:08 +0000
(22:23 +0100)
committer
Will Deacon
<will@kernel.org>
Wed, 11 May 2022 09:20:42 +0000
(10:20 +0100)
Carefully considering the bounds of an array is all well and good,
until you forget that that array also contains a NULL sentinel at
the end and dereference it. So close...
Reported-by: Qian Cai <quic_qiancai@quicinc.com>
Signed-off-by: Robin Murphy <robin.murphy@arm.com>
Link:
https://lore.kernel.org/r/bebba768156aa3c0757140457bdd0fec10819388.1652217788.git.robin.murphy@arm.com
Signed-off-by: Will Deacon <will@kernel.org>
drivers/perf/arm-cmn.c
patch
|
blob
|
history
diff --git
a/drivers/perf/arm-cmn.c
b/drivers/perf/arm-cmn.c
index
62f3842
..
a8421a4
100644
(file)
--- a/
drivers/perf/arm-cmn.c
+++ b/
drivers/perf/arm-cmn.c
@@
-1514,7
+1514,7
@@
static enum cmn_filter_select arm_cmn_filter_sel(enum cmn_model model,
struct arm_cmn_event_attr *e;
int i;
- for (i = 0; i < ARRAY_SIZE(arm_cmn_event_attrs); i++) {
+ for (i = 0; i < ARRAY_SIZE(arm_cmn_event_attrs)
- 1
; i++) {
e = container_of(arm_cmn_event_attrs[i], typeof(*e), attr.attr);
if (e->model & model && e->type == type && e->eventid == eventid)
return e->fsel;