mirror of
https://mirrors.bfsu.edu.cn/git/linux.git
synced 2024-11-20 02:34:23 +08:00
net: calxedaxgmac: fix clearing of old filter addresses
In commit 2ee68f621a
(net: calxedaxgmac: fix various errors in
xgmac_set_rx_mode), a fix to clean-up old address entries was added.
However, the loop to zero out the entries failed to increment the register
address resulting in only 1 entry getting cleared. Fix this to correctly
use the loop index. Also, the end of the loop condition was off by 1 and
should have been <= rather than <.
Signed-off-by: Rob Herring <rob.herring@calxeda.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
6865d1e834
commit
8c1c58ec70
@ -1342,8 +1342,8 @@ static void xgmac_set_rx_mode(struct net_device *dev)
|
|||||||
}
|
}
|
||||||
|
|
||||||
out:
|
out:
|
||||||
for (i = reg; i < XGMAC_MAX_FILTER_ADDR; i++)
|
for (i = reg; i <= XGMAC_MAX_FILTER_ADDR; i++)
|
||||||
xgmac_set_mac_addr(ioaddr, NULL, reg);
|
xgmac_set_mac_addr(ioaddr, NULL, i);
|
||||||
for (i = 0; i < XGMAC_NUM_HASH; i++)
|
for (i = 0; i < XGMAC_NUM_HASH; i++)
|
||||||
writel(hash_filter[i], ioaddr + XGMAC_HASH(i));
|
writel(hash_filter[i], ioaddr + XGMAC_HASH(i));
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user