Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/arch/arm/cortex - Add an isb before cnt[pv]_ctl read
details: https://anonhg.NetBSD.org/src/rev/3932e8160d21
branches: trunk
changeset: 985587:3932e8160d21
user: jmcneill <jmcneill%NetBSD.org@localhost>
date: Mon Aug 30 22:53:37 2021 +0000
description:
- Add an isb before cnt[pv]_ctl read
- cntk_ctl is 64-bits
- Do not toggle CNTCTL_IMASK in intr handler, as this may be needed
elsewhere.
diffstat:
sys/arch/arm/cortex/gtmr.c | 44 ++++++++++++++++++++------------------------
1 files changed, 20 insertions(+), 24 deletions(-)
diffs (115 lines):
diff -r 037c393b8c2d -r 3932e8160d21 sys/arch/arm/cortex/gtmr.c
--- a/sys/arch/arm/cortex/gtmr.c Mon Aug 30 22:49:42 2021 +0000
+++ b/sys/arch/arm/cortex/gtmr.c Mon Aug 30 22:53:37 2021 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: gtmr.c,v 1.43 2021/01/18 23:43:34 jmcneill Exp $ */
+/* $NetBSD: gtmr.c,v 1.44 2021/08/30 22:53:37 jmcneill Exp $ */
/*-
* Copyright (c) 2012 The NetBSD Foundation, Inc.
@@ -30,7 +30,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: gtmr.c,v 1.43 2021/01/18 23:43:34 jmcneill Exp $");
+__KERNEL_RCSID(0, "$NetBSD: gtmr.c,v 1.44 2021/08/30 22:53:37 jmcneill Exp $");
#include <sys/param.h>
#include <sys/bus.h>
@@ -41,6 +41,7 @@
#include <sys/proc.h>
#include <sys/systm.h>
#include <sys/timetc.h>
+#include <sys/cpu.h>
#include <prop/proplib.h>
@@ -195,6 +196,8 @@
static uint32_t
gtmr_read_ctl(struct gtmr_softc *sc)
{
+ isb();
+
if (sc->sc_physical)
return gtmr_cntp_ctl_read();
else
@@ -239,7 +242,8 @@
gtmr_init_cpu_clock(struct cpu_info *ci)
{
struct gtmr_softc * const sc = >mr_sc;
- uint32_t val;
+ uint32_t cntk;
+ uint64_t ctl;
KASSERT(ci == curcpu());
@@ -249,29 +253,34 @@
* Allow the virtual and physical counters to be accessed from
* usermode. (PL0)
*/
- val = gtmr_cntk_ctl_read();
- val &= ~(CNTKCTL_PL0PTEN | CNTKCTL_PL0VTEN | CNTKCTL_EVNTEN);
+ cntk = gtmr_cntk_ctl_read();
+ cntk &= ~(CNTKCTL_PL0PTEN | CNTKCTL_PL0VTEN | CNTKCTL_EVNTEN);
if (sc->sc_physical) {
- val |= CNTKCTL_PL0PCTEN;
- val &= ~CNTKCTL_PL0VCTEN;
+ cntk |= CNTKCTL_PL0PCTEN;
+ cntk &= ~CNTKCTL_PL0VCTEN;
} else {
- val |= CNTKCTL_PL0VCTEN;
- val &= ~CNTKCTL_PL0PCTEN;
+ cntk |= CNTKCTL_PL0VCTEN;
+ cntk &= ~CNTKCTL_PL0PCTEN;
}
- gtmr_cntk_ctl_write(val);
+ gtmr_cntk_ctl_write(cntk);
isb();
/*
* enable timer and stop masking the timer.
*/
- gtmr_write_ctl(sc, CNTCTL_ENABLE);
+ ctl = gtmr_read_ctl(sc);
+ ctl &= ~CNTCTL_IMASK;
+ ctl |= CNTCTL_ENABLE;
+ gtmr_write_ctl(sc, ctl);
/*
* Get now and update the compare timer.
*/
ci->ci_lastintr = gtmr_read_cntct(sc);
gtmr_write_tval(sc, sc->sc_autoinc);
+
splx(s);
+
KASSERT(gtmr_read_cntct(sc) != 0);
}
@@ -324,14 +333,6 @@
struct cpu_info * const ci = curcpu();
struct clockframe * const cf = arg;
struct gtmr_softc * const sc = >mr_sc;
- uint32_t ctl;
-
- ctl = gtmr_read_ctl(sc);
- if ((ctl & CNTCTL_ISTATUS) == 0)
- return 0;
-
- ctl |= CNTCTL_IMASK;
- gtmr_write_ctl(sc, ctl);
const uint64_t now = gtmr_read_cntct(sc);
uint64_t delta = now - ci->ci_lastintr;
@@ -371,11 +372,6 @@
gtmr_write_tval(sc, sc->sc_autoinc - delta);
}
- ctl = gtmr_read_ctl(sc);
- ctl &= ~CNTCTL_IMASK;
- ctl |= CNTCTL_ENABLE;
- gtmr_write_ctl(sc, ctl);
-
ci->ci_lastintr = now;
#ifdef DIAGNOSTIC
Home |
Main Index |
Thread Index |
Old Index