Commit 1f9dccb2 authored by Mike Kravetz's avatar Mike Kravetz Committed by Linus Torvalds

hugetlbfs: convert macros to static inline, fix sparse warning

huge_pte_offset() produced a sparse warning due to an improper return
type when the kernel was built with !CONFIG_HUGETLB_PAGE.  Fix the bad
type and also convert all the macros in this block to static inline
wrappers.  Two existing wrappers in this block had lines in excess of 80
columns so clean those up as well.

No functional change.

Link: http://lkml.kernel.org/r/20191112194558.139389-3-mike.kravetz@oracle.comSigned-off-by: default avatarMike Kravetz <mike.kravetz@oracle.com>
Reported-by: default avatarBen Dooks <ben.dooks@codethink.co.uk>
Suggested-by: default avatarJason Gunthorpe <jgg@ziepe.ca>
Cc: Michael Ellerman <mpe@ellerman.id.au>
Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
Signed-off-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
parent 997cdcb0
...@@ -164,38 +164,130 @@ static inline void adjust_range_if_pmd_sharing_possible( ...@@ -164,38 +164,130 @@ static inline void adjust_range_if_pmd_sharing_possible(
{ {
} }
#define follow_hugetlb_page(m,v,p,vs,a,b,i,w,n) ({ BUG(); 0; }) static inline long follow_hugetlb_page(struct mm_struct *mm,
#define follow_huge_addr(mm, addr, write) ERR_PTR(-EINVAL) struct vm_area_struct *vma, struct page **pages,
#define copy_hugetlb_page_range(src, dst, vma) ({ BUG(); 0; }) struct vm_area_struct **vmas, unsigned long *position,
unsigned long *nr_pages, long i, unsigned int flags,
int *nonblocking)
{
BUG();
return 0;
}
static inline struct page *follow_huge_addr(struct mm_struct *mm,
unsigned long address, int write)
{
return ERR_PTR(-EINVAL);
}
static inline int copy_hugetlb_page_range(struct mm_struct *dst,
struct mm_struct *src, struct vm_area_struct *vma)
{
BUG();
return 0;
}
static inline void hugetlb_report_meminfo(struct seq_file *m) static inline void hugetlb_report_meminfo(struct seq_file *m)
{ {
} }
#define hugetlb_report_node_meminfo(n, buf) 0
static inline int hugetlb_report_node_meminfo(int nid, char *buf)
{
return 0;
}
static inline void hugetlb_show_meminfo(void) static inline void hugetlb_show_meminfo(void)
{ {
} }
#define follow_huge_pd(vma, addr, hpd, flags, pdshift) NULL
#define follow_huge_pmd(mm, addr, pmd, flags) NULL static inline struct page *follow_huge_pd(struct vm_area_struct *vma,
#define follow_huge_pud(mm, addr, pud, flags) NULL unsigned long address, hugepd_t hpd, int flags,
#define follow_huge_pgd(mm, addr, pgd, flags) NULL int pdshift)
#define prepare_hugepage_range(file, addr, len) (-EINVAL) {
#define pmd_huge(x) 0 return NULL;
#define pud_huge(x) 0 }
#define is_hugepage_only_range(mm, addr, len) 0
#define hugetlb_free_pgd_range(tlb, addr, end, floor, ceiling) ({BUG(); 0; }) static inline struct page *follow_huge_pmd(struct mm_struct *mm,
#define hugetlb_mcopy_atomic_pte(dst_mm, dst_pte, dst_vma, dst_addr, \ unsigned long address, pmd_t *pmd, int flags)
src_addr, pagep) ({ BUG(); 0; }) {
#define huge_pte_offset(mm, address, sz) 0 return NULL;
}
static inline struct page *follow_huge_pud(struct mm_struct *mm,
unsigned long address, pud_t *pud, int flags)
{
return NULL;
}
static inline struct page *follow_huge_pgd(struct mm_struct *mm,
unsigned long address, pgd_t *pgd, int flags)
{
return NULL;
}
static inline int prepare_hugepage_range(struct file *file,
unsigned long addr, unsigned long len)
{
return -EINVAL;
}
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,
unsigned long addr, unsigned long len)
{
return 0;
}
static inline void hugetlb_free_pgd_range(struct mmu_gather *tlb,
unsigned long addr, unsigned long end,
unsigned long floor, unsigned long ceiling)
{
BUG();
}
static inline int hugetlb_mcopy_atomic_pte(struct mm_struct *dst_mm,
pte_t *dst_pte,
struct vm_area_struct *dst_vma,
unsigned long dst_addr,
unsigned long src_addr,
struct page **pagep)
{
BUG();
return 0;
}
static inline pte_t *huge_pte_offset(struct mm_struct *mm, unsigned long addr,
unsigned long sz)
{
return NULL;
}
static inline bool isolate_huge_page(struct page *page, struct list_head *list) static inline bool isolate_huge_page(struct page *page, struct list_head *list)
{ {
return false; return false;
} }
#define putback_active_hugepage(p) do {} while (0)
#define move_hugetlb_state(old, new, reason) do {} while (0)
static inline unsigned long hugetlb_change_protection(struct vm_area_struct *vma, static inline void putback_active_hugepage(struct page *page)
unsigned long address, unsigned long end, pgprot_t newprot) {
}
static inline void move_hugetlb_state(struct page *oldpage,
struct page *newpage, int reason)
{
}
static inline unsigned long hugetlb_change_protection(
struct vm_area_struct *vma, unsigned long address,
unsigned long end, pgprot_t newprot)
{ {
return 0; return 0;
} }
...@@ -213,6 +305,7 @@ static inline void __unmap_hugepage_range(struct mmu_gather *tlb, ...@@ -213,6 +305,7 @@ static inline void __unmap_hugepage_range(struct mmu_gather *tlb,
{ {
BUG(); BUG();
} }
static inline vm_fault_t hugetlb_fault(struct mm_struct *mm, static inline vm_fault_t hugetlb_fault(struct mm_struct *mm,
struct vm_area_struct *vma, unsigned long address, struct vm_area_struct *vma, unsigned long address,
unsigned int flags) unsigned int flags)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment