Source-Changes-HG archive

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

[src/trunk]: src/sys/arch/mips/mips Fix octeon spinup code to branch to right...



details:   https://anonhg.NetBSD.org/src/rev/ab32ce51bdcb
branches:  trunk
changeset: 808775:ab32ce51bdcb
user:      matt <matt%NetBSD.org@localhost>
date:      Tue Jun 02 05:10:18 2015 +0000

description:
Fix octeon spinup code to branch to right instruction and to jump to the
right routine.

diffstat:

 sys/arch/mips/mips/locore_octeon.S |  34 +++++++++++++++++++---------------
 1 files changed, 19 insertions(+), 15 deletions(-)

diffs (71 lines):

diff -r bbbf1281b266 -r ab32ce51bdcb sys/arch/mips/mips/locore_octeon.S
--- a/sys/arch/mips/mips/locore_octeon.S        Tue Jun 02 05:09:15 2015 +0000
+++ b/sys/arch/mips/mips/locore_octeon.S        Tue Jun 02 05:10:18 2015 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: locore_octeon.S,v 1.2 2015/06/01 22:55:13 matt Exp $   */
+/*     $NetBSD: locore_octeon.S,v 1.3 2015/06/02 05:10:18 matt Exp $   */
 
 /*
  * Copyright (c) 2007 Internet Initiative Japan, Inc.
@@ -27,7 +27,7 @@
  */
 
 #include <mips/asm.h>
-RCSID("$NetBSD: locore_octeon.S,v 1.2 2015/06/01 22:55:13 matt Exp $")
+RCSID("$NetBSD: locore_octeon.S,v 1.3 2015/06/02 05:10:18 matt Exp $")
 
 #include "opt_cputype.h"
 #include "opt_multiprocessor.h"
@@ -116,16 +116,17 @@
        // must has its own exception vector page.  The exceptions will be
        // modified to refer to that CPU's cpu_info structure.
        //
-       mfc0    a0, MIPS_COP_0_PRID, 1  # get EBASE
-       ext     s0, a0, 0, 10           # fetch cpunum (MIPSNNR2)
-       ins     a0, zero, 0, 10         # clear it (MIPSNNR2)
-       ins     a0, v0, 12, 10          # insert cpunum as exception address
-       mtc0    a0, MIPS_COP_0_PRID, 1  # set EBASE
+       mfc0    s1, MIPS_COP_0_PRID, 1  # get EBASE
+       ext     s0, s1, 0, 10           # fetch cpunum (MIPSNNR2)
+       ins     s1, zero, 0, 10         # clear it (MIPSNNR2)
+       ins     s1, s0, 12, 10          # insert cpunum as exception address
+       ehb
+       mtc0    s1, MIPS_COP_0_PRID, 1  # set EBASE
        COP0_SYNC
 
        // we only can deal with 2 cores
        li      v0, 1
-       bne     s0, v0, 2f
+       beq     s0, v0, 2f
         nop
        // spin if this isn't cpu 1
 1:     wait
@@ -133,18 +134,21 @@
         nop
 
        // Indicate we've gotten this far
-       PTR_LA  a0, _C_LABEL(cpus_booted)
+2:     PTR_LA  a0, _C_LABEL(cpus_booted)
+       li      a1, 1
        jal     _C_LABEL(atomic_or_64)
-        sll    a1, v0, s0
+        sllv   a1, a1, s0
 
        // Wait until cpuid_infos[cpunum] is not NULL.
-2:     PTR_LA  a1, _C_LABEL(cpuid_infos)
-       dsll    s0, s0, PTR_SCALESHIFT  # cpunum -> array index
-       PTR_ADD t0, a1, s0              # add to array start
-3:     PTR_L   a1, (t0)                # get cpu_info pointer
+       PTR_LA  a1, _C_LABEL(cpuid_infos)
+       dsll    v0, s0, PTR_SCALESHIFT  # cpunum -> array index
+       PTR_ADD t0, a1, v0              # add to array start
+3:     sync
+       PTR_L   a1, (t0)                # get cpu_info pointer
        beqz    a1, 3b                  # loop until non-NULL
         nop
-       j       _C_LABEL(cpu_hatch)
+
+       j       _C_LABEL(cpu_trampoline)
         nop
 END(octeon_cpu_spinup)
 #endif /* MULTIPROCESSOR */



Home | Main Index | Thread Index | Old Index