forked from mirrors/linux
		
	Add new interface cma_pages_valid() which indicates if the specified pages are part of a CMA region. This interface will be used in a subsequent patch by hugetlb code. In order to keep the same amount of DEBUG information, a pr_debug() call was added to cma_pages_valid(). In the case where the page passed to cma_release is not in cma region, the debug message will be printed from cma_pages_valid as opposed to cma_release. Link: https://lkml.kernel.org/r/20211007181918.136982-3-mike.kravetz@oracle.com Signed-off-by: Mike Kravetz <mike.kravetz@oracle.com> Acked-by: David Hildenbrand <david@redhat.com> Reviewed-by: Oscar Salvador <osalvador@suse.de> Cc: "Aneesh Kumar K . V" <aneesh.kumar@linux.ibm.com> Cc: David Rientjes <rientjes@google.com> Cc: Michal Hocko <mhocko@suse.com> Cc: Muchun Song <songmuchun@bytedance.com> Cc: Naoya Horiguchi <naoya.horiguchi@linux.dev> Cc: Nghia Le <nghialm78@gmail.com> Cc: Zi Yan <ziy@nvidia.com> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
		
			
				
	
	
		
			53 lines
		
	
	
	
		
			1.7 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			53 lines
		
	
	
	
		
			1.7 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
/* SPDX-License-Identifier: GPL-2.0 */
 | 
						|
#ifndef __CMA_H__
 | 
						|
#define __CMA_H__
 | 
						|
 | 
						|
#include <linux/init.h>
 | 
						|
#include <linux/types.h>
 | 
						|
#include <linux/numa.h>
 | 
						|
 | 
						|
/*
 | 
						|
 * There is always at least global CMA area and a few optional
 | 
						|
 * areas configured in kernel .config.
 | 
						|
 */
 | 
						|
#ifdef CONFIG_CMA_AREAS
 | 
						|
#define MAX_CMA_AREAS	(1 + CONFIG_CMA_AREAS)
 | 
						|
 | 
						|
#else
 | 
						|
#define MAX_CMA_AREAS	(0)
 | 
						|
 | 
						|
#endif
 | 
						|
 | 
						|
#define CMA_MAX_NAME 64
 | 
						|
 | 
						|
struct cma;
 | 
						|
 | 
						|
extern unsigned long totalcma_pages;
 | 
						|
extern phys_addr_t cma_get_base(const struct cma *cma);
 | 
						|
extern unsigned long cma_get_size(const struct cma *cma);
 | 
						|
extern const char *cma_get_name(const struct cma *cma);
 | 
						|
 | 
						|
extern int __init cma_declare_contiguous_nid(phys_addr_t base,
 | 
						|
			phys_addr_t size, phys_addr_t limit,
 | 
						|
			phys_addr_t alignment, unsigned int order_per_bit,
 | 
						|
			bool fixed, const char *name, struct cma **res_cma,
 | 
						|
			int nid);
 | 
						|
static inline int __init cma_declare_contiguous(phys_addr_t base,
 | 
						|
			phys_addr_t size, phys_addr_t limit,
 | 
						|
			phys_addr_t alignment, unsigned int order_per_bit,
 | 
						|
			bool fixed, const char *name, struct cma **res_cma)
 | 
						|
{
 | 
						|
	return cma_declare_contiguous_nid(base, size, limit, alignment,
 | 
						|
			order_per_bit, fixed, name, res_cma, NUMA_NO_NODE);
 | 
						|
}
 | 
						|
extern int cma_init_reserved_mem(phys_addr_t base, phys_addr_t size,
 | 
						|
					unsigned int order_per_bit,
 | 
						|
					const char *name,
 | 
						|
					struct cma **res_cma);
 | 
						|
extern struct page *cma_alloc(struct cma *cma, unsigned long count, unsigned int align,
 | 
						|
			      bool no_warn);
 | 
						|
extern bool cma_pages_valid(struct cma *cma, const struct page *pages, unsigned long count);
 | 
						|
extern bool cma_release(struct cma *cma, const struct page *pages, unsigned long count);
 | 
						|
 | 
						|
extern int cma_for_each_area(int (*it)(struct cma *cma, void *data), void *data);
 | 
						|
#endif
 |