|
@@ -498,12 +498,16 @@ int __ref online_pages(unsigned long pfn, unsigned long nr_pages)
|
|
|
* So, zonelist must be updated after online.
|
|
|
*/
|
|
|
mutex_lock(&zonelists_mutex);
|
|
|
- if (!populated_zone(zone))
|
|
|
+ if (!populated_zone(zone)) {
|
|
|
need_zonelists_rebuild = 1;
|
|
|
+ build_all_zonelists(NULL, zone);
|
|
|
+ }
|
|
|
|
|
|
ret = walk_system_ram_range(pfn, nr_pages, &onlined_pages,
|
|
|
online_pages_range);
|
|
|
if (ret) {
|
|
|
+ if (need_zonelists_rebuild)
|
|
|
+ zone_pcp_reset(zone);
|
|
|
mutex_unlock(&zonelists_mutex);
|
|
|
printk(KERN_DEBUG "online_pages [mem %#010llx-%#010llx] failed\n",
|
|
|
(unsigned long long) pfn << PAGE_SHIFT,
|
|
@@ -519,7 +523,7 @@ int __ref online_pages(unsigned long pfn, unsigned long nr_pages)
|
|
|
if (onlined_pages) {
|
|
|
node_set_state(zone_to_nid(zone), N_HIGH_MEMORY);
|
|
|
if (need_zonelists_rebuild)
|
|
|
- build_all_zonelists(NULL, zone);
|
|
|
+ build_all_zonelists(NULL, NULL);
|
|
|
else
|
|
|
zone_pcp_update(zone);
|
|
|
}
|