cregit-Linux how code gets into the kernel

Release 4.10 include/linux/migrate.h

Directory: include/linux
#ifndef _LINUX_MIGRATE_H

#define _LINUX_MIGRATE_H

#include <linux/mm.h>
#include <linux/mempolicy.h>
#include <linux/migrate_mode.h>


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);

/*
 * Return values from addresss_space_operations.migratepage():
 * - negative errno on page migration failure;
 * - zero on page migration success;
 */

#define MIGRATEPAGE_SUCCESS		0


enum migrate_reason {
	
MR_COMPACTION,
	
MR_MEMORY_FAILURE,
	
MR_MEMORY_HOTPLUG,
	
MR_SYSCALL,		/* also applies to cpusets */
	
MR_MEMPOLICY_MBIND,
	
MR_NUMA_MISPLACED,
	
MR_CMA,
	
MR_TYPES
};

/* In mm/debug.c; also keep sync with include/trace/events/migrate.h */
extern char *migrate_reason_names[MR_TYPES];

#ifdef CONFIG_MIGRATION

extern void putback_movable_pages(struct list_head *l);
extern int migrate_page(struct address_space *,
			struct page *, struct page *, enum migrate_mode);
extern int migrate_pages(struct list_head *l, new_page_t new, free_page_t free,
		unsigned long private, enum migrate_mode mode, int reason);
extern bool isolate_movable_page(struct page *page, isolate_mode_t mode);
extern void putback_movable_page(struct page *page);

extern int migrate_prep(void);
extern int migrate_prep_local(void);
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);
extern int migrate_page_move_mapping(struct address_space *mapping,
		struct page *newpage, struct page *page,
		struct buffer_head *head, enum migrate_mode mode,
		int extra_count);
#else


static inline void putback_movable_pages(struct list_head *l) {}

Contributors

PersonTokensPropCommitsCommitProp
rafael aquinirafael aquini11100.00%1100.00%
Total11100.00%1100.00%


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) { return -ENOSYS; }

Contributors

PersonTokensPropCommitsCommitProp
christoph lameterchristoph lameter1751.52%342.86%
naoya horiguchinaoya horiguchi618.18%114.29%
mel gormanmel gorman618.18%228.57%
david rientjesdavid rientjes412.12%114.29%
Total33100.00%7100.00%


static inline int migrate_prep(void) { return -ENOSYS; }

Contributors

PersonTokensPropCommitsCommitProp
christoph lameterchristoph lameter1184.62%150.00%
mel gormanmel gorman215.38%150.00%
Total13100.00%2100.00%


static inline int migrate_prep_local(void) { return -ENOSYS; }

Contributors

PersonTokensPropCommitsCommitProp
mel gormanmel gorman1184.62%150.00%
christoph lameterchristoph lameter215.38%150.00%
Total13100.00%2100.00%


static inline void migrate_page_copy(struct page *newpage, struct page *page) {}

Contributors

PersonTokensPropCommitsCommitProp
naoya horiguchinaoya horiguchi16100.00%1100.00%
Total16100.00%1100.00%


static inline int migrate_huge_page_move_mapping(struct address_space *mapping, struct page *newpage, struct page *page) { return -ENOSYS; }

Contributors

PersonTokensPropCommitsCommitProp
naoya horiguchinaoya horiguchi26100.00%2100.00%
Total26100.00%2100.00%

#endif /* CONFIG_MIGRATION */ #ifdef CONFIG_COMPACTION extern int PageMovable(struct page *page); extern void __SetPageMovable(struct page *page, struct address_space *mapping); extern void __ClearPageMovable(struct page *page); #else
static inline int PageMovable(struct page *page) { return 0; }

Contributors

PersonTokensPropCommitsCommitProp
minchan kimminchan kim15100.00%1100.00%
Total15100.00%1100.00%

;
static inline void __SetPageMovable(struct page *page, struct address_space *mapping) { }

Contributors

PersonTokensPropCommitsCommitProp
minchan kimminchan kim16100.00%1100.00%
Total16100.00%1100.00%


static inline void __ClearPageMovable(struct page *page) { }

Contributors

PersonTokensPropCommitsCommitProp
minchan kimminchan kim11100.00%1100.00%
Total11100.00%1100.00%

#endif #ifdef CONFIG_NUMA_BALANCING extern bool pmd_trans_migrating(pmd_t pmd); extern int migrate_misplaced_page(struct page *page, struct vm_area_struct *vma, int node); #else
static inline bool pmd_trans_migrating(pmd_t pmd) { return false; }

Contributors

PersonTokensPropCommitsCommitProp
mel gormanmel gorman13100.00%1100.00%
Total13100.00%1100.00%


static inline int migrate_misplaced_page(struct page *page, struct vm_area_struct *vma, int node) { return -EAGAIN; /* can't migrate now */ }

Contributors

PersonTokensPropCommitsCommitProp
peter zijlstrapeter zijlstra2080.00%150.00%
mel gormanmel gorman520.00%150.00%
Total25100.00%2100.00%

#endif /* CONFIG_NUMA_BALANCING */ #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
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; }

Contributors

PersonTokensPropCommitsCommitProp
mel gormanmel gorman40100.00%1100.00%
Total40100.00%1100.00%

#endif /* CONFIG_NUMA_BALANCING && CONFIG_TRANSPARENT_HUGEPAGE*/ #endif /* _LINUX_MIGRATE_H */

Overall Contributors

PersonTokensPropCommitsCommitProp
mel gormanmel gorman17728.73%929.03%
christoph lameterchristoph lameter11318.34%722.58%
minchan kimminchan kim10917.69%39.68%
naoya horiguchinaoya horiguchi8213.31%26.45%
peter zijlstrapeter zijlstra386.17%13.23%
gu zhenggu zheng294.71%13.23%
david rientjesdavid rientjes243.90%13.23%
rafael aquinirafael aquini243.90%26.45%
vlastimil babkavlastimil babka111.79%13.23%
andrew mortonandrew morton30.49%13.23%
benjamin lahaisebenjamin lahaise30.49%13.23%
hugh dickinshugh dickins20.32%13.23%
konstantin khlebnikovkonstantin khlebnikov10.16%13.23%
Total616100.00%31100.00%
Directory: include/linux
Information contained on this website is for historical information purposes only and does not indicate or represent copyright ownership.