diff options
author | Mark Kettenis <kettenis@cvs.openbsd.org> | 2018-12-31 18:00:54 +0000 |
---|---|---|
committer | Mark Kettenis <kettenis@cvs.openbsd.org> | 2018-12-31 18:00:54 +0000 |
commit | 85e059247b72c33431b308f6894e96cd1da7a827 (patch) | |
tree | 6df13adcb20186ddc4adfe3f4fa3b625f6a7e109 /sys/arch | |
parent | c7031b640a2e01d3c72a2b32890d163a2bddbe57 (diff) |
Avoid calling setperf() with a negative level.
Avoid a potential use of an unitilized variable to pick an operating point.
Remove an unused (but set) variable.
ok patrick@
Diffstat (limited to 'sys/arch')
-rw-r--r-- | sys/arch/arm64/arm64/cpu.c | 16 |
1 files changed, 10 insertions, 6 deletions
diff --git a/sys/arch/arm64/arm64/cpu.c b/sys/arch/arm64/arm64/cpu.c index 539259d6195..42d440c2b6c 100644 --- a/sys/arch/arm64/arm64/cpu.c +++ b/sys/arch/arm64/arm64/cpu.c @@ -1,4 +1,4 @@ -/* $OpenBSD: cpu.c,v 1.24 2018/08/25 20:45:28 kettenis Exp $ */ +/* $OpenBSD: cpu.c,v 1.25 2018/12/31 18:00:53 kettenis Exp $ */ /* * Copyright (c) 2016 Dale Rahn <drahn@dalerahn.com> @@ -730,7 +730,7 @@ cpu_opp_mountroot(struct device *self) cpu_setperf = cpu_opp_setperf; perflevel = (level > 0) ? level : 0; - cpu_setperf(level); + cpu_setperf(perflevel); } } @@ -786,8 +786,7 @@ cpu_opp_setperf(int level) struct opp_table *ot = ci->ci_opp_table; uint64_t min, max; uint64_t level_hz, opp_hz; - uint32_t opp_microvolt; - int opp_idx; + int opp_idx = -1; int i; if (ot == NULL) @@ -803,10 +802,15 @@ cpu_opp_setperf(int level) opp_hz = min; for (i = 0; i < ot->ot_nopp; i++) { if (ot->ot_opp[i].opp_hz <= level_hz && - ot->ot_opp[i].opp_hz >= opp_hz) { + ot->ot_opp[i].opp_hz >= opp_hz) opp_hz = ot->ot_opp[i].opp_hz; - opp_microvolt = ot->ot_opp[i].opp_microvolt; + } + + /* Find index of selected operating point. */ + for (i = 0; i < ot->ot_nopp; i++) { + if (ot->ot_opp[i].opp_hz == opp_hz) { opp_idx = i; + break; } } KASSERT(opp_idx >= 0); |