Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/dev/fdt Skip nodes with an "opp-suspend" property and fi...
details: https://anonhg.NetBSD.org/src/rev/9f89db7eabd6
branches: trunk
changeset: 460571:9f89db7eabd6
user: jmcneill <jmcneill%NetBSD.org@localhost>
date: Mon Oct 28 10:43:08 2019 +0000
description:
Skip nodes with an "opp-suspend" property and fix tables that have disabled
nodes in the middle.
diffstat:
sys/dev/fdt/cpufreq_dt.c | 18 ++++++++++++------
1 files changed, 12 insertions(+), 6 deletions(-)
diffs (64 lines):
diff -r b4cc9c76141d -r 9f89db7eabd6 sys/dev/fdt/cpufreq_dt.c
--- a/sys/dev/fdt/cpufreq_dt.c Mon Oct 28 09:00:08 2019 +0000
+++ b/sys/dev/fdt/cpufreq_dt.c Mon Oct 28 10:43:08 2019 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: cpufreq_dt.c,v 1.10 2019/10/07 13:54:59 martin Exp $ */
+/* $NetBSD: cpufreq_dt.c,v 1.11 2019/10/28 10:43:08 jmcneill Exp $ */
/*-
* Copyright (c) 2015-2017 Jared McNeill <jmcneill%invisible.ca@localhost>
@@ -27,7 +27,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: cpufreq_dt.c,v 1.10 2019/10/07 13:54:59 martin Exp $");
+__KERNEL_RCSID(0, "$NetBSD: cpufreq_dt.c,v 1.11 2019/10/28 10:43:08 jmcneill Exp $");
#include <sys/param.h>
#include <sys/systm.h>
@@ -363,7 +363,7 @@
struct cpufreq_dt_table *table;
const u_int *opp_uv;
uint64_t opp_hz;
- int opp_node, len, i;
+ int opp_node, len, i, index;
const int opp_table = fdtbus_get_phandle(phandle, "operating-points-v2");
if (opp_table < 0)
@@ -379,27 +379,33 @@
}
for (opp_node = OF_child(opp_table); opp_node; opp_node = OF_peer(opp_node)) {
- if (fdtbus_status_okay(opp_node))
- sc->sc_nopp++;
+ if (!fdtbus_status_okay(opp_node))
+ continue;
+ if (of_hasprop(opp_node, "opp-suspend"))
+ continue;
+ sc->sc_nopp++;
}
if (sc->sc_nopp == 0)
return EINVAL;
sc->sc_opp = kmem_zalloc(sizeof(*sc->sc_opp) * sc->sc_nopp, KM_SLEEP);
+ index = sc->sc_nopp - 1;
for (opp_node = OF_child(opp_table), i = 0; opp_node; opp_node = OF_peer(opp_node), i++) {
if (!fdtbus_status_okay(opp_node))
continue;
+ if (of_hasprop(opp_node, "opp-suspend"))
+ continue;
if (of_getprop_uint64(opp_node, "opp-hz", &opp_hz) != 0)
return EINVAL;
opp_uv = fdtbus_get_prop(opp_node, "opp-microvolt", &len);
if (opp_uv == NULL || len < 1)
return EINVAL;
/* Table is in reverse order */
- const int index = sc->sc_nopp - i - 1;
sc->sc_opp[index].freq_khz = (u_int)(opp_hz / 1000);
sc->sc_opp[index].voltage_uv = be32toh(opp_uv[0]);
of_getprop_uint32(opp_node, "clock-latency-ns", &sc->sc_opp[index].latency_ns);
+ --index;
}
return 0;
Home |
Main Index |
Thread Index |
Old Index