mirror of
https://git.kernel.org/pub/scm/network/wireless/iwd.git
synced 2024-12-22 13:02:44 +01:00
station: set evict_nocarrier sysfs option during roaming
If the kernel supports evict_nocarrier set this during the roam to prevent packet delays post roam.
This commit is contained in:
parent
25936b1365
commit
873924a027
@ -57,12 +57,15 @@
|
|||||||
#include "src/anqputil.h"
|
#include "src/anqputil.h"
|
||||||
#include "src/diagnostic.h"
|
#include "src/diagnostic.h"
|
||||||
#include "src/frame-xchg.h"
|
#include "src/frame-xchg.h"
|
||||||
|
#include "src/sysfs.h"
|
||||||
|
|
||||||
static struct l_queue *station_list;
|
static struct l_queue *station_list;
|
||||||
static uint32_t netdev_watch;
|
static uint32_t netdev_watch;
|
||||||
static uint32_t mfp_setting;
|
static uint32_t mfp_setting;
|
||||||
static uint32_t roam_retry_interval;
|
static uint32_t roam_retry_interval;
|
||||||
static bool anqp_disabled;
|
static bool anqp_disabled;
|
||||||
|
static bool supports_arp_evict_nocarrier;
|
||||||
|
static bool supports_ndisc_evict_nocarrier;
|
||||||
static struct watchlist event_watches;
|
static struct watchlist event_watches;
|
||||||
|
|
||||||
struct station {
|
struct station {
|
||||||
@ -1384,6 +1387,19 @@ static const char *station_state_to_string(enum station_state state)
|
|||||||
return "invalid";
|
return "invalid";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void station_set_evict_nocarrier(struct station *station, bool value)
|
||||||
|
{
|
||||||
|
char *v = value ? "1" : "0";
|
||||||
|
|
||||||
|
if (supports_arp_evict_nocarrier)
|
||||||
|
sysfs_write_ipv4_setting(netdev_get_name(station->netdev),
|
||||||
|
"arp_evict_nocarrier", v);
|
||||||
|
|
||||||
|
if (supports_ndisc_evict_nocarrier)
|
||||||
|
sysfs_write_ipv6_setting(netdev_get_name(station->netdev),
|
||||||
|
"ndisc_evict_nocarrier", v);
|
||||||
|
}
|
||||||
|
|
||||||
static void station_enter_state(struct station *station,
|
static void station_enter_state(struct station *station,
|
||||||
enum station_state state)
|
enum station_state state)
|
||||||
{
|
{
|
||||||
@ -1429,9 +1445,6 @@ static void station_enter_state(struct station *station,
|
|||||||
network_get_path(station->connected_network),
|
network_get_path(station->connected_network),
|
||||||
IWD_NETWORK_INTERFACE, "Connected");
|
IWD_NETWORK_INTERFACE, "Connected");
|
||||||
|
|
||||||
periodic_scan_stop(station);
|
|
||||||
break;
|
|
||||||
case STATION_STATE_DISCONNECTED:
|
|
||||||
periodic_scan_stop(station);
|
periodic_scan_stop(station);
|
||||||
break;
|
break;
|
||||||
case STATION_STATE_CONNECTED:
|
case STATION_STATE_CONNECTED:
|
||||||
@ -1439,11 +1452,16 @@ static void station_enter_state(struct station *station,
|
|||||||
netdev_get_path(station->netdev),
|
netdev_get_path(station->netdev),
|
||||||
IWD_STATION_DIAGNOSTIC_INTERFACE,
|
IWD_STATION_DIAGNOSTIC_INTERFACE,
|
||||||
station);
|
station);
|
||||||
|
/* Fall through */
|
||||||
|
case STATION_STATE_DISCONNECTED:
|
||||||
periodic_scan_stop(station);
|
periodic_scan_stop(station);
|
||||||
|
|
||||||
|
station_set_evict_nocarrier(station, true);
|
||||||
break;
|
break;
|
||||||
case STATION_STATE_DISCONNECTING:
|
case STATION_STATE_DISCONNECTING:
|
||||||
break;
|
break;
|
||||||
case STATION_STATE_ROAMING:
|
case STATION_STATE_ROAMING:
|
||||||
|
station_set_evict_nocarrier(station, false);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -4457,6 +4475,11 @@ static int station_init(void)
|
|||||||
if (!netconfig_enabled())
|
if (!netconfig_enabled())
|
||||||
l_info("station: Network configuration is disabled.");
|
l_info("station: Network configuration is disabled.");
|
||||||
|
|
||||||
|
supports_arp_evict_nocarrier = sysfs_supports_ipv4_setting("all",
|
||||||
|
"arp_evict_nocarrier");
|
||||||
|
supports_ndisc_evict_nocarrier = sysfs_supports_ipv6_setting("all",
|
||||||
|
"ndisc_evict_nocarrier");
|
||||||
|
|
||||||
watchlist_init(&event_watches, NULL);
|
watchlist_init(&event_watches, NULL);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
Loading…
Reference in New Issue
Block a user