From: Martin Wilck <[email protected]>

Also removing the comment about dlog() and dm_write_log().
dlog() can cope with get_multipath_config() returning NULL,
and dm_write_log() hasn't accessed the configuration for a while.

Reviewed-by: Benjamin Marzinski <[email protected]>
Signed-off-by: Martin Wilck <[email protected]>
---
 multipathd/main.c | 20 +++++++++++---------
 1 file changed, 11 insertions(+), 9 deletions(-)

diff --git a/multipathd/main.c b/multipathd/main.c
index 9eb658d..07973e8 100644
--- a/multipathd/main.c
+++ b/multipathd/main.c
@@ -2892,6 +2892,16 @@ set_oom_adj (void)
        condlog(0, "couldn't adjust oom score");
 }
 
+static void cleanup_conf(void) {
+       struct config *conf;
+
+       conf = rcu_dereference(multipath_conf);
+       if (!conf)
+               return;
+       rcu_assign_pointer(multipath_conf, NULL);
+       call_rcu(&conf->rcu, rcu_free_config);
+}
+
 static void cleanup_maps(struct vectors *vecs)
 {
        int queue_without_daemon, i;
@@ -3196,15 +3206,7 @@ child (__attribute__((unused)) void *param)
 
        if (logsink == 1)
                log_thread_stop();
-
-       /*
-        * Freeing config must be done after condlog() and dm_lib_exit(),
-        * because logging functions like dlog() and dm_write_log()
-        * reference the config.
-        */
-       conf = rcu_dereference(multipath_conf);
-       rcu_assign_pointer(multipath_conf, NULL);
-       call_rcu(&conf->rcu, rcu_free_config);
+       cleanup_conf();
 #ifdef _DEBUG_
        dbg_free_final(NULL);
 #endif
-- 
2.29.0


--
dm-devel mailing list
[email protected]
https://www.redhat.com/mailman/listinfo/dm-devel

Reply via email to