diff options
Diffstat (limited to 'arch/mips/netlogic/common/reset.S')
-rw-r--r-- | arch/mips/netlogic/common/reset.S | 22 |
1 files changed, 21 insertions, 1 deletions
diff --git a/arch/mips/netlogic/common/reset.S b/arch/mips/netlogic/common/reset.S index 701c4bcb9e47..edbab9b8691f 100644 --- a/arch/mips/netlogic/common/reset.S +++ b/arch/mips/netlogic/common/reset.S | |||
@@ -60,7 +60,7 @@ | |||
60 | li t0, LSU_DEFEATURE | 60 | li t0, LSU_DEFEATURE |
61 | mfcr t1, t0 | 61 | mfcr t1, t0 |
62 | 62 | ||
63 | lui t2, 0xc080 /* SUE, Enable Unaligned Access, L2HPE */ | 63 | lui t2, 0x4080 /* Enable Unaligned Access, L2HPE */ |
64 | or t1, t1, t2 | 64 | or t1, t1, t2 |
65 | mtcr t1, t0 | 65 | mtcr t1, t0 |
66 | 66 | ||
@@ -235,6 +235,26 @@ EXPORT(nlm_boot_siblings) | |||
235 | mfc0 v0, CP0_EBASE, 1 | 235 | mfc0 v0, CP0_EBASE, 1 |
236 | andi v0, 0x3ff /* v0 <- node/core */ | 236 | andi v0, 0x3ff /* v0 <- node/core */ |
237 | 237 | ||
238 | /* | ||
239 | * Errata: to avoid potential live lock, setup IFU_BRUB_RESERVE | ||
240 | * when running 4 threads per core | ||
241 | */ | ||
242 | andi v1, v0, 0x3 /* v1 <- thread id */ | ||
243 | bnez v1, 2f | ||
244 | nop | ||
245 | |||
246 | /* thread 0 of each core. */ | ||
247 | li t0, CKSEG1ADDR(RESET_DATA_PHYS) | ||
248 | lw t1, BOOT_THREAD_MODE(t0) /* t1 <- thread mode */ | ||
249 | subu t1, 0x3 /* 4-thread per core mode? */ | ||
250 | bnez t1, 2f | ||
251 | nop | ||
252 | |||
253 | li t0, IFU_BRUB_RESERVE | ||
254 | li t1, 0x55 | ||
255 | mtcr t1, t0 | ||
256 | _ehb | ||
257 | 2: | ||
238 | beqz v0, 4f /* boot cpu (cpuid == 0)? */ | 258 | beqz v0, 4f /* boot cpu (cpuid == 0)? */ |
239 | nop | 259 | nop |
240 | 260 | ||