|
@@ -206,6 +206,7 @@ static int wpa_supplicant_ctrl_iface_tdls_discover(
|
|
|
struct wpa_supplicant *wpa_s, char *addr)
|
|
|
{
|
|
|
u8 peer[ETH_ALEN];
|
|
|
+ int ret;
|
|
|
|
|
|
if (hwaddr_aton(addr, peer)) {
|
|
|
wpa_printf(MSG_DEBUG, "CTRL_IFACE TDLS_DISCOVER: invalid "
|
|
@@ -216,7 +217,12 @@ static int wpa_supplicant_ctrl_iface_tdls_discover(
|
|
|
wpa_printf(MSG_DEBUG, "CTRL_IFACE TDLS_DISCOVER " MACSTR,
|
|
|
MAC2STR(peer));
|
|
|
|
|
|
- return wpa_drv_tdls_oper(wpa_s, TDLS_DISCOVERY_REQ, peer);
|
|
|
+ if (wpa_tdls_is_external_setup(wpa_s->wpa))
|
|
|
+ ret = wpa_tdls_send_discovery_request(wpa_s->wpa, peer);
|
|
|
+ else
|
|
|
+ ret = wpa_drv_tdls_oper(wpa_s, TDLS_DISCOVERY_REQ, peer);
|
|
|
+
|
|
|
+ return ret;
|
|
|
}
|
|
|
|
|
|
|
|
@@ -236,8 +242,13 @@ static int wpa_supplicant_ctrl_iface_tdls_setup(
|
|
|
MAC2STR(peer));
|
|
|
|
|
|
ret = wpa_tdls_reneg(wpa_s->wpa, peer);
|
|
|
- if (ret)
|
|
|
- ret = wpa_drv_tdls_oper(wpa_s, TDLS_SETUP, peer);
|
|
|
+ if (ret) {
|
|
|
+ if (wpa_tdls_is_external_setup(wpa_s->wpa))
|
|
|
+ ret = wpa_tdls_start(wpa_s->wpa, peer);
|
|
|
+ else
|
|
|
+ ret = wpa_drv_tdls_oper(wpa_s, TDLS_SETUP, peer);
|
|
|
+ }
|
|
|
+
|
|
|
return ret;
|
|
|
}
|
|
|
|
|
@@ -256,7 +267,8 @@ static int wpa_supplicant_ctrl_iface_tdls_teardown(
|
|
|
wpa_printf(MSG_DEBUG, "CTRL_IFACE TDLS_TEARDOWN " MACSTR,
|
|
|
MAC2STR(peer));
|
|
|
|
|
|
- return wpa_drv_tdls_oper(wpa_s, TDLS_TEARDOWN, peer);
|
|
|
+ return wpa_tdls_teardown_link(wpa_s->wpa, peer,
|
|
|
+ WLAN_REASON_TDLS_TEARDOWN_UNSPECIFIED);
|
|
|
}
|
|
|
|
|
|
#endif
|