Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit c9a9116e authored by Yisheng Xie's avatar Yisheng Xie Committed by Arun KS
Browse files

mm/migration: make isolate_movable_page() return int type

Patch series "HWPOISON: soft offlining for non-lru movable page", v6.

After Minchan's commit bda807d44454 ("mm: migrate: support non-lru
movable page migration"), some type of non-lru page like zsmalloc and
virtio-balloon page also support migration.

Therefore, we can:

1) soft offlining no-lru movable pages, which means when memory
   corrected errors occur on a non-lru movable page, we can stop to use
   it by migrating data onto another page and disable the original
   (maybe half-broken) one.

2) enable memory hotplug for non-lru movable pages, i.e. we may offline
   blocks, which include such pages, by using non-lru page migration.

This patchset is heavily dependent on non-lru movable page migration.

This patch (of 4):

Change the return type of isolate_movable_page() from bool to int.  It
will return 0 when isolate movable page successfully, and return -EBUSY
when it isolates failed.

There is no functional change within this patch but prepare for later
patch.

[xieyisheng1@huawei.com: v6]
  Link: http://lkml.kernel.org/r/1486108770-630-2-git-send-email-xieyisheng1@huawei.com
Link: http://lkml.kernel.org/r/1485867981-16037-2-git-send-email-ysxie@foxmail.com


Signed-off-by: default avatarYisheng Xie <xieyisheng1@huawei.com>
Suggested-by: default avatarMichal Hocko <mhocko@kernel.org>
Acked-by: default avatarMinchan Kim <minchan@kernel.org>
Cc: Andi Kleen <ak@linux.intel.com>
Cc: Hanjun Guo <guohanjun@huawei.com>
Cc: Johannes Weiner <hannes@cmpxchg.org>
Cc: Joonsoo Kim <iamjoonsoo.kim@lge.com>
Cc: Mel Gorman <mgorman@techsingularity.net>
Cc: Naoya Horiguchi <n-horiguchi@ah.jp.nec.com>
Cc: Reza Arbab <arbab@linux.vnet.ibm.com>
Cc: Taku Izumi <izumi.taku@jp.fujitsu.com>
Cc: Vitaly Kuznetsov <vkuznets@redhat.com>
Cc: Vlastimil Babka <vbabka@suse.cz>
Cc: Xishi Qiu <qiuxishi@huawei.com>
Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
Signed-off-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
Git-commit: 9e5bcd610ffcedf5e485e78a72762810b25c7f25
Git-repo: git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git


Change-Id: I0d921d0a4e202397ce2a37909c67aaafd86fb465
Signed-off-by: default avatarArun KS <arunks@codeaurora.org>
parent 0eac567d
Loading
Loading
Loading
Loading
+1 −1
Original line number Original line Diff line number Diff line
@@ -37,7 +37,7 @@ extern int migrate_page(struct address_space *,
			struct page *, struct page *, enum migrate_mode);
			struct page *, struct page *, enum migrate_mode);
extern int migrate_pages(struct list_head *l, new_page_t new, free_page_t free,
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);
		unsigned long private, enum migrate_mode mode, int reason);
extern bool isolate_movable_page(struct page *page, isolate_mode_t mode);
extern int isolate_movable_page(struct page *page, isolate_mode_t mode);
extern void putback_movable_page(struct page *page);
extern void putback_movable_page(struct page *page);


extern int migrate_prep(void);
extern int migrate_prep(void);
+1 −1
Original line number Original line Diff line number Diff line
@@ -853,7 +853,7 @@ isolate_migratepages_block(struct compact_control *cc, unsigned long low_pfn,
					locked = false;
					locked = false;
				}
				}


				if (isolate_movable_page(page, isolate_mode))
				if (!isolate_movable_page(page, isolate_mode))
					goto isolate_success;
					goto isolate_success;
			}
			}


+3 −3
Original line number Original line Diff line number Diff line
@@ -75,7 +75,7 @@ int migrate_prep_local(void)
	return 0;
	return 0;
}
}


bool isolate_movable_page(struct page *page, isolate_mode_t mode)
int isolate_movable_page(struct page *page, isolate_mode_t mode)
{
{
	struct address_space *mapping;
	struct address_space *mapping;


@@ -126,14 +126,14 @@ bool isolate_movable_page(struct page *page, isolate_mode_t mode)
	__SetPageIsolated(page);
	__SetPageIsolated(page);
	unlock_page(page);
	unlock_page(page);


	return true;
	return 0;


out_no_isolated:
out_no_isolated:
	unlock_page(page);
	unlock_page(page);
out_putpage:
out_putpage:
	put_page(page);
	put_page(page);
out:
out:
	return false;
	return -EBUSY;
}
}


/* It should be called on page which is PG_movable */
/* It should be called on page which is PG_movable */