diff options
author | Linus Lüssing <linus.luessing@c0d3.blue> | 2019-05-07 06:08:26 +0200 |
---|---|---|
committer | Simon Wunderlich <sw@simonwunderlich.de> | 2019-05-25 12:59:54 +0200 |
commit | 6bc4544021f82283f0949f94494011730ecdd084 (patch) | |
tree | 04bb23d43a1ed1c8d117d510da9fa22e37c44426 /net/mpls | |
parent | 68a600de9afc2134aa24d0cce539b98a0acb68b1 (diff) | |
download | linux-6bc4544021f82283f0949f94494011730ecdd084.tar.gz linux-6bc4544021f82283f0949f94494011730ecdd084.tar.bz2 linux-6bc4544021f82283f0949f94494011730ecdd084.zip |
batman-adv: mcast: shorten multicast tt/tvlv worker spinlock section
It is not necessary to hold the mla_lock spinlock during the whole
multicast tt/tvlv worker callback. Just holding it during the checks and
updates of the bat_priv stored multicast flags and mla_list is enough.
Therefore this patch splits batadv_mcast_mla_tvlv_update() in two:
batadv_mcast_mla_flags_get() at the beginning of the worker to gather
and calculate the new multicast flags, which does not need any locking
as it neither reads from nor writes to bat_priv->mcast.
And batadv_mcast_mla_flags_update() at the end of the worker which
commits the newly calculated flags and lists to bat_priv->mcast and
therefore needs the lock.
Signed-off-by: Linus Lüssing <linus.luessing@c0d3.blue>
Signed-off-by: Sven Eckelmann <sven@narfation.org>
Signed-off-by: Simon Wunderlich <sw@simonwunderlich.de>
Diffstat (limited to 'net/mpls')
0 files changed, 0 insertions, 0 deletions