mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-04 20:19:47 +08:00 
			
		
		
		
	 27d121d0ec
			
		
	
	
		27d121d0ec
		
	
	
	
	
		
			
			Patch series "powerpc/fadump: handle CMA activation failure appropriately", v3.
Commit 072355c1cf ("mm/cma: expose all pages to the buddy if
activation of an area fails") started exposing all pages to buddy
allocator on CMA activation failure.  But there can be CMA users that
want to handle the reserved memory differently on CMA allocation
failure.
Provide an option to opt out from exposing pages to buddy for such
cases.
Link: https://lkml.kernel.org/r/20220117075246.36072-1-hbathini@linux.ibm.com
Link: https://lkml.kernel.org/r/20220117075246.36072-2-hbathini@linux.ibm.com
Signed-off-by: Hari Bathini <hbathini@linux.ibm.com>
Reviewed-by: David Hildenbrand <david@redhat.com>
Cc: Oscar Salvador <osalvador@suse.de>
Cc: Mike Kravetz <mike.kravetz@oracle.com>
Cc: Mahesh Salgaonkar <mahesh@linux.ibm.com>
Cc: Sourabh Jain <sourabhjain@linux.ibm.com>
Cc: Michael Ellerman <mpe@ellerman.id.au>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
		
	
			
		
			
				
	
	
		
			54 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			54 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /* SPDX-License-Identifier: GPL-2.0 */
 | |
| #ifndef __MM_CMA_H__
 | |
| #define __MM_CMA_H__
 | |
| 
 | |
| #include <linux/debugfs.h>
 | |
| #include <linux/kobject.h>
 | |
| 
 | |
| struct cma_kobject {
 | |
| 	struct kobject kobj;
 | |
| 	struct cma *cma;
 | |
| };
 | |
| 
 | |
| struct cma {
 | |
| 	unsigned long   base_pfn;
 | |
| 	unsigned long   count;
 | |
| 	unsigned long   *bitmap;
 | |
| 	unsigned int order_per_bit; /* Order of pages represented by one bit */
 | |
| 	spinlock_t	lock;
 | |
| #ifdef CONFIG_CMA_DEBUGFS
 | |
| 	struct hlist_head mem_head;
 | |
| 	spinlock_t mem_head_lock;
 | |
| 	struct debugfs_u32_array dfs_bitmap;
 | |
| #endif
 | |
| 	char name[CMA_MAX_NAME];
 | |
| #ifdef CONFIG_CMA_SYSFS
 | |
| 	/* the number of CMA page successful allocations */
 | |
| 	atomic64_t nr_pages_succeeded;
 | |
| 	/* the number of CMA page allocation failures */
 | |
| 	atomic64_t nr_pages_failed;
 | |
| 	/* kobject requires dynamic object */
 | |
| 	struct cma_kobject *cma_kobj;
 | |
| #endif
 | |
| 	bool reserve_pages_on_error;
 | |
| };
 | |
| 
 | |
| extern struct cma cma_areas[MAX_CMA_AREAS];
 | |
| extern unsigned cma_area_count;
 | |
| 
 | |
| static inline unsigned long cma_bitmap_maxno(struct cma *cma)
 | |
| {
 | |
| 	return cma->count >> cma->order_per_bit;
 | |
| }
 | |
| 
 | |
| #ifdef CONFIG_CMA_SYSFS
 | |
| void cma_sysfs_account_success_pages(struct cma *cma, unsigned long nr_pages);
 | |
| void cma_sysfs_account_fail_pages(struct cma *cma, unsigned long nr_pages);
 | |
| #else
 | |
| static inline void cma_sysfs_account_success_pages(struct cma *cma,
 | |
| 						   unsigned long nr_pages) {};
 | |
| static inline void cma_sysfs_account_fail_pages(struct cma *cma,
 | |
| 						unsigned long nr_pages) {};
 | |
| #endif
 | |
| #endif
 |