mv643xx_eth: Neaten mv643xx_eth_program_multicast_filter

The code around the allocation and loops are a bit obfuscated.

Neaten it by using:

o kcalloc with decimal count and sizeof(u32)
o Decimal loop indexing and i++ not i += 4
o A promiscuous block using a similar style
  to the multicast block
o Remove unnecessary variables

Signed-off-by: Joe Perches <joe@perches.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
Joe Perches 2015-09-09 17:40:56 -07:00 committed by David S. Miller
parent 29feb66a9a
commit 8b711d6db5
1 changed files with 22 additions and 21 deletions

View File

@ -1845,29 +1845,19 @@ static void mv643xx_eth_program_multicast_filter(struct net_device *dev)
struct netdev_hw_addr *ha; struct netdev_hw_addr *ha;
int i; int i;
if (dev->flags & (IFF_PROMISC | IFF_ALLMULTI)) { if (dev->flags & (IFF_PROMISC | IFF_ALLMULTI))
int port_num; goto promiscuous;
u32 accept;
oom: /* Allocate both mc_spec and mc_other tables */
port_num = mp->port_num; mc_spec = kcalloc(128, sizeof(u32), GFP_ATOMIC);
accept = 0x01010101; if (!mc_spec)
for (i = 0; i < 0x100; i += 4) { goto promiscuous;
wrl(mp, SPECIAL_MCAST_TABLE(port_num) + i, accept); mc_other = &mc_spec[64];
wrl(mp, OTHER_MCAST_TABLE(port_num) + i, accept);
}
return;
}
mc_spec = kzalloc(0x200, GFP_ATOMIC);
if (mc_spec == NULL)
goto oom;
mc_other = mc_spec + (0x100 >> 2);
netdev_for_each_mc_addr(ha, dev) { netdev_for_each_mc_addr(ha, dev) {
u8 *a = ha->addr; u8 *a = ha->addr;
u32 *table; u32 *table;
int entry; u8 entry;
if (memcmp(a, "\x01\x00\x5e\x00\x00", 5) == 0) { if (memcmp(a, "\x01\x00\x5e\x00\x00", 5) == 0) {
table = mc_spec; table = mc_spec;
@ -1880,12 +1870,23 @@ static void mv643xx_eth_program_multicast_filter(struct net_device *dev)
table[entry >> 2] |= 1 << (8 * (entry & 3)); table[entry >> 2] |= 1 << (8 * (entry & 3));
} }
for (i = 0; i < 0x100; i += 4) { for (i = 0; i < 64; i++) {
wrl(mp, SPECIAL_MCAST_TABLE(mp->port_num) + i, mc_spec[i >> 2]); wrl(mp, SPECIAL_MCAST_TABLE(mp->port_num) + i * sizeof(u32),
wrl(mp, OTHER_MCAST_TABLE(mp->port_num) + i, mc_other[i >> 2]); mc_spec[i]);
wrl(mp, OTHER_MCAST_TABLE(mp->port_num) + i * sizeof(u32),
mc_other[i]);
} }
kfree(mc_spec); kfree(mc_spec);
return;
promiscuous:
for (i = 0; i < 64; i++) {
wrl(mp, SPECIAL_MCAST_TABLE(mp->port_num) + i * sizeof(u32),
0x01010101u);
wrl(mp, OTHER_MCAST_TABLE(mp->port_num) + i * sizeof(u32),
0x01010101u);
}
} }
static void mv643xx_eth_set_rx_mode(struct net_device *dev) static void mv643xx_eth_set_rx_mode(struct net_device *dev)