Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
L
linux
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
linux
Commits
d1a9421d
Commit
d1a9421d
authored
Nov 14, 2011
by
Kalle Valo
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
ath6kl: add firmware filename info to struct ath6kl_hw
Signed-off-by:
Kalle Valo
<
kvalo@qca.qualcomm.com
>
parent
f0ea5d58
Changes
2
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
67 additions
and
90 deletions
+67
-90
drivers/net/wireless/ath/ath6kl/core.h
drivers/net/wireless/ath/ath6kl/core.h
+8
-0
drivers/net/wireless/ath/ath6kl/init.c
drivers/net/wireless/ath/ath6kl/init.c
+59
-90
No files found.
drivers/net/wireless/ath/ath6kl/core.h
View file @
d1a9421d
...
@@ -553,6 +553,14 @@ struct ath6kl {
...
@@ -553,6 +553,14 @@ struct ath6kl {
u32
board_ext_data_addr
;
u32
board_ext_data_addr
;
u32
reserved_ram_size
;
u32
reserved_ram_size
;
u32
board_addr
;
u32
board_addr
;
const
char
*
fw_otp
;
const
char
*
fw
;
const
char
*
fw_tcmd
;
const
char
*
fw_patch
;
const
char
*
fw_api2
;
const
char
*
fw_board
;
const
char
*
fw_default_board
;
}
hw
;
}
hw
;
u16
conf_flags
;
u16
conf_flags
;
...
...
drivers/net/wireless/ath/ath6kl/init.c
View file @
d1a9421d
...
@@ -44,6 +44,14 @@ static const struct ath6kl_hw hw_list[] = {
...
@@ -44,6 +44,14 @@ static const struct ath6kl_hw hw_list[] = {
/* hw2.0 needs override address hardcoded */
/* hw2.0 needs override address hardcoded */
.
app_start_override_addr
=
0x944C00
,
.
app_start_override_addr
=
0x944C00
,
.
fw_otp
=
AR6003_HW_2_0_OTP_FILE
,
.
fw
=
AR6003_HW_2_0_FIRMWARE_FILE
,
.
fw_tcmd
=
AR6003_HW_2_0_TCMD_FIRMWARE_FILE
,
.
fw_patch
=
AR6003_HW_2_0_PATCH_FILE
,
.
fw_api2
=
AR6003_HW_2_0_FIRMWARE_2_FILE
,
.
fw_board
=
AR6003_HW_2_0_BOARD_DATA_FILE
,
.
fw_default_board
=
AR6003_HW_2_0_DEFAULT_BOARD_DATA_FILE
,
},
},
{
{
.
id
=
AR6003_HW_2_1_1_VERSION
,
.
id
=
AR6003_HW_2_1_1_VERSION
,
...
@@ -52,6 +60,14 @@ static const struct ath6kl_hw hw_list[] = {
...
@@ -52,6 +60,14 @@ static const struct ath6kl_hw hw_list[] = {
.
app_load_addr
=
0x1234
,
.
app_load_addr
=
0x1234
,
.
board_ext_data_addr
=
0x542330
,
.
board_ext_data_addr
=
0x542330
,
.
reserved_ram_size
=
512
,
.
reserved_ram_size
=
512
,
.
fw_otp
=
AR6003_HW_2_1_1_OTP_FILE
,
.
fw
=
AR6003_HW_2_1_1_FIRMWARE_FILE
,
.
fw_tcmd
=
AR6003_HW_2_1_1_TCMD_FIRMWARE_FILE
,
.
fw_patch
=
AR6003_HW_2_1_1_PATCH_FILE
,
.
fw_api2
=
AR6003_HW_2_1_1_FIRMWARE_2_FILE
,
.
fw_board
=
AR6003_HW_2_1_1_BOARD_DATA_FILE
,
.
fw_default_board
=
AR6003_HW_2_1_1_DEFAULT_BOARD_DATA_FILE
,
},
},
{
{
.
id
=
AR6004_HW_1_0_VERSION
,
.
id
=
AR6004_HW_1_0_VERSION
,
...
@@ -61,6 +77,11 @@ static const struct ath6kl_hw hw_list[] = {
...
@@ -61,6 +77,11 @@ static const struct ath6kl_hw hw_list[] = {
.
board_ext_data_addr
=
0x437000
,
.
board_ext_data_addr
=
0x437000
,
.
reserved_ram_size
=
19456
,
.
reserved_ram_size
=
19456
,
.
board_addr
=
0x433900
,
.
board_addr
=
0x433900
,
.
fw
=
AR6004_HW_1_0_FIRMWARE_FILE
,
.
fw_api2
=
AR6004_HW_1_0_FIRMWARE_2_FILE
,
.
fw_board
=
AR6004_HW_1_0_BOARD_DATA_FILE
,
.
fw_default_board
=
AR6004_HW_1_0_DEFAULT_BOARD_DATA_FILE
,
},
},
{
{
.
id
=
AR6004_HW_1_1_VERSION
,
.
id
=
AR6004_HW_1_1_VERSION
,
...
@@ -70,6 +91,11 @@ static const struct ath6kl_hw hw_list[] = {
...
@@ -70,6 +91,11 @@ static const struct ath6kl_hw hw_list[] = {
.
board_ext_data_addr
=
0x437000
,
.
board_ext_data_addr
=
0x437000
,
.
reserved_ram_size
=
11264
,
.
reserved_ram_size
=
11264
,
.
board_addr
=
0x43d400
,
.
board_addr
=
0x43d400
,
.
fw
=
AR6004_HW_1_1_FIRMWARE_FILE
,
.
fw_api2
=
AR6004_HW_1_1_FIRMWARE_2_FILE
,
.
fw_board
=
AR6004_HW_1_1_BOARD_DATA_FILE
,
.
fw_default_board
=
AR6004_HW_1_1_DEFAULT_BOARD_DATA_FILE
,
},
},
};
};
...
@@ -652,17 +678,10 @@ static int ath6kl_fetch_board_file(struct ath6kl *ar)
...
@@ -652,17 +678,10 @@ static int ath6kl_fetch_board_file(struct ath6kl *ar)
if
(
ar
->
fw_board
!=
NULL
)
if
(
ar
->
fw_board
!=
NULL
)
return
0
;
return
0
;
switch
(
ar
->
version
.
target_ver
)
{
if
(
WARN_ON
(
ar
->
hw
.
fw_board
==
NULL
))
case
AR6003_HW_2_0_VERSION
:
return
-
EINVAL
;
filename
=
AR6003_HW_2_0_BOARD_DATA_FILE
;
break
;
filename
=
ar
->
hw
.
fw_board
;
case
AR6004_HW_1_0_VERSION
:
filename
=
AR6004_HW_1_0_BOARD_DATA_FILE
;
break
;
default:
filename
=
AR6003_HW_2_1_1_BOARD_DATA_FILE
;
break
;
}
ret
=
ath6kl_get_fw
(
ar
,
filename
,
&
ar
->
fw_board
,
ret
=
ath6kl_get_fw
(
ar
,
filename
,
&
ar
->
fw_board
,
&
ar
->
fw_board_len
);
&
ar
->
fw_board_len
);
...
@@ -680,17 +699,7 @@ static int ath6kl_fetch_board_file(struct ath6kl *ar)
...
@@ -680,17 +699,7 @@ static int ath6kl_fetch_board_file(struct ath6kl *ar)
ath6kl_warn
(
"Failed to get board file %s (%d), trying to find default board file.
\n
"
,
ath6kl_warn
(
"Failed to get board file %s (%d), trying to find default board file.
\n
"
,
filename
,
ret
);
filename
,
ret
);
switch
(
ar
->
version
.
target_ver
)
{
filename
=
ar
->
hw
.
fw_default_board
;
case
AR6003_HW_2_0_VERSION
:
filename
=
AR6003_HW_2_0_DEFAULT_BOARD_DATA_FILE
;
break
;
case
AR6004_HW_1_0_VERSION
:
filename
=
AR6004_HW_1_0_DEFAULT_BOARD_DATA_FILE
;
break
;
default:
filename
=
AR6003_HW_2_1_1_DEFAULT_BOARD_DATA_FILE
;
break
;
}
ret
=
ath6kl_get_fw
(
ar
,
filename
,
&
ar
->
fw_board
,
ret
=
ath6kl_get_fw
(
ar
,
filename
,
&
ar
->
fw_board
,
&
ar
->
fw_board_len
);
&
ar
->
fw_board_len
);
...
@@ -714,19 +723,14 @@ static int ath6kl_fetch_otp_file(struct ath6kl *ar)
...
@@ -714,19 +723,14 @@ static int ath6kl_fetch_otp_file(struct ath6kl *ar)
if
(
ar
->
fw_otp
!=
NULL
)
if
(
ar
->
fw_otp
!=
NULL
)
return
0
;
return
0
;
switch
(
ar
->
version
.
target_ver
)
{
if
(
ar
->
hw
.
fw_otp
==
NULL
)
{
case
AR6003_HW_2_0_VERSION
:
ath6kl_dbg
(
ATH6KL_DBG_BOOT
,
filename
=
AR6003_HW_2_0_OTP_FILE
;
"no OTP file configured for this hw
\n
"
);
break
;
case
AR6004_HW_1_0_VERSION
:
ath6kl_dbg
(
ATH6KL_DBG_TRC
,
"AR6004 doesn't need OTP file
\n
"
);
return
0
;
return
0
;
break
;
default:
filename
=
AR6003_HW_2_1_1_OTP_FILE
;
break
;
}
}
filename
=
ar
->
hw
.
fw_otp
;
ret
=
ath6kl_get_fw
(
ar
,
filename
,
&
ar
->
fw_otp
,
ret
=
ath6kl_get_fw
(
ar
,
filename
,
&
ar
->
fw_otp
,
&
ar
->
fw_otp_len
);
&
ar
->
fw_otp_len
);
if
(
ret
)
{
if
(
ret
)
{
...
@@ -747,38 +751,22 @@ static int ath6kl_fetch_fw_file(struct ath6kl *ar)
...
@@ -747,38 +751,22 @@ static int ath6kl_fetch_fw_file(struct ath6kl *ar)
return
0
;
return
0
;
if
(
testmode
)
{
if
(
testmode
)
{
switch
(
ar
->
version
.
target_ver
)
{
if
(
ar
->
hw
.
fw_tcmd
==
NULL
)
{
case
AR6003_HW_2_0_VERSION
:
ath6kl_warn
(
"testmode not supported
\n
"
);
filename
=
AR6003_HW_2_0_TCMD_FIRMWARE_FILE
;
break
;
case
AR6003_HW_2_1_1_VERSION
:
filename
=
AR6003_HW_2_1_1_TCMD_FIRMWARE_FILE
;
break
;
case
AR6004_HW_1_0_VERSION
:
ath6kl_warn
(
"testmode not supported with ar6004
\n
"
);
return
-
EOPNOTSUPP
;
return
-
EOPNOTSUPP
;
default:
ath6kl_warn
(
"unknown target version: 0x%x
\n
"
,
ar
->
version
.
target_ver
);
return
-
EINVAL
;
}
}
filename
=
ar
->
hw
.
fw_tcmd
;
set_bit
(
TESTMODE
,
&
ar
->
flag
);
set_bit
(
TESTMODE
,
&
ar
->
flag
);
goto
get_fw
;
goto
get_fw
;
}
}
switch
(
ar
->
version
.
target_ver
)
{
if
(
WARN_ON
(
ar
->
hw
.
fw
==
NULL
))
case
AR6003_HW_2_0_VERSION
:
return
-
EINVAL
;
filename
=
AR6003_HW_2_0_FIRMWARE_FILE
;
break
;
filename
=
ar
->
hw
.
fw
;
case
AR6004_HW_1_0_VERSION
:
filename
=
AR6004_HW_1_0_FIRMWARE_FILE
;
break
;
default:
filename
=
AR6003_HW_2_1_1_FIRMWARE_FILE
;
break
;
}
get_fw:
get_fw:
ret
=
ath6kl_get_fw
(
ar
,
filename
,
&
ar
->
fw
,
&
ar
->
fw_len
);
ret
=
ath6kl_get_fw
(
ar
,
filename
,
&
ar
->
fw
,
&
ar
->
fw_len
);
...
@@ -796,20 +784,14 @@ static int ath6kl_fetch_patch_file(struct ath6kl *ar)
...
@@ -796,20 +784,14 @@ static int ath6kl_fetch_patch_file(struct ath6kl *ar)
const
char
*
filename
;
const
char
*
filename
;
int
ret
;
int
ret
;
switch
(
ar
->
version
.
target_ver
)
{
if
(
ar
->
fw_patch
!=
NULL
)
case
AR6003_HW_2_0_VERSION
:
filename
=
AR6003_HW_2_0_PATCH_FILE
;
break
;
case
AR6004_HW_1_0_VERSION
:
/* FIXME: implement for AR6004 */
return
0
;
return
0
;
break
;
default:
filename
=
AR6003_HW_2_1_1_PATCH_FILE
;
break
;
}
if
(
ar
->
fw_patch
==
NULL
)
{
if
(
ar
->
hw
.
fw_patch
==
NULL
)
return
0
;
filename
=
ar
->
hw
.
fw_patch
;
ret
=
ath6kl_get_fw
(
ar
,
filename
,
&
ar
->
fw_patch
,
ret
=
ath6kl_get_fw
(
ar
,
filename
,
&
ar
->
fw_patch
,
&
ar
->
fw_patch_len
);
&
ar
->
fw_patch_len
);
if
(
ret
)
{
if
(
ret
)
{
...
@@ -817,7 +799,6 @@ static int ath6kl_fetch_patch_file(struct ath6kl *ar)
...
@@ -817,7 +799,6 @@ static int ath6kl_fetch_patch_file(struct ath6kl *ar)
filename
,
ret
);
filename
,
ret
);
return
ret
;
return
ret
;
}
}
}
return
0
;
return
0
;
}
}
...
@@ -851,22 +832,10 @@ static int ath6kl_fetch_fw_api2(struct ath6kl *ar)
...
@@ -851,22 +832,10 @@ static int ath6kl_fetch_fw_api2(struct ath6kl *ar)
int
ret
,
ie_id
,
i
,
index
,
bit
;
int
ret
,
ie_id
,
i
,
index
,
bit
;
__le32
*
val
;
__le32
*
val
;
switch
(
ar
->
version
.
target_ver
)
{
if
(
ar
->
hw
.
fw_api2
==
NULL
)
case
AR6003_HW_2_0_VERSION
:
filename
=
AR6003_HW_2_0_FIRMWARE_2_FILE
;
break
;
case
AR6003_HW_2_1_1_VERSION
:
filename
=
AR6003_HW_2_1_1_FIRMWARE_2_FILE
;
break
;
case
AR6004_HW_1_0_VERSION
:
filename
=
AR6004_HW_1_0_FIRMWARE_2_FILE
;
break
;
case
AR6004_HW_1_1_VERSION
:
filename
=
AR6004_HW_1_1_FIRMWARE_2_FILE
;
break
;
default:
return
-
EOPNOTSUPP
;
return
-
EOPNOTSUPP
;
}
filename
=
ar
->
hw
.
fw_api2
;
ret
=
request_firmware
(
&
fw
,
filename
,
ar
->
dev
);
ret
=
request_firmware
(
&
fw
,
filename
,
ar
->
dev
);
if
(
ret
)
if
(
ret
)
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment