]> git.baikalelectronics.ru Git - kernel.git/commit
net: bridge: switchdev: fix incorrect use of FDB flags when picking the dst device
authorVladimir Oltean <vladimir.oltean@nxp.com>
Mon, 2 Aug 2021 11:36:33 +0000 (14:36 +0300)
committerJakub Kicinski <kuba@kernel.org>
Tue, 3 Aug 2021 21:29:52 +0000 (14:29 -0700)
commit0a457996efceb8db35038873e90937a95ad5bcde
tree1e725c8addb33c43c83f4a90e8e3ac430f391095
parent3fc49bebabbf73322b9dc0c4c093f559ea15b7df
net: bridge: switchdev: fix incorrect use of FDB flags when picking the dst device

Nikolay points out that it is incorrect to assume that it is impossible
to have an fdb entry with fdb->dst == NULL and the BR_FDB_LOCAL bit in
fdb->flags not set. This is because there are reader-side places that
test_bit(BR_FDB_LOCAL, &fdb->flags) without the br->hash_lock, and if
the updating of the FDB entry happens on another CPU, there are no
memory barriers at writer or reader side which would ensure that the
reader sees the updates to both fdb->flags and fdb->dst in the same
order, i.e. the reader will not see an inconsistent FDB entry.

So we must be prepared to deal with FDB entries where fdb->dst and
fdb->flags are in a potentially inconsistent state, and that means that
fdb->dst == NULL should remain a condition to pick the net_device that
we report to switchdev as being the bridge device, which is what the
code did prior to the blamed patch.

Fixes: 84cb455c86d9 ("net: bridge: switchdev: treat local FDBs the same as entries towards the bridge")
Suggested-by: Nikolay Aleksandrov <nikolay@nvidia.com>
Signed-off-by: Vladimir Oltean <vladimir.oltean@nxp.com>
Acked-by: Nikolay Aleksandrov <nikolay@nvidia.com>
Link: https://lore.kernel.org/r/20210802113633.189831-1-vladimir.oltean@nxp.com
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
net/bridge/br_fdb.c
net/bridge/br_switchdev.c