Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/arch For Explora 451, call calc_delayconst() before pckb...
details: https://anonhg.NetBSD.org/src/rev/c9f13f57cc8b
branches: trunk
changeset: 981228:c9f13f57cc8b
user: rin <rin%NetBSD.org@localhost>
date: Fri Mar 05 06:06:34 2021 +0000
description:
For Explora 451, call calc_delayconst() before pckbc_cnattach(), which
depends on delay() and DELAY().
Unfortunately, proplib(9) API is not available for MD codes, that are
called before consinit() (since pool(9) is not initialized yet).
Therefore, hard-code CPU frequency to calc_delayconst() in case
"processor-frequency" is not initialized.
diffstat:
sys/arch/evbppc/conf/std.explora | 4 +++-
sys/arch/evbppc/explora/consinit.c | 8 ++++++--
sys/arch/powerpc/conf/files.powerpc | 4 ++--
sys/arch/powerpc/ibm4xx/clock.c | 17 +++++++++++++----
4 files changed, 24 insertions(+), 9 deletions(-)
diffs (108 lines):
diff -r 475b4383fdf8 -r c9f13f57cc8b sys/arch/evbppc/conf/std.explora
--- a/sys/arch/evbppc/conf/std.explora Fri Mar 05 05:35:50 2021 +0000
+++ b/sys/arch/evbppc/conf/std.explora Fri Mar 05 06:06:34 2021 +0000
@@ -1,4 +1,4 @@
-# $NetBSD: std.explora,v 1.5 2011/06/20 17:44:33 matt Exp $
+# $NetBSD: std.explora,v 1.6 2021/03/05 06:06:34 rin Exp $
#
# Standard/required options for NetBSD/explora.
@@ -22,4 +22,6 @@
options INTSTK=8192
+options PPC_CPU_FREQ=66000000 # XXX hack for pckbc_cnattach()
+
include "arch/evbppc/conf/files.explora"
diff -r 475b4383fdf8 -r c9f13f57cc8b sys/arch/evbppc/explora/consinit.c
--- a/sys/arch/evbppc/explora/consinit.c Fri Mar 05 05:35:50 2021 +0000
+++ b/sys/arch/evbppc/explora/consinit.c Fri Mar 05 06:06:34 2021 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: consinit.c,v 1.9 2012/10/13 17:58:53 jdc Exp $ */
+/* $NetBSD: consinit.c,v 1.10 2021/03/05 06:06:34 rin Exp $ */
/*-
* Copyright (c) 2003 The NetBSD Foundation, Inc.
@@ -30,7 +30,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: consinit.c,v 1.9 2012/10/13 17:58:53 jdc Exp $");
+__KERNEL_RCSID(0, "$NetBSD: consinit.c,v 1.10 2021/03/05 06:06:34 rin Exp $");
#include <sys/param.h>
#include <sys/systm.h>
@@ -54,6 +54,7 @@
#include "pckbd.h"
#include <evbppc/explora/dev/elbvar.h>
+#include <powerpc/ibm4xx/cpu.h>
#include "opt_explora.h"
@@ -86,6 +87,9 @@
tag = elb_get_bus_space_tag(BASE_FB);
fb_cnattach(tag, BASE_FB2, (void *)BASE_FB);
+
+ calc_delayconst(); /* required by pckbc_cnattach() */
+
tag = elb_get_bus_space_tag(BASE_PCKBC);
pckbc_cnattach(tag, _BUS_SPACE_UNSTRIDE(tag, BASE_PCKBC),
_BUS_SPACE_UNSTRIDE(tag, BASE_PCKBC2-BASE_PCKBC), PCKBC_KBD_SLOT,
diff -r 475b4383fdf8 -r c9f13f57cc8b sys/arch/powerpc/conf/files.powerpc
--- a/sys/arch/powerpc/conf/files.powerpc Fri Mar 05 05:35:50 2021 +0000
+++ b/sys/arch/powerpc/conf/files.powerpc Fri Mar 05 06:06:34 2021 +0000
@@ -1,8 +1,8 @@
-# $NetBSD: files.powerpc,v 1.97 2020/10/21 13:31:51 christos Exp $
+# $NetBSD: files.powerpc,v 1.98 2021/03/05 06:06:34 rin Exp $
defflag opt_altivec.h ALTIVEC K_ALTIVEC PPC_HAVE_SPE
defflag opt_openpic.h OPENPIC_DISTRIBUTE
-defparam opt_ppcparam.h L2CR_CONFIG L3CR_CONFIG INTSTK CLOCKBASE VERBOSE_INITPPC
+defparam opt_ppcparam.h L2CR_CONFIG L3CR_CONFIG INTSTK CLOCKBASE VERBOSE_INITPPC PPC_CPU_FREQ
defflag opt_ppcarch.h PPC_OEA PPC_OEA601 PPC_OEA64 PPC_OEA64_BRIDGE PPC_MPC8XX PPC_IBM4XX PPC_IBM403 PPC_IBM440 PPC_BOOKE
defflag opt_ppccache.h CACHE_PROTO_MEI
defflag opt_pmap.h PMAPDEBUG PMAPCHECK PMAPCOUNTERS PMAP_MINIMALTLB PMAP_TLBDEBUG
diff -r 475b4383fdf8 -r c9f13f57cc8b sys/arch/powerpc/ibm4xx/clock.c
--- a/sys/arch/powerpc/ibm4xx/clock.c Fri Mar 05 05:35:50 2021 +0000
+++ b/sys/arch/powerpc/ibm4xx/clock.c Fri Mar 05 06:06:34 2021 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: clock.c,v 1.31 2021/01/18 04:35:04 rin Exp $ */
+/* $NetBSD: clock.c,v 1.32 2021/03/05 06:06:34 rin Exp $ */
/* $OpenBSD: clock.c,v 1.3 1997/10/13 13:42:53 pefo Exp $ */
/*
@@ -33,10 +33,11 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: clock.c,v 1.31 2021/01/18 04:35:04 rin Exp $");
+__KERNEL_RCSID(0, "$NetBSD: clock.c,v 1.32 2021/03/05 06:06:34 rin Exp $");
#ifdef _KERNEL_OPT
#include "opt_ppcarch.h"
+#include "opt_ppcparam.h"
#endif
#include <sys/param.h>
@@ -197,9 +198,17 @@
prop_number_t freq;
freq = prop_dictionary_get(board_properties, "processor-frequency");
- KASSERT(freq != NULL);
- ticks_per_sec = (u_long) prop_number_integer_value(freq);
+#ifndef PPC_CPU_FREQ
+ KASSERT(freq != NULL);
+#else
+ /* XXX hack for pckbc_cnattach() for Explora */
+ if (freq == NULL)
+ ticks_per_sec = (u_long) PPC_CPU_FREQ;
+ else
+#endif
+ ticks_per_sec = (u_long) prop_number_integer_value(freq);
+
ns_per_tick = 1000000000 / ticks_per_sec;
}
Home |
Main Index |
Thread Index |
Old Index