|
@@ -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);
|