Merge dc06fe51d2
("Merge tag 'rtc-5.9' of git://git.kernel.org/pub/scm/linux/kernel/git/abelloni/linux") into android-mainline
Steps on the way to 5.9-rc1. Signed-off-by: Greg Kroah-Hartman <gregkh@google.com> Change-Id: Iceded779988ff472863b7e1c54e22a9fa6383a30
This commit is contained in:
@@ -129,7 +129,7 @@ static struct mempolicy preferred_node_policy[MAX_NUMNODES];
|
||||
|
||||
/**
|
||||
* numa_map_to_online_node - Find closest online node
|
||||
* @nid: Node id to start the search
|
||||
* @node: Node id to start the search
|
||||
*
|
||||
* Lookup the next closest node by distance if @nid is not online.
|
||||
*/
|
||||
@@ -1066,27 +1066,6 @@ static int migrate_page_add(struct page *page, struct list_head *pagelist,
|
||||
return 0;
|
||||
}
|
||||
|
||||
/* page allocation callback for NUMA node migration */
|
||||
struct page *alloc_new_node_page(struct page *page, unsigned long node)
|
||||
{
|
||||
if (PageHuge(page))
|
||||
return alloc_huge_page_node(page_hstate(compound_head(page)),
|
||||
node);
|
||||
else if (PageTransHuge(page)) {
|
||||
struct page *thp;
|
||||
|
||||
thp = alloc_pages_node(node,
|
||||
(GFP_TRANSHUGE | __GFP_THISNODE),
|
||||
HPAGE_PMD_ORDER);
|
||||
if (!thp)
|
||||
return NULL;
|
||||
prep_transhuge_page(thp);
|
||||
return thp;
|
||||
} else
|
||||
return __alloc_pages_node(node, GFP_HIGHUSER_MOVABLE |
|
||||
__GFP_THISNODE, 0);
|
||||
}
|
||||
|
||||
/*
|
||||
* Migrate pages from one node to a target node.
|
||||
* Returns error or the number of pages not migrated.
|
||||
@@ -1097,6 +1076,10 @@ static int migrate_to_node(struct mm_struct *mm, int source, int dest,
|
||||
nodemask_t nmask;
|
||||
LIST_HEAD(pagelist);
|
||||
int err = 0;
|
||||
struct migration_target_control mtc = {
|
||||
.nid = dest,
|
||||
.gfp_mask = GFP_HIGHUSER_MOVABLE | __GFP_THISNODE,
|
||||
};
|
||||
|
||||
nodes_clear(nmask);
|
||||
node_set(source, nmask);
|
||||
@@ -1111,8 +1094,8 @@ static int migrate_to_node(struct mm_struct *mm, int source, int dest,
|
||||
flags | MPOL_MF_DISCONTIG_OK, &pagelist);
|
||||
|
||||
if (!list_empty(&pagelist)) {
|
||||
err = migrate_pages(&pagelist, alloc_new_node_page, NULL, dest,
|
||||
MIGRATE_SYNC, MR_SYSCALL);
|
||||
err = migrate_pages(&pagelist, alloc_migration_target, NULL,
|
||||
(unsigned long)&mtc, MIGRATE_SYNC, MR_SYSCALL);
|
||||
if (err)
|
||||
putback_movable_pages(&pagelist);
|
||||
}
|
||||
@@ -1633,11 +1616,11 @@ static int kernel_get_mempolicy(int __user *policy,
|
||||
int pval;
|
||||
nodemask_t nodes;
|
||||
|
||||
addr = untagged_addr(addr);
|
||||
|
||||
if (nmask != NULL && maxnode < nr_node_ids)
|
||||
return -EINVAL;
|
||||
|
||||
addr = untagged_addr(addr);
|
||||
|
||||
err = do_get_mempolicy(&pval, &nodes, addr, flags);
|
||||
|
||||
if (err)
|
||||
@@ -1891,7 +1874,7 @@ static int apply_policy_zone(struct mempolicy *policy, enum zone_type zone)
|
||||
* Return a nodemask representing a mempolicy for filtering nodes for
|
||||
* page allocation
|
||||
*/
|
||||
static nodemask_t *policy_nodemask(gfp_t gfp, struct mempolicy *policy)
|
||||
nodemask_t *policy_nodemask(gfp_t gfp, struct mempolicy *policy)
|
||||
{
|
||||
/* Lower zones don't get a nodemask applied for MPOL_BIND */
|
||||
if (unlikely(policy->mode == MPOL_BIND) &&
|
||||
|
Reference in New Issue
Block a user