mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/next/linux-next.git
synced 2025-01-16 13:34:30 +00:00
mm/treewide: remove pXd_huge()
This API is not used anymore, drop it for the whole tree. Link: https://lkml.kernel.org/r/20240318200404.448346-13-peterx@redhat.com Signed-off-by: Peter Xu <peterx@redhat.com> Cc: Alistair Popple <apopple@nvidia.com> Cc: Andreas Larsson <andreas@gaisler.com> Cc: "Aneesh Kumar K.V" <aneesh.kumar@kernel.org> Cc: Arnd Bergmann <arnd@arndb.de> Cc: Bjorn Andersson <andersson@kernel.org> Cc: Borislav Petkov <bp@alien8.de> Cc: Catalin Marinas <catalin.marinas@arm.com> Cc: Christophe Leroy <christophe.leroy@csgroup.eu> Cc: Dave Hansen <dave.hansen@linux.intel.com> Cc: David S. Miller <davem@davemloft.net> Cc: Fabio Estevam <festevam@denx.de> Cc: Ingo Molnar <mingo@redhat.com> Cc: Jason Gunthorpe <jgg@nvidia.com> Cc: Konrad Dybcio <konrad.dybcio@linaro.org> Cc: Krzysztof Kozlowski <krzysztof.kozlowski@linaro.org> Cc: Lucas Stach <l.stach@pengutronix.de> Cc: Mark Salter <msalter@redhat.com> Cc: "Matthew Wilcox (Oracle)" <willy@infradead.org> Cc: Michael Ellerman <mpe@ellerman.id.au> Cc: Mike Rapoport (IBM) <rppt@kernel.org> Cc: Muchun Song <muchun.song@linux.dev> Cc: Naoya Horiguchi <nao.horiguchi@gmail.com> Cc: "Naveen N. Rao" <naveen.n.rao@linux.ibm.com> Cc: Nicholas Piggin <npiggin@gmail.com> Cc: Russell King <linux@armlinux.org.uk> Cc: Shawn Guo <shawnguo@kernel.org> Cc: Thomas Gleixner <tglx@linutronix.de> Cc: Will Deacon <will@kernel.org> Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
This commit is contained in:
parent
1965e933dd
commit
9636f055da
@ -21,7 +21,6 @@ KASAN_SANITIZE_physaddr.o := n
|
|||||||
obj-$(CONFIG_DEBUG_VIRTUAL) += physaddr.o
|
obj-$(CONFIG_DEBUG_VIRTUAL) += physaddr.o
|
||||||
|
|
||||||
obj-$(CONFIG_ALIGNMENT_TRAP) += alignment.o
|
obj-$(CONFIG_ALIGNMENT_TRAP) += alignment.o
|
||||||
obj-$(CONFIG_HUGETLB_PAGE) += hugetlbpage.o
|
|
||||||
obj-$(CONFIG_ARM_PV_FIXUP) += pv-fixup-asm.o
|
obj-$(CONFIG_ARM_PV_FIXUP) += pv-fixup-asm.o
|
||||||
|
|
||||||
obj-$(CONFIG_CPU_ABRT_NOMMU) += abort-nommu.o
|
obj-$(CONFIG_CPU_ABRT_NOMMU) += abort-nommu.o
|
||||||
|
@ -1,29 +0,0 @@
|
|||||||
// SPDX-License-Identifier: GPL-2.0-only
|
|
||||||
/*
|
|
||||||
* arch/arm/mm/hugetlbpage.c
|
|
||||||
*
|
|
||||||
* Copyright (C) 2012 ARM Ltd.
|
|
||||||
*
|
|
||||||
* Based on arch/x86/include/asm/hugetlb.h and Bill Carson's patches
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include <linux/init.h>
|
|
||||||
#include <linux/fs.h>
|
|
||||||
#include <linux/mm.h>
|
|
||||||
#include <linux/hugetlb.h>
|
|
||||||
#include <linux/pagemap.h>
|
|
||||||
#include <linux/err.h>
|
|
||||||
#include <linux/sysctl.h>
|
|
||||||
#include <asm/mman.h>
|
|
||||||
#include <asm/tlb.h>
|
|
||||||
#include <asm/tlbflush.h>
|
|
||||||
|
|
||||||
int pud_huge(pud_t pud)
|
|
||||||
{
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
int pmd_huge(pmd_t pmd)
|
|
||||||
{
|
|
||||||
return pmd_leaf(pmd);
|
|
||||||
}
|
|
@ -79,16 +79,6 @@ bool arch_hugetlb_migration_supported(struct hstate *h)
|
|||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
int pmd_huge(pmd_t pmd)
|
|
||||||
{
|
|
||||||
return pmd_leaf(pmd);
|
|
||||||
}
|
|
||||||
|
|
||||||
int pud_huge(pud_t pud)
|
|
||||||
{
|
|
||||||
return pud_leaf(pud);
|
|
||||||
}
|
|
||||||
|
|
||||||
static int find_num_contig(struct mm_struct *mm, unsigned long addr,
|
static int find_num_contig(struct mm_struct *mm, unsigned long addr,
|
||||||
pte_t *ptep, size_t *pgsize)
|
pte_t *ptep, size_t *pgsize)
|
||||||
{
|
{
|
||||||
|
@ -50,16 +50,6 @@ pte_t *huge_pte_offset(struct mm_struct *mm, unsigned long addr,
|
|||||||
return (pte_t *) pmd;
|
return (pte_t *) pmd;
|
||||||
}
|
}
|
||||||
|
|
||||||
int pmd_huge(pmd_t pmd)
|
|
||||||
{
|
|
||||||
return (pmd_val(pmd) & _PAGE_HUGE) != 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
int pud_huge(pud_t pud)
|
|
||||||
{
|
|
||||||
return (pud_val(pud) & _PAGE_HUGE) != 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
uint64_t pmd_to_entrylo(unsigned long pmd_val)
|
uint64_t pmd_to_entrylo(unsigned long pmd_val)
|
||||||
{
|
{
|
||||||
uint64_t val;
|
uint64_t val;
|
||||||
|
@ -129,7 +129,7 @@ static inline int pmd_none(pmd_t pmd)
|
|||||||
static inline int pmd_bad(pmd_t pmd)
|
static inline int pmd_bad(pmd_t pmd)
|
||||||
{
|
{
|
||||||
#ifdef CONFIG_MIPS_HUGE_TLB_SUPPORT
|
#ifdef CONFIG_MIPS_HUGE_TLB_SUPPORT
|
||||||
/* pmd_huge(pmd) but inline */
|
/* pmd_leaf(pmd) but inline */
|
||||||
if (unlikely(pmd_val(pmd) & _PAGE_HUGE))
|
if (unlikely(pmd_val(pmd) & _PAGE_HUGE))
|
||||||
return 0;
|
return 0;
|
||||||
#endif
|
#endif
|
||||||
|
@ -245,7 +245,7 @@ static inline int pmd_none(pmd_t pmd)
|
|||||||
static inline int pmd_bad(pmd_t pmd)
|
static inline int pmd_bad(pmd_t pmd)
|
||||||
{
|
{
|
||||||
#ifdef CONFIG_MIPS_HUGE_TLB_SUPPORT
|
#ifdef CONFIG_MIPS_HUGE_TLB_SUPPORT
|
||||||
/* pmd_huge(pmd) but inline */
|
/* pmd_leaf(pmd) but inline */
|
||||||
if (unlikely(pmd_val(pmd) & _PAGE_HUGE))
|
if (unlikely(pmd_val(pmd) & _PAGE_HUGE))
|
||||||
return 0;
|
return 0;
|
||||||
#endif
|
#endif
|
||||||
|
@ -57,13 +57,3 @@ pte_t *huge_pte_offset(struct mm_struct *mm, unsigned long addr,
|
|||||||
}
|
}
|
||||||
return (pte_t *) pmd;
|
return (pte_t *) pmd;
|
||||||
}
|
}
|
||||||
|
|
||||||
int pmd_huge(pmd_t pmd)
|
|
||||||
{
|
|
||||||
return (pmd_val(pmd) & _PAGE_HUGE) != 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
int pud_huge(pud_t pud)
|
|
||||||
{
|
|
||||||
return (pud_val(pud) & _PAGE_HUGE) != 0;
|
|
||||||
}
|
|
||||||
|
@ -180,14 +180,3 @@ int huge_ptep_set_access_flags(struct vm_area_struct *vma,
|
|||||||
}
|
}
|
||||||
return changed;
|
return changed;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
int pmd_huge(pmd_t pmd)
|
|
||||||
{
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
int pud_huge(pud_t pud)
|
|
||||||
{
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
@ -6,16 +6,6 @@
|
|||||||
*/
|
*/
|
||||||
#ifndef __ASSEMBLY__
|
#ifndef __ASSEMBLY__
|
||||||
#ifdef CONFIG_HUGETLB_PAGE
|
#ifdef CONFIG_HUGETLB_PAGE
|
||||||
static inline int pmd_huge(pmd_t pmd)
|
|
||||||
{
|
|
||||||
return pmd_leaf(pmd);
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline int pud_huge(pud_t pud)
|
|
||||||
{
|
|
||||||
return pud_leaf(pud);
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* With radix , we have hugepage ptes in the pud and pmd entries. We don't
|
* With radix , we have hugepage ptes in the pud and pmd entries. We don't
|
||||||
* need to setup hugepage directory for them. Our pte and page directory format
|
* need to setup hugepage directory for them. Our pte and page directory format
|
||||||
|
@ -4,31 +4,6 @@
|
|||||||
|
|
||||||
#ifndef __ASSEMBLY__
|
#ifndef __ASSEMBLY__
|
||||||
#ifdef CONFIG_HUGETLB_PAGE
|
#ifdef CONFIG_HUGETLB_PAGE
|
||||||
/*
|
|
||||||
* We have PGD_INDEX_SIZ = 12 and PTE_INDEX_SIZE = 8, so that we can have
|
|
||||||
* 16GB hugepage pte in PGD and 16MB hugepage pte at PMD;
|
|
||||||
*
|
|
||||||
* Defined in such a way that we can optimize away code block at build time
|
|
||||||
* if CONFIG_HUGETLB_PAGE=n.
|
|
||||||
*
|
|
||||||
* returns true for pmd migration entries, THP, devmap, hugetlb
|
|
||||||
* But compile time dependent on CONFIG_HUGETLB_PAGE
|
|
||||||
*/
|
|
||||||
static inline int pmd_huge(pmd_t pmd)
|
|
||||||
{
|
|
||||||
/*
|
|
||||||
* leaf pte for huge page
|
|
||||||
*/
|
|
||||||
return !!(pmd_raw(pmd) & cpu_to_be64(_PAGE_PTE));
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline int pud_huge(pud_t pud)
|
|
||||||
{
|
|
||||||
/*
|
|
||||||
* leaf pte for huge page
|
|
||||||
*/
|
|
||||||
return !!(pud_raw(pud) & cpu_to_be64(_PAGE_PTE));
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* With 64k page size, we have hugepage ptes in the pgd and pmd entries. We don't
|
* With 64k page size, we have hugepage ptes in the pgd and pmd entries. We don't
|
||||||
|
@ -351,16 +351,6 @@ static inline int hugepd_ok(hugepd_t hpd)
|
|||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline int pmd_huge(pmd_t pmd)
|
|
||||||
{
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline int pud_huge(pud_t pud)
|
|
||||||
{
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
#define is_hugepd(hpd) (hugepd_ok(hpd))
|
#define is_hugepd(hpd) (hugepd_ok(hpd))
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -399,16 +399,6 @@ static bool is_napot_size(unsigned long size)
|
|||||||
|
|
||||||
#endif /*CONFIG_RISCV_ISA_SVNAPOT*/
|
#endif /*CONFIG_RISCV_ISA_SVNAPOT*/
|
||||||
|
|
||||||
int pud_huge(pud_t pud)
|
|
||||||
{
|
|
||||||
return pud_leaf(pud);
|
|
||||||
}
|
|
||||||
|
|
||||||
int pmd_huge(pmd_t pmd)
|
|
||||||
{
|
|
||||||
return pmd_leaf(pmd);
|
|
||||||
}
|
|
||||||
|
|
||||||
static bool __hugetlb_valid_size(unsigned long size)
|
static bool __hugetlb_valid_size(unsigned long size)
|
||||||
{
|
{
|
||||||
if (size == HPAGE_SIZE)
|
if (size == HPAGE_SIZE)
|
||||||
|
@ -233,16 +233,6 @@ pte_t *huge_pte_offset(struct mm_struct *mm,
|
|||||||
return (pte_t *) pmdp;
|
return (pte_t *) pmdp;
|
||||||
}
|
}
|
||||||
|
|
||||||
int pmd_huge(pmd_t pmd)
|
|
||||||
{
|
|
||||||
return pmd_leaf(pmd);
|
|
||||||
}
|
|
||||||
|
|
||||||
int pud_huge(pud_t pud)
|
|
||||||
{
|
|
||||||
return pud_leaf(pud);
|
|
||||||
}
|
|
||||||
|
|
||||||
bool __init arch_hugetlb_valid_size(unsigned long size)
|
bool __init arch_hugetlb_valid_size(unsigned long size)
|
||||||
{
|
{
|
||||||
if (MACHINE_HAS_EDAT1 && size == PMD_SIZE)
|
if (MACHINE_HAS_EDAT1 && size == PMD_SIZE)
|
||||||
|
@ -70,13 +70,3 @@ pte_t *huge_pte_offset(struct mm_struct *mm,
|
|||||||
|
|
||||||
return pte;
|
return pte;
|
||||||
}
|
}
|
||||||
|
|
||||||
int pmd_huge(pmd_t pmd)
|
|
||||||
{
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
int pud_huge(pud_t pud)
|
|
||||||
{
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
@ -407,16 +407,6 @@ pte_t huge_ptep_get_and_clear(struct mm_struct *mm, unsigned long addr,
|
|||||||
return entry;
|
return entry;
|
||||||
}
|
}
|
||||||
|
|
||||||
int pmd_huge(pmd_t pmd)
|
|
||||||
{
|
|
||||||
return pmd_leaf(pmd);
|
|
||||||
}
|
|
||||||
|
|
||||||
int pud_huge(pud_t pud)
|
|
||||||
{
|
|
||||||
return pud_leaf(pud);
|
|
||||||
}
|
|
||||||
|
|
||||||
static void hugetlb_free_pte_range(struct mmu_gather *tlb, pmd_t *pmd,
|
static void hugetlb_free_pte_range(struct mmu_gather *tlb, pmd_t *pmd,
|
||||||
unsigned long addr)
|
unsigned long addr)
|
||||||
{
|
{
|
||||||
|
@ -19,22 +19,6 @@
|
|||||||
#include <asm/tlbflush.h>
|
#include <asm/tlbflush.h>
|
||||||
#include <asm/elf.h>
|
#include <asm/elf.h>
|
||||||
|
|
||||||
/*
|
|
||||||
* pmd_huge() returns 1 if @pmd is hugetlb related entry.
|
|
||||||
*/
|
|
||||||
int pmd_huge(pmd_t pmd)
|
|
||||||
{
|
|
||||||
return pmd_leaf(pmd);
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
* pud_huge() returns 1 if @pud is hugetlb related entry.
|
|
||||||
*/
|
|
||||||
int pud_huge(pud_t pud)
|
|
||||||
{
|
|
||||||
return pud_leaf(pud);
|
|
||||||
}
|
|
||||||
|
|
||||||
#ifdef CONFIG_HUGETLB_PAGE
|
#ifdef CONFIG_HUGETLB_PAGE
|
||||||
static unsigned long hugetlb_get_unmapped_area_bottomup(struct file *file,
|
static unsigned long hugetlb_get_unmapped_area_bottomup(struct file *file,
|
||||||
unsigned long addr, unsigned long len,
|
unsigned long addr, unsigned long len,
|
||||||
|
@ -272,13 +272,9 @@ void hugetlb_vma_unlock_write(struct vm_area_struct *vma);
|
|||||||
int hugetlb_vma_trylock_write(struct vm_area_struct *vma);
|
int hugetlb_vma_trylock_write(struct vm_area_struct *vma);
|
||||||
void hugetlb_vma_assert_locked(struct vm_area_struct *vma);
|
void hugetlb_vma_assert_locked(struct vm_area_struct *vma);
|
||||||
void hugetlb_vma_lock_release(struct kref *kref);
|
void hugetlb_vma_lock_release(struct kref *kref);
|
||||||
|
|
||||||
int pmd_huge(pmd_t pmd);
|
|
||||||
int pud_huge(pud_t pud);
|
|
||||||
long hugetlb_change_protection(struct vm_area_struct *vma,
|
long hugetlb_change_protection(struct vm_area_struct *vma,
|
||||||
unsigned long address, unsigned long end, pgprot_t newprot,
|
unsigned long address, unsigned long end, pgprot_t newprot,
|
||||||
unsigned long cp_flags);
|
unsigned long cp_flags);
|
||||||
|
|
||||||
bool is_hugetlb_entry_migration(pte_t pte);
|
bool is_hugetlb_entry_migration(pte_t pte);
|
||||||
bool is_hugetlb_entry_hwpoisoned(pte_t pte);
|
bool is_hugetlb_entry_hwpoisoned(pte_t pte);
|
||||||
void hugetlb_unshare_all_pmds(struct vm_area_struct *vma);
|
void hugetlb_unshare_all_pmds(struct vm_area_struct *vma);
|
||||||
@ -399,16 +395,6 @@ static inline void hugetlb_vma_assert_locked(struct vm_area_struct *vma)
|
|||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline int pmd_huge(pmd_t pmd)
|
|
||||||
{
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline int pud_huge(pud_t pud)
|
|
||||||
{
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline int is_hugepage_only_range(struct mm_struct *mm,
|
static inline int is_hugepage_only_range(struct mm_struct *mm,
|
||||||
unsigned long addr, unsigned long len)
|
unsigned long addr, unsigned long len)
|
||||||
{
|
{
|
||||||
@ -493,16 +479,6 @@ static inline vm_fault_t hugetlb_fault(struct mm_struct *mm,
|
|||||||
static inline void hugetlb_unshare_all_pmds(struct vm_area_struct *vma) { }
|
static inline void hugetlb_unshare_all_pmds(struct vm_area_struct *vma) { }
|
||||||
|
|
||||||
#endif /* !CONFIG_HUGETLB_PAGE */
|
#endif /* !CONFIG_HUGETLB_PAGE */
|
||||||
/*
|
|
||||||
* hugepages at page global directory. If arch support
|
|
||||||
* hugepages at pgd level, they need to define this.
|
|
||||||
*/
|
|
||||||
#ifndef pgd_huge
|
|
||||||
#define pgd_huge(x) 0
|
|
||||||
#endif
|
|
||||||
#ifndef p4d_huge
|
|
||||||
#define p4d_huge(x) 0
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifndef pgd_write
|
#ifndef pgd_write
|
||||||
static inline int pgd_write(pgd_t pgd)
|
static inline int pgd_write(pgd_t pgd)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user