Merge branch 'slub/hotplug' into slab/urgent
This commit is contained in:
commit
597fb188cb
3 changed files with 12 additions and 2 deletions
|
@ -165,6 +165,12 @@ extern void register_page_bootmem_info_node(struct pglist_data *pgdat);
|
||||||
extern void put_page_bootmem(struct page *page);
|
extern void put_page_bootmem(struct page *page);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Lock for memory hotplug guarantees 1) all callbacks for memory hotplug
|
||||||
|
* notifier will be called under this. 2) offline/online/add/remove memory
|
||||||
|
* will not run simultaneously.
|
||||||
|
*/
|
||||||
|
|
||||||
void lock_memory_hotplug(void);
|
void lock_memory_hotplug(void);
|
||||||
void unlock_memory_hotplug(void);
|
void unlock_memory_hotplug(void);
|
||||||
|
|
||||||
|
|
|
@ -409,6 +409,7 @@ int online_pages(unsigned long pfn, unsigned long nr_pages)
|
||||||
int ret;
|
int ret;
|
||||||
struct memory_notify arg;
|
struct memory_notify arg;
|
||||||
|
|
||||||
|
lock_memory_hotplug();
|
||||||
arg.start_pfn = pfn;
|
arg.start_pfn = pfn;
|
||||||
arg.nr_pages = nr_pages;
|
arg.nr_pages = nr_pages;
|
||||||
arg.status_change_nid = -1;
|
arg.status_change_nid = -1;
|
||||||
|
@ -421,6 +422,7 @@ int online_pages(unsigned long pfn, unsigned long nr_pages)
|
||||||
ret = notifier_to_errno(ret);
|
ret = notifier_to_errno(ret);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
memory_notify(MEM_CANCEL_ONLINE, &arg);
|
memory_notify(MEM_CANCEL_ONLINE, &arg);
|
||||||
|
unlock_memory_hotplug();
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
/*
|
/*
|
||||||
|
@ -445,6 +447,7 @@ int online_pages(unsigned long pfn, unsigned long nr_pages)
|
||||||
printk(KERN_DEBUG "online_pages %lx at %lx failed\n",
|
printk(KERN_DEBUG "online_pages %lx at %lx failed\n",
|
||||||
nr_pages, pfn);
|
nr_pages, pfn);
|
||||||
memory_notify(MEM_CANCEL_ONLINE, &arg);
|
memory_notify(MEM_CANCEL_ONLINE, &arg);
|
||||||
|
unlock_memory_hotplug();
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -469,6 +472,7 @@ int online_pages(unsigned long pfn, unsigned long nr_pages)
|
||||||
|
|
||||||
if (onlined_pages)
|
if (onlined_pages)
|
||||||
memory_notify(MEM_ONLINE, &arg);
|
memory_notify(MEM_ONLINE, &arg);
|
||||||
|
unlock_memory_hotplug();
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
|
@ -3797,7 +3797,7 @@ static ssize_t show_slab_objects(struct kmem_cache *s,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
down_read(&slub_lock);
|
lock_memory_hotplug();
|
||||||
#ifdef CONFIG_SLUB_DEBUG
|
#ifdef CONFIG_SLUB_DEBUG
|
||||||
if (flags & SO_ALL) {
|
if (flags & SO_ALL) {
|
||||||
for_each_node_state(node, N_NORMAL_MEMORY) {
|
for_each_node_state(node, N_NORMAL_MEMORY) {
|
||||||
|
@ -3838,7 +3838,7 @@ static ssize_t show_slab_objects(struct kmem_cache *s,
|
||||||
x += sprintf(buf + x, " N%d=%lu",
|
x += sprintf(buf + x, " N%d=%lu",
|
||||||
node, nodes[node]);
|
node, nodes[node]);
|
||||||
#endif
|
#endif
|
||||||
up_read(&slub_lock);
|
unlock_memory_hotplug();
|
||||||
kfree(nodes);
|
kfree(nodes);
|
||||||
return x + sprintf(buf + x, "\n");
|
return x + sprintf(buf + x, "\n");
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Reference in a new issue