|
@@ -37,80 +37,73 @@ enum {
|
|
|
D11UCODE_OVERSIGHT_BOMMINOR
|
|
|
};
|
|
|
|
|
|
-struct d11init *d11lcn0bsinitvals24;
|
|
|
-struct d11init *d11lcn0initvals24;
|
|
|
-struct d11init *d11lcn1bsinitvals24;
|
|
|
-struct d11init *d11lcn1initvals24;
|
|
|
-struct d11init *d11lcn2bsinitvals24;
|
|
|
-struct d11init *d11lcn2initvals24;
|
|
|
-struct d11init *d11n0absinitvals16;
|
|
|
-struct d11init *d11n0bsinitvals16;
|
|
|
-struct d11init *d11n0initvals16;
|
|
|
-u32 *bcm43xx_16_mimo;
|
|
|
-u32 bcm43xx_16_mimosz;
|
|
|
-u32 *bcm43xx_24_lcn;
|
|
|
-u32 bcm43xx_24_lcnsz;
|
|
|
-
|
|
|
-static u32 *bcm43xx_bommajor;
|
|
|
-static u32 *bcm43xx_bomminor;
|
|
|
-
|
|
|
-int brcms_ucode_data_init(struct brcms_info *wl)
|
|
|
+int brcms_ucode_data_init(struct brcms_info *wl, struct brcms_ucode *ucode)
|
|
|
{
|
|
|
int rc;
|
|
|
+
|
|
|
rc = brcms_check_firmwares(wl);
|
|
|
|
|
|
rc = rc < 0 ? rc :
|
|
|
- brcms_ucode_init_buf(wl, (void **)&d11lcn0bsinitvals24,
|
|
|
+ brcms_ucode_init_buf(wl, (void **)&ucode->d11lcn0bsinitvals24,
|
|
|
D11LCN0BSINITVALS24);
|
|
|
- rc = rc < 0 ? rc : brcms_ucode_init_buf(wl, (void **)&d11lcn0initvals24,
|
|
|
- D11LCN0INITVALS24);
|
|
|
+ rc = rc < 0 ?
|
|
|
+ rc : brcms_ucode_init_buf(wl, (void **)&ucode->d11lcn0initvals24,
|
|
|
+ D11LCN0INITVALS24);
|
|
|
+ rc = rc < 0 ?
|
|
|
+ rc : brcms_ucode_init_buf(wl, (void **)&ucode->d11lcn1bsinitvals24,
|
|
|
+ D11LCN1BSINITVALS24);
|
|
|
+ rc = rc < 0 ?
|
|
|
+ rc : brcms_ucode_init_buf(wl, (void **)&ucode->d11lcn1initvals24,
|
|
|
+ D11LCN1INITVALS24);
|
|
|
rc = rc < 0 ? rc :
|
|
|
- brcms_ucode_init_buf(wl, (void **)&d11lcn1bsinitvals24,
|
|
|
- D11LCN1BSINITVALS24);
|
|
|
- rc = rc < 0 ? rc : brcms_ucode_init_buf(wl, (void **)&d11lcn1initvals24,
|
|
|
- D11LCN1INITVALS24);
|
|
|
- rc = rc < 0 ? rc :
|
|
|
- brcms_ucode_init_buf(wl, (void **)&d11lcn2bsinitvals24,
|
|
|
+ brcms_ucode_init_buf(wl, (void **)&ucode->d11lcn2bsinitvals24,
|
|
|
D11LCN2BSINITVALS24);
|
|
|
- rc = rc < 0 ? rc : brcms_ucode_init_buf(wl, (void **)&d11lcn2initvals24,
|
|
|
- D11LCN2INITVALS24);
|
|
|
- rc = rc < 0 ? rc :
|
|
|
- brcms_ucode_init_buf(wl, (void **)&d11n0absinitvals16,
|
|
|
- D11N0ABSINITVALS16);
|
|
|
- rc = rc < 0 ? rc : brcms_ucode_init_buf(wl, (void **)&d11n0bsinitvals16,
|
|
|
- D11N0BSINITVALS16);
|
|
|
- rc = rc < 0 ? rc : brcms_ucode_init_buf(wl, (void **)&d11n0initvals16,
|
|
|
- D11N0INITVALS16);
|
|
|
- rc = rc < 0 ? rc : brcms_ucode_init_buf(wl, (void **)&bcm43xx_16_mimo,
|
|
|
- D11UCODE_OVERSIGHT16_MIMO);
|
|
|
- rc = rc < 0 ? rc : brcms_ucode_init_uint(wl, &bcm43xx_16_mimosz,
|
|
|
- D11UCODE_OVERSIGHT16_MIMOSZ);
|
|
|
- rc = rc < 0 ? rc : brcms_ucode_init_buf(wl, (void **)&bcm43xx_24_lcn,
|
|
|
- D11UCODE_OVERSIGHT24_LCN);
|
|
|
- rc = rc < 0 ? rc : brcms_ucode_init_uint(wl, &bcm43xx_24_lcnsz,
|
|
|
- D11UCODE_OVERSIGHT24_LCNSZ);
|
|
|
- rc = rc < 0 ? rc : brcms_ucode_init_buf(wl, (void **)&bcm43xx_bommajor,
|
|
|
- D11UCODE_OVERSIGHT_BOMMAJOR);
|
|
|
- rc = rc < 0 ? rc : brcms_ucode_init_buf(wl, (void **)&bcm43xx_bomminor,
|
|
|
- D11UCODE_OVERSIGHT_BOMMINOR);
|
|
|
+ rc = rc < 0 ?
|
|
|
+ rc : brcms_ucode_init_buf(wl, (void **)&ucode->d11lcn2initvals24,
|
|
|
+ D11LCN2INITVALS24);
|
|
|
+ rc = rc < 0 ?
|
|
|
+ rc : brcms_ucode_init_buf(wl, (void **)&ucode->d11n0absinitvals16,
|
|
|
+ D11N0ABSINITVALS16);
|
|
|
+ rc = rc < 0 ?
|
|
|
+ rc : brcms_ucode_init_buf(wl, (void **)&ucode->d11n0bsinitvals16,
|
|
|
+ D11N0BSINITVALS16);
|
|
|
+ rc = rc < 0 ?
|
|
|
+ rc : brcms_ucode_init_buf(wl, (void **)&ucode->d11n0initvals16,
|
|
|
+ D11N0INITVALS16);
|
|
|
+ rc = rc < 0 ?
|
|
|
+ rc : brcms_ucode_init_buf(wl, (void **)&ucode->bcm43xx_16_mimo,
|
|
|
+ D11UCODE_OVERSIGHT16_MIMO);
|
|
|
+ rc = rc < 0 ?
|
|
|
+ rc : brcms_ucode_init_uint(wl, &ucode->bcm43xx_16_mimosz,
|
|
|
+ D11UCODE_OVERSIGHT16_MIMOSZ);
|
|
|
+ rc = rc < 0 ?
|
|
|
+ rc : brcms_ucode_init_buf(wl, (void **)&ucode->bcm43xx_24_lcn,
|
|
|
+ D11UCODE_OVERSIGHT24_LCN);
|
|
|
+ rc = rc < 0 ?
|
|
|
+ rc : brcms_ucode_init_uint(wl, &ucode->bcm43xx_24_lcnsz,
|
|
|
+ D11UCODE_OVERSIGHT24_LCNSZ);
|
|
|
+ rc = rc < 0 ?
|
|
|
+ rc : brcms_ucode_init_buf(wl, (void **)&ucode->bcm43xx_bommajor,
|
|
|
+ D11UCODE_OVERSIGHT_BOMMAJOR);
|
|
|
+ rc = rc < 0 ?
|
|
|
+ rc : brcms_ucode_init_buf(wl, (void **)&ucode->bcm43xx_bomminor,
|
|
|
+ D11UCODE_OVERSIGHT_BOMMINOR);
|
|
|
return rc;
|
|
|
}
|
|
|
|
|
|
-void brcms_ucode_data_free(void)
|
|
|
+void brcms_ucode_data_free(struct brcms_ucode *ucode)
|
|
|
{
|
|
|
- brcms_ucode_free_buf((void *)d11lcn0bsinitvals24);
|
|
|
- brcms_ucode_free_buf((void *)d11lcn0initvals24);
|
|
|
- brcms_ucode_free_buf((void *)d11lcn1bsinitvals24);
|
|
|
- brcms_ucode_free_buf((void *)d11lcn1initvals24);
|
|
|
- brcms_ucode_free_buf((void *)d11lcn2bsinitvals24);
|
|
|
- brcms_ucode_free_buf((void *)d11lcn2initvals24);
|
|
|
- brcms_ucode_free_buf((void *)d11n0absinitvals16);
|
|
|
- brcms_ucode_free_buf((void *)d11n0bsinitvals16);
|
|
|
- brcms_ucode_free_buf((void *)d11n0initvals16);
|
|
|
- brcms_ucode_free_buf((void *)bcm43xx_16_mimo);
|
|
|
- brcms_ucode_free_buf((void *)bcm43xx_24_lcn);
|
|
|
- brcms_ucode_free_buf((void *)bcm43xx_bommajor);
|
|
|
- brcms_ucode_free_buf((void *)bcm43xx_bomminor);
|
|
|
-
|
|
|
- return;
|
|
|
+ brcms_ucode_free_buf((void *)ucode->d11lcn0bsinitvals24);
|
|
|
+ brcms_ucode_free_buf((void *)ucode->d11lcn0initvals24);
|
|
|
+ brcms_ucode_free_buf((void *)ucode->d11lcn1bsinitvals24);
|
|
|
+ brcms_ucode_free_buf((void *)ucode->d11lcn1initvals24);
|
|
|
+ brcms_ucode_free_buf((void *)ucode->d11lcn2bsinitvals24);
|
|
|
+ brcms_ucode_free_buf((void *)ucode->d11lcn2initvals24);
|
|
|
+ brcms_ucode_free_buf((void *)ucode->d11n0absinitvals16);
|
|
|
+ brcms_ucode_free_buf((void *)ucode->d11n0bsinitvals16);
|
|
|
+ brcms_ucode_free_buf((void *)ucode->d11n0initvals16);
|
|
|
+ brcms_ucode_free_buf((void *)ucode->bcm43xx_16_mimo);
|
|
|
+ brcms_ucode_free_buf((void *)ucode->bcm43xx_24_lcn);
|
|
|
+ brcms_ucode_free_buf((void *)ucode->bcm43xx_bommajor);
|
|
|
+ brcms_ucode_free_buf((void *)ucode->bcm43xx_bomminor);
|
|
|
}
|