mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/next/linux-next.git
synced 2025-01-12 00:38:55 +00:00
powerpc/mm: Make MMU_FTR_RADIX a MMU family feature
MMU feature bits are defined such that we use the lower half to present MMU family features. Remove the strict split of half and also move Radix to a mmu family feature. Radix introduce a new MMU model and strictly speaking it is a new MMU family. This also free up bits which can be used for individual features later. Signed-off-by: Aneesh Kumar K.V <aneesh.kumar@linux.vnet.ibm.com> Signed-off-by: Michael Ellerman <mpe@ellerman.id.au>
This commit is contained in:
parent
a28e46f109
commit
5a25b6f527
@ -24,7 +24,7 @@ struct mmu_psize_def {
|
|||||||
extern struct mmu_psize_def mmu_psize_defs[MMU_PAGE_COUNT];
|
extern struct mmu_psize_def mmu_psize_defs[MMU_PAGE_COUNT];
|
||||||
|
|
||||||
#ifdef CONFIG_PPC_RADIX_MMU
|
#ifdef CONFIG_PPC_RADIX_MMU
|
||||||
#define radix_enabled() mmu_has_feature(MMU_FTR_RADIX)
|
#define radix_enabled() mmu_has_feature(MMU_FTR_TYPE_RADIX)
|
||||||
#else
|
#else
|
||||||
#define radix_enabled() (0)
|
#define radix_enabled() (0)
|
||||||
#endif
|
#endif
|
||||||
|
@ -12,7 +12,7 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* First half is MMU families
|
* MMU families
|
||||||
*/
|
*/
|
||||||
#define MMU_FTR_HPTE_TABLE ASM_CONST(0x00000001)
|
#define MMU_FTR_HPTE_TABLE ASM_CONST(0x00000001)
|
||||||
#define MMU_FTR_TYPE_8xx ASM_CONST(0x00000002)
|
#define MMU_FTR_TYPE_8xx ASM_CONST(0x00000002)
|
||||||
@ -21,9 +21,13 @@
|
|||||||
#define MMU_FTR_TYPE_FSL_E ASM_CONST(0x00000010)
|
#define MMU_FTR_TYPE_FSL_E ASM_CONST(0x00000010)
|
||||||
#define MMU_FTR_TYPE_47x ASM_CONST(0x00000020)
|
#define MMU_FTR_TYPE_47x ASM_CONST(0x00000020)
|
||||||
|
|
||||||
|
/* Radix page table supported and enabled */
|
||||||
|
#define MMU_FTR_TYPE_RADIX ASM_CONST(0x00000040)
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* This is individual features
|
* Individual features below.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* We need to clear top 16bits of va (from the remaining 64 bits )in
|
* We need to clear top 16bits of va (from the remaining 64 bits )in
|
||||||
* tlbie* instructions
|
* tlbie* instructions
|
||||||
@ -93,11 +97,6 @@
|
|||||||
*/
|
*/
|
||||||
#define MMU_FTR_1T_SEGMENT ASM_CONST(0x40000000)
|
#define MMU_FTR_1T_SEGMENT ASM_CONST(0x40000000)
|
||||||
|
|
||||||
/*
|
|
||||||
* Radix page table available
|
|
||||||
*/
|
|
||||||
#define MMU_FTR_RADIX ASM_CONST(0x80000000)
|
|
||||||
|
|
||||||
/* MMU feature bit sets for various CPUs */
|
/* MMU feature bit sets for various CPUs */
|
||||||
#define MMU_FTRS_DEFAULT_HPTE_ARCH_V2 \
|
#define MMU_FTRS_DEFAULT_HPTE_ARCH_V2 \
|
||||||
MMU_FTR_HPTE_TABLE | MMU_FTR_PPCAS_ARCH_V2
|
MMU_FTR_HPTE_TABLE | MMU_FTR_PPCAS_ARCH_V2
|
||||||
@ -131,7 +130,7 @@ enum {
|
|||||||
MMU_FTR_LOCKLESS_TLBIE | MMU_FTR_CI_LARGE_PAGE |
|
MMU_FTR_LOCKLESS_TLBIE | MMU_FTR_CI_LARGE_PAGE |
|
||||||
MMU_FTR_1T_SEGMENT | MMU_FTR_TLBIE_CROP_VA |
|
MMU_FTR_1T_SEGMENT | MMU_FTR_TLBIE_CROP_VA |
|
||||||
#ifdef CONFIG_PPC_RADIX_MMU
|
#ifdef CONFIG_PPC_RADIX_MMU
|
||||||
MMU_FTR_RADIX |
|
MMU_FTR_TYPE_RADIX |
|
||||||
#endif
|
#endif
|
||||||
0,
|
0,
|
||||||
};
|
};
|
||||||
|
@ -532,7 +532,7 @@ END_FTR_SECTION_IFSET(CPU_FTR_ARCH_300)
|
|||||||
#ifdef CONFIG_PPC_STD_MMU_64
|
#ifdef CONFIG_PPC_STD_MMU_64
|
||||||
BEGIN_MMU_FTR_SECTION
|
BEGIN_MMU_FTR_SECTION
|
||||||
b 2f
|
b 2f
|
||||||
END_MMU_FTR_SECTION_IFSET(MMU_FTR_RADIX)
|
END_MMU_FTR_SECTION_IFSET(MMU_FTR_TYPE_RADIX)
|
||||||
BEGIN_FTR_SECTION
|
BEGIN_FTR_SECTION
|
||||||
clrrdi r6,r8,28 /* get its ESID */
|
clrrdi r6,r8,28 /* get its ESID */
|
||||||
clrrdi r9,r1,28 /* get current sp ESID */
|
clrrdi r9,r1,28 /* get current sp ESID */
|
||||||
|
@ -938,7 +938,7 @@ BEGIN_MMU_FTR_SECTION
|
|||||||
b do_hash_page /* Try to handle as hpte fault */
|
b do_hash_page /* Try to handle as hpte fault */
|
||||||
MMU_FTR_SECTION_ELSE
|
MMU_FTR_SECTION_ELSE
|
||||||
b handle_page_fault
|
b handle_page_fault
|
||||||
ALT_MMU_FTR_SECTION_END_IFCLR(MMU_FTR_RADIX)
|
ALT_MMU_FTR_SECTION_END_IFCLR(MMU_FTR_TYPE_RADIX)
|
||||||
|
|
||||||
.align 7
|
.align 7
|
||||||
.globl h_data_storage_common
|
.globl h_data_storage_common
|
||||||
@ -969,7 +969,7 @@ BEGIN_MMU_FTR_SECTION
|
|||||||
b do_hash_page /* Try to handle as hpte fault */
|
b do_hash_page /* Try to handle as hpte fault */
|
||||||
MMU_FTR_SECTION_ELSE
|
MMU_FTR_SECTION_ELSE
|
||||||
b handle_page_fault
|
b handle_page_fault
|
||||||
ALT_MMU_FTR_SECTION_END_IFCLR(MMU_FTR_RADIX)
|
ALT_MMU_FTR_SECTION_END_IFCLR(MMU_FTR_TYPE_RADIX)
|
||||||
|
|
||||||
STD_EXCEPTION_COMMON(0xe20, h_instr_storage, unknown_exception)
|
STD_EXCEPTION_COMMON(0xe20, h_instr_storage, unknown_exception)
|
||||||
|
|
||||||
@ -1390,7 +1390,7 @@ slb_miss_realmode:
|
|||||||
#ifdef CONFIG_PPC_STD_MMU_64
|
#ifdef CONFIG_PPC_STD_MMU_64
|
||||||
BEGIN_MMU_FTR_SECTION
|
BEGIN_MMU_FTR_SECTION
|
||||||
bl slb_allocate_realmode
|
bl slb_allocate_realmode
|
||||||
END_MMU_FTR_SECTION_IFCLR(MMU_FTR_RADIX)
|
END_MMU_FTR_SECTION_IFCLR(MMU_FTR_TYPE_RADIX)
|
||||||
#endif
|
#endif
|
||||||
/* All done -- return from exception. */
|
/* All done -- return from exception. */
|
||||||
|
|
||||||
@ -1404,7 +1404,7 @@ BEGIN_MMU_FTR_SECTION
|
|||||||
beq- 2f
|
beq- 2f
|
||||||
FTR_SECTION_ELSE
|
FTR_SECTION_ELSE
|
||||||
b 2f
|
b 2f
|
||||||
ALT_MMU_FTR_SECTION_END_IFCLR(MMU_FTR_RADIX)
|
ALT_MMU_FTR_SECTION_END_IFCLR(MMU_FTR_TYPE_RADIX)
|
||||||
|
|
||||||
.machine push
|
.machine push
|
||||||
.machine "power4"
|
.machine "power4"
|
||||||
|
@ -570,7 +570,7 @@ common_exit:
|
|||||||
|
|
||||||
BEGIN_MMU_FTR_SECTION
|
BEGIN_MMU_FTR_SECTION
|
||||||
b no_segments
|
b no_segments
|
||||||
END_MMU_FTR_SECTION_IFSET(MMU_FTR_RADIX)
|
END_MMU_FTR_SECTION_IFSET(MMU_FTR_TYPE_RADIX)
|
||||||
/* Restore SLB from PACA */
|
/* Restore SLB from PACA */
|
||||||
ld r8,PACA_SLBSHADOWPTR(r13)
|
ld r8,PACA_SLBSHADOWPTR(r13)
|
||||||
|
|
||||||
|
@ -170,7 +170,7 @@ static struct ibm_pa_feature {
|
|||||||
*/
|
*/
|
||||||
{CPU_FTR_TM_COMP, 0, 0,
|
{CPU_FTR_TM_COMP, 0, 0,
|
||||||
PPC_FEATURE2_HTM_COMP|PPC_FEATURE2_HTM_NOSC_COMP, 22, 0, 0},
|
PPC_FEATURE2_HTM_COMP|PPC_FEATURE2_HTM_NOSC_COMP, 22, 0, 0},
|
||||||
{0, MMU_FTR_RADIX, 0, 0, 40, 0, 0},
|
{0, MMU_FTR_TYPE_RADIX, 0, 0, 40, 0, 0},
|
||||||
};
|
};
|
||||||
|
|
||||||
static void __init scan_features(unsigned long node, const unsigned char *ftrs,
|
static void __init scan_features(unsigned long node, const unsigned char *ftrs,
|
||||||
|
@ -425,7 +425,7 @@ void __init mmu_early_init_devtree(void)
|
|||||||
{
|
{
|
||||||
/* Disable radix mode based on kernel command line. */
|
/* Disable radix mode based on kernel command line. */
|
||||||
if (disable_radix)
|
if (disable_radix)
|
||||||
cur_cpu_spec->mmu_features &= ~MMU_FTR_RADIX;
|
cur_cpu_spec->mmu_features &= ~MMU_FTR_TYPE_RADIX;
|
||||||
|
|
||||||
if (radix_enabled())
|
if (radix_enabled())
|
||||||
radix__early_init_devtree();
|
radix__early_init_devtree();
|
||||||
|
Loading…
x
Reference in New Issue
Block a user