Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/arch Provide and use some CP0 accessor functions instead...
details: https://anonhg.NetBSD.org/src/rev/60a9ab501359
branches: trunk
changeset: 353753:60a9ab501359
user: skrll <skrll%NetBSD.org@localhost>
date: Sun May 21 06:49:12 2017 +0000
description:
Provide and use some CP0 accessor functions instead of M[TF]C0 macros
for readability.
While here convert some other M[TF]C0 uses to already exising accessor
functions, e.g. mipsNN_cp0_ebase_read
diffstat:
sys/arch/evbmips/ingenic/clock.c | 7 +-
sys/arch/evbmips/ingenic/cpu.c | 17 ++-
sys/arch/evbmips/ingenic/intr.c | 27 +++--
sys/arch/evbmips/ingenic/machdep.c | 13 +-
sys/arch/evbmips/ingenic/mainbus.c | 8 +-
sys/arch/mips/conf/files.ingenic | 3 +-
sys/arch/mips/ingenic/ingenic_coreregs.h | 70 ++++++++++++++
sys/arch/mips/ingenic/ingenic_regs.h | 43 +--------
sys/arch/mips/ingenic/ingenic_var.h | 12 ++-
sys/arch/mips/mips/locore_ingenic.S | 150 +++++++++++++++++++++++++++++++
10 files changed, 274 insertions(+), 76 deletions(-)
diffs (truncated from 593 to 300 lines):
diff -r 8f42574a7df2 -r 60a9ab501359 sys/arch/evbmips/ingenic/clock.c
--- a/sys/arch/evbmips/ingenic/clock.c Sun May 21 06:19:37 2017 +0000
+++ b/sys/arch/evbmips/ingenic/clock.c Sun May 21 06:49:12 2017 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: clock.c,v 1.9 2017/05/19 07:40:58 skrll Exp $ */
+/* $NetBSD: clock.c,v 1.10 2017/05/21 06:49:12 skrll Exp $ */
/*-
* Copyright (c) 2014 Michael Lorenz
@@ -27,7 +27,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: clock.c,v 1.9 2017/05/19 07:40:58 skrll Exp $");
+__KERNEL_RCSID(0, "$NetBSD: clock.c,v 1.10 2017/05/21 06:49:12 skrll Exp $");
#include "opt_multiprocessor.h"
@@ -38,6 +38,7 @@
#include <sys/systm.h>
#include <sys/timetc.h>
+#include <mips/ingenic/ingenic_var.h>
#include <mips/ingenic/ingenic_regs.h>
#include "opt_ingenic.h"
@@ -236,7 +237,7 @@
* XXX
* needs to take the IPI lock and ping all online CPUs, not just core 1
*/
- MTC0(1 << IPI_CLOCK, 20, 1);
+ mips_cp0_corembox_write(1, 1 << IPI_CLOCK);
#endif
hardclock(cf);
splx(s);
diff -r 8f42574a7df2 -r 60a9ab501359 sys/arch/evbmips/ingenic/cpu.c
--- a/sys/arch/evbmips/ingenic/cpu.c Sun May 21 06:19:37 2017 +0000
+++ b/sys/arch/evbmips/ingenic/cpu.c Sun May 21 06:49:12 2017 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: cpu.c,v 1.3 2017/05/19 07:40:58 skrll Exp $ */
+/* $NetBSD: cpu.c,v 1.4 2017/05/21 06:49:12 skrll Exp $ */
/*
* Copyright 2002 Wasabi Systems, Inc.
@@ -36,7 +36,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: cpu.c,v 1.3 2017/05/19 07:40:58 skrll Exp $");
+__KERNEL_RCSID(0, "$NetBSD: cpu.c,v 1.4 2017/05/21 06:49:12 skrll Exp $");
#include "opt_ingenic.h"
#include "opt_multiprocessor.h"
@@ -47,8 +47,9 @@
#include <sys/cpu.h>
#include <mips/locore.h>
-#include <mips/asm.h>
+#include <mips/ingenic/ingenic_coreregs.h>
#include <mips/ingenic/ingenic_regs.h>
+#include <mips/ingenic/ingenic_var.h>
static int cpu_match(device_t, cfdata_t, void *);
static void cpu_attach(device_t, device_t, void *);
@@ -85,14 +86,16 @@
ci = startup_cpu_info;
wbflush();
vec = (uint32_t)&ingenic_wakeup;
- reg = MFC0(12, 4); /* reset entry reg */
+ reg = mips_cp0_corereim_read();
reg &= ~REIM_ENTRY_M;
reg |= vec;
- MTC0(reg, 12, 4);
- reg = MFC0(12, 2); /* core control reg */
+ mips_cp0_corereim_write(reg);
+
+ reg = mips_cp0_corectrl_read();
reg |= CC_RPC1; /* use our exception vector */
reg &= ~CC_SW_RST1; /* get core 1 out of reset */
- MTC0(reg, 12, 2);
+ mips_cp0_corectrl_write(reg);
+
while ((!kcpuset_isset(cpus_hatched, cpu_index(startup_cpu_info))) && (bail > 0)) {
delay(1000);
bail--;
diff -r 8f42574a7df2 -r 60a9ab501359 sys/arch/evbmips/ingenic/intr.c
--- a/sys/arch/evbmips/ingenic/intr.c Sun May 21 06:19:37 2017 +0000
+++ b/sys/arch/evbmips/ingenic/intr.c Sun May 21 06:49:12 2017 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: intr.c,v 1.12 2016/08/27 05:52:43 skrll Exp $ */
+/* $NetBSD: intr.c,v 1.13 2017/05/21 06:49:12 skrll Exp $ */
/*-
* Copyright (c) 2014 Michael Lorenz
@@ -27,7 +27,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: intr.c,v 1.12 2016/08/27 05:52:43 skrll Exp $");
+__KERNEL_RCSID(0, "$NetBSD: intr.c,v 1.13 2017/05/21 06:49:12 skrll Exp $");
#define __INTR_PRIVATE
@@ -44,7 +44,9 @@
#include <mips/locore.h>
#include <machine/intr.h>
+#include <mips/ingenic/ingenic_var.h>
#include <mips/ingenic/ingenic_regs.h>
+#include <mips/ingenic/ingenic_coreregs.h>
#include "opt_ingenic.h"
@@ -126,14 +128,15 @@
writereg(JZ_ICMR1, 0xffffffff);
/* allow peripheral interrupts to core 0 only */
- reg = MFC0(12, 4); /* reset entry and interrupts */
+ reg = mips_cp0_corereim_read();
reg &= 0xffff0000;
reg |= REIM_IRQ0_M | REIM_MIRQ0_M;
#ifdef MULTIPROCESSOR
reg |= REIM_MIRQ1_M;
#endif
- MTC0(reg, 12, 4);
- MTC0(0, 20, 1); /* ping the 2nd core */
+ mips_cp0_corereim_write(reg);
+
+ mips_cp0_corembox_write(1, 0); /* ping the 2nd core */
DPRINTF("%s %08x\n", __func__, reg);
}
@@ -146,12 +149,12 @@
#if 0
snprintf(buffer, 256, "pending: %08x CR %08x\n", ipending,
- MFC0(MIPS_COP_0_CAUSE, 0));
+ mipsNN_cp0_cause_read());
ingenic_puts(buffer);
#endif
#endif
/* see which core we're on */
- id = MFC0(15, 1) & 7;
+ id = mipsNN_cp0_ebase_read() & 7;
/*
* XXX
@@ -166,12 +169,12 @@
int s = splsched();
/* read pending IPIs */
- reg = MFC0(12, 3);
+ reg = mips_cp0_corestatus_read();
if (id == 0) {
if (reg & CS_MIRQ0_P) {
#ifdef MULTIPROCESSOR
uint32_t tag;
- tag = MFC0(CP0_CORE_MBOX, 0);
+ tag = mips_cp0_corembox_read(id);
ipi_process(curcpu(), tag);
#ifdef INGENIC_INTR_DEBUG
@@ -182,13 +185,13 @@
#endif
reg &= (~CS_MIRQ0_P);
/* clear it */
- MTC0(reg, 12, 3);
+ mips_cp0_corestatus_write(reg);
}
} else if (id == 1) {
if (reg & CS_MIRQ1_P) {
#ifdef MULTIPROCESSOR
uint32_t tag;
- tag = MFC0(CP0_CORE_MBOX, 1);
+ tag = mips_cp0_corembox_read(id);
ingenic_puts("1");
if (tag & 0x400)
hardclock(cf);
@@ -201,7 +204,7 @@
#endif
reg &= (~CS_MIRQ1_P);
/* clear it */
- MTC0(reg, 12, 3);
+ mips_cp0_corestatus_write(reg);
}
}
splx(s);
diff -r 8f42574a7df2 -r 60a9ab501359 sys/arch/evbmips/ingenic/machdep.c
--- a/sys/arch/evbmips/ingenic/machdep.c Sun May 21 06:19:37 2017 +0000
+++ b/sys/arch/evbmips/ingenic/machdep.c Sun May 21 06:49:12 2017 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: machdep.c,v 1.13 2017/05/19 07:40:58 skrll Exp $ */
+/* $NetBSD: machdep.c,v 1.14 2017/05/21 06:49:12 skrll Exp $ */
/*-
* Copyright (c) 2014 Michael Lorenz
@@ -27,7 +27,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: machdep.c,v 1.13 2017/05/19 07:40:58 skrll Exp $");
+__KERNEL_RCSID(0, "$NetBSD: machdep.c,v 1.14 2017/05/21 06:49:12 skrll Exp $");
#include "opt_ddb.h"
#include "opt_kgdb.h"
@@ -61,6 +61,7 @@
#include <mips/locore.h>
#include <mips/cpuregs.h>
+#include <mips/ingenic/ingenic_coreregs.h>
#include <mips/ingenic/ingenic_regs.h>
#include <mips/ingenic/ingenic_var.h>
@@ -128,12 +129,12 @@
uint32_t reg;
/* enable IPIs for this core */
- reg = MFC0(12, 4); /* reset entry and interrupts */
+ reg = mips_cp0_corereim_read();
if (cpu_index(ci) == 1) {
reg |= REIM_MIRQ1_M;
} else
reg |= REIM_MIRQ0_M;
- MTC0(reg, 12, 4);
+ mips_cp0_corereim_write(reg);
printf("%s %d %08x\n", __func__, cpu_index(ci), reg);
}
@@ -147,9 +148,9 @@
mutex_enter(&ingenic_ipi_lock);
if (kcpuset_isset(cpus_running, cpu_index(ci))) {
if (cpu_index(ci) == 0) {
- MTC0(msg, CP0_CORE_MBOX, 0);
+ mips_cp0_corembox_write(msg, 0);
} else {
- MTC0(msg, CP0_CORE_MBOX, 1);
+ mips_cp0_corembox_write(msg, 1);
}
}
mutex_exit(&ingenic_ipi_lock);
diff -r 8f42574a7df2 -r 60a9ab501359 sys/arch/evbmips/ingenic/mainbus.c
--- a/sys/arch/evbmips/ingenic/mainbus.c Sun May 21 06:19:37 2017 +0000
+++ b/sys/arch/evbmips/ingenic/mainbus.c Sun May 21 06:49:12 2017 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: mainbus.c,v 1.6 2017/05/19 07:40:58 skrll Exp $ */
+/* $NetBSD: mainbus.c,v 1.7 2017/05/21 06:49:12 skrll Exp $ */
/*-
* Copyright (c) 2014 Michael Lorenz
@@ -27,7 +27,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: mainbus.c,v 1.6 2017/05/19 07:40:58 skrll Exp $");
+__KERNEL_RCSID(0, "$NetBSD: mainbus.c,v 1.7 2017/05/21 06:49:12 skrll Exp $");
#include "opt_multiprocessor.h"
@@ -95,11 +95,11 @@
printf("TMR: %08x\n", readreg(JZ_TC_TMR));
/* send ourselves an IPI */
- MTC0(0x12345678, CP0_CORE_MBOX, 0);
+ mips_cp0_corembox_write(0x12345678, 0);
delay(1000);
/* send the other core an IPI */
- MTC0(0x12345678, CP0_CORE_MBOX, 1);
+ mips_cp0_corembox_write(0x12345678, 1);
delay(1000);
#endif
}
diff -r 8f42574a7df2 -r 60a9ab501359 sys/arch/mips/conf/files.ingenic
--- a/sys/arch/mips/conf/files.ingenic Sun May 21 06:19:37 2017 +0000
+++ b/sys/arch/mips/conf/files.ingenic Sun May 21 06:49:12 2017 +0000
@@ -1,6 +1,7 @@
-# $NetBSD: files.ingenic,v 1.9 2017/05/19 07:30:24 skrll Exp $
+# $NetBSD: files.ingenic,v 1.10 2017/05/21 06:49:13 skrll Exp $
file arch/mips/mips/bus_dma.c
+file arch/mips/mips/locore_ingenic.S
include "dev/scsipi/files.scsipi" # SCSI devices
include "dev/ata/files.ata" # ATA devices
diff -r 8f42574a7df2 -r 60a9ab501359 sys/arch/mips/ingenic/ingenic_coreregs.h
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/sys/arch/mips/ingenic/ingenic_coreregs.h Sun May 21 06:49:12 2017 +0000
@@ -0,0 +1,70 @@
+/* $NetBSD: ingenic_coreregs.h,v 1.1 2017/05/21 06:49:13 skrll Exp $ */
+
+/*-
+ * Copyright (c) 2014 Michael Lorenz
+ * All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ * 1. Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ * 2. Redistributions in binary form must reproduce the above copyright
Home |
Main Index |
Thread Index |
Old Index