mirror of
				https://git.kernel.org/pub/scm/linux/kernel/git/chenhuacai/linux-loongson
				synced 2025-10-25 23:06:18 +00:00 
			
		
		
		
	 83d1674a94
			
		
	
	
		83d1674a94
		
	
	
	
	
		
			
			We'd like to support CONFIG_MEMORY_HOTREMOVE on s390, which depends on CONFIG_MIGRATION. So far, CONFIG_MIGRATION is only available with NUMA support. This patch makes CONFIG_MIGRATION selectable for architectures that define ARCH_ENABLE_MEMORY_HOTREMOVE. When MIGRATION is enabled w/o NUMA, the kernel won't compile because migrate_vmas() does not know about vm_ops->migrate() and vma_migratable() does not know about policy_zone. To fix this, those two functions can be restricted to '#ifdef CONFIG_NUMA' because they are not being used w/o NUMA. vma_migratable() is moved over from migrate.h to mempolicy.h. [kosaki.motohiro@jp.fujitsu.com: build fix] Acked-by: Christoph Lameter <cl@linux-foundation.org> Signed-off-by: Gerald Schaefer <gerald.schaefer@de.ibm.com> Cc: Martin Schwidefsky <schwidefsky@de.ibm.com> Cc: Heiko Carstens <heiko.carstens@de.ibm.com> Signed-off-by: KOSAKI Motorhiro <kosaki.motohiro@jp.fujitsu.com> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
		
			
				
	
	
		
			48 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			48 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| #ifndef _LINUX_MIGRATE_H
 | |
| #define _LINUX_MIGRATE_H
 | |
| 
 | |
| #include <linux/mm.h>
 | |
| #include <linux/mempolicy.h>
 | |
| 
 | |
| typedef struct page *new_page_t(struct page *, unsigned long private, int **);
 | |
| 
 | |
| #ifdef CONFIG_MIGRATION
 | |
| extern int isolate_lru_page(struct page *p, struct list_head *pagelist);
 | |
| extern int putback_lru_pages(struct list_head *l);
 | |
| extern int migrate_page(struct address_space *,
 | |
| 			struct page *, struct page *);
 | |
| extern int migrate_pages(struct list_head *l, new_page_t x, unsigned long);
 | |
| 
 | |
| extern int fail_migrate_page(struct address_space *,
 | |
| 			struct page *, struct page *);
 | |
| 
 | |
| extern int migrate_prep(void);
 | |
| extern int migrate_vmas(struct mm_struct *mm,
 | |
| 		const nodemask_t *from, const nodemask_t *to,
 | |
| 		unsigned long flags);
 | |
| #else
 | |
| static inline int isolate_lru_page(struct page *p, struct list_head *list)
 | |
| 					{ return -ENOSYS; }
 | |
| static inline int putback_lru_pages(struct list_head *l) { return 0; }
 | |
| static inline int migrate_pages(struct list_head *l, new_page_t x,
 | |
| 		unsigned long private) { return -ENOSYS; }
 | |
| 
 | |
| static inline int migrate_pages_to(struct list_head *pagelist,
 | |
| 			struct vm_area_struct *vma, int dest) { return 0; }
 | |
| 
 | |
| static inline int migrate_prep(void) { return -ENOSYS; }
 | |
| 
 | |
| static inline int migrate_vmas(struct mm_struct *mm,
 | |
| 		const nodemask_t *from, const nodemask_t *to,
 | |
| 		unsigned long flags)
 | |
| {
 | |
| 	return -ENOSYS;
 | |
| }
 | |
| 
 | |
| /* Possible settings for the migrate_page() method in address_operations */
 | |
| #define migrate_page NULL
 | |
| #define fail_migrate_page NULL
 | |
| 
 | |
| #endif /* CONFIG_MIGRATION */
 | |
| #endif /* _LINUX_MIGRATE_H */
 |