Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/netbsd-8]: src Pull up following revision(s) (requested by maya in ticke...
details: https://anonhg.NetBSD.org/src/rev/1da8cd622ab2
branches: netbsd-8
changeset: 434244:1da8cd622ab2
user: martin <martin%NetBSD.org@localhost>
date: Tue Aug 29 12:47:29 2017 +0000
description:
Pull up following revision(s) (requested by maya in ticket #246):
sys/arch/evbmips/conf/std.loongson: revision 1.2
usr.sbin/sysinst/arch/evbmips/md.h: revision 1.2
sys/arch/mips/mips/mipsX_subr.S: revision 1.101
sys/arch/mips/mips/mipsX_subr.S: revision 1.102
sys/arch/mips/mips/mipsX_subr.S: revision 1.103
sys/arch/mips/mips/mipsX_subr.S: revision 1.104
In working around loongson errata clear BTB and RAS, same as
other operating systems.
15 Errata: Issue of Out-of-order in loongson (translated)
In loongson 2F, because of the branch prediction, sometimes the CPU
may fetch the instructions from some unexpected area (for example I/O
space). It is an invalid operation. There are two ways for the CPU to
choose the branch target. The first one is predicting the branch
target according to the branch target history. The second one is
calculating the branch target by the ALU. There are most 8
instructions in the instruction window at the same time in loongson2f
(Remember the loongson 2f is superscalar, right?). Hence, the
branch target of an indirect branch(such as jr) could be got(may be
predicted by the branch target history) earlier and the instrctions of
the branch target could be prefetched even if there are branch
instructions before it. As a result, it is possible to fetch the
instructions from I/O region( say out-of the physical address range of
[0- 0x100000]) in kernel model because of the instruction prefetch of
the branch target.
There are some suggestions to prevent prefetching instructions from
the I/O region in kernel mode.
(1) When switching from user model to kernel model, you should flush
the branch target history such as BTB and RAS.
(2) Doing some tricks to the indirect branch target to make sure that
the indirect branch target can not be in the I/O region.
Remove whitespace I just introduced
Build the loongson kernels with all the binutils loongson2f errata workarounds
>From Zhang Fuxin via <a rel="nofollow" href="https://sourceware.org/ml/binutils/2009-11/msg00387.html">https://sourceware.org/ml/binutils/2009-11/msg00387.html</a>
- The NOP issue
"The nature of the erratum is deeply related to the microarchitecture of
Loongson-2. It uses roughly a 4-way superscalar dynamically scheduled core,
instructions are excuted as much as possible in parallel with technics like
branch prediction etc. We use a 8-entry internal branch prediction queue to
keep track of each predicted branches, if some branches are proved to be
wrongly predicted, all the instructions following it will be cancelled,together
with the resources used by them, including the registers used for renaming, and
the queue entry will be freeed. There is a bug that might cause a hang when the
queue is full(some resources might been leaked due to conflict branch entries),
the workaround is to reduce the possiblity of branch queue full by using
renaming registers(they are also limited, can prevent too many simutaneos
branches). In theory this is still not enough to fully eliminate possible
hangs, but the possiblity is extremely low now and hard to be hit in real
code."
- The JUMP instructions issue
"The Loongson-2 series processors have quite complex micro-architecture, it will
try to execute instructions from the predicated branch of coming instruction
stream before they are confirmed to be run, if the predication of branch
direction is proved wrong later, the instructions will be cancelled, but if the
instructions is a read from memory, the read action might not be cancelled(but
the changes to register will) to enable some prefetch. This will lead to some
problems when compining with some chipsets. E.g. the AMD CS5536 used in
Yeeloong/Fuloong will hang if it gets an address in the physical address range
of 0x100000-0x200000(might be more other ranges). Speculative reads can perform
read at any address in theory(due to wrong prediction of branch directions and
the use of branch target buffer), thus in very few occasions they might cause a
hard lock of the machine.
To prevent this, we need to prevent some addresses from entering branch
target buffers. A way to do this is that to modify all jump targets, e.g.,
calulations of t9
...
jalr t9 =>
calculations of t9
or t9, t9, 0x80000000; // to make sure t9 is in kseg0
jalr t9
Of course, we have to consider 64/32bit, and modules addresses etc.
This only need to be performed on kernel code, because only there we can have
accesses not translated/limited by TLB. For user code, it is impossible to
generate accesses to unwanted physical address. So it is safe.
Also, to prevent addresses generated by user mode code to be used by the
kernel, we add a few empty jumps to flush the BTB upon entrance to kernel."
evbmips can "boot root FFSv2"
It typically uses a non-NetBSD bootloader (PMON, u-boot...) and those
don't differentiate from v1 from v2 - both are unsupported and it requires
a separate boot partition.
Don't need the errata workaround on user return
It's reported that the MMU will block such invalid reads in userland,
and it's only needed on entry.
use meaningful name for errata hack, dedup
diffstat:
sys/arch/evbmips/conf/std.loongson | 7 ++-----
sys/arch/mips/mips/mipsX_subr.S | 33 ++++++++++++---------------------
usr.sbin/sysinst/arch/evbmips/md.h | 5 ++++-
3 files changed, 18 insertions(+), 27 deletions(-)
diffs (122 lines):
diff -r b9406df98bf0 -r 1da8cd622ab2 sys/arch/evbmips/conf/std.loongson
--- a/sys/arch/evbmips/conf/std.loongson Tue Aug 29 11:58:26 2017 +0000
+++ b/sys/arch/evbmips/conf/std.loongson Tue Aug 29 12:47:29 2017 +0000
@@ -1,4 +1,4 @@
-# $NetBSD: std.loongson,v 1.1 2011/08/27 13:42:44 bouyer Exp $
+# $NetBSD: std.loongson,v 1.1.46.1 2017/08/29 12:47:29 martin Exp $
machine evbmips mips
include "conf/std" # MI standard options
@@ -21,10 +21,7 @@
options EXEC_SCRIPT # exec #! scripts
options COMPAT_NETBSD32
-#makeoptions AFLAGS+="-Wa,-mfix-loongson2f-jump -Wa,-mfix-loongson2f-nop"
-#makeoptions CFLAGS+="-Wa,-mfix-loongson2f-jump -Wa,-mfix-loongson2f-nop"
-#makeoptions CPUFLAGS="-mips3 -mdivide-breaks" # CPU codegen options
-makeoptions CPUFLAGS="-mips3 -mdivide-breaks -Wa,-mfix-loongson2f-btb" # CPU codegen options
+makeoptions CPUFLAGS="-mips3 -mdivide-breaks -Wa,-mfix-loongson2f-btb -Wa,-mfix-loongson2f-jump -Wa,-mfix-loongson2f-nop" # CPU codegen options
makeoptions DEFTEXTADDR="0x80200000"
makeoptions BOARDTYPE="loongson"
diff -r b9406df98bf0 -r 1da8cd622ab2 sys/arch/mips/mips/mipsX_subr.S
--- a/sys/arch/mips/mips/mipsX_subr.S Tue Aug 29 11:58:26 2017 +0000
+++ b/sys/arch/mips/mips/mipsX_subr.S Tue Aug 29 12:47:29 2017 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: mipsX_subr.S,v 1.100 2017/05/15 10:59:24 skrll Exp $ */
+/* $NetBSD: mipsX_subr.S,v 1.100.2.1 2017/08/29 12:47:29 martin Exp $ */
/*
* Copyright 2002 Wasabi Systems, Inc.
@@ -150,6 +150,13 @@
li reg, MIPS_SR_EXL | MIPS_SR_KX; mtc0 reg, MIPS_COP_0_STATUS
#endif
+#ifdef MIPS3_LOONGSON2
+#define KERN_ENTRY_ERRATA \
+ li k0, MIPS_DIAG_BTB_CLEAR|MIPS_DIAG_RAS_DISABLE; mtc0 k0, MIPS_COP_0_DIAG
+#else
+#define KERN_ENTRY_ERRATA /* nothing */
+#endif
+
#if MIPS1
#error This file can not be compiled with MIPS1 defined
#endif
@@ -1288,10 +1295,7 @@
/*
* Save a minimum of registers to see if this is rdhwr $3,$29
*/
-#ifdef MIPS3_LOONGSON2
- li k0, MIPS_DIAG_BTB_CLEAR
- mtc0 k0, MIPS_COP_0_DIAG
-#endif
+ KERN_ENTRY_ERRATA
/* K1 already has CURLWP */
PTR_L k0, L_PCB(k1) # XXXuvm_lwp_getuarea
PTR_ADDU k0, USPACE - TF_SIZ - CALLFRAME_SIZ
@@ -1353,10 +1357,7 @@
/*
* Save all the registers except the kernel temporaries onto the stack.
*/
-#ifdef MIPS3_LOONGSON2
- li k0, MIPS_DIAG_BTB_CLEAR
- mtc0 k0, MIPS_COP_0_DIAG
-#endif
+ KERN_ENTRY_ERRATA
/* K1 already has CURLWP */
PTR_L k0, L_PCB(k1) # XXXuvm_lwp_getuarea
PTR_ADDU k0, USPACE - TF_SIZ - CALLFRAME_SIZ
@@ -1468,10 +1469,7 @@
* Save the relevant user registers onto the kernel stack.
* We don't need to save s0 - s8 because the compiler does it for us.
*/
-#ifdef MIPS3_LOONGSON2
- li k0, MIPS_DIAG_BTB_CLEAR
- mtc0 k0, MIPS_COP_0_DIAG
-#endif
+ KERN_ENTRY_ERRATA
/* k1 contains curlwp */
PTR_L k0, L_PCB(k1) # XXXuvm_lwp_getuarea
PTR_ADDU k0, USPACE - TF_SIZ - CALLFRAME_SIZ
@@ -1660,10 +1658,7 @@
/*
* Save all the registers but kernel temporaries onto the stack.
*/
-#ifdef MIPS3_LOONGSON2
- li k0, MIPS_DIAG_BTB_CLEAR
- mtc0 k0, MIPS_COP_0_DIAG
-#endif
+ KERN_ENTRY_ERRATA
/* k1 already contains cpulwp */
PTR_L k0, L_PCB(k1) # XXXuvm_lwp_getuarea
PTR_ADDU k0, USPACE - TF_SIZ - CALLFRAME_SIZ
@@ -2655,10 +2650,6 @@
REG_L s6, CALLFRAME_SIZ+TF_REG_S6(sp) # $22
REG_L s7, CALLFRAME_SIZ+TF_REG_S7(sp) # $23
REG_L s8, CALLFRAME_SIZ+TF_REG_S8(sp) # $30
-#ifdef MIPS3_LOONGSON2
- li t0, (MIPS_DIAG_BTB_CLEAR|MIPS_DIAG_ITLB_CLEAR)
- mtc0 t0, MIPS_COP_0_DIAG
-#endif
MIPSX(user_intr_return):
#ifdef PARANOIA
PTR_L t0, L_CPU(MIPS_CURLWP)
diff -r b9406df98bf0 -r 1da8cd622ab2 usr.sbin/sysinst/arch/evbmips/md.h
--- a/usr.sbin/sysinst/arch/evbmips/md.h Tue Aug 29 11:58:26 2017 +0000
+++ b/usr.sbin/sysinst/arch/evbmips/md.h Tue Aug 29 12:47:29 2017 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: md.h,v 1.1 2014/07/26 19:30:45 dholland Exp $ */
+/* $NetBSD: md.h,v 1.1.20.1 2017/08/29 12:47:29 martin Exp $ */
/*
* Copyright 1997 Piermont Information Systems Inc.
@@ -42,6 +42,9 @@
/* Megs required for a full X installation. */
#define XNEEDMB 50
+/* have support for booting from UFS2 */
+#define HAVE_UFS2_BOOT
+
/*
* Default filesets to fetch and install during installation or upgrade.
* The standard sets are: base etc comp games man misc tests text
Home |
Main Index |
Thread Index |
Old Index