After registration of a SignalLevelAgent, make iwd inform the client of the initial signal level via a "Changed" method call. --- src/netdev.c | 5 +++++ src/netdev.h | 1 + src/station.c | 16 ++++++++++++---- 3 files changed, 18 insertions(+), 4 deletions(-) diff --git a/src/netdev.c b/src/netdev.c index e483edf8..8b2143fd 100644 --- a/src/netdev.c +++ b/src/netdev.c @@ -450,6 +450,11 @@ const char *netdev_get_path(struct netdev *netdev) return path; } +uint8_t netdev_get_rssi_level_idx(struct netdev *netdev) +{ + return netdev->cur_rssi_level_idx; +} + static void netdev_set_powered_result(int error, uint16_t type, const void *data, uint32_t len, void *user_data) diff --git a/src/netdev.h b/src/netdev.h index 0094d5f9..f093c499 100644 --- a/src/netdev.h +++ b/src/netdev.h @@ -145,6 +145,7 @@ bool netdev_get_4addr(struct netdev *netdev); const char *netdev_get_name(struct netdev *netdev); bool netdev_get_is_up(struct netdev *netdev); const char *netdev_get_path(struct netdev *netdev); +uint8_t netdev_get_rssi_level_idx(struct netdev *netdev); struct handshake_state *netdev_handshake_state_new(struct netdev *netdev); struct handshake_state *netdev_get_handshake(struct netdev *netdev); diff --git a/src/station.c b/src/station.c index 2d85054c..7be256fe 100644 --- a/src/station.c +++ b/src/station.c @@ -3709,6 +3709,16 @@ static void signal_agent_disconnect(struct l_dbus *dbus, void *user_data) netdev_set_rssi_report_levels(station->netdev, NULL, 0); } +static void signal_agent_notify_initial(void *user_data) +{ + struct station *station = user_data; + struct netdev *netdev = station->netdev; + + station_signal_agent_notify(station->signal_agent, + netdev_get_path(netdev), + netdev_get_rssi_level_idx(netdev)); +} + static struct l_dbus_message *station_dbus_signal_agent_register( struct l_dbus *dbus, struct l_dbus_message *message, @@ -3758,10 +3768,8 @@ static struct l_dbus_message *station_dbus_signal_agent_register( l_debug("agent %s path %s", sender, path); - /* - * TODO: send an initial notification in a oneshot idle callback, - * if state is connected. - */ + if (station->connected_network) + l_idle_oneshot(signal_agent_notify_initial, station, NULL); return l_dbus_message_new_method_return(message); } -- 2.36.0