 b023f46813
			
		
	
	
	b023f46813
	
	
	
		
			
			hwpoisoned may be set when we offline a page by the sysfs interface /sys/devices/system/memory/soft_offline_page or /sys/devices/system/memory/hard_offline_page. If we don't clear this flag when onlining pages, this page can't be freed, and will not in free list. So we can't offline these pages again. So we should skip such page when offlining pages. Signed-off-by: Wen Congyang <wency@cn.fujitsu.com> Cc: David Rientjes <rientjes@google.com> Cc: Jiang Liu <liuj97@gmail.com> Cc: Len Brown <len.brown@intel.com> Cc: Benjamin Herrenschmidt <benh@kernel.crashing.org> Cc: Paul Mackerras <paulus@samba.org> Cc: Christoph Lameter <cl@linux.com> Cc: Minchan Kim <minchan.kim@gmail.com> Cc: KOSAKI Motohiro <kosaki.motohiro@jp.fujitsu.com> Cc: Yasuaki Ishimatsu <isimatu.yasuaki@jp.fujitsu.com> Cc: Andi Kleen <andi@firstfloor.org> Cc: Mel Gorman <mel@csn.ul.ie> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
		
			
				
	
	
		
			49 lines
		
	
	
	
		
			1.6 KiB
			
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			49 lines
		
	
	
	
		
			1.6 KiB
			
		
	
	
	
		
			C
		
	
	
	
	
	
| #ifndef __LINUX_PAGEISOLATION_H
 | |
| #define __LINUX_PAGEISOLATION_H
 | |
| 
 | |
| 
 | |
| bool has_unmovable_pages(struct zone *zone, struct page *page, int count,
 | |
| 			 bool skip_hwpoisoned_pages);
 | |
| void set_pageblock_migratetype(struct page *page, int migratetype);
 | |
| int move_freepages_block(struct zone *zone, struct page *page,
 | |
| 				int migratetype);
 | |
| int move_freepages(struct zone *zone,
 | |
| 			  struct page *start_page, struct page *end_page,
 | |
| 			  int migratetype);
 | |
| 
 | |
| /*
 | |
|  * 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.
 | |
|  */
 | |
| int
 | |
| start_isolate_page_range(unsigned long start_pfn, unsigned long end_pfn,
 | |
| 			 unsigned migratetype, bool skip_hwpoisoned_pages);
 | |
| 
 | |
| /*
 | |
|  * 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);
 | |
| 
 | |
| /*
 | |
|  * Internal functions. Changes pageblock's migrate type.
 | |
|  */
 | |
| int set_migratetype_isolate(struct page *page, bool skip_hwpoisoned_pages);
 | |
| void unset_migratetype_isolate(struct page *page, unsigned migratetype);
 | |
| struct page *alloc_migrate_target(struct page *page, unsigned long private,
 | |
| 				int **resultp);
 | |
| 
 | |
| #endif
 |