mirror of
https://gitlab.freedesktop.org/NetworkManager/NetworkManager.git
synced 2026-02-04 14:10:36 +01:00
manager: rename nm_manager_write_device_state()
Rename nm_manager_write_device_state() to nm_manager_write_device_state_all(), and split out the code to write a single device state to a new function.
This commit is contained in:
parent
bdebb8e2cf
commit
060f2138ee
3 changed files with 64 additions and 54 deletions
|
|
@ -443,7 +443,7 @@ done:
|
|||
* state here. We don't bother updating the state as devices
|
||||
* change during regular operation. If NM is killed with SIGKILL,
|
||||
* it misses to update the state. */
|
||||
nm_manager_write_device_state (manager);
|
||||
nm_manager_write_device_state_all (manager);
|
||||
|
||||
nm_manager_stop (manager);
|
||||
|
||||
|
|
|
|||
113
src/nm-manager.c
113
src/nm-manager.c
|
|
@ -5934,66 +5934,75 @@ start_factory (NMDeviceFactory *factory, gpointer user_data)
|
|||
nm_device_factory_start (factory);
|
||||
}
|
||||
|
||||
void
|
||||
nm_manager_write_device_state (NMManager *self)
|
||||
gboolean
|
||||
nm_manager_write_device_state (NMManager *self, NMDevice *device)
|
||||
{
|
||||
NMManagerPrivate *priv = NM_MANAGER_GET_PRIVATE (self);
|
||||
NMDevice *device;
|
||||
gs_unref_hashtable GHashTable *seen_ifindexes = NULL;
|
||||
int ifindex;
|
||||
gboolean managed;
|
||||
NMConfigDeviceStateManagedType managed_type;
|
||||
NMConnection *settings_connection;
|
||||
const char *uuid = NULL;
|
||||
const char *perm_hw_addr_fake = NULL;
|
||||
gboolean perm_hw_addr_is_fake;
|
||||
guint32 route_metric_default_aspired;
|
||||
guint32 route_metric_default_effective;
|
||||
int nm_owned;
|
||||
|
||||
ifindex = nm_device_get_ip_ifindex (device);
|
||||
if (ifindex <= 0)
|
||||
return FALSE;
|
||||
if (ifindex == 1) {
|
||||
/* ignore loopback */
|
||||
return FALSE;
|
||||
}
|
||||
|
||||
if (!nm_platform_link_get (priv->platform, ifindex))
|
||||
return FALSE;
|
||||
|
||||
managed = nm_device_get_managed (device, FALSE);
|
||||
if (managed) {
|
||||
settings_connection = NM_CONNECTION (nm_device_get_settings_connection (device));
|
||||
if (settings_connection)
|
||||
uuid = nm_connection_get_uuid (settings_connection);
|
||||
managed_type = NM_CONFIG_DEVICE_STATE_MANAGED_TYPE_MANAGED;
|
||||
} else if (nm_device_get_unmanaged_flags (device, NM_UNMANAGED_USER_EXPLICIT))
|
||||
managed_type = NM_CONFIG_DEVICE_STATE_MANAGED_TYPE_UNMANAGED;
|
||||
else
|
||||
managed_type = NM_CONFIG_DEVICE_STATE_MANAGED_TYPE_UNKNOWN;
|
||||
|
||||
perm_hw_addr_fake = nm_device_get_permanent_hw_address_full (device, FALSE, &perm_hw_addr_is_fake);
|
||||
if (perm_hw_addr_fake && !perm_hw_addr_is_fake)
|
||||
perm_hw_addr_fake = NULL;
|
||||
|
||||
nm_owned = nm_device_is_software (device) ? nm_device_is_nm_owned (device) : -1;
|
||||
|
||||
route_metric_default_effective = _device_route_metric_get (self, ifindex, NM_DEVICE_TYPE_UNKNOWN,
|
||||
TRUE, &route_metric_default_aspired);
|
||||
|
||||
return nm_config_device_state_write (ifindex,
|
||||
managed_type,
|
||||
perm_hw_addr_fake,
|
||||
uuid,
|
||||
nm_owned,
|
||||
route_metric_default_aspired,
|
||||
route_metric_default_effective);
|
||||
}
|
||||
|
||||
void
|
||||
nm_manager_write_device_state_all (NMManager *self)
|
||||
{
|
||||
NMManagerPrivate *priv = NM_MANAGER_GET_PRIVATE (self);
|
||||
gs_unref_hashtable GHashTable *seen_ifindexes = NULL;
|
||||
NMDevice *device;
|
||||
|
||||
seen_ifindexes = g_hash_table_new (nm_direct_hash, NULL);
|
||||
|
||||
c_list_for_each_entry (device, &priv->devices_lst_head, devices_lst) {
|
||||
int ifindex;
|
||||
gboolean managed;
|
||||
NMConfigDeviceStateManagedType managed_type;
|
||||
NMConnection *settings_connection;
|
||||
const char *uuid = NULL;
|
||||
const char *perm_hw_addr_fake = NULL;
|
||||
gboolean perm_hw_addr_is_fake;
|
||||
guint32 route_metric_default_aspired;
|
||||
guint32 route_metric_default_effective;
|
||||
|
||||
ifindex = nm_device_get_ip_ifindex (device);
|
||||
if (ifindex <= 0)
|
||||
continue;
|
||||
if (ifindex == 1) {
|
||||
/* ignore loopback */
|
||||
continue;
|
||||
if (nm_manager_write_device_state (self, device)) {
|
||||
g_hash_table_add (seen_ifindexes,
|
||||
GINT_TO_POINTER (nm_device_get_ip_ifindex (device)));
|
||||
}
|
||||
|
||||
if (!nm_platform_link_get (priv->platform, ifindex))
|
||||
continue;
|
||||
|
||||
managed = nm_device_get_managed (device, FALSE);
|
||||
if (managed) {
|
||||
settings_connection = NM_CONNECTION (nm_device_get_settings_connection (device));
|
||||
if (settings_connection)
|
||||
uuid = nm_connection_get_uuid (settings_connection);
|
||||
managed_type = NM_CONFIG_DEVICE_STATE_MANAGED_TYPE_MANAGED;
|
||||
} else if (nm_device_get_unmanaged_flags (device, NM_UNMANAGED_USER_EXPLICIT))
|
||||
managed_type = NM_CONFIG_DEVICE_STATE_MANAGED_TYPE_UNMANAGED;
|
||||
else
|
||||
managed_type = NM_CONFIG_DEVICE_STATE_MANAGED_TYPE_UNKNOWN;
|
||||
|
||||
perm_hw_addr_fake = nm_device_get_permanent_hw_address_full (device, FALSE, &perm_hw_addr_is_fake);
|
||||
if (perm_hw_addr_fake && !perm_hw_addr_is_fake)
|
||||
perm_hw_addr_fake = NULL;
|
||||
|
||||
nm_owned = nm_device_is_software (device) ? nm_device_is_nm_owned (device) : -1;
|
||||
|
||||
route_metric_default_effective = _device_route_metric_get (self, ifindex, NM_DEVICE_TYPE_UNKNOWN,
|
||||
TRUE, &route_metric_default_aspired);
|
||||
|
||||
if (nm_config_device_state_write (ifindex,
|
||||
managed_type,
|
||||
perm_hw_addr_fake,
|
||||
uuid,
|
||||
nm_owned,
|
||||
route_metric_default_aspired,
|
||||
route_metric_default_effective))
|
||||
g_hash_table_add (seen_ifindexes, GINT_TO_POINTER (ifindex));
|
||||
}
|
||||
|
||||
nm_config_device_state_prune_unseen (seen_ifindexes);
|
||||
|
|
|
|||
|
|
@ -101,7 +101,8 @@ NMSettingsConnection **nm_manager_get_activatable_connections (NMManager *manage
|
|||
guint *out_len,
|
||||
gboolean sort);
|
||||
|
||||
void nm_manager_write_device_state (NMManager *manager);
|
||||
void nm_manager_write_device_state_all (NMManager *manager);
|
||||
gboolean nm_manager_write_device_state (NMManager *manager, NMDevice *device);
|
||||
|
||||
/* Device handling */
|
||||
|
||||
|
|
|
|||
Loading…
Add table
Reference in a new issue