Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/sys/dev/fdt Select the highest rate at boot, and update cycl...



details:   https://anonhg.NetBSD.org/src/rev/fec1bf63b7dd
branches:  trunk
changeset: 972664:fec1bf63b7dd
user:      jmcneill <jmcneill%NetBSD.org@localhost>
date:      Tue Jun 02 11:40:02 2020 +0000

description:
Select the highest rate at boot, and update cycle counter frequency when rates change

diffstat:

 sys/dev/fdt/cpufreq_dt.c |  20 ++++++++++++++------
 1 files changed, 14 insertions(+), 6 deletions(-)

diffs (56 lines):

diff -r b9048eb9f674 -r fec1bf63b7dd sys/dev/fdt/cpufreq_dt.c
--- a/sys/dev/fdt/cpufreq_dt.c  Tue Jun 02 10:41:30 2020 +0000
+++ b/sys/dev/fdt/cpufreq_dt.c  Tue Jun 02 11:40:02 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: cpufreq_dt.c,v 1.13 2019/10/29 10:52:22 jmcneill Exp $ */
+/* $NetBSD: cpufreq_dt.c,v 1.14 2020/06/02 11:40:02 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.13 2019/10/29 10:52:22 jmcneill Exp $");
+__KERNEL_RCSID(0, "$NetBSD: cpufreq_dt.c,v 1.14 2020/06/02 11:40:02 jmcneill Exp $");
 
 #include <sys/param.h>
 #include <sys/systm.h>
@@ -83,10 +83,10 @@
 static void
 cpufreq_dt_change_cb(void *arg1, void *arg2)
 {
-#if notyet
+       struct cpufreq_dt_softc * const sc = arg1;
        struct cpu_info *ci = curcpu();
-       ci->ci_data.cpu_cc_freq = cpufreq_get_rate() * 1000000;
-#endif
+
+       ci->ci_data.cpu_cc_freq = sc->sc_freq_target * 1000000;
 }
 
 static int
@@ -489,7 +489,7 @@
        }
 
        for (i = 0; i < sc->sc_nopp; i++) {
-               aprint_verbose_dev(sc->sc_dev, "%u.%03u MHz, %u uV\n",
+               aprint_debug_dev(sc->sc_dev, "supported rate: %u.%03u MHz, %u uV\n",
                    sc->sc_opp[i].freq_khz / 1000,
                    sc->sc_opp[i].freq_khz % 1000,
                    sc->sc_opp[i].voltage_uv);
@@ -531,6 +531,14 @@
        pmf_event_register(sc->sc_dev, PMFE_THROTTLE_DISABLE, cpufreq_dt_throttle_disable, true);
 
        cpufreq_dt_init_sysctl(sc);
+
+       if (sc->sc_nopp > 0) {
+               struct cpufreq_dt_opp * const opp = &sc->sc_opp[sc->sc_nopp - 1];
+
+               aprint_normal_dev(sc->sc_dev, "rate: %u.%03u MHz, %u uV\n",
+                   opp->freq_khz / 1000, opp->freq_khz % 1000, opp->voltage_uv);
+               cpufreq_dt_set_rate(sc, opp->freq_khz);
+       }
 }
 
 static int



Home | Main Index | Thread Index | Old Index