Commit 99d5040e authored by Max Filippov's avatar Max Filippov Committed by Chris Zankel

xtensa: keep a3 and excsave1 on entry to exception handlers

Based on the SMP patch by Joe Taylor and subsequent fixes.
Preserve exception table pointer (normally stored in excsave1 SR) as it
cannot be easily restored in SMP environment.
Signed-off-by: default avatarMax Filippov <jcmvbkbc@gmail.com>
Signed-off-by: default avatarChris Zankel <chris@zankel.net>
parent 16c5becf
...@@ -82,6 +82,7 @@ ...@@ -82,6 +82,7 @@
#define PS_CALLINC_SHIFT 16 #define PS_CALLINC_SHIFT 16
#define PS_CALLINC_MASK 0x00030000 #define PS_CALLINC_MASK 0x00030000
#define PS_OWB_SHIFT 8 #define PS_OWB_SHIFT 8
#define PS_OWB_WIDTH 4
#define PS_OWB_MASK 0x00000F00 #define PS_OWB_MASK 0x00000F00
#define PS_RING_SHIFT 6 #define PS_RING_SHIFT 6
#define PS_RING_MASK 0x000000C0 #define PS_RING_MASK 0x000000C0
......
...@@ -146,9 +146,9 @@ ...@@ -146,9 +146,9 @@
* a0: trashed, original value saved on stack (PT_AREG0) * a0: trashed, original value saved on stack (PT_AREG0)
* a1: a1 * a1: a1
* a2: new stack pointer, original in DEPC * a2: new stack pointer, original in DEPC
* a3: dispatch table * a3: a3
* depc: a2, original value saved on stack (PT_DEPC) * depc: a2, original value saved on stack (PT_DEPC)
* excsave_1: a3 * excsave_1: dispatch table
* *
* PT_DEPC >= VALID_DOUBLE_EXCEPTION_ADDRESS: double exception, DEPC * PT_DEPC >= VALID_DOUBLE_EXCEPTION_ADDRESS: double exception, DEPC
* < VALID_DOUBLE_EXCEPTION_ADDRESS: regular exception * < VALID_DOUBLE_EXCEPTION_ADDRESS: regular exception
...@@ -171,7 +171,6 @@ ENTRY(fast_unaligned) ...@@ -171,7 +171,6 @@ ENTRY(fast_unaligned)
s32i a8, a2, PT_AREG8 s32i a8, a2, PT_AREG8
rsr a0, depc rsr a0, depc
xsr a3, excsave1
s32i a0, a2, PT_AREG2 s32i a0, a2, PT_AREG2
s32i a3, a2, PT_AREG3 s32i a3, a2, PT_AREG3
......
...@@ -32,9 +32,9 @@ ...@@ -32,9 +32,9 @@
* a0: trashed, original value saved on stack (PT_AREG0) * a0: trashed, original value saved on stack (PT_AREG0)
* a1: a1 * a1: a1
* a2: new stack pointer, original in DEPC * a2: new stack pointer, original in DEPC
* a3: dispatch table * a3: a3
* depc: a2, original value saved on stack (PT_DEPC) * depc: a2, original value saved on stack (PT_DEPC)
* excsave_1: a3 * excsave_1: dispatch table
* *
* PT_DEPC >= VALID_DOUBLE_EXCEPTION_ADDRESS: double exception, DEPC * PT_DEPC >= VALID_DOUBLE_EXCEPTION_ADDRESS: double exception, DEPC
* < VALID_DOUBLE_EXCEPTION_ADDRESS: regular exception * < VALID_DOUBLE_EXCEPTION_ADDRESS: regular exception
...@@ -225,9 +225,9 @@ ENDPROC(coprocessor_restore) ...@@ -225,9 +225,9 @@ ENDPROC(coprocessor_restore)
* a0: trashed, original value saved on stack (PT_AREG0) * a0: trashed, original value saved on stack (PT_AREG0)
* a1: a1 * a1: a1
* a2: new stack pointer, original in DEPC * a2: new stack pointer, original in DEPC
* a3: dispatch table * a3: a3
* depc: a2, original value saved on stack (PT_DEPC) * depc: a2, original value saved on stack (PT_DEPC)
* excsave_1: a3 * excsave_1: dispatch table
* *
* PT_DEPC >= VALID_DOUBLE_EXCEPTION_ADDRESS: double exception, DEPC * PT_DEPC >= VALID_DOUBLE_EXCEPTION_ADDRESS: double exception, DEPC
* < VALID_DOUBLE_EXCEPTION_ADDRESS: regular exception * < VALID_DOUBLE_EXCEPTION_ADDRESS: regular exception
...@@ -245,7 +245,6 @@ ENTRY(fast_coprocessor) ...@@ -245,7 +245,6 @@ ENTRY(fast_coprocessor)
/* Save remaining registers a1-a3 and SAR */ /* Save remaining registers a1-a3 and SAR */
xsr a3, excsave1
s32i a3, a2, PT_AREG3 s32i a3, a2, PT_AREG3
rsr a3, sar rsr a3, sar
s32i a1, a2, PT_AREG1 s32i a1, a2, PT_AREG1
......
This diff is collapsed.
This diff is collapsed.
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