|
@@ -176,7 +176,8 @@ wpa_driver_nl80211_finish_drv_init(struct wpa_driver_nl80211_data *drv,
|
|
|
static int nl80211_send_frame_cmd(struct i802_bss *bss,
|
|
|
unsigned int freq, unsigned int wait,
|
|
|
const u8 *buf, size_t buf_len, u64 *cookie,
|
|
|
- int no_cck, int no_ack, int offchanok);
|
|
|
+ int no_cck, int no_ack, int offchanok,
|
|
|
+ const u16 *csa_offs, size_t csa_offs_len);
|
|
|
static int wpa_driver_nl80211_probe_req_report(struct i802_bss *bss,
|
|
|
int report);
|
|
|
|
|
@@ -3093,7 +3094,9 @@ static int wpa_driver_nl80211_send_frame(struct i802_bss *bss,
|
|
|
const void *data, size_t len,
|
|
|
int encrypt, int noack,
|
|
|
unsigned int freq, int no_cck,
|
|
|
- int offchanok, unsigned int wait_time)
|
|
|
+ int offchanok, unsigned int wait_time,
|
|
|
+ const u16 *csa_offs,
|
|
|
+ size_t csa_offs_len)
|
|
|
{
|
|
|
struct wpa_driver_nl80211_data *drv = bss->drv;
|
|
|
u64 cookie;
|
|
@@ -3119,7 +3122,8 @@ static int wpa_driver_nl80211_send_frame(struct i802_bss *bss,
|
|
|
|
|
|
wpa_printf(MSG_DEBUG, "nl80211: send_frame -> send_frame_cmd");
|
|
|
res = nl80211_send_frame_cmd(bss, freq, wait_time, data, len,
|
|
|
- &cookie, no_cck, noack, offchanok);
|
|
|
+ &cookie, no_cck, noack, offchanok,
|
|
|
+ csa_offs, csa_offs_len);
|
|
|
if (res == 0 && !noack) {
|
|
|
const struct ieee80211_mgmt *mgmt;
|
|
|
u16 fc;
|
|
@@ -3145,7 +3149,9 @@ static int wpa_driver_nl80211_send_mlme(struct i802_bss *bss, const u8 *data,
|
|
|
size_t data_len, int noack,
|
|
|
unsigned int freq, int no_cck,
|
|
|
int offchanok,
|
|
|
- unsigned int wait_time)
|
|
|
+ unsigned int wait_time,
|
|
|
+ const u16 *csa_offs,
|
|
|
+ size_t csa_offs_len)
|
|
|
{
|
|
|
struct wpa_driver_nl80211_data *drv = bss->drv;
|
|
|
struct ieee80211_mgmt *mgmt;
|
|
@@ -3175,7 +3181,7 @@ static int wpa_driver_nl80211_send_mlme(struct i802_bss *bss, const u8 *data,
|
|
|
}
|
|
|
return nl80211_send_frame_cmd(bss, freq, 0,
|
|
|
data, data_len, NULL, 1, noack,
|
|
|
- 1);
|
|
|
+ 1, csa_offs, csa_offs_len);
|
|
|
}
|
|
|
|
|
|
if (drv->device_ap_sme && is_ap_interface(drv->nlmode)) {
|
|
@@ -3189,7 +3195,8 @@ static int wpa_driver_nl80211_send_mlme(struct i802_bss *bss, const u8 *data,
|
|
|
wait_time,
|
|
|
data, data_len,
|
|
|
&drv->send_action_cookie,
|
|
|
- no_cck, noack, offchanok);
|
|
|
+ no_cck, noack, offchanok,
|
|
|
+ csa_offs, csa_offs_len);
|
|
|
}
|
|
|
|
|
|
if (WLAN_FC_GET_TYPE(fc) == WLAN_FC_TYPE_MGMT &&
|
|
@@ -3209,7 +3216,8 @@ static int wpa_driver_nl80211_send_mlme(struct i802_bss *bss, const u8 *data,
|
|
|
wpa_printf(MSG_DEBUG, "nl80211: send_mlme -> send_frame");
|
|
|
return wpa_driver_nl80211_send_frame(bss, data, data_len, encrypt,
|
|
|
noack, freq, no_cck, offchanok,
|
|
|
- wait_time);
|
|
|
+ wait_time, csa_offs,
|
|
|
+ csa_offs_len);
|
|
|
}
|
|
|
|
|
|
|
|
@@ -4248,7 +4256,7 @@ static int wpa_driver_nl80211_hapd_send_eapol(
|
|
|
memcpy(pos, data, data_len);
|
|
|
|
|
|
res = wpa_driver_nl80211_send_frame(bss, (u8 *) hdr, len, encrypt, 0,
|
|
|
- 0, 0, 0, 0);
|
|
|
+ 0, 0, 0, 0, NULL, 0);
|
|
|
if (res < 0) {
|
|
|
wpa_printf(MSG_ERROR, "i802_send_eapol - packet len: %lu - "
|
|
|
"failed: %d (%s)",
|
|
@@ -5439,7 +5447,7 @@ static int i802_sta_deauth(void *priv, const u8 *own_addr, const u8 *addr,
|
|
|
return wpa_driver_nl80211_send_mlme(bss, (u8 *) &mgmt,
|
|
|
IEEE80211_HDRLEN +
|
|
|
sizeof(mgmt.u.deauth), 0, 0, 0, 0,
|
|
|
- 0);
|
|
|
+ 0, NULL, 0);
|
|
|
}
|
|
|
|
|
|
|
|
@@ -5466,7 +5474,7 @@ static int i802_sta_disassoc(void *priv, const u8 *own_addr, const u8 *addr,
|
|
|
return wpa_driver_nl80211_send_mlme(bss, (u8 *) &mgmt,
|
|
|
IEEE80211_HDRLEN +
|
|
|
sizeof(mgmt.u.disassoc), 0, 0, 0, 0,
|
|
|
- 0);
|
|
|
+ 0, NULL, 0);
|
|
|
}
|
|
|
|
|
|
|
|
@@ -6125,7 +6133,8 @@ static int nl80211_send_frame_cmd(struct i802_bss *bss,
|
|
|
unsigned int freq, unsigned int wait,
|
|
|
const u8 *buf, size_t buf_len,
|
|
|
u64 *cookie_out, int no_cck, int no_ack,
|
|
|
- int offchanok)
|
|
|
+ int offchanok, const u16 *csa_offs,
|
|
|
+ size_t csa_offs_len)
|
|
|
{
|
|
|
struct wpa_driver_nl80211_data *drv = bss->drv;
|
|
|
struct nl_msg *msg;
|
|
@@ -6145,6 +6154,8 @@ static int nl80211_send_frame_cmd(struct i802_bss *bss,
|
|
|
nla_put_flag(msg, NL80211_ATTR_OFFCHANNEL_TX_OK)) ||
|
|
|
(no_cck && nla_put_flag(msg, NL80211_ATTR_TX_NO_CCK_RATE)) ||
|
|
|
(no_ack && nla_put_flag(msg, NL80211_ATTR_DONT_WAIT_FOR_ACK)) ||
|
|
|
+ (csa_offs && nla_put(msg, NL80211_ATTR_CSA_C_OFFSETS_TX,
|
|
|
+ csa_offs_len * sizeof(u16), csa_offs)) ||
|
|
|
nla_put(msg, NL80211_ATTR_FRAME, buf_len, buf))
|
|
|
goto fail;
|
|
|
|
|
@@ -6204,12 +6215,12 @@ static int wpa_driver_nl80211_send_action(struct i802_bss *bss,
|
|
|
!drv->use_monitor))
|
|
|
ret = wpa_driver_nl80211_send_mlme(bss, buf, 24 + data_len,
|
|
|
0, freq, no_cck, 1,
|
|
|
- wait_time);
|
|
|
+ wait_time, NULL, 0);
|
|
|
else
|
|
|
ret = nl80211_send_frame_cmd(bss, freq, wait_time, buf,
|
|
|
24 + data_len,
|
|
|
&drv->send_action_cookie,
|
|
|
- no_cck, 0, 1);
|
|
|
+ no_cck, 0, 1, NULL, 0);
|
|
|
|
|
|
os_free(buf);
|
|
|
return ret;
|
|
@@ -6551,7 +6562,7 @@ static int nl80211_send_frame(void *priv, const u8 *data, size_t data_len,
|
|
|
{
|
|
|
struct i802_bss *bss = priv;
|
|
|
return wpa_driver_nl80211_send_frame(bss, data, data_len, encrypt, 0,
|
|
|
- 0, 0, 0, 0);
|
|
|
+ 0, 0, 0, 0, NULL, 0);
|
|
|
}
|
|
|
|
|
|
|
|
@@ -6960,7 +6971,7 @@ static void nl80211_send_null_frame(struct i802_bss *bss, const u8 *own_addr,
|
|
|
os_memcpy(nulldata.hdr.IEEE80211_SA_FROMDS, own_addr, ETH_ALEN);
|
|
|
|
|
|
if (wpa_driver_nl80211_send_mlme(bss, (u8 *) &nulldata, size, 0, 0, 0,
|
|
|
- 0, 0) < 0)
|
|
|
+ 0, 0, NULL, 0) < 0)
|
|
|
wpa_printf(MSG_DEBUG, "nl80211_send_null_frame: Failed to "
|
|
|
"send poll frame");
|
|
|
}
|
|
@@ -7280,11 +7291,13 @@ static int driver_nl80211_if_remove(void *priv, enum wpa_driver_if_type type,
|
|
|
|
|
|
static int driver_nl80211_send_mlme(void *priv, const u8 *data,
|
|
|
size_t data_len, int noack,
|
|
|
- unsigned int freq)
|
|
|
+ unsigned int freq,
|
|
|
+ const u16 *csa_offs, size_t csa_offs_len)
|
|
|
{
|
|
|
struct i802_bss *bss = priv;
|
|
|
return wpa_driver_nl80211_send_mlme(bss, data, data_len, noack,
|
|
|
- freq, 0, 0, 0);
|
|
|
+ freq, 0, 0, 0, csa_offs,
|
|
|
+ csa_offs_len);
|
|
|
}
|
|
|
|
|
|
|