Previously, code did a runtime check of RIXI and made runtime shifts/etc to fit into PTE as much as possible PFN bits. However, because there is no HUGE page support for MIPS32 R2 there is a way to fit all required bits in fixed positions: PTE low bits are: CCC D V G RI(=R) XI M A W P TLB refill will do a ROTR 6 (in case of cpu_has_rixi), or SRL 6 to strip low bits. All 20 bits PFN are preserved in high bits (4GB with 4KB pages) Also rearrange PTE bits for MIPS64 R2 in fixed positions: PTE low bits are: CCC D V G RI XI [S H] M A W R P TLB refill will do a ROTR 7/9 (in case of cpu_has_rixi), or SRL/DSRL 7/9 to strip low bits in absense of RIXI. PFN size in high bits is 49 or 51 bits --> 512TB or 4*512TB for 4KB pages Signed-off-by: Leonid Yegoshin <Leonid.Yegoshin@xxxxxxxxxx> --- arch/mips/include/asm/pgtable-bits.h | 102 ++++++++++++++++++++++++++++++++++ 1 files changed, 102 insertions(+), 0 deletions(-) diff --git a/arch/mips/include/asm/pgtable-bits.h b/arch/mips/include/asm/pgtable-bits.h index e592f36..4183771 100644 --- a/arch/mips/include/asm/pgtable-bits.h +++ b/arch/mips/include/asm/pgtable-bits.h @@ -102,6 +102,8 @@ #define _CACHE_MASK (1 << _CACHE_UNCACHED_SHIFT) #else /* 'Normal' r4K case */ + +#ifndef CONFIG_CPU_MIPSR2 /* * When using the RI/XI bit support, we have 13 bits of flags below * the physical address. The RI/XI bits are placed such that a SRL 5 @@ -154,6 +156,106 @@ #define _PAGE_NO_READ_SHIFT (cpu_has_rixi ? _PAGE_NO_EXEC_SHIFT + 1 : _PAGE_NO_EXEC_SHIFT) #define _PAGE_NO_READ ({BUG_ON(!cpu_has_rixi); 1 << _PAGE_NO_READ_SHIFT; }) +#else /* CONFIG_CPU_MIPSR2 */ + +/* static bits allocation in MIPS R2, two variants - + HUGE TLB in 64BIT kernel support or not. + RIXI support in both */ + +#ifdef CONFIG_64BIT + +/* + * Low bits are: CCC D V G RI XI [S H] M A W R P + * TLB refill will do a ROTR 7/9 (in case of cpu_has_rixi), + * or SRL/DSRL 7/9 to strip low bits. + * PFN size in high bits is 49 or 51 bit --> 512TB or 4*512TB for 4KB pages + */ + +#define _PAGE_PRESENT_SHIFT (0) +#define _PAGE_PRESENT (1 << _PAGE_PRESENT_SHIFT) +/* implemented in software, should be unused if cpu_has_rixi. */ +#define _PAGE_READ_SHIFT (_PAGE_PRESENT_SHIFT + 1) +#define _PAGE_READ (1 << _PAGE_READ_SHIFT) +/* implemented in software */ +#define _PAGE_WRITE_SHIFT (_PAGE_READ_SHIFT + 1) +#define _PAGE_WRITE (1 << _PAGE_WRITE_SHIFT) +/* implemented in software */ +#define _PAGE_ACCESSED_SHIFT (_PAGE_WRITE_SHIFT + 1) +#define _PAGE_ACCESSED (1 << _PAGE_ACCESSED_SHIFT) +/* implemented in software */ +#define _PAGE_MODIFIED_SHIFT (_PAGE_ACCESSED_SHIFT + 1) +#define _PAGE_MODIFIED (1 << _PAGE_MODIFIED_SHIFT) +/* set:pagecache unset:swap */ +#define _PAGE_FILE (_PAGE_MODIFIED) + +#ifdef CONFIG_MIPS_HUGE_TLB_SUPPORT +/* huge tlb page */ +#define _PAGE_HUGE_SHIFT (_PAGE_MODIFIED_SHIFT + 1) +#define _PAGE_HUGE (1 << _PAGE_HUGE_SHIFT) +#define _PAGE_SPLITTING_SHIFT (_PAGE_HUGE_SHIFT + 1) +#define _PAGE_SPLITTING (1 << _PAGE_SPLITTING_SHIFT) +#else +#define _PAGE_HUGE_SHIFT (_PAGE_MODIFIED_SHIFT) +#define _PAGE_HUGE ({BUG(); 1; }) /* Dummy value */ +#define _PAGE_SPLITTING_SHIFT (_PAGE_HUGE_SHIFT) +#define _PAGE_SPLITTING ({BUG(); 1; }) /* Dummy value */ +#endif /* CONFIG_MIPS_HUGE_TLB_SUPPORT */ + +/* Page cannot be executed */ +#define _PAGE_NO_EXEC_SHIFT (_PAGE_SPLITTING_SHIFT + 1) +#define _PAGE_NO_EXEC (1 << _PAGE_NO_EXEC_SHIFT) + +/* Page cannot be read */ +#define _PAGE_NO_READ_SHIFT (_PAGE_NO_EXEC_SHIFT + 1) +#define _PAGE_NO_READ (1 << _PAGE_NO_READ_SHIFT) + +#else /* !CONFIG_64BIT */ + +/* + * No HUGE page support + * Low bits are: CCC D V G RI(=R) XI M A W P + * TLB refill will do a ROTR 6 (in case of cpu_has_rixi), + * or SRL 6 to strip low bits. + * All 20 bits PFN are preserved in high bits (4GB in 4KB pages) + */ + +#define _PAGE_PRESENT_SHIFT (0) +#define _PAGE_PRESENT (1 << _PAGE_PRESENT_SHIFT) +/* implemented in software */ +#define _PAGE_WRITE_SHIFT (_PAGE_PRESENT_SHIFT + 1) +#define _PAGE_WRITE (1 << _PAGE_WRITE_SHIFT) +/* implemented in software */ +#define _PAGE_ACCESSED_SHIFT (_PAGE_WRITE_SHIFT + 1) +#define _PAGE_ACCESSED (1 << _PAGE_ACCESSED_SHIFT) +/* implemented in software */ +#define _PAGE_MODIFIED_SHIFT (_PAGE_ACCESSED_SHIFT + 1) +#define _PAGE_MODIFIED (1 << _PAGE_MODIFIED_SHIFT) +/* set:pagecache unset:swap */ +#define _PAGE_FILE (_PAGE_MODIFIED) + +/* huge tlb page dummies */ +#define _PAGE_HUGE_SHIFT (_PAGE_MODIFIED_SHIFT) +#define _PAGE_HUGE ({BUG(); 1; }) /* Dummy value */ +#define _PAGE_SPLITTING_SHIFT (_PAGE_HUGE_SHIFT) +#define _PAGE_SPLITTING ({BUG(); 1; }) /* Dummy value */ + +/* Page cannot be executed */ +#define _PAGE_NO_EXEC_SHIFT (_PAGE_SPLITTING_SHIFT + 1) +#define _PAGE_NO_EXEC (1 << _PAGE_NO_EXEC_SHIFT) + +/* Page cannot be read */ +#define _PAGE_NO_READ_SHIFT (_PAGE_NO_EXEC_SHIFT + 1) +#define _PAGE_NO_READ (1 << _PAGE_NO_READ_SHIFT) + +/* implemented in software, should be unused if cpu_has_rixi. */ +#define _PAGE_READ_SHIFT (_PAGE_NO_READ_SHIFT) +#define _PAGE_READ (1 << _PAGE_READ_SHIFT) + +#endif /* CONFIG_64BIT */ + +#endif /* !CONFIG_CPU_MIPSR2 */ + + #define _PAGE_GLOBAL_SHIFT (_PAGE_NO_READ_SHIFT + 1) #define _PAGE_GLOBAL (1 << _PAGE_GLOBAL_SHIFT)