forked from mirrors/linux
		
	mm/pgtable: add stubs for {pmd/pub}_{set/clear}_huge
For architectures with no PMD and/or no PUD, add stubs similar to what we
have for architectures without P4D.
[christophe.leroy@csgroup.eu: arm64: define only {pud/pmd}_{set/clear}_huge when useful]
  Link: https://lkml.kernel.org/r/73ec95f40cafbbb69bdfb43a7f53876fd845b0ce.1620990479.git.christophe.leroy@csgroup.eu
[christophe.leroy@csgroup.eu: x86: define only {pud/pmd}_{set/clear}_huge when useful]
  Link: https://lkml.kernel.org/r/7fbf1b6bc3e15c07c24fa45278d57064f14c896b.1620930415.git.christophe.leroy@csgroup.eu
Link: https://lkml.kernel.org/r/5ac5976419350e8e048d463a64cae449eb3ba4b0.1620795204.git.christophe.leroy@csgroup.eu
Signed-off-by: Christophe Leroy <christophe.leroy@csgroup.eu>
Cc: Benjamin Herrenschmidt <benh@kernel.crashing.org>
Cc: Michael Ellerman <mpe@ellerman.id.au>
Cc: Mike Kravetz <mike.kravetz@oracle.com>
Cc: Mike Rapoport <rppt@kernel.org>
Cc: Nicholas Piggin <npiggin@gmail.com>
Cc: Paul Mackerras <paulus@samba.org>
Cc: Uladzislau Rezki <uladzislau.rezki@sony.com>
Cc: Naresh Kamboju <naresh.kamboju@linaro.org>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
			
			
This commit is contained in:
		
							parent
							
								
									79c1c594f4
								
							
						
					
					
						commit
						c742199a01
					
				
					 3 changed files with 56 additions and 24 deletions
				
			
		| 
						 | 
					@ -1338,6 +1338,7 @@ void *__init fixmap_remap_fdt(phys_addr_t dt_phys, int *size, pgprot_t prot)
 | 
				
			||||||
	return dt_virt;
 | 
						return dt_virt;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#if CONFIG_PGTABLE_LEVELS > 3
 | 
				
			||||||
int pud_set_huge(pud_t *pudp, phys_addr_t phys, pgprot_t prot)
 | 
					int pud_set_huge(pud_t *pudp, phys_addr_t phys, pgprot_t prot)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
	pud_t new_pud = pfn_pud(__phys_to_pfn(phys), mk_pud_sect_prot(prot));
 | 
						pud_t new_pud = pfn_pud(__phys_to_pfn(phys), mk_pud_sect_prot(prot));
 | 
				
			||||||
| 
						 | 
					@ -1352,6 +1353,16 @@ int pud_set_huge(pud_t *pudp, phys_addr_t phys, pgprot_t prot)
 | 
				
			||||||
	return 1;
 | 
						return 1;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					int pud_clear_huge(pud_t *pudp)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
						if (!pud_sect(READ_ONCE(*pudp)))
 | 
				
			||||||
 | 
							return 0;
 | 
				
			||||||
 | 
						pud_clear(pudp);
 | 
				
			||||||
 | 
						return 1;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#if CONFIG_PGTABLE_LEVELS > 2
 | 
				
			||||||
int pmd_set_huge(pmd_t *pmdp, phys_addr_t phys, pgprot_t prot)
 | 
					int pmd_set_huge(pmd_t *pmdp, phys_addr_t phys, pgprot_t prot)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
	pmd_t new_pmd = pfn_pmd(__phys_to_pfn(phys), mk_pmd_sect_prot(prot));
 | 
						pmd_t new_pmd = pfn_pmd(__phys_to_pfn(phys), mk_pmd_sect_prot(prot));
 | 
				
			||||||
| 
						 | 
					@ -1366,14 +1377,6 @@ int pmd_set_huge(pmd_t *pmdp, phys_addr_t phys, pgprot_t prot)
 | 
				
			||||||
	return 1;
 | 
						return 1;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
int pud_clear_huge(pud_t *pudp)
 | 
					 | 
				
			||||||
{
 | 
					 | 
				
			||||||
	if (!pud_sect(READ_ONCE(*pudp)))
 | 
					 | 
				
			||||||
		return 0;
 | 
					 | 
				
			||||||
	pud_clear(pudp);
 | 
					 | 
				
			||||||
	return 1;
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
int pmd_clear_huge(pmd_t *pmdp)
 | 
					int pmd_clear_huge(pmd_t *pmdp)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
	if (!pmd_sect(READ_ONCE(*pmdp)))
 | 
						if (!pmd_sect(READ_ONCE(*pmdp)))
 | 
				
			||||||
| 
						 | 
					@ -1381,6 +1384,7 @@ int pmd_clear_huge(pmd_t *pmdp)
 | 
				
			||||||
	pmd_clear(pmdp);
 | 
						pmd_clear(pmdp);
 | 
				
			||||||
	return 1;
 | 
						return 1;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
int pmd_free_pte_page(pmd_t *pmdp, unsigned long addr)
 | 
					int pmd_free_pte_page(pmd_t *pmdp, unsigned long addr)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -682,6 +682,7 @@ int p4d_clear_huge(p4d_t *p4d)
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#if CONFIG_PGTABLE_LEVELS > 3
 | 
				
			||||||
/**
 | 
					/**
 | 
				
			||||||
 * pud_set_huge - setup kernel PUD mapping
 | 
					 * pud_set_huge - setup kernel PUD mapping
 | 
				
			||||||
 *
 | 
					 *
 | 
				
			||||||
| 
						 | 
					@ -720,6 +721,23 @@ int pud_set_huge(pud_t *pud, phys_addr_t addr, pgprot_t prot)
 | 
				
			||||||
	return 1;
 | 
						return 1;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * pud_clear_huge - clear kernel PUD mapping when it is set
 | 
				
			||||||
 | 
					 *
 | 
				
			||||||
 | 
					 * Returns 1 on success and 0 on failure (no PUD map is found).
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					int pud_clear_huge(pud_t *pud)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
						if (pud_large(*pud)) {
 | 
				
			||||||
 | 
							pud_clear(pud);
 | 
				
			||||||
 | 
							return 1;
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						return 0;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#if CONFIG_PGTABLE_LEVELS > 2
 | 
				
			||||||
/**
 | 
					/**
 | 
				
			||||||
 * pmd_set_huge - setup kernel PMD mapping
 | 
					 * pmd_set_huge - setup kernel PMD mapping
 | 
				
			||||||
 *
 | 
					 *
 | 
				
			||||||
| 
						 | 
					@ -750,21 +768,6 @@ int pmd_set_huge(pmd_t *pmd, phys_addr_t addr, pgprot_t prot)
 | 
				
			||||||
	return 1;
 | 
						return 1;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/**
 | 
					 | 
				
			||||||
 * pud_clear_huge - clear kernel PUD mapping when it is set
 | 
					 | 
				
			||||||
 *
 | 
					 | 
				
			||||||
 * Returns 1 on success and 0 on failure (no PUD map is found).
 | 
					 | 
				
			||||||
 */
 | 
					 | 
				
			||||||
int pud_clear_huge(pud_t *pud)
 | 
					 | 
				
			||||||
{
 | 
					 | 
				
			||||||
	if (pud_large(*pud)) {
 | 
					 | 
				
			||||||
		pud_clear(pud);
 | 
					 | 
				
			||||||
		return 1;
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	return 0;
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
/**
 | 
					/**
 | 
				
			||||||
 * pmd_clear_huge - clear kernel PMD mapping when it is set
 | 
					 * pmd_clear_huge - clear kernel PMD mapping when it is set
 | 
				
			||||||
 *
 | 
					 *
 | 
				
			||||||
| 
						 | 
					@ -779,6 +782,7 @@ int pmd_clear_huge(pmd_t *pmd)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	return 0;
 | 
						return 0;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifdef CONFIG_X86_64
 | 
					#ifdef CONFIG_X86_64
 | 
				
			||||||
/**
 | 
					/**
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -1379,10 +1379,34 @@ static inline int p4d_clear_huge(p4d_t *p4d)
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
#endif /* !__PAGETABLE_P4D_FOLDED */
 | 
					#endif /* !__PAGETABLE_P4D_FOLDED */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#ifndef __PAGETABLE_PUD_FOLDED
 | 
				
			||||||
int pud_set_huge(pud_t *pud, phys_addr_t addr, pgprot_t prot);
 | 
					int pud_set_huge(pud_t *pud, phys_addr_t addr, pgprot_t prot);
 | 
				
			||||||
int pmd_set_huge(pmd_t *pmd, phys_addr_t addr, pgprot_t prot);
 | 
					 | 
				
			||||||
int pud_clear_huge(pud_t *pud);
 | 
					int pud_clear_huge(pud_t *pud);
 | 
				
			||||||
 | 
					#else
 | 
				
			||||||
 | 
					static inline int pud_set_huge(pud_t *pud, phys_addr_t addr, pgprot_t prot)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
						return 0;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					static inline int pud_clear_huge(pud_t *pud)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
						return 0;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					#endif /* !__PAGETABLE_PUD_FOLDED */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#ifndef __PAGETABLE_PMD_FOLDED
 | 
				
			||||||
 | 
					int pmd_set_huge(pmd_t *pmd, phys_addr_t addr, pgprot_t prot);
 | 
				
			||||||
int pmd_clear_huge(pmd_t *pmd);
 | 
					int pmd_clear_huge(pmd_t *pmd);
 | 
				
			||||||
 | 
					#else
 | 
				
			||||||
 | 
					static inline int pmd_set_huge(pmd_t *pmd, phys_addr_t addr, pgprot_t prot)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
						return 0;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					static inline int pmd_clear_huge(pmd_t *pmd)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
						return 0;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					#endif /* !__PAGETABLE_PMD_FOLDED */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
int p4d_free_pud_page(p4d_t *p4d, unsigned long addr);
 | 
					int p4d_free_pud_page(p4d_t *p4d, unsigned long addr);
 | 
				
			||||||
int pud_free_pmd_page(pud_t *pud, unsigned long addr);
 | 
					int pud_free_pmd_page(pud_t *pud, unsigned long addr);
 | 
				
			||||||
int pmd_free_pte_page(pmd_t *pmd, unsigned long addr);
 | 
					int pmd_free_pte_page(pmd_t *pmd, unsigned long addr);
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
		Loading…
	
		Reference in a new issue