netfilter: nf_log: replace BUG_ON by WARN_ON_ONCE when putting logger
[ Upstream commit 259eb32971e9eb24d1777a28d82730659f50fdcb ]
Module reference is bumped for each user, this should not ever happen.
But BUG_ON check should use rcu_access_pointer() instead.
If this ever happens, do WARN_ON_ONCE() instead of BUG_ON() and
consolidate pointer check under the rcu read side lock section.
Fixes: fab4085f4e ("netfilter: log: nf_log_packet() as real unified interface")
Signed-off-by: Pablo Neira Ayuso <pablo@netfilter.org>
Signed-off-by: Sasha Levin <sashal@kernel.org>
This commit is contained in:
parent
67f0ca0a4c
commit
9ff981cd65
1 changed files with 4 additions and 3 deletions
|
|
@ -193,11 +193,12 @@ void nf_logger_put(int pf, enum nf_log_type type)
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
BUG_ON(loggers[pf][type] == NULL);
|
|
||||||
|
|
||||||
rcu_read_lock();
|
rcu_read_lock();
|
||||||
logger = rcu_dereference(loggers[pf][type]);
|
logger = rcu_dereference(loggers[pf][type]);
|
||||||
module_put(logger->me);
|
if (!logger)
|
||||||
|
WARN_ON_ONCE(1);
|
||||||
|
else
|
||||||
|
module_put(logger->me);
|
||||||
rcu_read_unlock();
|
rcu_read_unlock();
|
||||||
}
|
}
|
||||||
EXPORT_SYMBOL_GPL(nf_logger_put);
|
EXPORT_SYMBOL_GPL(nf_logger_put);
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue