Commit 919f9abb authored by Jayachandran C's avatar Jayachandran C Committed by Ralf Baechle

MIPS: Netlogic: move cpu_ready array to boot area

Move the nlm_cpu_ready[] array used by the cpu wakeup code to the
boot area, along with rest of the boot parameter code.
Signed-off-by: default avatarJayachandran C <jchandra@broadcom.com>
Cc: linux-mips@linux-mips.org
Patchwork: https://patchwork.linux-mips.org/patch/5425/Signed-off-by: default avatarRalf Baechle <ralf@linux-mips.org>
parent 53c83219
...@@ -39,11 +39,17 @@ ...@@ -39,11 +39,17 @@
* Common SMP definitions * Common SMP definitions
*/ */
#define RESET_VEC_PHYS 0x1fc00000 #define RESET_VEC_PHYS 0x1fc00000
#define RESET_VEC_SIZE 8192 /* 8KB reset code and data */
#define RESET_DATA_PHYS (RESET_VEC_PHYS + (1<<10)) #define RESET_DATA_PHYS (RESET_VEC_PHYS + (1<<10))
/* Offsets of parameters in the RESET_DATA_PHYS area */
#define BOOT_THREAD_MODE 0 #define BOOT_THREAD_MODE 0
#define BOOT_NMI_LOCK 4 #define BOOT_NMI_LOCK 4
#define BOOT_NMI_HANDLER 8 #define BOOT_NMI_HANDLER 8
/* CPU ready flags for each CPU */
#define BOOT_CPU_READY 2048
#ifndef __ASSEMBLY__ #ifndef __ASSEMBLY__
#include <linux/cpumask.h> #include <linux/cpumask.h>
#include <linux/spinlock.h> #include <linux/spinlock.h>
......
...@@ -216,8 +216,10 @@ EXPORT(nlm_boot_siblings) ...@@ -216,8 +216,10 @@ EXPORT(nlm_boot_siblings)
ori t1, ST0_KX ori t1, ST0_KX
#endif #endif
mtc0 t1, CP0_STATUS mtc0 t1, CP0_STATUS
/* mark CPU ready */
PTR_LA t1, nlm_cpu_ready /* mark CPU ready, careful here, previous mtcr trashed registers */
li t3, CKSEG1ADDR(RESET_DATA_PHYS)
ADDIU t1, t3, BOOT_CPU_READY
sll v1, v0, 2 sll v1, v0, 2
PTR_ADDU t1, v1 PTR_ADDU t1, v1
li t2, 1 li t2, 1
......
...@@ -145,7 +145,6 @@ void nlm_cpus_done(void) ...@@ -145,7 +145,6 @@ void nlm_cpus_done(void)
* Boot all other cpus in the system, initialize them, and bring them into * Boot all other cpus in the system, initialize them, and bring them into
* the boot function * the boot function
*/ */
int nlm_cpu_ready[NR_CPUS];
unsigned long nlm_next_gp; unsigned long nlm_next_gp;
unsigned long nlm_next_sp; unsigned long nlm_next_sp;
static cpumask_t phys_cpu_present_mask; static cpumask_t phys_cpu_present_mask;
...@@ -168,6 +167,7 @@ void __init nlm_smp_setup(void) ...@@ -168,6 +167,7 @@ void __init nlm_smp_setup(void)
{ {
unsigned int boot_cpu; unsigned int boot_cpu;
int num_cpus, i, ncore; int num_cpus, i, ncore;
volatile u32 *cpu_ready = nlm_get_boot_data(BOOT_CPU_READY);
char buf[64]; char buf[64];
boot_cpu = hard_smp_processor_id(); boot_cpu = hard_smp_processor_id();
...@@ -181,10 +181,10 @@ void __init nlm_smp_setup(void) ...@@ -181,10 +181,10 @@ void __init nlm_smp_setup(void)
num_cpus = 1; num_cpus = 1;
for (i = 0; i < NR_CPUS; i++) { for (i = 0; i < NR_CPUS; i++) {
/* /*
* nlm_cpu_ready array is not set for the boot_cpu, * cpu_ready array is not set for the boot_cpu,
* it is only set for ASPs (see smpboot.S) * it is only set for ASPs (see smpboot.S)
*/ */
if (nlm_cpu_ready[i]) { if (cpu_ready[i]) {
cpumask_set_cpu(i, &phys_cpu_present_mask); cpumask_set_cpu(i, &phys_cpu_present_mask);
__cpu_number_map[i] = num_cpus; __cpu_number_map[i] = num_cpus;
__cpu_logical_map[num_cpus] = i; __cpu_logical_map[num_cpus] = i;
......
...@@ -109,8 +109,9 @@ NESTED(nlm_rmiboot_preboot, 16, sp) ...@@ -109,8 +109,9 @@ NESTED(nlm_rmiboot_preboot, 16, sp)
andi t2, t0, 0x3 /* thread num */ andi t2, t0, 0x3 /* thread num */
sll t0, 2 /* offset in cpu array */ sll t0, 2 /* offset in cpu array */
PTR_LA t1, nlm_cpu_ready /* mark CPU ready */ li t3, CKSEG1ADDR(RESET_DATA_PHYS)
PTR_ADDU t1, t0 ADDIU t1, t3, BOOT_CPU_READY
ADDU t1, t0
li t3, 1 li t3, 1
sw t3, 0(t1) sw t3, 0(t1)
......
...@@ -108,6 +108,7 @@ void __init prom_init(void) ...@@ -108,6 +108,7 @@ void __init prom_init(void)
/* Update reset entry point with CPU init code */ /* Update reset entry point with CPU init code */
reset_vec = (void *)CKSEG1ADDR(RESET_VEC_PHYS); reset_vec = (void *)CKSEG1ADDR(RESET_VEC_PHYS);
memset(reset_vec, 0, RESET_VEC_SIZE);
memcpy(reset_vec, (void *)nlm_reset_entry, memcpy(reset_vec, (void *)nlm_reset_entry,
(nlm_reset_entry_end - nlm_reset_entry)); (nlm_reset_entry_end - nlm_reset_entry));
......
...@@ -82,6 +82,7 @@ static void xlp_enable_secondary_cores(const cpumask_t *wakeup_mask) ...@@ -82,6 +82,7 @@ static void xlp_enable_secondary_cores(const cpumask_t *wakeup_mask)
struct nlm_soc_info *nodep; struct nlm_soc_info *nodep;
uint64_t syspcibase; uint64_t syspcibase;
uint32_t syscoremask; uint32_t syscoremask;
volatile uint32_t *cpu_ready = nlm_get_boot_data(BOOT_CPU_READY);
int core, n, cpu, count, val; int core, n, cpu, count, val;
for (n = 0; n < NLM_NR_NODES; n++) { for (n = 0; n < NLM_NR_NODES; n++) {
...@@ -125,7 +126,7 @@ static void xlp_enable_secondary_cores(const cpumask_t *wakeup_mask) ...@@ -125,7 +126,7 @@ static void xlp_enable_secondary_cores(const cpumask_t *wakeup_mask)
/* spin until the first hw thread sets its ready */ /* spin until the first hw thread sets its ready */
count = 0x20000000; count = 0x20000000;
do { do {
val = *(volatile int *)&nlm_cpu_ready[cpu]; val = cpu_ready[cpu];
} while (val == 0 && --count > 0); } while (val == 0 && --count > 0);
} }
} }
......
...@@ -211,6 +211,7 @@ void __init prom_init(void) ...@@ -211,6 +211,7 @@ void __init prom_init(void)
/* Update reset entry point with CPU init code */ /* Update reset entry point with CPU init code */
reset_vec = (void *)CKSEG1ADDR(RESET_VEC_PHYS); reset_vec = (void *)CKSEG1ADDR(RESET_VEC_PHYS);
memset(reset_vec, 0, RESET_VEC_SIZE);
memcpy(reset_vec, (void *)nlm_reset_entry, memcpy(reset_vec, (void *)nlm_reset_entry,
(nlm_reset_entry_end - nlm_reset_entry)); (nlm_reset_entry_end - nlm_reset_entry));
......
...@@ -53,6 +53,7 @@ int __cpuinit xlr_wakeup_secondary_cpus(void) ...@@ -53,6 +53,7 @@ int __cpuinit xlr_wakeup_secondary_cpus(void)
{ {
struct nlm_soc_info *nodep; struct nlm_soc_info *nodep;
unsigned int i, j, boot_cpu; unsigned int i, j, boot_cpu;
volatile u32 *cpu_ready = nlm_get_boot_data(BOOT_CPU_READY);
/* /*
* In case of RMI boot, hit with NMI to get the cores * In case of RMI boot, hit with NMI to get the cores
...@@ -71,7 +72,7 @@ int __cpuinit xlr_wakeup_secondary_cpus(void) ...@@ -71,7 +72,7 @@ int __cpuinit xlr_wakeup_secondary_cpus(void)
nodep->coremask = 1; nodep->coremask = 1;
for (i = 1; i < NLM_CORES_PER_NODE; i++) { for (i = 1; i < NLM_CORES_PER_NODE; i++) {
for (j = 1000000; j > 0; j--) { for (j = 1000000; j > 0; j--) {
if (nlm_cpu_ready[i * NLM_THREADS_PER_CORE]) if (cpu_ready[i * NLM_THREADS_PER_CORE])
break; break;
udelay(10); udelay(10);
} }
......
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