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
8d40a13b
Commit
8d40a13b
authored
Aug 30, 2022
by
Kalle Valo
Browse files
Options
Browse Files
Download
Plain Diff
Merge ath-next from
git://git.kernel.org/pub/scm/linux/kernel/git/kvalo/ath.git
ath.git patches for v6.1. Only fixes this time.
parents
7c13844c
b383e8ab
Changes
5
Hide whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
83 additions
and
43 deletions
+83
-43
drivers/net/wireless/ath/ath10k/core.c
drivers/net/wireless/ath/ath10k/core.c
+16
-0
drivers/net/wireless/ath/ath10k/htc.c
drivers/net/wireless/ath/ath10k/htc.c
+8
-3
drivers/net/wireless/ath/ath10k/hw.h
drivers/net/wireless/ath/ath10k/hw.h
+2
-0
drivers/net/wireless/ath/ath10k/mac.c
drivers/net/wireless/ath/ath10k/mac.c
+29
-25
drivers/net/wireless/ath/ath9k/htc_hst.c
drivers/net/wireless/ath/ath9k/htc_hst.c
+28
-15
No files found.
drivers/net/wireless/ath/ath10k/core.c
View file @
8d40a13b
...
@@ -98,6 +98,7 @@ static const struct ath10k_hw_params ath10k_hw_params_list[] = {
...
@@ -98,6 +98,7 @@ static const struct ath10k_hw_params ath10k_hw_params_list[] = {
.
tx_stats_over_pktlog
=
true
,
.
tx_stats_over_pktlog
=
true
,
.
dynamic_sar_support
=
false
,
.
dynamic_sar_support
=
false
,
.
hw_restart_disconnect
=
false
,
.
hw_restart_disconnect
=
false
,
.
use_fw_tx_credits
=
true
,
},
},
{
{
.
id
=
QCA988X_HW_2_0_VERSION
,
.
id
=
QCA988X_HW_2_0_VERSION
,
...
@@ -136,6 +137,7 @@ static const struct ath10k_hw_params ath10k_hw_params_list[] = {
...
@@ -136,6 +137,7 @@ static const struct ath10k_hw_params ath10k_hw_params_list[] = {
.
tx_stats_over_pktlog
=
true
,
.
tx_stats_over_pktlog
=
true
,
.
dynamic_sar_support
=
false
,
.
dynamic_sar_support
=
false
,
.
hw_restart_disconnect
=
false
,
.
hw_restart_disconnect
=
false
,
.
use_fw_tx_credits
=
true
,
},
},
{
{
.
id
=
QCA9887_HW_1_0_VERSION
,
.
id
=
QCA9887_HW_1_0_VERSION
,
...
@@ -175,6 +177,7 @@ static const struct ath10k_hw_params ath10k_hw_params_list[] = {
...
@@ -175,6 +177,7 @@ static const struct ath10k_hw_params ath10k_hw_params_list[] = {
.
tx_stats_over_pktlog
=
false
,
.
tx_stats_over_pktlog
=
false
,
.
dynamic_sar_support
=
false
,
.
dynamic_sar_support
=
false
,
.
hw_restart_disconnect
=
false
,
.
hw_restart_disconnect
=
false
,
.
use_fw_tx_credits
=
true
,
},
},
{
{
.
id
=
QCA6174_HW_3_2_VERSION
,
.
id
=
QCA6174_HW_3_2_VERSION
,
...
@@ -209,6 +212,7 @@ static const struct ath10k_hw_params ath10k_hw_params_list[] = {
...
@@ -209,6 +212,7 @@ static const struct ath10k_hw_params ath10k_hw_params_list[] = {
.
supports_peer_stats_info
=
true
,
.
supports_peer_stats_info
=
true
,
.
dynamic_sar_support
=
true
,
.
dynamic_sar_support
=
true
,
.
hw_restart_disconnect
=
false
,
.
hw_restart_disconnect
=
false
,
.
use_fw_tx_credits
=
true
,
},
},
{
{
.
id
=
QCA6174_HW_2_1_VERSION
,
.
id
=
QCA6174_HW_2_1_VERSION
,
...
@@ -247,6 +251,7 @@ static const struct ath10k_hw_params ath10k_hw_params_list[] = {
...
@@ -247,6 +251,7 @@ static const struct ath10k_hw_params ath10k_hw_params_list[] = {
.
tx_stats_over_pktlog
=
false
,
.
tx_stats_over_pktlog
=
false
,
.
dynamic_sar_support
=
false
,
.
dynamic_sar_support
=
false
,
.
hw_restart_disconnect
=
false
,
.
hw_restart_disconnect
=
false
,
.
use_fw_tx_credits
=
true
,
},
},
{
{
.
id
=
QCA6174_HW_2_1_VERSION
,
.
id
=
QCA6174_HW_2_1_VERSION
,
...
@@ -285,6 +290,7 @@ static const struct ath10k_hw_params ath10k_hw_params_list[] = {
...
@@ -285,6 +290,7 @@ static const struct ath10k_hw_params ath10k_hw_params_list[] = {
.
tx_stats_over_pktlog
=
false
,
.
tx_stats_over_pktlog
=
false
,
.
dynamic_sar_support
=
false
,
.
dynamic_sar_support
=
false
,
.
hw_restart_disconnect
=
false
,
.
hw_restart_disconnect
=
false
,
.
use_fw_tx_credits
=
true
,
},
},
{
{
.
id
=
QCA6174_HW_3_0_VERSION
,
.
id
=
QCA6174_HW_3_0_VERSION
,
...
@@ -323,6 +329,7 @@ static const struct ath10k_hw_params ath10k_hw_params_list[] = {
...
@@ -323,6 +329,7 @@ static const struct ath10k_hw_params ath10k_hw_params_list[] = {
.
tx_stats_over_pktlog
=
false
,
.
tx_stats_over_pktlog
=
false
,
.
dynamic_sar_support
=
false
,
.
dynamic_sar_support
=
false
,
.
hw_restart_disconnect
=
false
,
.
hw_restart_disconnect
=
false
,
.
use_fw_tx_credits
=
true
,
},
},
{
{
.
id
=
QCA6174_HW_3_2_VERSION
,
.
id
=
QCA6174_HW_3_2_VERSION
,
...
@@ -365,6 +372,7 @@ static const struct ath10k_hw_params ath10k_hw_params_list[] = {
...
@@ -365,6 +372,7 @@ static const struct ath10k_hw_params ath10k_hw_params_list[] = {
.
supports_peer_stats_info
=
true
,
.
supports_peer_stats_info
=
true
,
.
dynamic_sar_support
=
true
,
.
dynamic_sar_support
=
true
,
.
hw_restart_disconnect
=
false
,
.
hw_restart_disconnect
=
false
,
.
use_fw_tx_credits
=
true
,
},
},
{
{
.
id
=
QCA99X0_HW_2_0_DEV_VERSION
,
.
id
=
QCA99X0_HW_2_0_DEV_VERSION
,
...
@@ -409,6 +417,7 @@ static const struct ath10k_hw_params ath10k_hw_params_list[] = {
...
@@ -409,6 +417,7 @@ static const struct ath10k_hw_params ath10k_hw_params_list[] = {
.
tx_stats_over_pktlog
=
false
,
.
tx_stats_over_pktlog
=
false
,
.
dynamic_sar_support
=
false
,
.
dynamic_sar_support
=
false
,
.
hw_restart_disconnect
=
false
,
.
hw_restart_disconnect
=
false
,
.
use_fw_tx_credits
=
true
,
},
},
{
{
.
id
=
QCA9984_HW_1_0_DEV_VERSION
,
.
id
=
QCA9984_HW_1_0_DEV_VERSION
,
...
@@ -460,6 +469,7 @@ static const struct ath10k_hw_params ath10k_hw_params_list[] = {
...
@@ -460,6 +469,7 @@ static const struct ath10k_hw_params ath10k_hw_params_list[] = {
.
tx_stats_over_pktlog
=
false
,
.
tx_stats_over_pktlog
=
false
,
.
dynamic_sar_support
=
false
,
.
dynamic_sar_support
=
false
,
.
hw_restart_disconnect
=
false
,
.
hw_restart_disconnect
=
false
,
.
use_fw_tx_credits
=
true
,
},
},
{
{
.
id
=
QCA9888_HW_2_0_DEV_VERSION
,
.
id
=
QCA9888_HW_2_0_DEV_VERSION
,
...
@@ -508,6 +518,7 @@ static const struct ath10k_hw_params ath10k_hw_params_list[] = {
...
@@ -508,6 +518,7 @@ static const struct ath10k_hw_params ath10k_hw_params_list[] = {
.
tx_stats_over_pktlog
=
false
,
.
tx_stats_over_pktlog
=
false
,
.
dynamic_sar_support
=
false
,
.
dynamic_sar_support
=
false
,
.
hw_restart_disconnect
=
false
,
.
hw_restart_disconnect
=
false
,
.
use_fw_tx_credits
=
true
,
},
},
{
{
.
id
=
QCA9377_HW_1_0_DEV_VERSION
,
.
id
=
QCA9377_HW_1_0_DEV_VERSION
,
...
@@ -546,6 +557,7 @@ static const struct ath10k_hw_params ath10k_hw_params_list[] = {
...
@@ -546,6 +557,7 @@ static const struct ath10k_hw_params ath10k_hw_params_list[] = {
.
tx_stats_over_pktlog
=
false
,
.
tx_stats_over_pktlog
=
false
,
.
dynamic_sar_support
=
false
,
.
dynamic_sar_support
=
false
,
.
hw_restart_disconnect
=
false
,
.
hw_restart_disconnect
=
false
,
.
use_fw_tx_credits
=
true
,
},
},
{
{
.
id
=
QCA9377_HW_1_1_DEV_VERSION
,
.
id
=
QCA9377_HW_1_1_DEV_VERSION
,
...
@@ -586,6 +598,7 @@ static const struct ath10k_hw_params ath10k_hw_params_list[] = {
...
@@ -586,6 +598,7 @@ static const struct ath10k_hw_params ath10k_hw_params_list[] = {
.
tx_stats_over_pktlog
=
false
,
.
tx_stats_over_pktlog
=
false
,
.
dynamic_sar_support
=
false
,
.
dynamic_sar_support
=
false
,
.
hw_restart_disconnect
=
false
,
.
hw_restart_disconnect
=
false
,
.
use_fw_tx_credits
=
true
,
},
},
{
{
.
id
=
QCA9377_HW_1_1_DEV_VERSION
,
.
id
=
QCA9377_HW_1_1_DEV_VERSION
,
...
@@ -617,6 +630,7 @@ static const struct ath10k_hw_params ath10k_hw_params_list[] = {
...
@@ -617,6 +630,7 @@ static const struct ath10k_hw_params ath10k_hw_params_list[] = {
.
credit_size_workaround
=
true
,
.
credit_size_workaround
=
true
,
.
dynamic_sar_support
=
false
,
.
dynamic_sar_support
=
false
,
.
hw_restart_disconnect
=
false
,
.
hw_restart_disconnect
=
false
,
.
use_fw_tx_credits
=
true
,
},
},
{
{
.
id
=
QCA4019_HW_1_0_DEV_VERSION
,
.
id
=
QCA4019_HW_1_0_DEV_VERSION
,
...
@@ -662,6 +676,7 @@ static const struct ath10k_hw_params ath10k_hw_params_list[] = {
...
@@ -662,6 +676,7 @@ static const struct ath10k_hw_params ath10k_hw_params_list[] = {
.
tx_stats_over_pktlog
=
false
,
.
tx_stats_over_pktlog
=
false
,
.
dynamic_sar_support
=
false
,
.
dynamic_sar_support
=
false
,
.
hw_restart_disconnect
=
false
,
.
hw_restart_disconnect
=
false
,
.
use_fw_tx_credits
=
true
,
},
},
{
{
.
id
=
WCN3990_HW_1_0_DEV_VERSION
,
.
id
=
WCN3990_HW_1_0_DEV_VERSION
,
...
@@ -693,6 +708,7 @@ static const struct ath10k_hw_params ath10k_hw_params_list[] = {
...
@@ -693,6 +708,7 @@ static const struct ath10k_hw_params ath10k_hw_params_list[] = {
.
tx_stats_over_pktlog
=
false
,
.
tx_stats_over_pktlog
=
false
,
.
dynamic_sar_support
=
true
,
.
dynamic_sar_support
=
true
,
.
hw_restart_disconnect
=
true
,
.
hw_restart_disconnect
=
true
,
.
use_fw_tx_credits
=
false
,
},
},
};
};
...
...
drivers/net/wireless/ath/ath10k/htc.c
View file @
8d40a13b
...
@@ -947,13 +947,18 @@ int ath10k_htc_wait_target(struct ath10k_htc *htc)
...
@@ -947,13 +947,18 @@ int ath10k_htc_wait_target(struct ath10k_htc *htc)
return
-
ECOMM
;
return
-
ECOMM
;
}
}
htc
->
total_transmit_credits
=
__le16_to_cpu
(
msg
->
ready
.
credit_count
);
if
(
ar
->
hw_params
.
use_fw_tx_credits
)
htc
->
total_transmit_credits
=
__le16_to_cpu
(
msg
->
ready
.
credit_count
);
else
htc
->
total_transmit_credits
=
1
;
htc
->
target_credit_size
=
__le16_to_cpu
(
msg
->
ready
.
credit_size
);
htc
->
target_credit_size
=
__le16_to_cpu
(
msg
->
ready
.
credit_size
);
ath10k_dbg
(
ar
,
ATH10K_DBG_HTC
,
ath10k_dbg
(
ar
,
ATH10K_DBG_HTC
,
"Target ready! transmit resources: %d size:%d
\n
"
,
"Target ready! transmit resources: %d size:%d
actual credits:%d
\n
"
,
htc
->
total_transmit_credits
,
htc
->
total_transmit_credits
,
htc
->
target_credit_size
);
htc
->
target_credit_size
,
msg
->
ready
.
credit_count
);
if
((
htc
->
total_transmit_credits
==
0
)
||
if
((
htc
->
total_transmit_credits
==
0
)
||
(
htc
->
target_credit_size
==
0
))
{
(
htc
->
target_credit_size
==
0
))
{
...
...
drivers/net/wireless/ath/ath10k/hw.h
View file @
8d40a13b
...
@@ -635,6 +635,8 @@ struct ath10k_hw_params {
...
@@ -635,6 +635,8 @@ struct ath10k_hw_params {
bool
dynamic_sar_support
;
bool
dynamic_sar_support
;
bool
hw_restart_disconnect
;
bool
hw_restart_disconnect
;
bool
use_fw_tx_credits
;
};
};
struct
htt_resp
;
struct
htt_resp
;
...
...
drivers/net/wireless/ath/ath10k/mac.c
View file @
8d40a13b
...
@@ -864,11 +864,36 @@ static int ath10k_peer_delete(struct ath10k *ar, u32 vdev_id, const u8 *addr)
...
@@ -864,11 +864,36 @@ static int ath10k_peer_delete(struct ath10k *ar, u32 vdev_id, const u8 *addr)
return
0
;
return
0
;
}
}
static
void
ath10k_peer_map_cleanup
(
struct
ath10k
*
ar
,
struct
ath10k_peer
*
peer
)
{
int
peer_id
,
i
;
lockdep_assert_held
(
&
ar
->
conf_mutex
);
for_each_set_bit
(
peer_id
,
peer
->
peer_ids
,
ATH10K_MAX_NUM_PEER_IDS
)
{
ar
->
peer_map
[
peer_id
]
=
NULL
;
}
/* Double check that peer is properly un-referenced from
* the peer_map
*/
for
(
i
=
0
;
i
<
ARRAY_SIZE
(
ar
->
peer_map
);
i
++
)
{
if
(
ar
->
peer_map
[
i
]
==
peer
)
{
ath10k_warn
(
ar
,
"removing stale peer_map entry for %pM (ptr %pK idx %d)
\n
"
,
peer
->
addr
,
peer
,
i
);
ar
->
peer_map
[
i
]
=
NULL
;
}
}
list_del
(
&
peer
->
list
);
kfree
(
peer
);
ar
->
num_peers
--
;
}
static
void
ath10k_peer_cleanup
(
struct
ath10k
*
ar
,
u32
vdev_id
)
static
void
ath10k_peer_cleanup
(
struct
ath10k
*
ar
,
u32
vdev_id
)
{
{
struct
ath10k_peer
*
peer
,
*
tmp
;
struct
ath10k_peer
*
peer
,
*
tmp
;
int
peer_id
;
int
i
;
lockdep_assert_held
(
&
ar
->
conf_mutex
);
lockdep_assert_held
(
&
ar
->
conf_mutex
);
...
@@ -880,25 +905,7 @@ static void ath10k_peer_cleanup(struct ath10k *ar, u32 vdev_id)
...
@@ -880,25 +905,7 @@ static void ath10k_peer_cleanup(struct ath10k *ar, u32 vdev_id)
ath10k_warn
(
ar
,
"removing stale peer %pM from vdev_id %d
\n
"
,
ath10k_warn
(
ar
,
"removing stale peer %pM from vdev_id %d
\n
"
,
peer
->
addr
,
vdev_id
);
peer
->
addr
,
vdev_id
);
for_each_set_bit
(
peer_id
,
peer
->
peer_ids
,
ath10k_peer_map_cleanup
(
ar
,
peer
);
ATH10K_MAX_NUM_PEER_IDS
)
{
ar
->
peer_map
[
peer_id
]
=
NULL
;
}
/* Double check that peer is properly un-referenced from
* the peer_map
*/
for
(
i
=
0
;
i
<
ARRAY_SIZE
(
ar
->
peer_map
);
i
++
)
{
if
(
ar
->
peer_map
[
i
]
==
peer
)
{
ath10k_warn
(
ar
,
"removing stale peer_map entry for %pM (ptr %pK idx %d)
\n
"
,
peer
->
addr
,
peer
,
i
);
ar
->
peer_map
[
i
]
=
NULL
;
}
}
list_del
(
&
peer
->
list
);
kfree
(
peer
);
ar
->
num_peers
--
;
}
}
spin_unlock_bh
(
&
ar
->
data_lock
);
spin_unlock_bh
(
&
ar
->
data_lock
);
}
}
...
@@ -7621,10 +7628,7 @@ static int ath10k_sta_state(struct ieee80211_hw *hw,
...
@@ -7621,10 +7628,7 @@ static int ath10k_sta_state(struct ieee80211_hw *hw,
/* Clean up the peer object as well since we
/* Clean up the peer object as well since we
* must have failed to do this above.
* must have failed to do this above.
*/
*/
list_del
(
&
peer
->
list
);
ath10k_peer_map_cleanup
(
ar
,
peer
);
ar
->
peer_map
[
i
]
=
NULL
;
kfree
(
peer
);
ar
->
num_peers
--
;
}
}
}
}
spin_unlock_bh
(
&
ar
->
data_lock
);
spin_unlock_bh
(
&
ar
->
data_lock
);
...
...
drivers/net/wireless/ath/ath9k/htc_hst.c
View file @
8d40a13b
...
@@ -364,33 +364,27 @@ void ath9k_htc_txcompletion_cb(struct htc_target *htc_handle,
...
@@ -364,33 +364,27 @@ void ath9k_htc_txcompletion_cb(struct htc_target *htc_handle,
}
}
static
void
ath9k_htc_fw_panic_report
(
struct
htc_target
*
htc_handle
,
static
void
ath9k_htc_fw_panic_report
(
struct
htc_target
*
htc_handle
,
struct
sk_buff
*
skb
)
struct
sk_buff
*
skb
,
u32
len
)
{
{
uint32_t
*
pattern
=
(
uint32_t
*
)
skb
->
data
;
uint32_t
*
pattern
=
(
uint32_t
*
)
skb
->
data
;
switch
(
*
pattern
)
{
if
(
*
pattern
==
0x33221199
&&
len
>=
sizeof
(
struct
htc_panic_bad_vaddr
))
{
case
0x33221199
:
{
struct
htc_panic_bad_vaddr
*
htc_panic
;
struct
htc_panic_bad_vaddr
*
htc_panic
;
htc_panic
=
(
struct
htc_panic_bad_vaddr
*
)
skb
->
data
;
htc_panic
=
(
struct
htc_panic_bad_vaddr
*
)
skb
->
data
;
dev_err
(
htc_handle
->
dev
,
"ath: firmware panic! "
dev_err
(
htc_handle
->
dev
,
"ath: firmware panic! "
"exccause: 0x%08x; pc: 0x%08x; badvaddr: 0x%08x.
\n
"
,
"exccause: 0x%08x; pc: 0x%08x; badvaddr: 0x%08x.
\n
"
,
htc_panic
->
exccause
,
htc_panic
->
pc
,
htc_panic
->
exccause
,
htc_panic
->
pc
,
htc_panic
->
badvaddr
);
htc_panic
->
badvaddr
);
break
;
return
;
}
}
case
0x33221299
:
if
(
*
pattern
==
0x33221299
)
{
{
struct
htc_panic_bad_epid
*
htc_panic
;
struct
htc_panic_bad_epid
*
htc_panic
;
htc_panic
=
(
struct
htc_panic_bad_epid
*
)
skb
->
data
;
htc_panic
=
(
struct
htc_panic_bad_epid
*
)
skb
->
data
;
dev_err
(
htc_handle
->
dev
,
"ath: firmware panic! "
dev_err
(
htc_handle
->
dev
,
"ath: firmware panic! "
"bad epid: 0x%08x
\n
"
,
htc_panic
->
epid
);
"bad epid: 0x%08x
\n
"
,
htc_panic
->
epid
);
break
;
return
;
}
default:
dev_err
(
htc_handle
->
dev
,
"ath: unknown panic pattern!
\n
"
);
break
;
}
}
dev_err
(
htc_handle
->
dev
,
"ath: unknown panic pattern!
\n
"
);
}
}
/*
/*
...
@@ -411,16 +405,26 @@ void ath9k_htc_rx_msg(struct htc_target *htc_handle,
...
@@ -411,16 +405,26 @@ void ath9k_htc_rx_msg(struct htc_target *htc_handle,
if
(
!
htc_handle
||
!
skb
)
if
(
!
htc_handle
||
!
skb
)
return
;
return
;
/* A valid message requires len >= 8.
*
* sizeof(struct htc_frame_hdr) == 8
* sizeof(struct htc_ready_msg) == 8
* sizeof(struct htc_panic_bad_vaddr) == 16
* sizeof(struct htc_panic_bad_epid) == 8
*/
if
(
unlikely
(
len
<
sizeof
(
struct
htc_frame_hdr
)))
goto
invalid
;
htc_hdr
=
(
struct
htc_frame_hdr
*
)
skb
->
data
;
htc_hdr
=
(
struct
htc_frame_hdr
*
)
skb
->
data
;
epid
=
htc_hdr
->
endpoint_id
;
epid
=
htc_hdr
->
endpoint_id
;
if
(
epid
==
0x99
)
{
if
(
epid
==
0x99
)
{
ath9k_htc_fw_panic_report
(
htc_handle
,
skb
);
ath9k_htc_fw_panic_report
(
htc_handle
,
skb
,
len
);
kfree_skb
(
skb
);
kfree_skb
(
skb
);
return
;
return
;
}
}
if
(
epid
<
0
||
epid
>=
ENDPOINT_MAX
)
{
if
(
epid
<
0
||
epid
>=
ENDPOINT_MAX
)
{
invalid:
if
(
pipe_id
!=
USB_REG_IN_PIPE
)
if
(
pipe_id
!=
USB_REG_IN_PIPE
)
dev_kfree_skb_any
(
skb
);
dev_kfree_skb_any
(
skb
);
else
else
...
@@ -432,21 +436,30 @@ void ath9k_htc_rx_msg(struct htc_target *htc_handle,
...
@@ -432,21 +436,30 @@ void ath9k_htc_rx_msg(struct htc_target *htc_handle,
/* Handle trailer */
/* Handle trailer */
if
(
htc_hdr
->
flags
&
HTC_FLAGS_RECV_TRAILER
)
{
if
(
htc_hdr
->
flags
&
HTC_FLAGS_RECV_TRAILER
)
{
if
(
be32_to_cpu
(
*
(
__be32
*
)
skb
->
data
)
==
0x00C60000
)
if
(
be32_to_cpu
(
*
(
__be32
*
)
skb
->
data
)
==
0x00C60000
)
{
/* Move past the Watchdog pattern */
/* Move past the Watchdog pattern */
htc_hdr
=
(
struct
htc_frame_hdr
*
)(
skb
->
data
+
4
);
htc_hdr
=
(
struct
htc_frame_hdr
*
)(
skb
->
data
+
4
);
len
-=
4
;
}
}
}
/* Get the message ID */
/* Get the message ID */
if
(
unlikely
(
len
<
sizeof
(
struct
htc_frame_hdr
)
+
sizeof
(
__be16
)))
goto
invalid
;
msg_id
=
(
__be16
*
)
((
void
*
)
htc_hdr
+
msg_id
=
(
__be16
*
)
((
void
*
)
htc_hdr
+
sizeof
(
struct
htc_frame_hdr
));
sizeof
(
struct
htc_frame_hdr
));
/* Now process HTC messages */
/* Now process HTC messages */
switch
(
be16_to_cpu
(
*
msg_id
))
{
switch
(
be16_to_cpu
(
*
msg_id
))
{
case
HTC_MSG_READY_ID
:
case
HTC_MSG_READY_ID
:
if
(
unlikely
(
len
<
sizeof
(
struct
htc_ready_msg
)))
goto
invalid
;
htc_process_target_rdy
(
htc_handle
,
htc_hdr
);
htc_process_target_rdy
(
htc_handle
,
htc_hdr
);
break
;
break
;
case
HTC_MSG_CONNECT_SERVICE_RESPONSE_ID
:
case
HTC_MSG_CONNECT_SERVICE_RESPONSE_ID
:
if
(
unlikely
(
len
<
sizeof
(
struct
htc_frame_hdr
)
+
sizeof
(
struct
htc_conn_svc_rspmsg
)))
goto
invalid
;
htc_process_conn_rsp
(
htc_handle
,
htc_hdr
);
htc_process_conn_rsp
(
htc_handle
,
htc_hdr
);
break
;
break
;
default:
default:
...
...
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