powerpc/booke: Revert SPE/AltiVec common defines for interrupt numbers
Book3E specification defines shared interrupt numbers for SPE and AltiVec units. Still SPE is present in e200/e500v2 cores while AltiVec is present in e6500 core. So we can currently decide at compile-time which unit to support exclusively. As Alexander Graf suggested, this will improve code readability especially in KVM. Use distinct defines to identify SPE/AltiVec interrupt numbers, revertingc58ce397
and6b310fc5
patches that added common defines. Signed-off-by: Mihai Caraman <mihai.caraman@freescale.com> Acked-by: Scott Wood <scottwood@freescale.com> Signed-off-by: Alexander Graf <agraf@suse.de>
This commit is contained in:
parent
3477e71d53
commit
2b2695a8d8
|
@ -635,7 +635,7 @@ interrupt_end_book3e:
|
||||||
|
|
||||||
/* Altivec Unavailable Interrupt */
|
/* Altivec Unavailable Interrupt */
|
||||||
START_EXCEPTION(altivec_unavailable);
|
START_EXCEPTION(altivec_unavailable);
|
||||||
NORMAL_EXCEPTION_PROLOG(0x200, BOOKE_INTERRUPT_SPE_ALTIVEC_UNAVAIL,
|
NORMAL_EXCEPTION_PROLOG(0x200, BOOKE_INTERRUPT_ALTIVEC_UNAVAIL,
|
||||||
PROLOG_ADDITION_NONE)
|
PROLOG_ADDITION_NONE)
|
||||||
/* we can probably do a shorter exception entry for that one... */
|
/* we can probably do a shorter exception entry for that one... */
|
||||||
EXCEPTION_COMMON(0x200)
|
EXCEPTION_COMMON(0x200)
|
||||||
|
@ -658,7 +658,7 @@ END_FTR_SECTION_IFSET(CPU_FTR_ALTIVEC)
|
||||||
/* AltiVec Assist */
|
/* AltiVec Assist */
|
||||||
START_EXCEPTION(altivec_assist);
|
START_EXCEPTION(altivec_assist);
|
||||||
NORMAL_EXCEPTION_PROLOG(0x220,
|
NORMAL_EXCEPTION_PROLOG(0x220,
|
||||||
BOOKE_INTERRUPT_SPE_FP_DATA_ALTIVEC_ASSIST,
|
BOOKE_INTERRUPT_ALTIVEC_ASSIST,
|
||||||
PROLOG_ADDITION_NONE)
|
PROLOG_ADDITION_NONE)
|
||||||
EXCEPTION_COMMON(0x220)
|
EXCEPTION_COMMON(0x220)
|
||||||
INTS_DISABLE
|
INTS_DISABLE
|
||||||
|
|
|
@ -617,27 +617,27 @@ END_FTR_SECTION_IFSET(CPU_FTR_EMB_HV)
|
||||||
#ifdef CONFIG_SPE
|
#ifdef CONFIG_SPE
|
||||||
/* SPE Unavailable */
|
/* SPE Unavailable */
|
||||||
START_EXCEPTION(SPEUnavailable)
|
START_EXCEPTION(SPEUnavailable)
|
||||||
NORMAL_EXCEPTION_PROLOG(SPE_ALTIVEC_UNAVAIL)
|
NORMAL_EXCEPTION_PROLOG(SPE_UNAVAIL)
|
||||||
beq 1f
|
beq 1f
|
||||||
bl load_up_spe
|
bl load_up_spe
|
||||||
b fast_exception_return
|
b fast_exception_return
|
||||||
1: addi r3,r1,STACK_FRAME_OVERHEAD
|
1: addi r3,r1,STACK_FRAME_OVERHEAD
|
||||||
EXC_XFER_EE_LITE(0x2010, KernelSPE)
|
EXC_XFER_EE_LITE(0x2010, KernelSPE)
|
||||||
#elif defined(CONFIG_SPE_POSSIBLE)
|
#elif defined(CONFIG_SPE_POSSIBLE)
|
||||||
EXCEPTION(0x2020, SPE_ALTIVEC_UNAVAIL, SPEUnavailable, \
|
EXCEPTION(0x2020, SPE_UNAVAIL, SPEUnavailable, \
|
||||||
unknown_exception, EXC_XFER_EE)
|
unknown_exception, EXC_XFER_EE)
|
||||||
#endif /* CONFIG_SPE_POSSIBLE */
|
#endif /* CONFIG_SPE_POSSIBLE */
|
||||||
|
|
||||||
/* SPE Floating Point Data */
|
/* SPE Floating Point Data */
|
||||||
#ifdef CONFIG_SPE
|
#ifdef CONFIG_SPE
|
||||||
EXCEPTION(0x2030, SPE_FP_DATA_ALTIVEC_ASSIST, SPEFloatingPointData,
|
EXCEPTION(0x2030, SPE_FP_DATA, SPEFloatingPointData,
|
||||||
SPEFloatingPointException, EXC_XFER_EE)
|
SPEFloatingPointException, EXC_XFER_EE)
|
||||||
|
|
||||||
/* SPE Floating Point Round */
|
/* SPE Floating Point Round */
|
||||||
EXCEPTION(0x2050, SPE_FP_ROUND, SPEFloatingPointRound, \
|
EXCEPTION(0x2050, SPE_FP_ROUND, SPEFloatingPointRound, \
|
||||||
SPEFloatingPointRoundException, EXC_XFER_EE)
|
SPEFloatingPointRoundException, EXC_XFER_EE)
|
||||||
#elif defined(CONFIG_SPE_POSSIBLE)
|
#elif defined(CONFIG_SPE_POSSIBLE)
|
||||||
EXCEPTION(0x2040, SPE_FP_DATA_ALTIVEC_ASSIST, SPEFloatingPointData,
|
EXCEPTION(0x2040, SPE_FP_DATA, SPEFloatingPointData,
|
||||||
unknown_exception, EXC_XFER_EE)
|
unknown_exception, EXC_XFER_EE)
|
||||||
EXCEPTION(0x2050, SPE_FP_ROUND, SPEFloatingPointRound, \
|
EXCEPTION(0x2050, SPE_FP_ROUND, SPEFloatingPointRound, \
|
||||||
unknown_exception, EXC_XFER_EE)
|
unknown_exception, EXC_XFER_EE)
|
||||||
|
|
Loading…
Reference in New Issue