Update priority list after priority change
Despite comments in the wpa_config_update_prio_list(struct wpa_config *config) telling that it is called "if priority for a network is changed", it is apparently not. Signed-off-by: Dmitry Shmidt <dimitrysh@google.com>
This commit is contained in:
parent
09bd6e8cca
commit
aa53509ffe
5 changed files with 13 additions and 3 deletions
|
@ -1543,7 +1543,7 @@ int wpa_config_add_prio_network(struct wpa_config *config,
|
||||||
* configuration when a network is being added or removed. This is also called
|
* configuration when a network is being added or removed. This is also called
|
||||||
* if a priority for a network is changed.
|
* if a priority for a network is changed.
|
||||||
*/
|
*/
|
||||||
static int wpa_config_update_prio_list(struct wpa_config *config)
|
int wpa_config_update_prio_list(struct wpa_config *config)
|
||||||
{
|
{
|
||||||
struct wpa_ssid *ssid;
|
struct wpa_ssid *ssid;
|
||||||
int ret = 0;
|
int ret = 0;
|
||||||
|
|
|
@ -364,6 +364,7 @@ char * wpa_config_get_no_key(struct wpa_ssid *ssid, const char *var);
|
||||||
void wpa_config_update_psk(struct wpa_ssid *ssid);
|
void wpa_config_update_psk(struct wpa_ssid *ssid);
|
||||||
int wpa_config_add_prio_network(struct wpa_config *config,
|
int wpa_config_add_prio_network(struct wpa_config *config,
|
||||||
struct wpa_ssid *ssid);
|
struct wpa_ssid *ssid);
|
||||||
|
int wpa_config_update_prio_list(struct wpa_config *config);
|
||||||
const struct wpa_config_blob * wpa_config_get_blob(struct wpa_config *config,
|
const struct wpa_config_blob * wpa_config_get_blob(struct wpa_config *config,
|
||||||
const char *name);
|
const char *name);
|
||||||
void wpa_config_set_blob(struct wpa_config *config,
|
void wpa_config_set_blob(struct wpa_config *config,
|
||||||
|
|
|
@ -1092,6 +1092,8 @@ static int wpa_supplicant_ctrl_iface_set_network(
|
||||||
value[0] == '"' && ssid->ssid_len) ||
|
value[0] == '"' && ssid->ssid_len) ||
|
||||||
(os_strcmp(name, "ssid") == 0 && ssid->passphrase))
|
(os_strcmp(name, "ssid") == 0 && ssid->passphrase))
|
||||||
wpa_config_update_psk(ssid);
|
wpa_config_update_psk(ssid);
|
||||||
|
else if (os_strcmp(name, "priority") == 0)
|
||||||
|
wpa_config_update_prio_list(wpa_s->conf);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
|
@ -214,6 +214,7 @@ static struct wpa_supplicant * get_iface_by_dbus_path(
|
||||||
/**
|
/**
|
||||||
* set_network_properties - Set properties of a configured network
|
* set_network_properties - Set properties of a configured network
|
||||||
* @message: Pointer to incoming dbus message
|
* @message: Pointer to incoming dbus message
|
||||||
|
* @wpa_s: wpa_supplicant structure for a network interface
|
||||||
* @ssid: wpa_ssid structure for a configured network
|
* @ssid: wpa_ssid structure for a configured network
|
||||||
* @iter: DBus message iterator containing dictionary of network
|
* @iter: DBus message iterator containing dictionary of network
|
||||||
* properties to set.
|
* properties to set.
|
||||||
|
@ -222,6 +223,7 @@ static struct wpa_supplicant * get_iface_by_dbus_path(
|
||||||
* Sets network configuration with parameters given id DBus dictionary
|
* Sets network configuration with parameters given id DBus dictionary
|
||||||
*/
|
*/
|
||||||
static DBusMessage * set_network_properties(DBusMessage *message,
|
static DBusMessage * set_network_properties(DBusMessage *message,
|
||||||
|
struct wpa_supplicant *wpa_s,
|
||||||
struct wpa_ssid *ssid,
|
struct wpa_ssid *ssid,
|
||||||
DBusMessageIter *iter)
|
DBusMessageIter *iter)
|
||||||
{
|
{
|
||||||
|
@ -304,6 +306,8 @@ static DBusMessage * set_network_properties(DBusMessage *message,
|
||||||
value[0] == '"' && ssid->ssid_len) ||
|
value[0] == '"' && ssid->ssid_len) ||
|
||||||
(strcmp(entry.key, "ssid") == 0 && ssid->passphrase))
|
(strcmp(entry.key, "ssid") == 0 && ssid->passphrase))
|
||||||
wpa_config_update_psk(ssid);
|
wpa_config_update_psk(ssid);
|
||||||
|
else if (os_strcmp(entry.key, "priority") == 0)
|
||||||
|
wpa_config_update_prio_list(wpa_s->conf);
|
||||||
|
|
||||||
os_free(value);
|
os_free(value);
|
||||||
wpa_dbus_dict_entry_clear(&entry);
|
wpa_dbus_dict_entry_clear(&entry);
|
||||||
|
@ -1338,7 +1342,7 @@ DBusMessage * wpas_dbus_handler_add_network(DBusMessage *message,
|
||||||
ssid->disabled = 1;
|
ssid->disabled = 1;
|
||||||
wpa_config_set_network_defaults(ssid);
|
wpa_config_set_network_defaults(ssid);
|
||||||
|
|
||||||
reply = set_network_properties(message, ssid, &iter);
|
reply = set_network_properties(message, wpa_s, ssid, &iter);
|
||||||
if (reply) {
|
if (reply) {
|
||||||
wpa_printf(MSG_DEBUG, "wpas_dbus_handler_add_network[dbus]:"
|
wpa_printf(MSG_DEBUG, "wpas_dbus_handler_add_network[dbus]:"
|
||||||
"control interface couldn't set network "
|
"control interface couldn't set network "
|
||||||
|
@ -2911,7 +2915,8 @@ DBusMessage * wpas_dbus_setter_network_properties(
|
||||||
|
|
||||||
dbus_message_iter_recurse(&iter, &variant_iter);
|
dbus_message_iter_recurse(&iter, &variant_iter);
|
||||||
|
|
||||||
reply = set_network_properties(message, ssid, &variant_iter);
|
reply = set_network_properties(message, net->wpa_s, ssid,
|
||||||
|
&variant_iter);
|
||||||
if (reply)
|
if (reply)
|
||||||
wpa_printf(MSG_DEBUG, "dbus control interface couldn't set "
|
wpa_printf(MSG_DEBUG, "dbus control interface couldn't set "
|
||||||
"network properties");
|
"network properties");
|
||||||
|
|
|
@ -997,6 +997,8 @@ DBusMessage * wpas_dbus_iface_set_network(DBusMessage *message,
|
||||||
value[0] == '"' && ssid->ssid_len) ||
|
value[0] == '"' && ssid->ssid_len) ||
|
||||||
(os_strcmp(entry.key, "ssid") == 0 && ssid->passphrase))
|
(os_strcmp(entry.key, "ssid") == 0 && ssid->passphrase))
|
||||||
wpa_config_update_psk(ssid);
|
wpa_config_update_psk(ssid);
|
||||||
|
else if (os_strcmp(entry.key, "priority") == 0)
|
||||||
|
wpa_config_update_prio_list(wpa_s->conf);
|
||||||
|
|
||||||
os_free(value);
|
os_free(value);
|
||||||
wpa_dbus_dict_entry_clear(&entry);
|
wpa_dbus_dict_entry_clear(&entry);
|
||||||
|
|
Loading…
Reference in a new issue