3
0
mirror of https://git.kernel.org/pub/scm/network/wireless/iwd.git synced 2025-01-20 17:54:05 +01:00

station: Move 'connected' logic out of enter state func

Previously, station state 'connected' used to identify an interface associated
with AP. With the introduction of netconfig, an interface is assumed to be
connected after the IP addresses have been assigned to it. If netconfig is
disabled, the behavior remains unchanged.
This commit is contained in:
Tim Kourt 2019-10-09 14:53:31 -07:00 committed by Denis Kenzior
parent e39bb6bfa0
commit 624933fab0

View File

@ -1158,26 +1158,9 @@ static void station_enter_state(struct station *station,
IWD_NETWORK_INTERFACE, "Connected"); IWD_NETWORK_INTERFACE, "Connected");
/* fall through */ /* fall through */
case STATION_STATE_DISCONNECTED: case STATION_STATE_DISCONNECTED:
periodic_scan_stop(station);
break;
case STATION_STATE_CONNECTED: case STATION_STATE_CONNECTED:
periodic_scan_stop(station); periodic_scan_stop(station);
if (!station->netconfig)
break;
if (station->state == STATION_STATE_ROAMING) {
netconfig_reconfigure(station->netconfig);
break;
}
netconfig_configure(station->netconfig,
network_get_settings(
station->connected_network),
netdev_get_address(
station->netdev));
break; break;
case STATION_STATE_DISCONNECTING: case STATION_STATE_DISCONNECTING:
case STATION_STATE_ROAMING: case STATION_STATE_ROAMING:
@ -1302,6 +1285,11 @@ static void station_roamed(struct station *station)
station->signal_low = false; station->signal_low = false;
station->roam_min_time.tv_sec = 0; station->roam_min_time.tv_sec = 0;
station->roam_no_orig_ap = false; station->roam_no_orig_ap = false;
if (station->netconfig)
netconfig_reconfigure(station->netconfig);
station_enter_state(station, STATION_STATE_CONNECTED);
} }
static void station_roam_failed(struct station *station) static void station_roam_failed(struct station *station)
@ -1338,10 +1326,9 @@ static void station_reassociate_cb(struct netdev *netdev,
if (station->state != STATION_STATE_ROAMING) if (station->state != STATION_STATE_ROAMING)
return; return;
if (result == NETDEV_RESULT_OK) { if (result == NETDEV_RESULT_OK)
station_roamed(station); station_roamed(station);
station_enter_state(station, STATION_STATE_CONNECTED); else
} else
station_roam_failed(station); station_roam_failed(station);
} }
@ -1357,10 +1344,9 @@ static void station_fast_transition_cb(struct netdev *netdev,
if (station->state != STATION_STATE_ROAMING) if (station->state != STATION_STATE_ROAMING)
return; return;
if (result == NETDEV_RESULT_OK) { if (result == NETDEV_RESULT_OK)
station_roamed(station); station_roamed(station);
station_enter_state(station, STATION_STATE_CONNECTED); else
} else
station_roam_failed(station); station_roam_failed(station);
} }
@ -2280,7 +2266,14 @@ static void station_connect_cb(struct netdev *netdev, enum netdev_result result,
} }
network_connected(station->connected_network); network_connected(station->connected_network);
station_enter_state(station, STATION_STATE_CONNECTED);
if (station->netconfig)
netconfig_configure(station->netconfig,
network_get_settings(
station->connected_network),
netdev_get_address(station->netdev));
else
station_enter_state(station, STATION_STATE_CONNECTED);
} }
int __station_connect_network(struct station *station, struct network *network, int __station_connect_network(struct station *station, struct network *network,