 d381c54760
			
		
	
	d381c54760
	
	
	
		
			
			Heiko has complained that his log is swamped by warnings from has_unmovable_pages [ 20.536664] page dumped because: has_unmovable_pages [ 20.536792] page:000003d081ff4080 count:1 mapcount:0 mapping:000000008ff88600 index:0x0 compound_mapcount: 0 [ 20.536794] flags: 0x3fffe0000010200(slab|head) [ 20.536795] raw: 03fffe0000010200 0000000000000100 0000000000000200 000000008ff88600 [ 20.536796] raw: 0000000000000000 0020004100000000 ffffffff00000001 0000000000000000 [ 20.536797] page dumped because: has_unmovable_pages [ 20.536814] page:000003d0823b0000 count:1 mapcount:0 mapping:0000000000000000 index:0x0 [ 20.536815] flags: 0x7fffe0000000000() [ 20.536817] raw: 07fffe0000000000 0000000000000100 0000000000000200 0000000000000000 [ 20.536818] raw: 0000000000000000 0000000000000000 ffffffff00000001 0000000000000000 which are not triggered by the memory hotplug but rather CMA allocator. The original idea behind dumping the page state for all call paths was that these messages will be helpful debugging failures. From the above it seems that this is not the case for the CMA path because we are lacking much more context. E.g the second reported page might be a CMA allocated page. It is still interesting to see a slab page in the CMA area but it is hard to tell whether this is bug from the above output alone. Address this issue by dumping the page state only on request. Both start_isolate_page_range and has_unmovable_pages already have an argument to ignore hwpoison pages so make this argument more generic and turn it into flags and allow callers to combine non-default modes into a mask. While we are at it, has_unmovable_pages call from is_pageblock_removable_nolock (sysfs removable file) is questionable to report the failure so drop it from there as well. Link: http://lkml.kernel.org/r/20181218092802.31429-1-mhocko@kernel.org Signed-off-by: Michal Hocko <mhocko@suse.com> Reported-by: Heiko Carstens <heiko.carstens@de.ibm.com> Reviewed-by: Oscar Salvador <osalvador@suse.de> Cc: Anshuman Khandual <anshuman.khandual@arm.com> Cc: Stephen Rothwell <sfr@canb.auug.org.au> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
		
			
				
	
	
		
			76 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			76 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /* SPDX-License-Identifier: GPL-2.0 */
 | |
| #ifndef __LINUX_PAGEISOLATION_H
 | |
| #define __LINUX_PAGEISOLATION_H
 | |
| 
 | |
| #ifdef CONFIG_MEMORY_ISOLATION
 | |
| static inline bool has_isolate_pageblock(struct zone *zone)
 | |
| {
 | |
| 	return zone->nr_isolate_pageblock;
 | |
| }
 | |
| static inline bool is_migrate_isolate_page(struct page *page)
 | |
| {
 | |
| 	return get_pageblock_migratetype(page) == MIGRATE_ISOLATE;
 | |
| }
 | |
| static inline bool is_migrate_isolate(int migratetype)
 | |
| {
 | |
| 	return migratetype == MIGRATE_ISOLATE;
 | |
| }
 | |
| #else
 | |
| static inline bool has_isolate_pageblock(struct zone *zone)
 | |
| {
 | |
| 	return false;
 | |
| }
 | |
| static inline bool is_migrate_isolate_page(struct page *page)
 | |
| {
 | |
| 	return false;
 | |
| }
 | |
| static inline bool is_migrate_isolate(int migratetype)
 | |
| {
 | |
| 	return false;
 | |
| }
 | |
| #endif
 | |
| 
 | |
| #define SKIP_HWPOISON	0x1
 | |
| #define REPORT_FAILURE	0x2
 | |
| 
 | |
| bool has_unmovable_pages(struct zone *zone, struct page *page, int count,
 | |
| 			 int migratetype, int flags);
 | |
| void set_pageblock_migratetype(struct page *page, int migratetype);
 | |
| int move_freepages_block(struct zone *zone, struct page *page,
 | |
| 				int migratetype, int *num_movable);
 | |
| 
 | |
| /*
 | |
|  * Changes migrate type in [start_pfn, end_pfn) to be MIGRATE_ISOLATE.
 | |
|  * If specified range includes migrate types other than MOVABLE or CMA,
 | |
|  * this will fail with -EBUSY.
 | |
|  *
 | |
|  * For isolating all pages in the range finally, the caller have to
 | |
|  * free all pages in the range. test_page_isolated() can be used for
 | |
|  * test it.
 | |
|  *
 | |
|  * The following flags are allowed (they can be combined in a bit mask)
 | |
|  * SKIP_HWPOISON - ignore hwpoison pages
 | |
|  * REPORT_FAILURE - report details about the failure to isolate the range
 | |
|  */
 | |
| int
 | |
| start_isolate_page_range(unsigned long start_pfn, unsigned long end_pfn,
 | |
| 			 unsigned migratetype, int flags);
 | |
| 
 | |
| /*
 | |
|  * Changes MIGRATE_ISOLATE to MIGRATE_MOVABLE.
 | |
|  * target range is [start_pfn, end_pfn)
 | |
|  */
 | |
| int
 | |
| undo_isolate_page_range(unsigned long start_pfn, unsigned long end_pfn,
 | |
| 			unsigned migratetype);
 | |
| 
 | |
| /*
 | |
|  * Test all pages in [start_pfn, end_pfn) are isolated or not.
 | |
|  */
 | |
| int test_pages_isolated(unsigned long start_pfn, unsigned long end_pfn,
 | |
| 			bool skip_hwpoisoned_pages);
 | |
| 
 | |
| struct page *alloc_migrate_target(struct page *page, unsigned long private);
 | |
| 
 | |
| #endif
 |