mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2025-01-08 14:13:53 +00:00
[S390] appldata_base: Remove module_exit function and modular stuff
arch/s390/Kconfig tells us that CONFIG_APPLDATA_BASE is bool and hence can never be built modular. Given this, defining appldata_exit() function is pointless (and wasteful, actually). Remove all that. Previous patch annotated appldata_offline_cpu() as __cpuexit, but now with the __exit function appldata_exit() gone, the only callsite that references it is __cpuinit, so this function can also be __cpuinit, thereby saving space when HOTPLUG_CPU=n. Signed-off-by: Satyam Sharma <satyam@infradead.org> Cc: Heiko Carstens <heiko.carstens@de.ibm.com> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Martin Schwidefsky <schwidefsky@de.ibm.com>
This commit is contained in:
parent
11b8bf0107
commit
076fc808ab
@ -547,7 +547,7 @@ static void __cpuinit appldata_online_cpu(int cpu)
|
||||
spin_unlock(&appldata_timer_lock);
|
||||
}
|
||||
|
||||
static void __cpuexit appldata_offline_cpu(int cpu)
|
||||
static void __cpuinit appldata_offline_cpu(int cpu)
|
||||
{
|
||||
del_virt_timer(&per_cpu(appldata_timer, cpu));
|
||||
if (atomic_dec_and_test(&appldata_expire_count)) {
|
||||
@ -607,65 +607,15 @@ static int __init appldata_init(void)
|
||||
register_hotcpu_notifier(&appldata_nb);
|
||||
|
||||
appldata_sysctl_header = register_sysctl_table(appldata_dir_table);
|
||||
#ifdef MODULE
|
||||
appldata_dir_table[0].de->owner = THIS_MODULE;
|
||||
appldata_table[0].de->owner = THIS_MODULE;
|
||||
appldata_table[1].de->owner = THIS_MODULE;
|
||||
#endif
|
||||
|
||||
P_DEBUG("Base interface initialized.\n");
|
||||
return 0;
|
||||
}
|
||||
|
||||
/*
|
||||
* appldata_exit()
|
||||
*
|
||||
* stop timer, unregister /proc entries
|
||||
*/
|
||||
static void __exit appldata_exit(void)
|
||||
{
|
||||
struct list_head *lh;
|
||||
struct appldata_ops *ops;
|
||||
int rc, i;
|
||||
__initcall(appldata_init);
|
||||
|
||||
P_DEBUG("Unloading module ...\n");
|
||||
/*
|
||||
* ops list should be empty, but just in case something went wrong...
|
||||
*/
|
||||
spin_lock(&appldata_ops_lock);
|
||||
list_for_each(lh, &appldata_ops_list) {
|
||||
ops = list_entry(lh, struct appldata_ops, list);
|
||||
rc = appldata_diag(ops->record_nr, APPLDATA_STOP_REC,
|
||||
(unsigned long) ops->data, ops->size,
|
||||
ops->mod_lvl);
|
||||
if (rc != 0) {
|
||||
P_ERROR("STOP DIAG 0xDC for %s failed, "
|
||||
"return code: %d\n", ops->name, rc);
|
||||
}
|
||||
}
|
||||
spin_unlock(&appldata_ops_lock);
|
||||
|
||||
unregister_hotcpu_notifier(&appldata_nb);
|
||||
|
||||
for_each_online_cpu(i)
|
||||
appldata_offline_cpu(i);
|
||||
|
||||
appldata_timer_active = 0;
|
||||
|
||||
unregister_sysctl_table(appldata_sysctl_header);
|
||||
|
||||
destroy_workqueue(appldata_wq);
|
||||
P_DEBUG("... module unloaded!\n");
|
||||
}
|
||||
/**************************** init / exit <END> ******************************/
|
||||
|
||||
|
||||
module_init(appldata_init);
|
||||
module_exit(appldata_exit);
|
||||
MODULE_LICENSE("GPL");
|
||||
MODULE_AUTHOR("Gerald Schaefer");
|
||||
MODULE_DESCRIPTION("Linux-VM Monitor Stream, base infrastructure");
|
||||
|
||||
EXPORT_SYMBOL_GPL(appldata_register_ops);
|
||||
EXPORT_SYMBOL_GPL(appldata_unregister_ops);
|
||||
EXPORT_SYMBOL_GPL(appldata_diag);
|
||||
|
Loading…
Reference in New Issue
Block a user