net: convert multicast list to list_head
Converts the list and the core manipulating with it to be the same as uc_list. +uses two functions for adding/removing mc address (normal and "global" variant) instead of a function parameter. +removes dev_mcast.c completely. +exposes netdev_hw_addr_list_* macros along with __hw_addr_* functions for manipulation with lists on a sandbox (used in bonding and 80211 drivers) Signed-off-by: Jiri Pirko <jpirko@redhat.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
committed by
David S. Miller
parent
a748ee2426
commit
22bedad3ce
@ -971,7 +971,7 @@ bmac_remove_multi(struct net_device *dev,
|
||||
*/
|
||||
static void bmac_set_multicast(struct net_device *dev)
|
||||
{
|
||||
struct dev_mc_list *dmi;
|
||||
struct netdev_hw_addr *ha;
|
||||
struct bmac_data *bp = netdev_priv(dev);
|
||||
int num_addrs = netdev_mc_count(dev);
|
||||
unsigned short rx_cfg;
|
||||
@ -1000,8 +1000,8 @@ static void bmac_set_multicast(struct net_device *dev)
|
||||
rx_cfg = bmac_rx_on(dev, 0, 0);
|
||||
XXDEBUG(("bmac: multi disabled, rx_cfg=%#08x\n", rx_cfg));
|
||||
} else {
|
||||
netdev_for_each_mc_addr(dmi, dev)
|
||||
bmac_addhash(bp, dmi->dmi_addr);
|
||||
netdev_for_each_mc_addr(ha, dev)
|
||||
bmac_addhash(bp, ha->addr);
|
||||
bmac_update_hash_table_mask(dev, bp);
|
||||
rx_cfg = bmac_rx_on(dev, 1, 0);
|
||||
XXDEBUG(("bmac: multi enabled, rx_cfg=%#08x\n", rx_cfg));
|
||||
@ -1015,7 +1015,7 @@ static void bmac_set_multicast(struct net_device *dev)
|
||||
|
||||
static void bmac_set_multicast(struct net_device *dev)
|
||||
{
|
||||
struct dev_mc_list *dmi;
|
||||
struct netdev_hw_addr *ha;
|
||||
char *addrs;
|
||||
int i;
|
||||
unsigned short rx_cfg;
|
||||
@ -1039,8 +1039,8 @@ static void bmac_set_multicast(struct net_device *dev)
|
||||
|
||||
for(i = 0; i < 4; i++) hash_table[i] = 0;
|
||||
|
||||
netdev_for_each_mc_addr(dmi, dev) {
|
||||
addrs = dmi->dmi_addr;
|
||||
netdev_for_each_mc_addr(ha, dev) {
|
||||
addrs = ha->addr;
|
||||
|
||||
if(!(*addrs & 1))
|
||||
continue;
|
||||
|
Reference in New Issue
Block a user