123456789101112131415161718192021222324252627282930313233343536373839 |
- --- a/driver/wl_linux.c
- +++ b/driver/wl_linux.c
- @@ -2082,7 +2082,11 @@ static void
- _wl_set_multicast_list(struct net_device *dev)
- {
- wl_info_t *wl;
- +#if LINUX_VERSION_CODE <= KERNEL_VERSION(2,6,34)
- struct dev_mc_list *mclist;
- +#else
- + struct netdev_hw_addr *ha;
- +#endif
- int i;
-
- if (!dev)
- @@ -2098,14 +2102,24 @@ _wl_set_multicast_list(struct net_device
- wl->pub->allmulti = (dev->flags & IFF_ALLMULTI)? TRUE: FALSE;
-
- /* copy the list of multicasts into our private table */
- +#if LINUX_VERSION_CODE <= KERNEL_VERSION(2,6,34)
- for (i = 0, mclist = dev->mc_list; mclist && (i < dev->mc_count);
- i++, mclist = mclist->next) {
- +#else
- + i = 0;
- + netdev_for_each_mc_addr(ha, dev) {
- +#endif
- if (i >= MAXMULTILIST) {
- wl->pub->allmulti = TRUE;
- i = 0;
- break;
- }
- +#if LINUX_VERSION_CODE <= KERNEL_VERSION(2,6,34)
- wl->pub->multicast[i] = *((struct ether_addr*) mclist->dmi_addr);
- +#else
- + wl->pub->multicast[i] = *((struct ether_addr*) ha->addr);
- + i++;
- +#endif
- }
- wl->pub->nmulticast = i;
- wlc_set(wl->wlc, WLC_SET_PROMISC, (dev->flags & IFF_PROMISC));
|