Commit 7e0f4872 authored by Varun Sethi's avatar Varun Sethi Committed by Kumar Gala

powepc/booke: Separate out E.HV check and ivor setup code.

Move the E.HV check and CPU_FTR_EMB_HV flag manipulation to the cpu setup
code.  Create a separate routine for E.HV ivors setup.
Signed-off-by: default avatarVarun Sethi <Varun.Sethi@freescale.com>
Signed-off-by: default avatarKumar Gala <galak@kernel.crashing.org>
parent d0832a75
...@@ -16,6 +16,8 @@ ...@@ -16,6 +16,8 @@
#include <asm/processor.h> #include <asm/processor.h>
#include <asm/cputable.h> #include <asm/cputable.h>
#include <asm/ppc_asm.h> #include <asm/ppc_asm.h>
#include <asm/mmu-book3e.h>
#include <asm/asm-offsets.h>
_GLOBAL(__e500_icache_setup) _GLOBAL(__e500_icache_setup)
mfspr r0, SPRN_L1CSR1 mfspr r0, SPRN_L1CSR1
...@@ -73,12 +75,33 @@ _GLOBAL(__setup_cpu_e500v2) ...@@ -73,12 +75,33 @@ _GLOBAL(__setup_cpu_e500v2)
mtlr r4 mtlr r4
blr blr
_GLOBAL(__setup_cpu_e500mc) _GLOBAL(__setup_cpu_e500mc)
mr r5, r4 mflr r5
mflr r4
bl __e500_icache_setup bl __e500_icache_setup
bl __e500_dcache_setup bl __e500_dcache_setup
bl __setup_e500mc_ivors bl __setup_e500mc_ivors
mtlr r4 /*
* We only want to touch IVOR38-41 if we're running on hardware
* that supports category E.HV. The architectural way to determine
* this is MMUCFG[LPIDSIZE].
*/
mfspr r3, SPRN_MMUCFG
rlwinm. r3, r3, 0, MMUCFG_LPIDSIZE
beq 1f
bl __setup_ehv_ivors
b 2f
1:
lwz r3, CPU_SPEC_FEATURES(r4)
/* We need this check as cpu_setup is also called for
* the secondary cores. So, if we have already cleared
* the feature on the primary core, avoid doing it on the
* secondary core.
*/
andis. r6, r3, CPU_FTR_EMB_HV@h
beq 2f
rlwinm r3, r3, 0, ~CPU_FTR_EMB_HV
stw r3, CPU_SPEC_FEATURES(r4)
2:
mtlr r5
blr blr
#endif #endif
/* Right now, restore and setup are the same thing */ /* Right now, restore and setup are the same thing */
......
...@@ -895,15 +895,11 @@ _GLOBAL(__setup_e500mc_ivors) ...@@ -895,15 +895,11 @@ _GLOBAL(__setup_e500mc_ivors)
mtspr SPRN_IVOR36,r3 mtspr SPRN_IVOR36,r3
li r3,CriticalDoorbell@l li r3,CriticalDoorbell@l
mtspr SPRN_IVOR37,r3 mtspr SPRN_IVOR37,r3
sync
blr
/* /* setup ehv ivors for */
* We only want to touch IVOR38-41 if we're running on hardware _GLOBAL(__setup_ehv_ivors)
* that supports category E.HV. The architectural way to determine
* this is MMUCFG[LPIDSIZE].
*/
mfspr r3, SPRN_MMUCFG
andis. r3, r3, MMUCFG_LPIDSIZE@h
beq no_hv
li r3,GuestDoorbell@l li r3,GuestDoorbell@l
mtspr SPRN_IVOR38,r3 mtspr SPRN_IVOR38,r3
li r3,CriticalGuestDoorbell@l li r3,CriticalGuestDoorbell@l
...@@ -912,14 +908,8 @@ _GLOBAL(__setup_e500mc_ivors) ...@@ -912,14 +908,8 @@ _GLOBAL(__setup_e500mc_ivors)
mtspr SPRN_IVOR40,r3 mtspr SPRN_IVOR40,r3
li r3,Ehvpriv@l li r3,Ehvpriv@l
mtspr SPRN_IVOR41,r3 mtspr SPRN_IVOR41,r3
skip_hv_ivors:
sync sync
blr blr
no_hv:
lwz r3, CPU_SPEC_FEATURES(r5)
rlwinm r3, r3, 0, ~CPU_FTR_EMB_HV
stw r3, CPU_SPEC_FEATURES(r5)
b skip_hv_ivors
#ifdef CONFIG_SPE #ifdef CONFIG_SPE
/* /*
......
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