diff options
| author | Thomas Gleixner <tglx@linutronix.de> | 2018-06-22 21:20:35 +0200 | 
|---|---|---|
| committer | Thomas Gleixner <tglx@linutronix.de> | 2018-06-22 21:20:35 +0200 | 
| commit | 7731b8bc94e599c9a79e428f3359ff2c34b7576a (patch) | |
| tree | 879f18ccbe274122f2d4f095b43cbc7f953e0ada /mm/memory_hotplug.c | |
| parent | 48e315618dc4dc8904182cd221e3d395d5d97005 (diff) | |
| parent | 9ffc59d57228d74809700be6f7ecb1db10292f05 (diff) | |
Merge branch 'linus' into x86/urgent
Required to queue a dependent fix.
Diffstat (limited to 'mm/memory_hotplug.c')
| -rw-r--r-- | mm/memory_hotplug.c | 23 | 
1 files changed, 23 insertions, 0 deletions
diff --git a/mm/memory_hotplug.c b/mm/memory_hotplug.c index 25982467800b..7deb49f69e27 100644 --- a/mm/memory_hotplug.c +++ b/mm/memory_hotplug.c @@ -1237,6 +1237,29 @@ static struct page *next_active_pageblock(struct page *page)  	return page + pageblock_nr_pages;  } +static bool is_pageblock_removable_nolock(struct page *page) +{ +	struct zone *zone; +	unsigned long pfn; + +	/* +	 * We have to be careful here because we are iterating over memory +	 * sections which are not zone aware so we might end up outside of +	 * the zone but still within the section. +	 * We have to take care about the node as well. If the node is offline +	 * its NODE_DATA will be NULL - see page_zone. +	 */ +	if (!node_online(page_to_nid(page))) +		return false; + +	zone = page_zone(page); +	pfn = page_to_pfn(page); +	if (!zone_spans_pfn(zone, pfn)) +		return false; + +	return !has_unmovable_pages(zone, page, 0, MIGRATE_MOVABLE, true); +} +  /* Checks if this range of memory is likely to be hot-removable. */  bool is_mem_section_removable(unsigned long start_pfn, unsigned long nr_pages)  {  | 
