Commit bbc105f3 authored by Kees Cook's avatar Kees Cook Committed by Greg Kroah-Hartman

pstore: Shut down worker when unregistering

commit 6330d553 upstream.

When built as a module and running with update_ms >= 0, pstore will Oops
during module unload since the work timer is still running. This makes sure
the worker is stopped before unloading.
Signed-off-by: default avatarKees Cook <keescook@chromium.org>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent ed8834ea
...@@ -709,6 +709,7 @@ int pstore_register(struct pstore_info *psi) ...@@ -709,6 +709,7 @@ int pstore_register(struct pstore_info *psi)
if (psi->flags & PSTORE_FLAGS_PMSG) if (psi->flags & PSTORE_FLAGS_PMSG)
pstore_register_pmsg(); pstore_register_pmsg();
/* Start watching for new records, if desired. */
if (pstore_update_ms >= 0) { if (pstore_update_ms >= 0) {
pstore_timer.expires = jiffies + pstore_timer.expires = jiffies +
msecs_to_jiffies(pstore_update_ms); msecs_to_jiffies(pstore_update_ms);
...@@ -731,6 +732,11 @@ EXPORT_SYMBOL_GPL(pstore_register); ...@@ -731,6 +732,11 @@ EXPORT_SYMBOL_GPL(pstore_register);
void pstore_unregister(struct pstore_info *psi) void pstore_unregister(struct pstore_info *psi)
{ {
/* Stop timer and make sure all work has finished. */
pstore_update_ms = -1;
del_timer_sync(&pstore_timer);
flush_work(&pstore_work);
if (psi->flags & PSTORE_FLAGS_PMSG) if (psi->flags & PSTORE_FLAGS_PMSG)
pstore_unregister_pmsg(); pstore_unregister_pmsg();
if (psi->flags & PSTORE_FLAGS_FTRACE) if (psi->flags & PSTORE_FLAGS_FTRACE)
...@@ -830,7 +836,9 @@ static void pstore_timefunc(unsigned long dummy) ...@@ -830,7 +836,9 @@ static void pstore_timefunc(unsigned long dummy)
schedule_work(&pstore_work); schedule_work(&pstore_work);
} }
mod_timer(&pstore_timer, jiffies + msecs_to_jiffies(pstore_update_ms)); if (pstore_update_ms >= 0)
mod_timer(&pstore_timer,
jiffies + msecs_to_jiffies(pstore_update_ms));
} }
module_param(backend, charp, 0444); module_param(backend, charp, 0444);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment