diff options
author | Yuval Mintz <Yuval.Mintz@qlogic.com> | 2016-08-24 13:27:19 +0300 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2016-08-24 09:45:20 -0700 |
commit | c7b7b483ccc9d64ae577a04d490aa9a975afe891 (patch) | |
tree | a0e669ab9cc7d9814bbdbdecc4847818895a9670 /net/dsa/slave.c | |
parent | 6546c78ea671b3ea1dfbdc39744b58f451885ac7 (diff) | |
download | linux-rt-c7b7b483ccc9d64ae577a04d490aa9a975afe891.tar.gz |
bnx2x: Don't flush multicast MACs
When ndo_set_rx_mode() is called for bnx2x, as part of process of
configuring the new MAC address filters [both unicast & multicast]
driver begins by flushing the existing configuration and then iterating
over the network device's list of addresses and configures those instead.
This has the side-effect of creating a short gap where traffic wouldn't
be properly classified, as no filters are configured in HW.
While for unicasts this is rather insignificant [as unicast MACs don't
frequently change while interface is actually running],
for multicast traffic it does pose an issue as there are multicast-based
networks where new multicast groups would constantly be removed and
added.
This patch tries to remedy this [at least for the newer adapters] -
Instead of flushing & reconfiguring all existing multicast filters,
the driver would instead create the approximate hash match that would
result from the required filters. It would then compare it against the
currently configured approximate hash match, and only add and remove the
delta between those.
Signed-off-by: Yuval Mintz <Yuval.Mintz@qlogic.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/dsa/slave.c')
0 files changed, 0 insertions, 0 deletions