Commit 1181eb87 authored by James Hogan's avatar James Hogan Committed by Thadeu Lima de Souza Cascardo

MIPS: Netlogic: Fix CP0_EBASE redefinition warnings

BugLink: http://bugs.launchpad.net/bugs/1674292

commit 32eb6e8b upstream.

A couple of netlogic assembly files define CP0_EBASE to $15, the same as
CP0_PRID in mipsregs.h, and use it for accessing both CP0_PRId and
CP0_EBase registers. However commit 609cf6f2 ("MIPS: CPS: Early
debug using an ns16550-compatible UART") added a different definition of
CP0_EBASE to mipsregs.h, which included a register select of 1. This
causes harmless build warnings like the following:

  arch/mips/netlogic/common/reset.S:53:0: warning: "CP0_EBASE" redefined
  #define CP0_EBASE $15
  ^
  In file included from arch/mips/netlogic/common/reset.S:41:0:
  ./arch/mips/include/asm/mipsregs.h:63:0: note: this is the location of the previous definition
  #define CP0_EBASE $15, 1
  ^

Update the code to use the definitions from mipsregs.h for accessing
both registers.

Fixes: 609cf6f2 ("MIPS: CPS: Early debug using an ns16550-compatible UART")
Signed-off-by: default avatarJames Hogan <james.hogan@imgtec.com>
Acked-by: default avatarJayachandran C <jchandra@broadcom.com>
Cc: linux-mips@linux-mips.org
Patchwork: https://patchwork.linux-mips.org/patch/13183/Signed-off-by: default avatarRalf Baechle <ralf@linux-mips.org>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Signed-off-by: default avatarTim Gardner <tim.gardner@canonical.com>
Signed-off-by: default avatarThadeu Lima de Souza Cascardo <cascardo@canonical.com>
parent 409f2530
...@@ -50,7 +50,6 @@ ...@@ -50,7 +50,6 @@
#include <asm/netlogic/xlp-hal/sys.h> #include <asm/netlogic/xlp-hal/sys.h>
#include <asm/netlogic/xlp-hal/cpucontrol.h> #include <asm/netlogic/xlp-hal/cpucontrol.h>
#define CP0_EBASE $15
#define SYS_CPU_COHERENT_BASE CKSEG1ADDR(XLP_DEFAULT_IO_BASE) + \ #define SYS_CPU_COHERENT_BASE CKSEG1ADDR(XLP_DEFAULT_IO_BASE) + \
XLP_IO_SYS_OFFSET(0) + XLP_IO_PCI_HDRSZ + \ XLP_IO_SYS_OFFSET(0) + XLP_IO_PCI_HDRSZ + \
SYS_CPU_NONCOHERENT_MODE * 4 SYS_CPU_NONCOHERENT_MODE * 4
...@@ -92,7 +91,7 @@ ...@@ -92,7 +91,7 @@
* registers. On XLPII CPUs, usual cache instructions work. * registers. On XLPII CPUs, usual cache instructions work.
*/ */
.macro xlp_flush_l1_dcache .macro xlp_flush_l1_dcache
mfc0 t0, CP0_EBASE, 0 mfc0 t0, CP0_PRID
andi t0, t0, PRID_IMP_MASK andi t0, t0, PRID_IMP_MASK
slt t1, t0, 0x1200 slt t1, t0, 0x1200
beqz t1, 15f beqz t1, 15f
...@@ -171,7 +170,7 @@ FEXPORT(nlm_reset_entry) ...@@ -171,7 +170,7 @@ FEXPORT(nlm_reset_entry)
nop nop
1: /* Entry point on core wakeup */ 1: /* Entry point on core wakeup */
mfc0 t0, CP0_EBASE, 0 /* processor ID */ mfc0 t0, CP0_PRID /* processor ID */
andi t0, PRID_IMP_MASK andi t0, PRID_IMP_MASK
li t1, 0x1500 /* XLP 9xx */ li t1, 0x1500 /* XLP 9xx */
beq t0, t1, 2f /* does not need to set coherent */ beq t0, t1, 2f /* does not need to set coherent */
...@@ -182,8 +181,8 @@ FEXPORT(nlm_reset_entry) ...@@ -182,8 +181,8 @@ FEXPORT(nlm_reset_entry)
nop nop
/* set bit in SYS coherent register for the core */ /* set bit in SYS coherent register for the core */
mfc0 t0, CP0_EBASE, 1 mfc0 t0, CP0_EBASE
mfc0 t1, CP0_EBASE, 1 mfc0 t1, CP0_EBASE
srl t1, 5 srl t1, 5
andi t1, 0x3 /* t1 <- node */ andi t1, 0x3 /* t1 <- node */
li t2, 0x40000 li t2, 0x40000
...@@ -232,7 +231,7 @@ EXPORT(nlm_boot_siblings) ...@@ -232,7 +231,7 @@ EXPORT(nlm_boot_siblings)
* NOTE: All GPR contents are lost after the mtcr above! * NOTE: All GPR contents are lost after the mtcr above!
*/ */
mfc0 v0, CP0_EBASE, 1 mfc0 v0, CP0_EBASE
andi v0, 0x3ff /* v0 <- node/core */ andi v0, 0x3ff /* v0 <- node/core */
/* /*
......
...@@ -48,8 +48,6 @@ ...@@ -48,8 +48,6 @@
#include <asm/netlogic/xlp-hal/sys.h> #include <asm/netlogic/xlp-hal/sys.h>
#include <asm/netlogic/xlp-hal/cpucontrol.h> #include <asm/netlogic/xlp-hal/cpucontrol.h>
#define CP0_EBASE $15
.set noreorder .set noreorder
.set noat .set noat
.set arch=xlr /* for mfcr/mtcr, XLR is sufficient */ .set arch=xlr /* for mfcr/mtcr, XLR is sufficient */
...@@ -86,7 +84,7 @@ NESTED(nlm_boot_secondary_cpus, 16, sp) ...@@ -86,7 +84,7 @@ NESTED(nlm_boot_secondary_cpus, 16, sp)
PTR_L gp, 0(t1) PTR_L gp, 0(t1)
/* a0 has the processor id */ /* a0 has the processor id */
mfc0 a0, CP0_EBASE, 1 mfc0 a0, CP0_EBASE
andi a0, 0x3ff /* a0 <- node/core */ andi a0, 0x3ff /* a0 <- node/core */
PTR_LA t0, nlm_early_init_secondary PTR_LA t0, nlm_early_init_secondary
jalr t0 jalr t0
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment