Commit 469d62be authored by Joakim Tjernlund's avatar Joakim Tjernlund Committed by Benjamin Herrenschmidt

powerpc/8xx: Use SPRG2 and DAR registers to stash r11 and cr.

This avoids storing these registers in memory.
CPU6 errata will still use the old way.
Remove some G2 leftover accesses from 2.4
Signed-off-by: default avatarJoakim Tjernlund <Joakim.Tjernlund@transmode.se>
Signed-off-by: default avatarBenjamin Herrenschmidt <benh@kernel.crashing.org>
parent d069cb43
...@@ -71,9 +71,6 @@ _ENTRY(_start); ...@@ -71,9 +71,6 @@ _ENTRY(_start);
* in the first level table, but that would require many changes to the * in the first level table, but that would require many changes to the
* Linux page directory/table functions that I don't want to do right now. * Linux page directory/table functions that I don't want to do right now.
* *
* I used to use SPRG2 for a temporary register in the TLB handler, but it
* has since been put to other uses. I now use a hack to save a register
* and the CCR at memory location 0.....Someday I'll fix this.....
* -- Dan * -- Dan
*/ */
.globl __start .globl __start
...@@ -302,8 +299,13 @@ InstructionTLBMiss: ...@@ -302,8 +299,13 @@ InstructionTLBMiss:
DO_8xx_CPU6(0x3f80, r3) DO_8xx_CPU6(0x3f80, r3)
mtspr SPRN_M_TW, r10 /* Save a couple of working registers */ mtspr SPRN_M_TW, r10 /* Save a couple of working registers */
mfcr r10 mfcr r10
#ifdef CONFIG_8xx_CPU6
stw r10, 0(r0) stw r10, 0(r0)
stw r11, 4(r0) stw r11, 4(r0)
#else
mtspr SPRN_DAR, r10
mtspr SPRN_SPRG2, r11
#endif
mfspr r10, SPRN_SRR0 /* Get effective address of fault */ mfspr r10, SPRN_SRR0 /* Get effective address of fault */
#ifdef CONFIG_8xx_CPU15 #ifdef CONFIG_8xx_CPU15
addi r11, r10, 0x1000 addi r11, r10, 0x1000
...@@ -359,13 +361,19 @@ InstructionTLBMiss: ...@@ -359,13 +361,19 @@ InstructionTLBMiss:
DO_8xx_CPU6(0x2d80, r3) DO_8xx_CPU6(0x2d80, r3)
mtspr SPRN_MI_RPN, r10 /* Update TLB entry */ mtspr SPRN_MI_RPN, r10 /* Update TLB entry */
mfspr r10, SPRN_M_TW /* Restore registers */ /* Restore registers */
#ifndef CONFIG_8xx_CPU6
mfspr r10, SPRN_DAR
mtcr r10
mtspr SPRN_DAR, r11 /* Tag DAR */
mfspr r11, SPRN_SPRG2
#else
lwz r11, 0(r0) lwz r11, 0(r0)
mtcr r11 mtcr r11
lwz r11, 4(r0) lwz r11, 4(r0)
#ifdef CONFIG_8xx_CPU6
lwz r3, 8(r0) lwz r3, 8(r0)
#endif #endif
mfspr r10, SPRN_M_TW
rfi rfi
2: 2:
mfspr r11, SPRN_SRR1 mfspr r11, SPRN_SRR1
...@@ -375,13 +383,20 @@ InstructionTLBMiss: ...@@ -375,13 +383,20 @@ InstructionTLBMiss:
rlwinm r11, r11, 0, 0xffff rlwinm r11, r11, 0, 0xffff
mtspr SPRN_SRR1, r11 mtspr SPRN_SRR1, r11
mfspr r10, SPRN_M_TW /* Restore registers */ /* Restore registers */
#ifndef CONFIG_8xx_CPU6
mfspr r10, SPRN_DAR
mtcr r10
li r11, 0x00f0
mtspr SPRN_DAR, r11 /* Tag DAR */
mfspr r11, SPRN_SPRG2
#else
lwz r11, 0(r0) lwz r11, 0(r0)
mtcr r11 mtcr r11
lwz r11, 4(r0) lwz r11, 4(r0)
#ifdef CONFIG_8xx_CPU6
lwz r3, 8(r0) lwz r3, 8(r0)
#endif #endif
mfspr r10, SPRN_M_TW
b InstructionAccess b InstructionAccess
. = 0x1200 . = 0x1200
...@@ -392,8 +407,13 @@ DataStoreTLBMiss: ...@@ -392,8 +407,13 @@ DataStoreTLBMiss:
DO_8xx_CPU6(0x3f80, r3) DO_8xx_CPU6(0x3f80, r3)
mtspr SPRN_M_TW, r10 /* Save a couple of working registers */ mtspr SPRN_M_TW, r10 /* Save a couple of working registers */
mfcr r10 mfcr r10
#ifdef CONFIG_8xx_CPU6
stw r10, 0(r0) stw r10, 0(r0)
stw r11, 4(r0) stw r11, 4(r0)
#else
mtspr SPRN_DAR, r10
mtspr SPRN_SPRG2, r11
#endif
mfspr r10, SPRN_M_TWB /* Get level 1 table entry address */ mfspr r10, SPRN_M_TWB /* Get level 1 table entry address */
/* If we are faulting a kernel address, we have to use the /* If we are faulting a kernel address, we have to use the
...@@ -461,18 +481,24 @@ DataStoreTLBMiss: ...@@ -461,18 +481,24 @@ DataStoreTLBMiss:
* of the MMU. * of the MMU.
*/ */
2: li r11, 0x00f0 2: li r11, 0x00f0
mtspr SPRN_DAR,r11 /* Tag DAR */
rlwimi r10, r11, 0, 24, 28 /* Set 24-27, clear 28 */ rlwimi r10, r11, 0, 24, 28 /* Set 24-27, clear 28 */
DO_8xx_CPU6(0x3d80, r3) DO_8xx_CPU6(0x3d80, r3)
mtspr SPRN_MD_RPN, r10 /* Update TLB entry */ mtspr SPRN_MD_RPN, r10 /* Update TLB entry */
mfspr r10, SPRN_M_TW /* Restore registers */ /* Restore registers */
#ifndef CONFIG_8xx_CPU6
mfspr r10, SPRN_DAR
mtcr r10
mtspr SPRN_DAR, r11 /* Tag DAR */
mfspr r11, SPRN_SPRG2
#else
mtspr SPRN_DAR, r11 /* Tag DAR */
lwz r11, 0(r0) lwz r11, 0(r0)
mtcr r11 mtcr r11
lwz r11, 4(r0) lwz r11, 4(r0)
#ifdef CONFIG_8xx_CPU6
lwz r3, 8(r0) lwz r3, 8(r0)
#endif #endif
mfspr r10, SPRN_M_TW
rfi rfi
/* This is an instruction TLB error on the MPC8xx. This could be due /* This is an instruction TLB error on the MPC8xx. This could be due
...@@ -684,9 +710,6 @@ start_here: ...@@ -684,9 +710,6 @@ start_here:
tophys(r4,r2) tophys(r4,r2)
addi r4,r4,THREAD /* init task's THREAD */ addi r4,r4,THREAD /* init task's THREAD */
mtspr SPRN_SPRG_THREAD,r4 mtspr SPRN_SPRG_THREAD,r4
li r3,0
/* XXX What is that for ? SPRG2 appears otherwise unused on 8xx */
mtspr SPRN_SPRG2,r3 /* 0 => r1 has kernel sp */
/* stack */ /* stack */
lis r1,init_thread_union@ha lis r1,init_thread_union@ha
......
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