ARC: mm: pmd_populate* to use the canonical set_pmd (and drop pmd_set)
authorVineet Gupta <vgupta@kernel.org>
Wed, 30 Oct 2019 23:54:32 +0000 (16:54 -0700)
committerVineet Gupta <vgupta@kernel.org>
Tue, 24 Aug 2021 21:25:48 +0000 (14:25 -0700)
Signed-off-by: Vineet Gupta <vgupta@kernel.org>
arch/arc/include/asm/pgalloc.h
arch/arc/include/asm/pgtable.h

index a32ca31..408bc4b 100644 (file)
 static inline void
 pmd_populate_kernel(struct mm_struct *mm, pmd_t *pmd, pte_t *pte)
 {
-       pmd_set(pmd, pte);
+       /*
+        * The cast to long below is OK in 32-bit PAE40 regime with long long pte
+        * Despite "wider" pte, the pte table needs to be in non-PAE low memory
+        * as all higher levels can only hold long pointers.
+        *
+        * The cast itself is needed given simplistic definition of set_pmd()
+        */
+       set_pmd(pmd, __pmd((unsigned long)pte));
 }
 
-static inline void
-pmd_populate(struct mm_struct *mm, pmd_t *pmd, pgtable_t ptep)
+static inline void pmd_populate(struct mm_struct *mm, pmd_t *pmd, pgtable_t pte)
 {
-       pmd_set(pmd, (pte_t *) ptep);
+       set_pmd(pmd, __pmd((unsigned long)pte));
 }
 
 static inline int __get_order_pgd(void)
index b054c14..f762bac 100644 (file)
@@ -222,12 +222,6 @@ extern char empty_zero_page[PAGE_SIZE];
 /* find the logical addr (phy for ARC) of the Page Tbl ref by PMD entry */
 #define pmd_page_vaddr(pmd)    (pmd_val(pmd) & PAGE_MASK)
 
-/* In a 2 level sys, setup the PGD entry with PTE value */
-static inline void pmd_set(pmd_t *pmdp, pte_t *ptep)
-{
-       pmd_val(*pmdp) = (unsigned long)ptep;
-}
-
 #define pte_none(x)                    (!pte_val(x))
 #define pte_present(x)                 (pte_val(x) & _PAGE_PRESENT)
 #define pte_clear(mm, addr, ptep)      set_pte_at(mm, addr, ptep, __pte(0))