Commit 86ceae90 authored by Bjorn Andersson's avatar Bjorn Andersson Committed by Kalle Valo

wcn36xx: Fix up wcn36xx_smd_update_scan_params()

Fix up the wcn36xx_smd_update_scan_params() to work with non-ancient
versions of the firmware and support actually specifying the list of
channels.
Signed-off-by: default avatarBjorn Andersson <bjorn.andersson@linaro.org>
Signed-off-by: default avatarKalle Valo <kvalo@qca.qualcomm.com>
parent 6f10b4e1
...@@ -4123,7 +4123,7 @@ struct wcn36xx_hal_update_scan_params_req { ...@@ -4123,7 +4123,7 @@ struct wcn36xx_hal_update_scan_params_req {
/* Update scan params - sent from host to PNO to be used during PNO /* Update scan params - sent from host to PNO to be used during PNO
* scanningx */ * scanningx */
struct update_scan_params_req_ex { struct wcn36xx_hal_update_scan_params_req_ex {
struct wcn36xx_hal_msg_header header; struct wcn36xx_hal_msg_header header;
...@@ -4151,7 +4151,7 @@ struct update_scan_params_req_ex { ...@@ -4151,7 +4151,7 @@ struct update_scan_params_req_ex {
/* Cb State */ /* Cb State */
enum phy_chan_bond_state state; enum phy_chan_bond_state state;
}; } __packed;
/* Update scan params - sent from host to PNO to be used during PNO /* Update scan params - sent from host to PNO to be used during PNO
* scanningx */ * scanningx */
......
...@@ -674,22 +674,25 @@ static int wcn36xx_smd_update_scan_params_rsp(void *buf, size_t len) ...@@ -674,22 +674,25 @@ static int wcn36xx_smd_update_scan_params_rsp(void *buf, size_t len)
return 0; return 0;
} }
int wcn36xx_smd_update_scan_params(struct wcn36xx *wcn) int wcn36xx_smd_update_scan_params(struct wcn36xx *wcn,
u8 *channels, size_t channel_count)
{ {
struct wcn36xx_hal_update_scan_params_req msg_body; struct wcn36xx_hal_update_scan_params_req_ex msg_body;
int ret = 0; int ret = 0;
mutex_lock(&wcn->hal_mutex); mutex_lock(&wcn->hal_mutex);
INIT_HAL_MSG(msg_body, WCN36XX_HAL_UPDATE_SCAN_PARAM_REQ); INIT_HAL_MSG(msg_body, WCN36XX_HAL_UPDATE_SCAN_PARAM_REQ);
msg_body.dot11d_enabled = 0; msg_body.dot11d_enabled = false;
msg_body.dot11d_resolved = 0; msg_body.dot11d_resolved = true;
msg_body.channel_count = 26;
msg_body.channel_count = channel_count;
memcpy(msg_body.channels, channels, channel_count);
msg_body.active_min_ch_time = 60; msg_body.active_min_ch_time = 60;
msg_body.active_max_ch_time = 120; msg_body.active_max_ch_time = 120;
msg_body.passive_min_ch_time = 60; msg_body.passive_min_ch_time = 60;
msg_body.passive_max_ch_time = 110; msg_body.passive_max_ch_time = 110;
msg_body.state = 0; msg_body.state = PHY_SINGLE_CHANNEL_CENTERED;
PREPARE_HAL_BUF(wcn->hal_buf, msg_body); PREPARE_HAL_BUF(wcn->hal_buf, msg_body);
......
...@@ -63,7 +63,7 @@ int wcn36xx_smd_start_scan(struct wcn36xx *wcn); ...@@ -63,7 +63,7 @@ int wcn36xx_smd_start_scan(struct wcn36xx *wcn);
int wcn36xx_smd_end_scan(struct wcn36xx *wcn); int wcn36xx_smd_end_scan(struct wcn36xx *wcn);
int wcn36xx_smd_finish_scan(struct wcn36xx *wcn, int wcn36xx_smd_finish_scan(struct wcn36xx *wcn,
enum wcn36xx_hal_sys_mode mode); enum wcn36xx_hal_sys_mode mode);
int wcn36xx_smd_update_scan_params(struct wcn36xx *wcn); int wcn36xx_smd_update_scan_params(struct wcn36xx *wcn, u8 *channels, size_t channel_count);
int wcn36xx_smd_add_sta_self(struct wcn36xx *wcn, struct ieee80211_vif *vif); int wcn36xx_smd_add_sta_self(struct wcn36xx *wcn, struct ieee80211_vif *vif);
int wcn36xx_smd_delete_sta_self(struct wcn36xx *wcn, u8 *addr); int wcn36xx_smd_delete_sta_self(struct wcn36xx *wcn, u8 *addr);
int wcn36xx_smd_delete_sta(struct wcn36xx *wcn, u8 sta_index); int wcn36xx_smd_delete_sta(struct wcn36xx *wcn, u8 sta_index);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment