powerpc/8xx: Enable 512k hugepage support with HW assistance
authorChristophe Leroy <christophe.leroy@c-s.fr>
Thu, 29 Nov 2018 14:07:19 +0000 (14:07 +0000)
committerMichael Ellerman <mpe@ellerman.id.au>
Tue, 4 Dec 2018 08:45:01 +0000 (19:45 +1100)
For using 512k pages with hardware assistance, the PTEs have to be spread
every 128 bytes in the L2 table.

Signed-off-by: Christophe Leroy <christophe.leroy@c-s.fr>
Signed-off-by: Michael Ellerman <mpe@ellerman.id.au>
arch/powerpc/include/asm/hugetlb.h
arch/powerpc/mm/hugetlbpage.c
arch/powerpc/mm/tlb_nohash.c

index dfb8bf236586e0cf6e18bd7db9b7f2df74905c75..62a0ca02ca7dd46002f91345ebfefd33d4f7e077 100644 (file)
@@ -74,7 +74,9 @@ static inline pte_t *hugepte_offset(hugepd_t hpd, unsigned long addr,
        unsigned long idx = 0;
 
        pte_t *dir = hugepd_page(hpd);
-#ifndef CONFIG_PPC_FSL_BOOK3E
+#ifdef CONFIG_PPC_8xx
+       idx = (addr & ((1UL << pdshift) - 1)) >> PAGE_SHIFT;
+#elif !defined(CONFIG_PPC_FSL_BOOK3E)
        idx = (addr & ((1UL << pdshift) - 1)) >> hugepd_shift(hpd);
 #endif
 
index bc97874d7c7477daf428fff17647ca733eb83573..5b236621d3029ef8c05ef6163f842287ef90f895 100644 (file)
@@ -65,6 +65,9 @@ static int __hugepte_alloc(struct mm_struct *mm, hugepd_t *hpdp,
        if (pshift >= pdshift) {
                cachep = PGT_CACHE(PTE_T_ORDER);
                num_hugepd = 1 << (pshift - pdshift);
+       } else if (IS_ENABLED(CONFIG_PPC_8xx)) {
+               cachep = PGT_CACHE(PTE_INDEX_SIZE);
+               num_hugepd = 1;
        } else {
                cachep = PGT_CACHE(pdshift - pshift);
                num_hugepd = 1;
@@ -331,6 +334,9 @@ static void free_hugepd_range(struct mmu_gather *tlb, hugepd_t *hpdp, int pdshif
 
        if (shift >= pdshift)
                hugepd_free(tlb, hugepte);
+       else if (IS_ENABLED(CONFIG_PPC_8xx))
+               pgtable_free_tlb(tlb, hugepte,
+                                get_hugepd_cache_index(PTE_INDEX_SIZE));
        else
                pgtable_free_tlb(tlb, hugepte,
                                 get_hugepd_cache_index(pdshift - shift));
@@ -700,7 +706,9 @@ static int __init hugetlbpage_init(void)
                 * if we have pdshift and shift value same, we don't
                 * use pgt cache for hugepd.
                 */
-               if (pdshift > shift)
+               if (pdshift > shift && IS_ENABLED(CONFIG_PPC_8xx))
+                       pgtable_cache_add(PTE_INDEX_SIZE);
+               else if (pdshift > shift)
                        pgtable_cache_add(pdshift - shift);
 #if defined(CONFIG_PPC_FSL_BOOK3E) || defined(CONFIG_PPC_8xx)
                else
index 8ad7aab150b722193099268fd35001a2da1689f4..ae5d568e267f681d43367b19e9b21f7307debfe3 100644 (file)
@@ -97,6 +97,9 @@ struct mmu_psize_def mmu_psize_defs[MMU_PAGE_COUNT] = {
                .shift  = 14,
        },
 #endif
+       [MMU_PAGE_512K] = {
+               .shift  = 19,
+       },
        [MMU_PAGE_8M] = {
                .shift  = 23,
        },