mirror of
https://git.kernel.org/pub/scm/network/wireless/iwd.git
synced 2025-01-05 04:32:34 +01:00
station: Break up station_connect_cb
Break this up into two parts, one handling the successful connect case, the other for handling error conditions
This commit is contained in:
parent
e265f95f45
commit
00763fde0d
118
src/station.c
118
src/station.c
@ -2429,27 +2429,6 @@ static bool station_retry_with_status(struct station *station,
|
|||||||
return station_try_next_bss(station);
|
return station_try_next_bss(station);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void station_connect_dbus_reply(struct station *station,
|
|
||||||
enum netdev_result result)
|
|
||||||
{
|
|
||||||
struct l_dbus_message *reply;
|
|
||||||
|
|
||||||
switch (result) {
|
|
||||||
case NETDEV_RESULT_ABORTED:
|
|
||||||
reply = dbus_error_aborted(station->connect_pending);
|
|
||||||
break;
|
|
||||||
case NETDEV_RESULT_OK:
|
|
||||||
reply = l_dbus_message_new_method_return(
|
|
||||||
station->connect_pending);
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
reply = dbus_error_failed(station->connect_pending);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
dbus_pending_reply(&station->connect_pending, reply);
|
|
||||||
}
|
|
||||||
|
|
||||||
static void station_ft_ds_action_start(struct station *station, uint16_t mdid)
|
static void station_ft_ds_action_start(struct station *station, uint16_t mdid)
|
||||||
{
|
{
|
||||||
const struct l_queue_entry *entry;
|
const struct l_queue_entry *entry;
|
||||||
@ -2480,49 +2459,17 @@ static void station_ft_ds_action_start(struct station *station, uint16_t mdid)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static void station_connect_cb(struct netdev *netdev, enum netdev_result result,
|
static void station_connect_ok(struct station *station)
|
||||||
void *event_data, void *user_data)
|
|
||||||
{
|
{
|
||||||
struct station *station = user_data;
|
struct handshake_state *hs = netdev_get_handshake(station->netdev);
|
||||||
struct handshake_state *hs = netdev_get_handshake(netdev);
|
|
||||||
|
|
||||||
l_debug("%u, result: %d", netdev_get_ifindex(station->netdev), result);
|
l_debug("");
|
||||||
|
|
||||||
switch (result) {
|
if (station->connect_pending) {
|
||||||
case NETDEV_RESULT_OK:
|
struct l_dbus_message *reply =
|
||||||
blacklist_remove_bss(station->connected_bss->addr);
|
l_dbus_message_new_method_return(
|
||||||
break;
|
station->connect_pending);
|
||||||
case NETDEV_RESULT_HANDSHAKE_FAILED:
|
dbus_pending_reply(&station->connect_pending, reply);
|
||||||
/* reason code in this case */
|
|
||||||
if (station_retry_with_reason(station, l_get_u16(event_data)))
|
|
||||||
return;
|
|
||||||
|
|
||||||
break;
|
|
||||||
case NETDEV_RESULT_AUTHENTICATION_FAILED:
|
|
||||||
case NETDEV_RESULT_ASSOCIATION_FAILED:
|
|
||||||
/* status code in this case */
|
|
||||||
if (station_retry_with_status(station, l_get_u16(event_data)))
|
|
||||||
return;
|
|
||||||
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (station->connect_pending)
|
|
||||||
station_connect_dbus_reply(station, result);
|
|
||||||
|
|
||||||
if (result != NETDEV_RESULT_OK) {
|
|
||||||
if (result != NETDEV_RESULT_ABORTED) {
|
|
||||||
bool in_handshake =
|
|
||||||
result == NETDEV_RESULT_HANDSHAKE_FAILED;
|
|
||||||
|
|
||||||
network_connect_failed(station->connected_network,
|
|
||||||
in_handshake);
|
|
||||||
station_disassociated(station);
|
|
||||||
}
|
|
||||||
|
|
||||||
return;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -2563,6 +2510,55 @@ static void station_connect_cb(struct netdev *netdev, enum netdev_result result,
|
|||||||
station_enter_state(station, STATION_STATE_CONNECTED);
|
station_enter_state(station, STATION_STATE_CONNECTED);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void station_connect_cb(struct netdev *netdev, enum netdev_result result,
|
||||||
|
void *event_data, void *user_data)
|
||||||
|
{
|
||||||
|
struct station *station = user_data;
|
||||||
|
bool during_eapol;
|
||||||
|
|
||||||
|
l_debug("%u, result: %d", netdev_get_ifindex(station->netdev), result);
|
||||||
|
|
||||||
|
switch (result) {
|
||||||
|
case NETDEV_RESULT_OK:
|
||||||
|
blacklist_remove_bss(station->connected_bss->addr);
|
||||||
|
station_connect_ok(station);
|
||||||
|
return;
|
||||||
|
case NETDEV_RESULT_HANDSHAKE_FAILED:
|
||||||
|
/* reason code in this case */
|
||||||
|
if (station_retry_with_reason(station, l_get_u16(event_data)))
|
||||||
|
return;
|
||||||
|
|
||||||
|
break;
|
||||||
|
case NETDEV_RESULT_AUTHENTICATION_FAILED:
|
||||||
|
case NETDEV_RESULT_ASSOCIATION_FAILED:
|
||||||
|
/* status code in this case */
|
||||||
|
if (station_retry_with_status(station, l_get_u16(event_data)))
|
||||||
|
return;
|
||||||
|
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (station->connect_pending) {
|
||||||
|
struct l_dbus_message *reply;
|
||||||
|
|
||||||
|
if (result == NETDEV_RESULT_ABORTED)
|
||||||
|
reply = dbus_error_aborted(station->connect_pending);
|
||||||
|
else
|
||||||
|
reply = dbus_error_failed(station->connect_pending);
|
||||||
|
|
||||||
|
dbus_pending_reply(&station->connect_pending, reply);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (result == NETDEV_RESULT_ABORTED)
|
||||||
|
return;
|
||||||
|
|
||||||
|
during_eapol = result == NETDEV_RESULT_HANDSHAKE_FAILED;
|
||||||
|
network_connect_failed(station->connected_network, during_eapol);
|
||||||
|
station_disassociated(station);
|
||||||
|
}
|
||||||
|
|
||||||
int __station_connect_network(struct station *station, struct network *network,
|
int __station_connect_network(struct station *station, struct network *network,
|
||||||
struct scan_bss *bss)
|
struct scan_bss *bss)
|
||||||
{
|
{
|
||||||
|
Loading…
Reference in New Issue
Block a user