powerpc: Remove MMU_FTR_SLB
authorMichael Ellerman <mpe@ellerman.id.au>
Thu, 10 Jul 2014 02:29:20 +0000 (12:29 +1000)
committerBenjamin Herrenschmidt <benh@kernel.crashing.org>
Mon, 28 Jul 2014 04:10:23 +0000 (14:10 +1000)
We now only support cpus that use an SLB, so we don't need an MMU
feature to indicate that.

Signed-off-by: Michael Ellerman <mpe@ellerman.id.au>
Signed-off-by: Benjamin Herrenschmidt <benh@kernel.crashing.org>
arch/powerpc/include/asm/cputable.h
arch/powerpc/include/asm/mmu.h
arch/powerpc/include/asm/mmu_context.h
arch/powerpc/kernel/entry_64.S
arch/powerpc/kernel/process.c
arch/powerpc/kernel/prom.c
arch/powerpc/mm/hash_utils_64.c
arch/powerpc/xmon/xmon.c

index 4b132cf48a4f433c82ad3abacf3d998c15cc8ea3..ca20cc3ee04d6d6ab045535a8fa5b434c62f44e5 100644 (file)
@@ -195,8 +195,7 @@ extern const char *powerpc_base_platform;
 
 #define CPU_FTR_PPCAS_ARCH_V2  (CPU_FTR_NOEXECUTE | CPU_FTR_NODSISRALIGN)
 
-#define MMU_FTR_PPCAS_ARCH_V2  (MMU_FTR_SLB | MMU_FTR_TLBIEL | \
-                                MMU_FTR_16M_PAGE)
+#define MMU_FTR_PPCAS_ARCH_V2  (MMU_FTR_TLBIEL | MMU_FTR_16M_PAGE)
 
 /* We only set the altivec features if the kernel was compiled with altivec
  * support
index e61f24ed4e65223290901ee23fe79d3354f82196..3d5abfe6ba6756324b71cfae8d69a9ba865da75c 100644 (file)
@@ -64,9 +64,9 @@
  */
 #define MMU_FTR_USE_PAIRED_MAS         ASM_CONST(0x01000000)
 
-/* MMU is SLB-based
+/* Doesn't support the B bit (1T segment) in SLBIE
  */
-#define MMU_FTR_SLB                    ASM_CONST(0x02000000)
+#define MMU_FTR_NO_SLBIE_B             ASM_CONST(0x02000000)
 
 /* Support 16M large pages
  */
  */
 #define MMU_FTR_1T_SEGMENT             ASM_CONST(0x40000000)
 
-/* Doesn't support the B bit (1T segment) in SLBIE
- */
-#define MMU_FTR_NO_SLBIE_B             ASM_CONST(0x80000000)
-
 /* MMU feature bit sets for various CPUs */
 #define MMU_FTRS_DEFAULT_HPTE_ARCH_V2  \
        MMU_FTR_HPTE_TABLE | MMU_FTR_PPCAS_ARCH_V2
index f5690e2689c7f10ace9dd8d5cadb24f7727b433a..73382eba02dccf2d8373bc860e4ebbe7fe7cac0a 100644 (file)
@@ -76,8 +76,7 @@ static inline void switch_mm(struct mm_struct *prev, struct mm_struct *next,
         * sub architectures.
         */
 #ifdef CONFIG_PPC_STD_MMU_64
-       if (mmu_has_feature(MMU_FTR_SLB))
-               switch_slb(tsk, next);
+       switch_slb(tsk, next);
 #else
        /* Out of line for now */
        switch_mmu_context(prev, next);
index 6528c5e2cc44800a201802858c23d34e92162041..d6b22e8c8ee16d557fbaa99ac85934cf8d41158d 100644 (file)
@@ -482,16 +482,12 @@ END_FTR_SECTION_IFSET(CPU_FTR_STCX_CHECKS_ADDRESS)
        ld      r8,KSP(r4)      /* new stack pointer */
 #ifdef CONFIG_PPC_BOOK3S
 BEGIN_FTR_SECTION
-  BEGIN_FTR_SECTION_NESTED(95)
        clrrdi  r6,r8,28        /* get its ESID */
        clrrdi  r9,r1,28        /* get current sp ESID */
-  FTR_SECTION_ELSE_NESTED(95)
+FTR_SECTION_ELSE
        clrrdi  r6,r8,40        /* get its 1T ESID */
        clrrdi  r9,r1,40        /* get current sp 1T ESID */
-  ALT_MMU_FTR_SECTION_END_NESTED_IFCLR(MMU_FTR_1T_SEGMENT, 95)
-FTR_SECTION_ELSE
-       b       2f
-ALT_MMU_FTR_SECTION_END_IFSET(MMU_FTR_SLB)
+ALT_MMU_FTR_SECTION_END_IFCLR(MMU_FTR_1T_SEGMENT)
        clrldi. r0,r6,2         /* is new ESID c00000000? */
        cmpd    cr1,r6,r9       /* or is new ESID the same as current ESID? */
        cror    eq,4*cr1+eq,eq
index be99774d3f44ac9ecc83d5e637a7bb4b4f460d80..e39f388fc25ccb7c42f8083e14f752d535ae35ed 100644 (file)
@@ -1175,7 +1175,7 @@ int copy_thread(unsigned long clone_flags, unsigned long usp,
 #endif
 
 #ifdef CONFIG_PPC_STD_MMU_64
-       if (mmu_has_feature(MMU_FTR_SLB)) {
+       {
                unsigned long sp_vsid;
                unsigned long llp = mmu_psize_defs[mmu_linear_psize].sllp;
 
index b694b0730971e1eba7a5ba4cebe7b91d3acf9279..1914791dd32979f3890dd57c441bbbfcd8e7b406 100644 (file)
@@ -155,7 +155,6 @@ static struct ibm_pa_feature {
 } ibm_pa_features[] __initdata = {
        {0, 0, PPC_FEATURE_HAS_MMU,     0, 0, 0},
        {0, 0, PPC_FEATURE_HAS_FPU,     0, 1, 0},
-       {0, MMU_FTR_SLB, 0,             0, 2, 0},
        {CPU_FTR_CTRL, 0, 0,            0, 3, 0},
        {CPU_FTR_NOEXECUTE, 0, 0,       0, 6, 0},
        {CPU_FTR_NODSISRALIGN, 0, 0,    1, 1, 1},
index fb8bea71327d62678896a5a66dc2c7931b4a4243..6b7c1c824cf973ead2fe861fc137582ff58c4882 100644 (file)
@@ -828,8 +828,7 @@ void __init early_init_mmu(void)
        htab_initialize();
 
        /* Initialize SLB management */
-       if (mmu_has_feature(MMU_FTR_SLB))
-               slb_initialize();
+       slb_initialize();
 }
 
 #ifdef CONFIG_SMP
@@ -840,8 +839,7 @@ void early_init_mmu_secondary(void)
                mtspr(SPRN_SDR1, _SDR1);
 
        /* Initialize SLB */
-       if (mmu_has_feature(MMU_FTR_SLB))
-               slb_initialize();
+       slb_initialize();
 }
 #endif /* CONFIG_SMP */
 
index dc8cf285c3ffde99c06f875970f50b0750b3bcf9..8d198b5e9e0a72813cc2beb702826e1a52072a4f 100644 (file)
@@ -2690,7 +2690,7 @@ static void xmon_print_symbol(unsigned long address, const char *mid,
 }
 
 #ifdef CONFIG_PPC_BOOK3S_64
-static void dump_slb(void)
+void dump_segments(void)
 {
        int i;
        unsigned long esid,vsid,valid;
@@ -2722,12 +2722,6 @@ static void dump_slb(void)
                }
        }
 }
-
-void dump_segments(void)
-{
-       if (mmu_has_feature(MMU_FTR_SLB))
-               dump_slb();
-}
 #endif
 
 #ifdef CONFIG_PPC_STD_MMU_32