diff options
author | Breno Leitao <leitao@debian.org> | 2024-07-09 16:44:00 +0200 |
---|---|---|
committer | Jakub Kicinski <kuba@kernel.org> | 2024-07-12 03:32:48 +0200 |
commit | 0066623d40085bb5d0af8d645a3bba27fc5cfced (patch) | |
tree | 91a6bc92f672ab709a03338ef89e1ca7a4d6b979 /drivers/net/netconsole.c | |
parent | net: netconsole: Remove unnecessary cast from bool (diff) | |
download | linux-0066623d40085bb5d0af8d645a3bba27fc5cfced.tar.xz linux-0066623d40085bb5d0af8d645a3bba27fc5cfced.zip |
net: netconsole: Eliminate redundant setting of enabled field
When disabling a netconsole target, enabled_store() is called with
enabled=false. Currently, this results in updating the nt->enabled
field twice:
1. Inside the if/else block, with the target_list_lock spinlock held
2. Later, without the target_list_lock
This patch eliminates the redundancy by setting the field only once,
improving efficiency and reducing potential race conditions.
Signed-off-by: Breno Leitao <leitao@debian.org>
Link: https://patch.msgid.link/20240709144403.544099-3-leitao@debian.org
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
Diffstat (limited to 'drivers/net/netconsole.c')
-rw-r--r-- | drivers/net/netconsole.c | 3 |
1 files changed, 1 insertions, 2 deletions
diff --git a/drivers/net/netconsole.c b/drivers/net/netconsole.c index de0d89e4e4e2..5ef680cf994a 100644 --- a/drivers/net/netconsole.c +++ b/drivers/net/netconsole.c @@ -369,6 +369,7 @@ static ssize_t enabled_store(struct config_item *item, if (err) goto out_unlock; + nt->enabled = true; pr_info("network logging started\n"); } else { /* false */ /* We need to disable the netconsole before cleaning it up @@ -381,8 +382,6 @@ static ssize_t enabled_store(struct config_item *item, netpoll_cleanup(&nt->np); } - nt->enabled = enabled; - mutex_unlock(&dynamic_netconsole_mutex); return strnlen(buf, count); out_unlock: |