migrate.h 3.3 KB
Newer Older
C
Christoph Lameter 已提交
1 2 3 4
#ifndef _LINUX_MIGRATE_H
#define _LINUX_MIGRATE_H

#include <linux/mm.h>
5
#include <linux/mempolicy.h>
6
#include <linux/migrate_mode.h>
C
Christoph Lameter 已提交
7

8 9 10
typedef struct page *new_page_t(struct page *page, unsigned long private,
				int **reason);
typedef void free_page_t(struct page *page, unsigned long private);
11

12 13 14 15 16 17
/*
 * Return values from addresss_space_operations.migratepage():
 * - negative errno on page migration failure;
 * - zero on page migration success;
 */
#define MIGRATEPAGE_SUCCESS		0
18

19 20 21 22 23 24
enum migrate_reason {
	MR_COMPACTION,
	MR_MEMORY_FAILURE,
	MR_MEMORY_HOTPLUG,
	MR_SYSCALL,		/* also applies to cpusets */
	MR_MEMPOLICY_MBIND,
25
	MR_NUMA_MISPLACED,
26 27
	MR_CMA
};
28

29
#ifdef CONFIG_MIGRATION
30

31
extern void putback_movable_pages(struct list_head *l);
32
extern int migrate_page(struct address_space *,
33
			struct page *, struct page *, enum migrate_mode);
34
extern int migrate_pages(struct list_head *l, new_page_t new, free_page_t free,
35
		unsigned long private, enum migrate_mode mode, int reason);
36

C
Christoph Lameter 已提交
37
extern int migrate_prep(void);
38
extern int migrate_prep_local(void);
N
Naoya Horiguchi 已提交
39 40 41
extern void migrate_page_copy(struct page *newpage, struct page *page);
extern int migrate_huge_page_move_mapping(struct address_space *mapping,
				  struct page *newpage, struct page *page);
42 43
extern int migrate_page_move_mapping(struct address_space *mapping,
		struct page *newpage, struct page *page,
44 45
		struct buffer_head *head, enum migrate_mode mode,
		int extra_count);
C
Christoph Lameter 已提交
46
#else
47

48
static inline void putback_movable_pages(struct list_head *l) {}
49 50 51
static inline int migrate_pages(struct list_head *l, new_page_t new,
		free_page_t free, unsigned long private, enum migrate_mode mode,
		int reason)
52
	{ return -ENOSYS; }
53

C
Christoph Lameter 已提交
54
static inline int migrate_prep(void) { return -ENOSYS; }
55
static inline int migrate_prep_local(void) { return -ENOSYS; }
C
Christoph Lameter 已提交
56

N
Naoya Horiguchi 已提交
57 58 59
static inline void migrate_page_copy(struct page *newpage,
				     struct page *page) {}

60
static inline int migrate_huge_page_move_mapping(struct address_space *mapping,
N
Naoya Horiguchi 已提交
61 62 63 64 65
				  struct page *newpage, struct page *page)
{
	return -ENOSYS;
}

C
Christoph Lameter 已提交
66
#endif /* CONFIG_MIGRATION */
67 68

#ifdef CONFIG_NUMA_BALANCING
69 70
extern bool pmd_trans_migrating(pmd_t pmd);
extern void wait_migrate_huge_page(struct anon_vma *anon_vma, pmd_t *pmd);
71 72
extern int migrate_misplaced_page(struct page *page,
				  struct vm_area_struct *vma, int node);
73
extern bool migrate_ratelimited(int node);
74
#else
75 76 77 78 79 80 81
static inline bool pmd_trans_migrating(pmd_t pmd)
{
	return false;
}
static inline void wait_migrate_huge_page(struct anon_vma *anon_vma, pmd_t *pmd)
{
}
82 83
static inline int migrate_misplaced_page(struct page *page,
					 struct vm_area_struct *vma, int node)
84 85 86
{
	return -EAGAIN; /* can't migrate now */
}
87 88 89 90
static inline bool migrate_ratelimited(int node)
{
	return false;
}
91
#endif /* CONFIG_NUMA_BALANCING */
92

93 94 95 96 97 98 99
#if defined(CONFIG_NUMA_BALANCING) && defined(CONFIG_TRANSPARENT_HUGEPAGE)
extern int migrate_misplaced_transhuge_page(struct mm_struct *mm,
			struct vm_area_struct *vma,
			pmd_t *pmd, pmd_t entry,
			unsigned long address,
			struct page *page, int node);
#else
100 101 102 103 104 105 106 107
static inline int migrate_misplaced_transhuge_page(struct mm_struct *mm,
			struct vm_area_struct *vma,
			pmd_t *pmd, pmd_t entry,
			unsigned long address,
			struct page *page, int node)
{
	return -EAGAIN;
}
108
#endif /* CONFIG_NUMA_BALANCING && CONFIG_TRANSPARENT_HUGEPAGE*/
109

C
Christoph Lameter 已提交
110
#endif /* _LINUX_MIGRATE_H */