diff options
author | Hauke Mehrtens <hauke@hauke-m.de> | 2012-12-06 18:35:53 -0500 |
---|---|---|
committer | John W. Linville <linville@tuxdriver.com> | 2012-12-10 15:47:29 -0500 |
commit | 6f80f01483d122174d9aa7864a8ac4050ba6daaa (patch) | |
tree | 8ff104437fa754d65188c44d9732dbd1e92808fd | |
parent | 9c170e068636deb3e3f96114034bb711675f0faa (diff) |
brcmsmac: add support for cores with revision 17
This adds support for bcma wifi core revision 17 which is found on
BCM4716/4717/4718 SoCs. The firmware version 610.812 for brcmsmac found
in linux-firmware does not support these cores, but a firmware
generated with b43-fwcutter from the proprietary broadcom wireless
driver works with these chips. This wifi core contains a revision 5
N-PHY and a revision 7 radio of type 0x2056.
Signed-off-by: Hauke Mehrtens <hauke@hauke-m.de>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
-rw-r--r-- | drivers/net/wireless/brcm80211/brcmsmac/mac80211_if.c | 1 | ||||
-rw-r--r-- | drivers/net/wireless/brcm80211/brcmsmac/main.c | 6 |
2 files changed, 4 insertions, 3 deletions
diff --git a/drivers/net/wireless/brcm80211/brcmsmac/mac80211_if.c b/drivers/net/wireless/brcm80211/brcmsmac/mac80211_if.c index 02d27eacc0e2..1fbd8ecbe2ea 100644 --- a/drivers/net/wireless/brcm80211/brcmsmac/mac80211_if.c +++ b/drivers/net/wireless/brcm80211/brcmsmac/mac80211_if.c | |||
@@ -93,6 +93,7 @@ MODULE_FIRMWARE("brcm/bcm43xx_hdr-0.fw"); | |||
93 | 93 | ||
94 | /* recognized BCMA Core IDs */ | 94 | /* recognized BCMA Core IDs */ |
95 | static struct bcma_device_id brcms_coreid_table[] = { | 95 | static struct bcma_device_id brcms_coreid_table[] = { |
96 | BCMA_CORE(BCMA_MANUF_BCM, BCMA_CORE_80211, 17, BCMA_ANY_CLASS), | ||
96 | BCMA_CORE(BCMA_MANUF_BCM, BCMA_CORE_80211, 23, BCMA_ANY_CLASS), | 97 | BCMA_CORE(BCMA_MANUF_BCM, BCMA_CORE_80211, 23, BCMA_ANY_CLASS), |
97 | BCMA_CORE(BCMA_MANUF_BCM, BCMA_CORE_80211, 24, BCMA_ANY_CLASS), | 98 | BCMA_CORE(BCMA_MANUF_BCM, BCMA_CORE_80211, 24, BCMA_ANY_CLASS), |
98 | BCMA_CORETABLE_END | 99 | BCMA_CORETABLE_END |
diff --git a/drivers/net/wireless/brcm80211/brcmsmac/main.c b/drivers/net/wireless/brcm80211/brcmsmac/main.c index 8fce68751e47..cb48fc479443 100644 --- a/drivers/net/wireless/brcm80211/brcmsmac/main.c +++ b/drivers/net/wireless/brcm80211/brcmsmac/main.c | |||
@@ -717,7 +717,7 @@ static void brcms_c_ucode_bsinit(struct brcms_hardware *wlc_hw) | |||
717 | brcms_c_write_mhf(wlc_hw, wlc_hw->band->mhfs); | 717 | brcms_c_write_mhf(wlc_hw, wlc_hw->band->mhfs); |
718 | 718 | ||
719 | /* do band-specific ucode IHR, SHM, and SCR inits */ | 719 | /* do band-specific ucode IHR, SHM, and SCR inits */ |
720 | if (D11REV_IS(wlc_hw->corerev, 23)) { | 720 | if (D11REV_IS(wlc_hw->corerev, 17) || D11REV_IS(wlc_hw->corerev, 23)) { |
721 | if (BRCMS_ISNPHY(wlc_hw->band)) | 721 | if (BRCMS_ISNPHY(wlc_hw->band)) |
722 | brcms_c_write_inits(wlc_hw, ucode->d11n0bsinitvals16); | 722 | brcms_c_write_inits(wlc_hw, ucode->d11n0bsinitvals16); |
723 | else | 723 | else |
@@ -2264,7 +2264,7 @@ static void brcms_ucode_download(struct brcms_hardware *wlc_hw) | |||
2264 | if (wlc_hw->ucode_loaded) | 2264 | if (wlc_hw->ucode_loaded) |
2265 | return; | 2265 | return; |
2266 | 2266 | ||
2267 | if (D11REV_IS(wlc_hw->corerev, 23)) { | 2267 | if (D11REV_IS(wlc_hw->corerev, 17) || D11REV_IS(wlc_hw->corerev, 23)) { |
2268 | if (BRCMS_ISNPHY(wlc_hw->band)) { | 2268 | if (BRCMS_ISNPHY(wlc_hw->band)) { |
2269 | brcms_ucode_write(wlc_hw, ucode->bcm43xx_16_mimo, | 2269 | brcms_ucode_write(wlc_hw, ucode->bcm43xx_16_mimo, |
2270 | ucode->bcm43xx_16_mimosz); | 2270 | ucode->bcm43xx_16_mimosz); |
@@ -3216,7 +3216,7 @@ static void brcms_b_coreinit(struct brcms_c_info *wlc) | |||
3216 | 3216 | ||
3217 | sflags = bcma_aread32(core, BCMA_IOST); | 3217 | sflags = bcma_aread32(core, BCMA_IOST); |
3218 | 3218 | ||
3219 | if (D11REV_IS(wlc_hw->corerev, 23)) { | 3219 | if (D11REV_IS(wlc_hw->corerev, 17) || D11REV_IS(wlc_hw->corerev, 23)) { |
3220 | if (BRCMS_ISNPHY(wlc_hw->band)) | 3220 | if (BRCMS_ISNPHY(wlc_hw->band)) |
3221 | brcms_c_write_inits(wlc_hw, ucode->d11n0initvals16); | 3221 | brcms_c_write_inits(wlc_hw, ucode->d11n0initvals16); |
3222 | else | 3222 | else |