xref: /freebsd/sys/contrib/dev/broadcom/brcm80211/brcmsmac/ucode_loader.c (revision b4c3e9b5b09c829b4135aff738bd2893ed052377)
1*b4c3e9b5SBjoern A. Zeeb /*
2*b4c3e9b5SBjoern A. Zeeb  * Copyright (c) 2010 Broadcom Corporation
3*b4c3e9b5SBjoern A. Zeeb  *
4*b4c3e9b5SBjoern A. Zeeb  * Permission to use, copy, modify, and/or distribute this software for any
5*b4c3e9b5SBjoern A. Zeeb  * purpose with or without fee is hereby granted, provided that the above
6*b4c3e9b5SBjoern A. Zeeb  * copyright notice and this permission notice appear in all copies.
7*b4c3e9b5SBjoern A. Zeeb  *
8*b4c3e9b5SBjoern A. Zeeb  * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
9*b4c3e9b5SBjoern A. Zeeb  * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
10*b4c3e9b5SBjoern A. Zeeb  * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY
11*b4c3e9b5SBjoern A. Zeeb  * SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
12*b4c3e9b5SBjoern A. Zeeb  * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION
13*b4c3e9b5SBjoern A. Zeeb  * OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN
14*b4c3e9b5SBjoern A. Zeeb  * CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
15*b4c3e9b5SBjoern A. Zeeb  */
16*b4c3e9b5SBjoern A. Zeeb 
17*b4c3e9b5SBjoern A. Zeeb #include <defs.h>
18*b4c3e9b5SBjoern A. Zeeb #include "types.h"
19*b4c3e9b5SBjoern A. Zeeb #include <ucode_loader.h>
20*b4c3e9b5SBjoern A. Zeeb 
21*b4c3e9b5SBjoern A. Zeeb enum {
22*b4c3e9b5SBjoern A. Zeeb 	D11UCODE_NAMETAG_START = 0,
23*b4c3e9b5SBjoern A. Zeeb 	D11LCN0BSINITVALS24,
24*b4c3e9b5SBjoern A. Zeeb 	D11LCN0INITVALS24,
25*b4c3e9b5SBjoern A. Zeeb 	D11LCN1BSINITVALS24,
26*b4c3e9b5SBjoern A. Zeeb 	D11LCN1INITVALS24,
27*b4c3e9b5SBjoern A. Zeeb 	D11LCN2BSINITVALS24,
28*b4c3e9b5SBjoern A. Zeeb 	D11LCN2INITVALS24,
29*b4c3e9b5SBjoern A. Zeeb 	D11N0ABSINITVALS16,
30*b4c3e9b5SBjoern A. Zeeb 	D11N0BSINITVALS16,
31*b4c3e9b5SBjoern A. Zeeb 	D11N0INITVALS16,
32*b4c3e9b5SBjoern A. Zeeb 	D11UCODE_OVERSIGHT16_MIMO,
33*b4c3e9b5SBjoern A. Zeeb 	D11UCODE_OVERSIGHT16_MIMOSZ,
34*b4c3e9b5SBjoern A. Zeeb 	D11UCODE_OVERSIGHT24_LCN,
35*b4c3e9b5SBjoern A. Zeeb 	D11UCODE_OVERSIGHT24_LCNSZ,
36*b4c3e9b5SBjoern A. Zeeb 	D11UCODE_OVERSIGHT_BOMMAJOR,
37*b4c3e9b5SBjoern A. Zeeb 	D11UCODE_OVERSIGHT_BOMMINOR
38*b4c3e9b5SBjoern A. Zeeb };
39*b4c3e9b5SBjoern A. Zeeb 
brcms_ucode_data_init(struct brcms_info * wl,struct brcms_ucode * ucode)40*b4c3e9b5SBjoern A. Zeeb int brcms_ucode_data_init(struct brcms_info *wl, struct brcms_ucode *ucode)
41*b4c3e9b5SBjoern A. Zeeb {
42*b4c3e9b5SBjoern A. Zeeb 	int rc;
43*b4c3e9b5SBjoern A. Zeeb 
44*b4c3e9b5SBjoern A. Zeeb 	rc = brcms_check_firmwares(wl);
45*b4c3e9b5SBjoern A. Zeeb 
46*b4c3e9b5SBjoern A. Zeeb 	rc = rc < 0 ? rc :
47*b4c3e9b5SBjoern A. Zeeb 		brcms_ucode_init_buf(wl, (void **)&ucode->d11lcn0bsinitvals24,
48*b4c3e9b5SBjoern A. Zeeb 				     D11LCN0BSINITVALS24);
49*b4c3e9b5SBjoern A. Zeeb 	rc = rc < 0 ?
50*b4c3e9b5SBjoern A. Zeeb 	     rc : brcms_ucode_init_buf(wl, (void **)&ucode->d11lcn0initvals24,
51*b4c3e9b5SBjoern A. Zeeb 				       D11LCN0INITVALS24);
52*b4c3e9b5SBjoern A. Zeeb 	rc = rc < 0 ?
53*b4c3e9b5SBjoern A. Zeeb 	     rc : brcms_ucode_init_buf(wl, (void **)&ucode->d11lcn1bsinitvals24,
54*b4c3e9b5SBjoern A. Zeeb 				       D11LCN1BSINITVALS24);
55*b4c3e9b5SBjoern A. Zeeb 	rc = rc < 0 ?
56*b4c3e9b5SBjoern A. Zeeb 	     rc : brcms_ucode_init_buf(wl, (void **)&ucode->d11lcn1initvals24,
57*b4c3e9b5SBjoern A. Zeeb 				       D11LCN1INITVALS24);
58*b4c3e9b5SBjoern A. Zeeb 	rc = rc < 0 ? rc :
59*b4c3e9b5SBjoern A. Zeeb 		brcms_ucode_init_buf(wl, (void **)&ucode->d11lcn2bsinitvals24,
60*b4c3e9b5SBjoern A. Zeeb 				     D11LCN2BSINITVALS24);
61*b4c3e9b5SBjoern A. Zeeb 	rc = rc < 0 ?
62*b4c3e9b5SBjoern A. Zeeb 	     rc : brcms_ucode_init_buf(wl, (void **)&ucode->d11lcn2initvals24,
63*b4c3e9b5SBjoern A. Zeeb 				       D11LCN2INITVALS24);
64*b4c3e9b5SBjoern A. Zeeb 	rc = rc < 0 ?
65*b4c3e9b5SBjoern A. Zeeb 	     rc : brcms_ucode_init_buf(wl, (void **)&ucode->d11n0absinitvals16,
66*b4c3e9b5SBjoern A. Zeeb 				       D11N0ABSINITVALS16);
67*b4c3e9b5SBjoern A. Zeeb 	rc = rc < 0 ?
68*b4c3e9b5SBjoern A. Zeeb 	     rc : brcms_ucode_init_buf(wl, (void **)&ucode->d11n0bsinitvals16,
69*b4c3e9b5SBjoern A. Zeeb 				       D11N0BSINITVALS16);
70*b4c3e9b5SBjoern A. Zeeb 	rc = rc < 0 ?
71*b4c3e9b5SBjoern A. Zeeb 	     rc : brcms_ucode_init_buf(wl, (void **)&ucode->d11n0initvals16,
72*b4c3e9b5SBjoern A. Zeeb 				       D11N0INITVALS16);
73*b4c3e9b5SBjoern A. Zeeb 	rc = rc < 0 ?
74*b4c3e9b5SBjoern A. Zeeb 	     rc : brcms_ucode_init_buf(wl, (void **)&ucode->bcm43xx_16_mimo,
75*b4c3e9b5SBjoern A. Zeeb 				       D11UCODE_OVERSIGHT16_MIMO);
76*b4c3e9b5SBjoern A. Zeeb 	rc = rc < 0 ?
77*b4c3e9b5SBjoern A. Zeeb 	     rc : brcms_ucode_init_uint(wl, &ucode->bcm43xx_16_mimosz,
78*b4c3e9b5SBjoern A. Zeeb 					D11UCODE_OVERSIGHT16_MIMOSZ);
79*b4c3e9b5SBjoern A. Zeeb 	rc = rc < 0 ?
80*b4c3e9b5SBjoern A. Zeeb 	     rc : brcms_ucode_init_buf(wl, (void **)&ucode->bcm43xx_24_lcn,
81*b4c3e9b5SBjoern A. Zeeb 				       D11UCODE_OVERSIGHT24_LCN);
82*b4c3e9b5SBjoern A. Zeeb 	rc = rc < 0 ?
83*b4c3e9b5SBjoern A. Zeeb 	     rc : brcms_ucode_init_uint(wl, &ucode->bcm43xx_24_lcnsz,
84*b4c3e9b5SBjoern A. Zeeb 					D11UCODE_OVERSIGHT24_LCNSZ);
85*b4c3e9b5SBjoern A. Zeeb 	rc = rc < 0 ?
86*b4c3e9b5SBjoern A. Zeeb 	     rc : brcms_ucode_init_buf(wl, (void **)&ucode->bcm43xx_bommajor,
87*b4c3e9b5SBjoern A. Zeeb 				       D11UCODE_OVERSIGHT_BOMMAJOR);
88*b4c3e9b5SBjoern A. Zeeb 	rc = rc < 0 ?
89*b4c3e9b5SBjoern A. Zeeb 	     rc : brcms_ucode_init_buf(wl, (void **)&ucode->bcm43xx_bomminor,
90*b4c3e9b5SBjoern A. Zeeb 				       D11UCODE_OVERSIGHT_BOMMINOR);
91*b4c3e9b5SBjoern A. Zeeb 	return rc;
92*b4c3e9b5SBjoern A. Zeeb }
93*b4c3e9b5SBjoern A. Zeeb 
brcms_ucode_data_free(struct brcms_ucode * ucode)94*b4c3e9b5SBjoern A. Zeeb void brcms_ucode_data_free(struct brcms_ucode *ucode)
95*b4c3e9b5SBjoern A. Zeeb {
96*b4c3e9b5SBjoern A. Zeeb 	brcms_ucode_free_buf((void *)ucode->d11lcn0bsinitvals24);
97*b4c3e9b5SBjoern A. Zeeb 	brcms_ucode_free_buf((void *)ucode->d11lcn0initvals24);
98*b4c3e9b5SBjoern A. Zeeb 	brcms_ucode_free_buf((void *)ucode->d11lcn1bsinitvals24);
99*b4c3e9b5SBjoern A. Zeeb 	brcms_ucode_free_buf((void *)ucode->d11lcn1initvals24);
100*b4c3e9b5SBjoern A. Zeeb 	brcms_ucode_free_buf((void *)ucode->d11lcn2bsinitvals24);
101*b4c3e9b5SBjoern A. Zeeb 	brcms_ucode_free_buf((void *)ucode->d11lcn2initvals24);
102*b4c3e9b5SBjoern A. Zeeb 	brcms_ucode_free_buf((void *)ucode->d11n0absinitvals16);
103*b4c3e9b5SBjoern A. Zeeb 	brcms_ucode_free_buf((void *)ucode->d11n0bsinitvals16);
104*b4c3e9b5SBjoern A. Zeeb 	brcms_ucode_free_buf((void *)ucode->d11n0initvals16);
105*b4c3e9b5SBjoern A. Zeeb 	brcms_ucode_free_buf((void *)ucode->bcm43xx_16_mimo);
106*b4c3e9b5SBjoern A. Zeeb 	brcms_ucode_free_buf((void *)ucode->bcm43xx_24_lcn);
107*b4c3e9b5SBjoern A. Zeeb 	brcms_ucode_free_buf((void *)ucode->bcm43xx_bommajor);
108*b4c3e9b5SBjoern A. Zeeb 	brcms_ucode_free_buf((void *)ucode->bcm43xx_bomminor);
109*b4c3e9b5SBjoern A. Zeeb }
110