diff options
Diffstat (limited to 'drivers/net/ewrk3.c')
| -rw-r--r-- | drivers/net/ewrk3.c | 9 | 
1 files changed, 4 insertions, 5 deletions
diff --git a/drivers/net/ewrk3.c b/drivers/net/ewrk3.c index 91e59f3a9d6..11ba70f4997 100644 --- a/drivers/net/ewrk3.c +++ b/drivers/net/ewrk3.c @@ -1169,7 +1169,7 @@ static void set_multicast_list(struct net_device *dev)  static void SetMulticastFilter(struct net_device *dev)  {  	struct ewrk3_private *lp = netdev_priv(dev); -	struct dev_mc_list *dmi; +	struct netdev_hw_addr *ha;  	u_long iobase = dev->base_addr;  	int i;  	char *addrs, bit, byte; @@ -1213,8 +1213,8 @@ static void SetMulticastFilter(struct net_device *dev)  		}  		/* Update table */ -		netdev_for_each_mc_addr(dmi, dev) { -			addrs = dmi->dmi_addr; +		netdev_for_each_mc_addr(ha, dev) { +			addrs = ha->addr;  			if ((*addrs & 0x01) == 1) {	/* multicast address? */  				crc = ether_crc_le(ETH_ALEN, addrs);  				hashcode = crc & ((1 << 9) - 1);	/* hashcode is 9 LSb of CRC */ @@ -1776,8 +1776,7 @@ static int ewrk3_ioctl(struct net_device *dev, struct ifreq *rq, int cmd)  		break;  	case EWRK3_SET_MCA:	/* Set a multicast address */  		if (capable(CAP_NET_ADMIN)) { -			if (ioc->len > 1024) -			{ +			if (ioc->len > HASH_TABLE_LEN) {  				status = -EINVAL;  				break;  			}  |