|
@@ -929,7 +929,7 @@ int __ref online_pages(unsigned long pfn, unsigned long nr_pages, int online_typ
|
|
mutex_lock(&zonelists_mutex);
|
|
mutex_lock(&zonelists_mutex);
|
|
if (!populated_zone(zone)) {
|
|
if (!populated_zone(zone)) {
|
|
need_zonelists_rebuild = 1;
|
|
need_zonelists_rebuild = 1;
|
|
- build_all_zonelists(NULL, zone);
|
|
|
|
|
|
+ setup_zone_pageset(zone);
|
|
}
|
|
}
|
|
|
|
|
|
ret = walk_system_ram_range(pfn, nr_pages, &onlined_pages,
|
|
ret = walk_system_ram_range(pfn, nr_pages, &onlined_pages,
|
|
@@ -950,7 +950,7 @@ int __ref online_pages(unsigned long pfn, unsigned long nr_pages, int online_typ
|
|
if (onlined_pages) {
|
|
if (onlined_pages) {
|
|
node_states_set_node(nid, &arg);
|
|
node_states_set_node(nid, &arg);
|
|
if (need_zonelists_rebuild)
|
|
if (need_zonelists_rebuild)
|
|
- build_all_zonelists(NULL, NULL);
|
|
|
|
|
|
+ build_all_zonelists(NULL);
|
|
else
|
|
else
|
|
zone_pcp_update(zone);
|
|
zone_pcp_update(zone);
|
|
}
|
|
}
|
|
@@ -1028,7 +1028,7 @@ static pg_data_t __ref *hotadd_new_pgdat(int nid, u64 start)
|
|
* to access not-initialized zonelist, build here.
|
|
* to access not-initialized zonelist, build here.
|
|
*/
|
|
*/
|
|
mutex_lock(&zonelists_mutex);
|
|
mutex_lock(&zonelists_mutex);
|
|
- build_all_zonelists(pgdat, NULL);
|
|
|
|
|
|
+ build_all_zonelists(pgdat);
|
|
mutex_unlock(&zonelists_mutex);
|
|
mutex_unlock(&zonelists_mutex);
|
|
|
|
|
|
/*
|
|
/*
|
|
@@ -1084,7 +1084,7 @@ int try_online_node(int nid)
|
|
|
|
|
|
if (pgdat->node_zonelists->_zonerefs->zone == NULL) {
|
|
if (pgdat->node_zonelists->_zonerefs->zone == NULL) {
|
|
mutex_lock(&zonelists_mutex);
|
|
mutex_lock(&zonelists_mutex);
|
|
- build_all_zonelists(NULL, NULL);
|
|
|
|
|
|
+ build_all_zonelists(NULL);
|
|
mutex_unlock(&zonelists_mutex);
|
|
mutex_unlock(&zonelists_mutex);
|
|
}
|
|
}
|
|
|
|
|
|
@@ -1704,7 +1704,7 @@ repeat:
|
|
if (!populated_zone(zone)) {
|
|
if (!populated_zone(zone)) {
|
|
zone_pcp_reset(zone);
|
|
zone_pcp_reset(zone);
|
|
mutex_lock(&zonelists_mutex);
|
|
mutex_lock(&zonelists_mutex);
|
|
- build_all_zonelists(NULL, NULL);
|
|
|
|
|
|
+ build_all_zonelists(NULL);
|
|
mutex_unlock(&zonelists_mutex);
|
|
mutex_unlock(&zonelists_mutex);
|
|
} else
|
|
} else
|
|
zone_pcp_update(zone);
|
|
zone_pcp_update(zone);
|