diff options
-rw-r--r-- | drivers/net/wireless/ath9k/ath9k.h | 1 | ||||
-rw-r--r-- | drivers/net/wireless/ath9k/hw.c | 71 | ||||
-rw-r--r-- | drivers/net/wireless/ath9k/hw.h | 14 | ||||
-rw-r--r-- | drivers/net/wireless/ath9k/main.c | 24 | ||||
-rw-r--r-- | drivers/net/wireless/ath9k/recv.c | 4 |
5 files changed, 38 insertions, 76 deletions
diff --git a/drivers/net/wireless/ath9k/ath9k.h b/drivers/net/wireless/ath9k/ath9k.h index d60b2e726414..03e4d0bf1590 100644 --- a/drivers/net/wireless/ath9k/ath9k.h +++ b/drivers/net/wireless/ath9k/ath9k.h | |||
@@ -580,7 +580,6 @@ struct ath_softc { | |||
580 | struct mutex mutex; | 580 | struct mutex mutex; |
581 | 581 | ||
582 | u8 curbssid[ETH_ALEN]; | 582 | u8 curbssid[ETH_ALEN]; |
583 | u8 macaddr[ETH_ALEN]; | ||
584 | u8 bssidmask[ETH_ALEN]; | 583 | u8 bssidmask[ETH_ALEN]; |
585 | u32 intrstatus; | 584 | u32 intrstatus; |
586 | u32 sc_flags; /* SC_OP_* */ | 585 | u32 sc_flags; /* SC_OP_* */ |
diff --git a/drivers/net/wireless/ath9k/hw.c b/drivers/net/wireless/ath9k/hw.c index 9eafada743d4..5d7287549c0b 100644 --- a/drivers/net/wireless/ath9k/hw.c +++ b/drivers/net/wireless/ath9k/hw.c | |||
@@ -392,8 +392,6 @@ static struct ath_hal_5416 *ath9k_hw_newstate(u16 devid, | |||
392 | void __iomem *mem, | 392 | void __iomem *mem, |
393 | int *status) | 393 | int *status) |
394 | { | 394 | { |
395 | static const u8 defbssidmask[ETH_ALEN] = | ||
396 | { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff }; | ||
397 | struct ath_hal_5416 *ahp; | 395 | struct ath_hal_5416 *ahp; |
398 | struct ath_hal *ah; | 396 | struct ath_hal *ah; |
399 | 397 | ||
@@ -432,7 +430,6 @@ static struct ath_hal_5416 *ath9k_hw_newstate(u16 devid, | |||
432 | ahp->ah_acktimeout = (u32) -1; | 430 | ahp->ah_acktimeout = (u32) -1; |
433 | ahp->ah_ctstimeout = (u32) -1; | 431 | ahp->ah_ctstimeout = (u32) -1; |
434 | ahp->ah_globaltxtimeout = (u32) -1; | 432 | ahp->ah_globaltxtimeout = (u32) -1; |
435 | memcpy(&ahp->ah_bssidmask, defbssidmask, ETH_ALEN); | ||
436 | 433 | ||
437 | ahp->ah_gBeaconRate = 0; | 434 | ahp->ah_gBeaconRate = 0; |
438 | 435 | ||
@@ -488,19 +485,18 @@ static int ath9k_hw_init_macaddr(struct ath_hal *ah) | |||
488 | u32 sum; | 485 | u32 sum; |
489 | int i; | 486 | int i; |
490 | u16 eeval; | 487 | u16 eeval; |
491 | struct ath_hal_5416 *ahp = AH5416(ah); | ||
492 | 488 | ||
493 | sum = 0; | 489 | sum = 0; |
494 | for (i = 0; i < 3; i++) { | 490 | for (i = 0; i < 3; i++) { |
495 | eeval = ath9k_hw_get_eeprom(ah, AR_EEPROM_MAC(i)); | 491 | eeval = ath9k_hw_get_eeprom(ah, AR_EEPROM_MAC(i)); |
496 | sum += eeval; | 492 | sum += eeval; |
497 | ahp->ah_macaddr[2 * i] = eeval >> 8; | 493 | ah->macaddr[2 * i] = eeval >> 8; |
498 | ahp->ah_macaddr[2 * i + 1] = eeval & 0xff; | 494 | ah->macaddr[2 * i + 1] = eeval & 0xff; |
499 | } | 495 | } |
500 | if (sum == 0 || sum == 0xffff * 3) { | 496 | if (sum == 0 || sum == 0xffff * 3) { |
501 | DPRINTF(ah->ah_sc, ATH_DBG_EEPROM, | 497 | DPRINTF(ah->ah_sc, ATH_DBG_EEPROM, |
502 | "mac address read failed: %pM\n", | 498 | "mac address read failed: %pM\n", |
503 | ahp->ah_macaddr); | 499 | ah->macaddr); |
504 | return -EADDRNOTAVAIL; | 500 | return -EADDRNOTAVAIL; |
505 | } | 501 | } |
506 | 502 | ||
@@ -2251,8 +2247,8 @@ int ath9k_hw_reset(struct ath_hal *ah, struct ath9k_channel *chan, | |||
2251 | 2247 | ||
2252 | ath9k_hw_decrease_chain_power(ah, chan); | 2248 | ath9k_hw_decrease_chain_power(ah, chan); |
2253 | 2249 | ||
2254 | REG_WRITE(ah, AR_STA_ID0, get_unaligned_le32(ahp->ah_macaddr)); | 2250 | REG_WRITE(ah, AR_STA_ID0, get_unaligned_le32(ah->macaddr)); |
2255 | REG_WRITE(ah, AR_STA_ID1, get_unaligned_le16(ahp->ah_macaddr + 4) | 2251 | REG_WRITE(ah, AR_STA_ID1, get_unaligned_le16(ah->macaddr + 4) |
2256 | | macStaId1 | 2252 | | macStaId1 |
2257 | | AR_STA_ID1_RTS_USE_DEF | 2253 | | AR_STA_ID1_RTS_USE_DEF |
2258 | | (ah->ah_config. | 2254 | | (ah->ah_config. |
@@ -2260,14 +2256,14 @@ int ath9k_hw_reset(struct ath_hal *ah, struct ath9k_channel *chan, | |||
2260 | | ahp->ah_staId1Defaults); | 2256 | | ahp->ah_staId1Defaults); |
2261 | ath9k_hw_set_operating_mode(ah, ah->ah_opmode); | 2257 | ath9k_hw_set_operating_mode(ah, ah->ah_opmode); |
2262 | 2258 | ||
2263 | REG_WRITE(ah, AR_BSSMSKL, get_unaligned_le32(ahp->ah_bssidmask)); | 2259 | REG_WRITE(ah, AR_BSSMSKL, get_unaligned_le32(sc->bssidmask)); |
2264 | REG_WRITE(ah, AR_BSSMSKU, get_unaligned_le16(ahp->ah_bssidmask + 4)); | 2260 | REG_WRITE(ah, AR_BSSMSKU, get_unaligned_le16(sc->bssidmask + 4)); |
2265 | 2261 | ||
2266 | REG_WRITE(ah, AR_DEF_ANTENNA, saveDefAntenna); | 2262 | REG_WRITE(ah, AR_DEF_ANTENNA, saveDefAntenna); |
2267 | 2263 | ||
2268 | REG_WRITE(ah, AR_BSS_ID0, get_unaligned_le32(ahp->ah_bssid)); | 2264 | REG_WRITE(ah, AR_BSS_ID0, get_unaligned_le32(sc->curbssid)); |
2269 | REG_WRITE(ah, AR_BSS_ID1, get_unaligned_le16(ahp->ah_bssid + 4) | | 2265 | REG_WRITE(ah, AR_BSS_ID1, get_unaligned_le16(sc->curbssid + 4) | |
2270 | ((ahp->ah_assocId & 0x3fff) << AR_BSS_ID1_AID_S)); | 2266 | ((sc->curaid & 0x3fff) << AR_BSS_ID1_AID_S)); |
2271 | 2267 | ||
2272 | REG_WRITE(ah, AR_ISR, ~0); | 2268 | REG_WRITE(ah, AR_ISR, ~0); |
2273 | 2269 | ||
@@ -3669,20 +3665,9 @@ bool ath9k_hw_set_txpowerlimit(struct ath_hal *ah, u32 limit) | |||
3669 | return true; | 3665 | return true; |
3670 | } | 3666 | } |
3671 | 3667 | ||
3672 | void ath9k_hw_getmac(struct ath_hal *ah, u8 *mac) | 3668 | void ath9k_hw_setmac(struct ath_hal *ah, const u8 *mac) |
3673 | { | ||
3674 | struct ath_hal_5416 *ahp = AH5416(ah); | ||
3675 | |||
3676 | memcpy(mac, ahp->ah_macaddr, ETH_ALEN); | ||
3677 | } | ||
3678 | |||
3679 | bool ath9k_hw_setmac(struct ath_hal *ah, const u8 *mac) | ||
3680 | { | 3669 | { |
3681 | struct ath_hal_5416 *ahp = AH5416(ah); | 3670 | memcpy(ah->macaddr, mac, ETH_ALEN); |
3682 | |||
3683 | memcpy(ahp->ah_macaddr, mac, ETH_ALEN); | ||
3684 | |||
3685 | return true; | ||
3686 | } | 3671 | } |
3687 | 3672 | ||
3688 | void ath9k_hw_setopmode(struct ath_hal *ah) | 3673 | void ath9k_hw_setopmode(struct ath_hal *ah) |
@@ -3696,35 +3681,17 @@ void ath9k_hw_setmcastfilter(struct ath_hal *ah, u32 filter0, u32 filter1) | |||
3696 | REG_WRITE(ah, AR_MCAST_FIL1, filter1); | 3681 | REG_WRITE(ah, AR_MCAST_FIL1, filter1); |
3697 | } | 3682 | } |
3698 | 3683 | ||
3699 | void ath9k_hw_getbssidmask(struct ath_hal *ah, u8 *mask) | 3684 | void ath9k_hw_setbssidmask(struct ath_softc *sc) |
3700 | { | 3685 | { |
3701 | struct ath_hal_5416 *ahp = AH5416(ah); | 3686 | REG_WRITE(sc->sc_ah, AR_BSSMSKL, get_unaligned_le32(sc->bssidmask)); |
3702 | 3687 | REG_WRITE(sc->sc_ah, AR_BSSMSKU, get_unaligned_le16(sc->bssidmask + 4)); | |
3703 | memcpy(mask, ahp->ah_bssidmask, ETH_ALEN); | ||
3704 | } | 3688 | } |
3705 | 3689 | ||
3706 | bool ath9k_hw_setbssidmask(struct ath_hal *ah, const u8 *mask) | 3690 | void ath9k_hw_write_associd(struct ath_softc *sc) |
3707 | { | 3691 | { |
3708 | struct ath_hal_5416 *ahp = AH5416(ah); | 3692 | REG_WRITE(sc->sc_ah, AR_BSS_ID0, get_unaligned_le32(sc->curbssid)); |
3709 | 3693 | REG_WRITE(sc->sc_ah, AR_BSS_ID1, get_unaligned_le16(sc->curbssid + 4) | | |
3710 | memcpy(ahp->ah_bssidmask, mask, ETH_ALEN); | 3694 | ((sc->curaid & 0x3fff) << AR_BSS_ID1_AID_S)); |
3711 | |||
3712 | REG_WRITE(ah, AR_BSSMSKL, get_unaligned_le32(ahp->ah_bssidmask)); | ||
3713 | REG_WRITE(ah, AR_BSSMSKU, get_unaligned_le16(ahp->ah_bssidmask + 4)); | ||
3714 | |||
3715 | return true; | ||
3716 | } | ||
3717 | |||
3718 | void ath9k_hw_write_associd(struct ath_hal *ah, const u8 *bssid, u16 assocId) | ||
3719 | { | ||
3720 | struct ath_hal_5416 *ahp = AH5416(ah); | ||
3721 | |||
3722 | memcpy(ahp->ah_bssid, bssid, ETH_ALEN); | ||
3723 | ahp->ah_assocId = assocId; | ||
3724 | |||
3725 | REG_WRITE(ah, AR_BSS_ID0, get_unaligned_le32(ahp->ah_bssid)); | ||
3726 | REG_WRITE(ah, AR_BSS_ID1, get_unaligned_le16(ahp->ah_bssid + 4) | | ||
3727 | ((assocId & 0x3fff) << AR_BSS_ID1_AID_S)); | ||
3728 | } | 3695 | } |
3729 | 3696 | ||
3730 | u64 ath9k_hw_gettsf64(struct ath_hal *ah) | 3697 | u64 ath9k_hw_gettsf64(struct ath_hal *ah) |
diff --git a/drivers/net/wireless/ath9k/hw.h b/drivers/net/wireless/ath9k/hw.h index 3fdf9626a766..f4bf70215744 100644 --- a/drivers/net/wireless/ath9k/hw.h +++ b/drivers/net/wireless/ath9k/hw.h | |||
@@ -427,6 +427,7 @@ struct ath_hal { | |||
427 | struct ath9k_hw_capabilities ah_caps; | 427 | struct ath9k_hw_capabilities ah_caps; |
428 | struct ath9k_regulatory regulatory; | 428 | struct ath9k_regulatory regulatory; |
429 | u32 ah_flags; | 429 | u32 ah_flags; |
430 | u8 macaddr[ETH_ALEN]; | ||
430 | 431 | ||
431 | enum ath9k_power_mode ah_power_mode; | 432 | enum ath9k_power_mode ah_power_mode; |
432 | enum ath9k_power_mode ah_restore_mode; | 433 | enum ath9k_power_mode ah_restore_mode; |
@@ -457,11 +458,6 @@ struct ath_hal_5416 { | |||
457 | struct ath9k_tx_queue_info ah_txq[ATH9K_NUM_TX_QUEUES]; | 458 | struct ath9k_tx_queue_info ah_txq[ATH9K_NUM_TX_QUEUES]; |
458 | void __iomem *ah_cal_mem; | 459 | void __iomem *ah_cal_mem; |
459 | 460 | ||
460 | u8 ah_macaddr[ETH_ALEN]; | ||
461 | u8 ah_bssid[ETH_ALEN]; | ||
462 | u8 ah_bssidmask[ETH_ALEN]; | ||
463 | u16 ah_assocId; | ||
464 | |||
465 | int16_t ah_curchanRadIndex; | 461 | int16_t ah_curchanRadIndex; |
466 | u32 ah_maskReg; | 462 | u32 ah_maskReg; |
467 | u32 ah_txOkInterruptMask; | 463 | u32 ah_txOkInterruptMask; |
@@ -633,13 +629,11 @@ void ath9k_hw_setrxfilter(struct ath_hal *ah, u32 bits); | |||
633 | bool ath9k_hw_phy_disable(struct ath_hal *ah); | 629 | bool ath9k_hw_phy_disable(struct ath_hal *ah); |
634 | bool ath9k_hw_disable(struct ath_hal *ah); | 630 | bool ath9k_hw_disable(struct ath_hal *ah); |
635 | bool ath9k_hw_set_txpowerlimit(struct ath_hal *ah, u32 limit); | 631 | bool ath9k_hw_set_txpowerlimit(struct ath_hal *ah, u32 limit); |
636 | void ath9k_hw_getmac(struct ath_hal *ah, u8 *mac); | 632 | void ath9k_hw_setmac(struct ath_hal *ah, const u8 *mac); |
637 | bool ath9k_hw_setmac(struct ath_hal *ah, const u8 *mac); | ||
638 | void ath9k_hw_setopmode(struct ath_hal *ah); | 633 | void ath9k_hw_setopmode(struct ath_hal *ah); |
639 | void ath9k_hw_setmcastfilter(struct ath_hal *ah, u32 filter0, u32 filter1); | 634 | void ath9k_hw_setmcastfilter(struct ath_hal *ah, u32 filter0, u32 filter1); |
640 | void ath9k_hw_getbssidmask(struct ath_hal *ah, u8 *mask); | 635 | void ath9k_hw_setbssidmask(struct ath_softc *sc); |
641 | bool ath9k_hw_setbssidmask(struct ath_hal *ah, const u8 *mask); | 636 | void ath9k_hw_write_associd(struct ath_softc *sc); |
642 | void ath9k_hw_write_associd(struct ath_hal *ah, const u8 *bssid, u16 assocId); | ||
643 | u64 ath9k_hw_gettsf64(struct ath_hal *ah); | 637 | u64 ath9k_hw_gettsf64(struct ath_hal *ah); |
644 | void ath9k_hw_settsf64(struct ath_hal *ah, u64 tsf64); | 638 | void ath9k_hw_settsf64(struct ath_hal *ah, u64 tsf64); |
645 | void ath9k_hw_reset_tsf(struct ath_hal *ah); | 639 | void ath9k_hw_reset_tsf(struct ath_hal *ah); |
diff --git a/drivers/net/wireless/ath9k/main.c b/drivers/net/wireless/ath9k/main.c index a1c76ec09b3a..bafefbed8382 100644 --- a/drivers/net/wireless/ath9k/main.c +++ b/drivers/net/wireless/ath9k/main.c | |||
@@ -905,8 +905,7 @@ static void ath9k_bss_assoc_info(struct ath_softc *sc, | |||
905 | /* New association, store aid */ | 905 | /* New association, store aid */ |
906 | if (avp->av_opmode == NL80211_IFTYPE_STATION) { | 906 | if (avp->av_opmode == NL80211_IFTYPE_STATION) { |
907 | sc->curaid = bss_conf->aid; | 907 | sc->curaid = bss_conf->aid; |
908 | ath9k_hw_write_associd(sc->sc_ah, sc->curbssid, | 908 | ath9k_hw_write_associd(sc); |
909 | sc->curaid); | ||
910 | } | 909 | } |
911 | 910 | ||
912 | /* Configure the beacon */ | 911 | /* Configure the beacon */ |
@@ -1514,11 +1513,10 @@ static int ath_init(u16 devid, struct ath_softc *sc) | |||
1514 | ath9k_hw_setcapability(ah, ATH9K_CAP_DIVERSITY, 1, true, NULL); | 1513 | ath9k_hw_setcapability(ah, ATH9K_CAP_DIVERSITY, 1, true, NULL); |
1515 | sc->rx.defant = ath9k_hw_getdefantenna(ah); | 1514 | sc->rx.defant = ath9k_hw_getdefantenna(ah); |
1516 | 1515 | ||
1517 | ath9k_hw_getmac(ah, sc->macaddr); | ||
1518 | if (ah->ah_caps.hw_caps & ATH9K_HW_CAP_BSSIDMASK) { | 1516 | if (ah->ah_caps.hw_caps & ATH9K_HW_CAP_BSSIDMASK) { |
1519 | ath9k_hw_getbssidmask(ah, sc->bssidmask); | 1517 | memcpy(sc->bssidmask, ath_bcast_mac, ETH_ALEN); |
1520 | ATH_SET_VIF_BSSID_MASK(sc->bssidmask); | 1518 | ATH_SET_VIF_BSSID_MASK(sc->bssidmask); |
1521 | ath9k_hw_setbssidmask(ah, sc->bssidmask); | 1519 | ath9k_hw_setbssidmask(sc); |
1522 | } | 1520 | } |
1523 | 1521 | ||
1524 | sc->beacon.slottime = ATH9K_SLOT_TIME_9; /* default to short slot time */ | 1522 | sc->beacon.slottime = ATH9K_SLOT_TIME_9; /* default to short slot time */ |
@@ -1577,7 +1575,7 @@ int ath_attach(u16 devid, struct ath_softc *sc) | |||
1577 | 1575 | ||
1578 | /* get mac address from hardware and set in mac80211 */ | 1576 | /* get mac address from hardware and set in mac80211 */ |
1579 | 1577 | ||
1580 | SET_IEEE80211_PERM_ADDR(hw, sc->macaddr); | 1578 | SET_IEEE80211_PERM_ADDR(hw, sc->sc_ah->macaddr); |
1581 | 1579 | ||
1582 | hw->flags = IEEE80211_HW_RX_INCLUDES_FCS | | 1580 | hw->flags = IEEE80211_HW_RX_INCLUDES_FCS | |
1583 | IEEE80211_HW_HOST_BROADCAST_PS_BUFFERING | | 1581 | IEEE80211_HW_HOST_BROADCAST_PS_BUFFERING | |
@@ -2285,7 +2283,9 @@ static int ath9k_config_interface(struct ieee80211_hw *hw, | |||
2285 | ah->ah_opmode != NL80211_IFTYPE_AP) { | 2283 | ah->ah_opmode != NL80211_IFTYPE_AP) { |
2286 | ah->ah_opmode = NL80211_IFTYPE_STATION; | 2284 | ah->ah_opmode = NL80211_IFTYPE_STATION; |
2287 | ath9k_hw_setopmode(ah); | 2285 | ath9k_hw_setopmode(ah); |
2288 | ath9k_hw_write_associd(ah, sc->macaddr, 0); | 2286 | memcpy(sc->curbssid, sc->sc_ah->macaddr, ETH_ALEN); |
2287 | sc->curaid = 0; | ||
2288 | ath9k_hw_write_associd(sc); | ||
2289 | /* Request full reset to get hw opmode changed properly */ | 2289 | /* Request full reset to get hw opmode changed properly */ |
2290 | sc->sc_flags |= SC_OP_FULL_RESET; | 2290 | sc->sc_flags |= SC_OP_FULL_RESET; |
2291 | } | 2291 | } |
@@ -2298,8 +2298,7 @@ static int ath9k_config_interface(struct ieee80211_hw *hw, | |||
2298 | /* Set BSSID */ | 2298 | /* Set BSSID */ |
2299 | memcpy(sc->curbssid, conf->bssid, ETH_ALEN); | 2299 | memcpy(sc->curbssid, conf->bssid, ETH_ALEN); |
2300 | sc->curaid = 0; | 2300 | sc->curaid = 0; |
2301 | ath9k_hw_write_associd(sc->sc_ah, sc->curbssid, | 2301 | ath9k_hw_write_associd(sc); |
2302 | sc->curaid); | ||
2303 | 2302 | ||
2304 | /* Set aggregation protection mode parameters */ | 2303 | /* Set aggregation protection mode parameters */ |
2305 | sc->config.ath_aggr_prot = 0; | 2304 | sc->config.ath_aggr_prot = 0; |
@@ -2382,8 +2381,11 @@ static void ath9k_configure_filter(struct ieee80211_hw *hw, | |||
2382 | ath9k_hw_setrxfilter(sc->sc_ah, rfilt); | 2381 | ath9k_hw_setrxfilter(sc->sc_ah, rfilt); |
2383 | 2382 | ||
2384 | if (changed_flags & FIF_BCN_PRBRESP_PROMISC) { | 2383 | if (changed_flags & FIF_BCN_PRBRESP_PROMISC) { |
2385 | if (*total_flags & FIF_BCN_PRBRESP_PROMISC) | 2384 | if (*total_flags & FIF_BCN_PRBRESP_PROMISC) { |
2386 | ath9k_hw_write_associd(sc->sc_ah, ath_bcast_mac, 0); | 2385 | memcpy(sc->curbssid, ath_bcast_mac, ETH_ALEN); |
2386 | sc->curaid = 0; | ||
2387 | ath9k_hw_write_associd(sc); | ||
2388 | } | ||
2387 | } | 2389 | } |
2388 | 2390 | ||
2389 | DPRINTF(sc, ATH_DBG_CONFIG, "Set HW RX filter: 0x%x\n", sc->rx.rxfilter); | 2391 | DPRINTF(sc, ATH_DBG_CONFIG, "Set HW RX filter: 0x%x\n", sc->rx.rxfilter); |
diff --git a/drivers/net/wireless/ath9k/recv.c b/drivers/net/wireless/ath9k/recv.c index e8e4a32037f9..c51c085f55d6 100644 --- a/drivers/net/wireless/ath9k/recv.c +++ b/drivers/net/wireless/ath9k/recv.c | |||
@@ -242,13 +242,13 @@ static void ath_opmode_init(struct ath_softc *sc) | |||
242 | 242 | ||
243 | /* configure bssid mask */ | 243 | /* configure bssid mask */ |
244 | if (ah->ah_caps.hw_caps & ATH9K_HW_CAP_BSSIDMASK) | 244 | if (ah->ah_caps.hw_caps & ATH9K_HW_CAP_BSSIDMASK) |
245 | ath9k_hw_setbssidmask(ah, sc->bssidmask); | 245 | ath9k_hw_setbssidmask(sc); |
246 | 246 | ||
247 | /* configure operational mode */ | 247 | /* configure operational mode */ |
248 | ath9k_hw_setopmode(ah); | 248 | ath9k_hw_setopmode(ah); |
249 | 249 | ||
250 | /* Handle any link-level address change. */ | 250 | /* Handle any link-level address change. */ |
251 | ath9k_hw_setmac(ah, sc->macaddr); | 251 | ath9k_hw_setmac(ah, sc->sc_ah->macaddr); |
252 | 252 | ||
253 | /* calculate and install multicast filter */ | 253 | /* calculate and install multicast filter */ |
254 | mfilt[0] = mfilt[1] = ~0; | 254 | mfilt[0] = mfilt[1] = ~0; |