Auto sync2gitlab import of NetworkManager-1.40.10-1.el8.src.rpm
This commit is contained in:
parent
5944a9a043
commit
9ac11e5a61
1
.gitignore
vendored
1
.gitignore
vendored
@ -8,3 +8,4 @@
|
||||
/NetworkManager-1.40.4.tar.xz
|
||||
/NetworkManager-1.40.6.tar.xz
|
||||
/NetworkManager-1.40.8.tar.xz
|
||||
/NetworkManager-1.40.10.tar.xz
|
||||
|
@ -1,341 +0,0 @@
|
||||
From a021ee273afeaa5e9324270185bbfe33c64a92cf Mon Sep 17 00:00:00 2001
|
||||
From: Thomas Haller <thaller@redhat.com>
|
||||
Date: Tue, 20 Dec 2022 16:11:16 +0100
|
||||
Subject: [PATCH 1/1] Revert "policy: track the autoconnect retries in devices
|
||||
for multi-connect"
|
||||
|
||||
With multi-connect enabled, this can cause infinite retries to autoconnect,
|
||||
see [1].
|
||||
|
||||
That has bad consequences for example in initrd, where
|
||||
nm-wait-online-initrd.service would wait up to one hour before failing
|
||||
and blocking boot.
|
||||
|
||||
This reverts commit 1656d82045343b5af5b86cf129d4f2b12540b277.
|
||||
|
||||
[1] https://bugzilla.redhat.com/show_bug.cgi?id=2039734#c5
|
||||
|
||||
Fixes: 1656d8204534 ('policy: track the autoconnect retries in devices for multi-connect')
|
||||
(cherry picked from commit aec7ae8279cc9b3de7e75140b75fe997f43700fc)
|
||||
(cherry picked from commit ba663123669ae1a5670e4a85ce2cf520fea875f6)
|
||||
---
|
||||
src/core/devices/nm-device.c | 50 ----------------
|
||||
src/core/devices/nm-device.h | 5 --
|
||||
src/core/nm-policy.c | 112 ++++-------------------------------
|
||||
3 files changed, 10 insertions(+), 157 deletions(-)
|
||||
|
||||
diff --git a/src/core/devices/nm-device.c b/src/core/devices/nm-device.c
|
||||
index 059e31f298a5..056ca34c1c4d 100644
|
||||
--- a/src/core/devices/nm-device.c
|
||||
+++ b/src/core/devices/nm-device.c
|
||||
@@ -96,8 +96,6 @@
|
||||
#define NM_DEVICE_AUTH_RETRIES_INFINITY -2
|
||||
#define NM_DEVICE_AUTH_RETRIES_DEFAULT 3
|
||||
|
||||
-#define AUTOCONNECT_RESET_RETRIES_TIMER 300
|
||||
-
|
||||
/*****************************************************************************/
|
||||
|
||||
typedef void (*ActivationHandleFunc)(NMDevice *self);
|
||||
@@ -763,9 +761,6 @@ typedef struct _NMDevicePrivate {
|
||||
|
||||
GVariant *ports_variant; /* Array of port devices D-Bus path */
|
||||
char *prop_ip_iface; /* IP interface D-Bus property */
|
||||
-
|
||||
- int autoconnect_retries;
|
||||
- gint32 autoconnect_retries_blocked_until;
|
||||
} NMDevicePrivate;
|
||||
|
||||
G_DEFINE_ABSTRACT_TYPE(NMDevice, nm_device, NM_TYPE_DBUS_OBJECT)
|
||||
@@ -16881,49 +16876,6 @@ nm_device_get_initial_hw_address(NMDevice *self)
|
||||
return NM_DEVICE_GET_PRIVATE(self)->hw_addr_initial;
|
||||
}
|
||||
|
||||
-void
|
||||
-nm_device_set_autoconnect_retries(NMDevice *self, int tries)
|
||||
-{
|
||||
- NMDevicePrivate *priv = NM_DEVICE_GET_PRIVATE(self);
|
||||
-
|
||||
- if (priv->autoconnect_retries != tries) {
|
||||
- _LOGT(LOGD_DEVICE, "autoconnect: retries set %d", tries);
|
||||
- priv->autoconnect_retries = tries;
|
||||
- }
|
||||
-
|
||||
- if (tries)
|
||||
- priv->autoconnect_retries_blocked_until = 0; /* we are not blocked anymore */
|
||||
- else
|
||||
- priv->autoconnect_retries_blocked_until =
|
||||
- nm_utils_get_monotonic_timestamp_sec() + AUTOCONNECT_RESET_RETRIES_TIMER;
|
||||
-}
|
||||
-
|
||||
-int
|
||||
-nm_device_get_autoconnect_retries(NMDevice *self)
|
||||
-{
|
||||
- NMDevicePrivate *priv = NM_DEVICE_GET_PRIVATE(self);
|
||||
-
|
||||
- return priv->autoconnect_retries;
|
||||
-}
|
||||
-
|
||||
-gint32
|
||||
-nm_device_autoconnect_retries_blocked_until(NMDevice *self)
|
||||
-{
|
||||
- NMDevicePrivate *priv = NM_DEVICE_GET_PRIVATE(self);
|
||||
-
|
||||
- return priv->autoconnect_retries_blocked_until;
|
||||
-}
|
||||
-
|
||||
-void
|
||||
-nm_device_autoconnect_retries_reset(NMDevice *self)
|
||||
-{
|
||||
- NMDevicePrivate *priv = NM_DEVICE_GET_PRIVATE(self);
|
||||
-
|
||||
- /* default value, we will sync. with connection value when needed */
|
||||
- priv->autoconnect_retries = -2;
|
||||
- priv->autoconnect_retries_blocked_until = 0;
|
||||
-}
|
||||
-
|
||||
/**
|
||||
* nm_device_spec_match_list:
|
||||
* @self: an #NMDevice
|
||||
@@ -17675,8 +17627,6 @@ nm_device_init(NMDevice *self)
|
||||
priv->sys_iface_state_ = NM_DEVICE_SYS_IFACE_STATE_EXTERNAL;
|
||||
|
||||
priv->promisc_reset = NM_OPTION_BOOL_DEFAULT;
|
||||
-
|
||||
- priv->autoconnect_retries = -2;
|
||||
}
|
||||
|
||||
static GObject *
|
||||
diff --git a/src/core/devices/nm-device.h b/src/core/devices/nm-device.h
|
||||
index fea46bb78cae..de850e68f2a1 100644
|
||||
--- a/src/core/devices/nm-device.h
|
||||
+++ b/src/core/devices/nm-device.h
|
||||
@@ -464,11 +464,6 @@ const char *nm_device_get_permanent_hw_address_full(NMDevice *self,
|
||||
gboolean *out_is_fake);
|
||||
const char *nm_device_get_initial_hw_address(NMDevice *dev);
|
||||
|
||||
-void nm_device_set_autoconnect_retries(NMDevice *self, int tries);
|
||||
-int nm_device_get_autoconnect_retries(NMDevice *self);
|
||||
-gint32 nm_device_autoconnect_retries_blocked_until(NMDevice *self);
|
||||
-void nm_device_autoconnect_retries_reset(NMDevice *self);
|
||||
-
|
||||
NMDhcpConfig *nm_device_get_dhcp_config(NMDevice *dev, int addr_family);
|
||||
|
||||
NML3Cfg *nm_device_get_l3cfg(NMDevice *self);
|
||||
diff --git a/src/core/nm-policy.c b/src/core/nm-policy.c
|
||||
index 518fc596dc88..0c07c29e98eb 100644
|
||||
--- a/src/core/nm-policy.c
|
||||
+++ b/src/core/nm-policy.c
|
||||
@@ -1579,7 +1579,6 @@ nm_policy_unblock_failed_ovs_interfaces(NMPolicy *self)
|
||||
NMPolicyPrivate *priv = NM_POLICY_GET_PRIVATE(self);
|
||||
NMSettingsConnection *const *connections = NULL;
|
||||
guint i;
|
||||
- gboolean multiconnect = FALSE;
|
||||
|
||||
_LOGT(LOGD_DEVICE, "unblocking failed OVS interfaces");
|
||||
|
||||
@@ -1587,13 +1586,6 @@ nm_policy_unblock_failed_ovs_interfaces(NMPolicy *self)
|
||||
for (i = 0; connections[i]; i++) {
|
||||
NMSettingsConnection *sett_conn = connections[i];
|
||||
NMConnection *connection = nm_settings_connection_get_connection(sett_conn);
|
||||
- NMSettingConnection *s_con = nm_connection_get_setting_connection(connection);
|
||||
-
|
||||
- /* Check if any connection is connect multiple */
|
||||
- if (s_con
|
||||
- && nm_setting_connection_get_multi_connect(s_con)
|
||||
- == NM_CONNECTION_MULTI_CONNECT_MULTIPLE)
|
||||
- multiconnect = TRUE;
|
||||
|
||||
if (nm_connection_get_setting_ovs_interface(connection)) {
|
||||
nm_settings_connection_autoconnect_retries_reset(sett_conn);
|
||||
@@ -1603,18 +1595,6 @@ nm_policy_unblock_failed_ovs_interfaces(NMPolicy *self)
|
||||
FALSE);
|
||||
}
|
||||
}
|
||||
-
|
||||
- /* There is, at least, one multiconnect connection with an OVS setting.
|
||||
- * Let's check the OVS devices retries */
|
||||
- if (multiconnect) {
|
||||
- NMDevice *device;
|
||||
- GHashTableIter h_iter;
|
||||
- g_hash_table_iter_init(&h_iter, priv->devices);
|
||||
- while (g_hash_table_iter_next(&h_iter, (gpointer *) &device, NULL)) {
|
||||
- if (nm_device_get_device_type(device) == NM_DEVICE_TYPE_OVS_INTERFACE)
|
||||
- nm_device_autoconnect_retries_reset(device);
|
||||
- }
|
||||
- }
|
||||
}
|
||||
|
||||
static gboolean
|
||||
@@ -1626,8 +1606,7 @@ reset_autoconnect_all(
|
||||
NMPolicyPrivate *priv = NM_POLICY_GET_PRIVATE(self);
|
||||
NMSettingsConnection *const *connections = NULL;
|
||||
guint i;
|
||||
- gboolean changed = FALSE;
|
||||
- gboolean multiconnect = FALSE;
|
||||
+ gboolean changed = FALSE;
|
||||
|
||||
_LOGD(LOGD_DEVICE,
|
||||
"re-enabling autoconnect for all connections%s%s%s",
|
||||
@@ -1638,8 +1617,6 @@ reset_autoconnect_all(
|
||||
connections = nm_settings_get_connections(priv->settings, NULL);
|
||||
for (i = 0; connections[i]; i++) {
|
||||
NMSettingsConnection *sett_conn = connections[i];
|
||||
- NMSettingConnection *s_con =
|
||||
- nm_connection_get_setting_connection(nm_settings_connection_get_connection(sett_conn));
|
||||
|
||||
if (device
|
||||
&& !nm_device_check_connection_compatible(
|
||||
@@ -1648,11 +1625,6 @@ reset_autoconnect_all(
|
||||
NULL))
|
||||
continue;
|
||||
|
||||
- if (s_con
|
||||
- && nm_setting_connection_get_multi_connect(s_con)
|
||||
- == NM_CONNECTION_MULTI_CONNECT_MULTIPLE)
|
||||
- multiconnect = TRUE;
|
||||
-
|
||||
if (only_no_secrets) {
|
||||
/* we only reset the no-secrets blocked flag. */
|
||||
if (nm_settings_connection_autoconnect_blocked_reason_set(
|
||||
@@ -1681,20 +1653,6 @@ reset_autoconnect_all(
|
||||
}
|
||||
}
|
||||
}
|
||||
-
|
||||
- /* There is, at least, one multiconnect connection. Let's check the devices retries */
|
||||
- if (multiconnect) {
|
||||
- NMDevice *device_iter;
|
||||
- GHashTableIter h_iter;
|
||||
- g_hash_table_iter_init(&h_iter, priv->devices);
|
||||
- while (g_hash_table_iter_next(&h_iter, (gpointer *) &device_iter, NULL)) {
|
||||
- if (nm_device_get_autoconnect_retries(device_iter) != -2) {
|
||||
- nm_device_autoconnect_retries_reset(device_iter);
|
||||
- changed = TRUE;
|
||||
- }
|
||||
- }
|
||||
- }
|
||||
-
|
||||
return changed;
|
||||
}
|
||||
|
||||
@@ -1752,8 +1710,7 @@ reset_connections_retries(gpointer user_data)
|
||||
NMSettingsConnection *const *connections = NULL;
|
||||
guint i;
|
||||
gint32 con_stamp, min_stamp, now;
|
||||
- gboolean changed = FALSE;
|
||||
- gboolean multiconnect = FALSE;
|
||||
+ gboolean changed = FALSE;
|
||||
|
||||
priv->reset_retries_id = 0;
|
||||
|
||||
@@ -1762,14 +1719,6 @@ reset_connections_retries(gpointer user_data)
|
||||
connections = nm_settings_get_connections(priv->settings, NULL);
|
||||
for (i = 0; connections[i]; i++) {
|
||||
NMSettingsConnection *connection = connections[i];
|
||||
- NMSettingConnection *s_con =
|
||||
- nm_connection_get_setting_connection(nm_settings_connection_get_connection(connection));
|
||||
-
|
||||
- /* Check if any connection is connect multiple */
|
||||
- if (s_con
|
||||
- && nm_setting_connection_get_multi_connect(s_con)
|
||||
- == NM_CONNECTION_MULTI_CONNECT_MULTIPLE)
|
||||
- multiconnect = TRUE;
|
||||
|
||||
con_stamp = nm_settings_connection_autoconnect_retries_blocked_until(connection);
|
||||
if (con_stamp == 0)
|
||||
@@ -1782,25 +1731,6 @@ reset_connections_retries(gpointer user_data)
|
||||
min_stamp = con_stamp;
|
||||
}
|
||||
|
||||
- /* There is, at least, one multiconnect connection. Let's check the devices retries */
|
||||
- if (multiconnect) {
|
||||
- NMDevice *device;
|
||||
- GHashTableIter h_iter;
|
||||
- g_hash_table_iter_init(&h_iter, priv->devices);
|
||||
- while (g_hash_table_iter_next(&h_iter, (gpointer *) &device, NULL)) {
|
||||
- con_stamp = nm_device_autoconnect_retries_blocked_until(device);
|
||||
-
|
||||
- /* default value in device is -2, which means, we do not care */
|
||||
- if (con_stamp <= 0)
|
||||
- continue;
|
||||
- if (con_stamp <= now) {
|
||||
- nm_device_autoconnect_retries_reset(device);
|
||||
- changed = TRUE;
|
||||
- } else if (min_stamp == 0 || min_stamp > con_stamp)
|
||||
- min_stamp = con_stamp;
|
||||
- }
|
||||
- }
|
||||
-
|
||||
/* Schedule the handler again if there are some stamps left */
|
||||
if (min_stamp != 0)
|
||||
priv->reset_retries_id =
|
||||
@@ -1814,31 +1744,21 @@ reset_connections_retries(gpointer user_data)
|
||||
}
|
||||
|
||||
static void
|
||||
-_connection_autoconnect_retries_set(NMPolicy *self,
|
||||
- NMSettingsConnection *connection,
|
||||
- NMDevice *device,
|
||||
- int tries)
|
||||
+_connection_autoconnect_retries_set(NMPolicy *self, NMSettingsConnection *connection, int tries)
|
||||
{
|
||||
- NMPolicyPrivate *priv = NM_POLICY_GET_PRIVATE(self);
|
||||
- NMSettingConnection *s_con;
|
||||
- gint32 retry_time;
|
||||
+ NMPolicyPrivate *priv = NM_POLICY_GET_PRIVATE(self);
|
||||
|
||||
nm_assert(NM_IS_SETTINGS_CONNECTION(connection));
|
||||
nm_assert(tries >= 0);
|
||||
|
||||
- s_con = nm_connection_get_setting_connection(nm_settings_connection_get_connection(connection));
|
||||
- if (s_con
|
||||
- && nm_setting_connection_get_multi_connect(s_con) == NM_CONNECTION_MULTI_CONNECT_MULTIPLE) {
|
||||
- nm_device_set_autoconnect_retries(device, tries);
|
||||
- retry_time = nm_device_autoconnect_retries_blocked_until(device);
|
||||
- } else {
|
||||
- nm_settings_connection_autoconnect_retries_set(connection, tries);
|
||||
- retry_time = nm_settings_connection_autoconnect_retries_blocked_until(connection);
|
||||
- }
|
||||
+ nm_settings_connection_autoconnect_retries_set(connection, tries);
|
||||
|
||||
if (tries == 0) {
|
||||
/* Schedule a handler to reset retries count */
|
||||
if (!priv->reset_retries_id) {
|
||||
+ gint32 retry_time =
|
||||
+ nm_settings_connection_autoconnect_retries_blocked_until(connection);
|
||||
+
|
||||
g_warn_if_fail(retry_time != 0);
|
||||
priv->reset_retries_id =
|
||||
g_timeout_add_seconds(MAX(0, retry_time - nm_utils_get_monotonic_timestamp_sec()),
|
||||
@@ -2100,25 +2020,13 @@ device_state_changed(NMDevice *device,
|
||||
}
|
||||
|
||||
if (!blocked) {
|
||||
- s_con = nm_connection_get_setting_connection(
|
||||
- nm_settings_connection_get_connection(sett_conn));
|
||||
- if (s_con
|
||||
- && nm_setting_connection_get_multi_connect(s_con)
|
||||
- == NM_CONNECTION_MULTI_CONNECT_MULTIPLE) {
|
||||
- if (nm_device_get_autoconnect_retries(device) == -2)
|
||||
- nm_device_set_autoconnect_retries(
|
||||
- device,
|
||||
- nm_settings_connection_autoconnect_retries_get(sett_conn));
|
||||
-
|
||||
- tries = nm_device_get_autoconnect_retries(device);
|
||||
- } else
|
||||
- tries = nm_settings_connection_autoconnect_retries_get(sett_conn);
|
||||
+ tries = nm_settings_connection_autoconnect_retries_get(sett_conn);
|
||||
if (tries > 0) {
|
||||
_LOGD(LOGD_DEVICE,
|
||||
"connection '%s' failed to autoconnect; %d tries left",
|
||||
nm_settings_connection_get_id(sett_conn),
|
||||
tries - 1);
|
||||
- _connection_autoconnect_retries_set(self, sett_conn, device, tries - 1);
|
||||
+ _connection_autoconnect_retries_set(self, sett_conn, tries - 1);
|
||||
} else if (tries != 0) {
|
||||
_LOGD(LOGD_DEVICE,
|
||||
"connection '%s' failed to autoconnect; infinite tries left",
|
||||
--
|
||||
2.38.1
|
||||
|
@ -4,9 +4,9 @@
|
||||
%global glib2_version %(pkg-config --modversion glib-2.0 2>/dev/null || echo bad)
|
||||
|
||||
%global epoch_version 1
|
||||
%global real_version 1.40.8
|
||||
%global real_version 1.40.10
|
||||
%global rpm_version %{real_version}
|
||||
%global release_version 2
|
||||
%global release_version 1
|
||||
%global snapshot %{nil}
|
||||
%global git_sha %{nil}
|
||||
%global bcond_default_debug 0
|
||||
@ -196,7 +196,6 @@ Patch3: 0003-order-ipv6-addresses.patch
|
||||
|
||||
# Bugfixes that are only relevant until next rebase of the package.
|
||||
# Patch1001: 1001-some.patch
|
||||
Patch1001: 1001-Revert-policy-track-the-autoconnect-retries-in-devic.patch
|
||||
|
||||
Requires(post): systemd
|
||||
%if 0%{?fedora} || 0%{?rhel} >= 8
|
||||
@ -1232,6 +1231,12 @@ fi
|
||||
|
||||
|
||||
%changelog
|
||||
* Wed Jan 11 2023 Beniamino Galvani <bgalvani@redhat.com> - 1:1.40.10-1
|
||||
- Update to 1.40.10 release
|
||||
- cloud-setup: preserve addresses added externally (rh #2132754)
|
||||
- veth: fix detection of existing interface and peer (rh #2129829)
|
||||
- dns: ensure dnsmasq is stopped after disabling it and a restart (rh #2120763)
|
||||
|
||||
* Wed Dec 21 2022 Thomas Haller <thaller@redhat.com> - 1:1.40.8-2
|
||||
- core: avoid infinite autoconnect with multi-connect profiles (rh #2155531)
|
||||
|
||||
|
2
sources
2
sources
@ -1 +1 @@
|
||||
SHA512 (NetworkManager-1.40.8.tar.xz) = 1c3f986c0f37160fced3cc790f6e569ae2185aec2bb2b5ef9635848ba493d4e920cc7ea83cd34a8df7bc12902d071238f9ae6aeb7721658ac54ba862f7c822ef
|
||||
SHA512 (NetworkManager-1.40.10.tar.xz) = 7454791592664a49f9340ee55b4c9abe0f32c00cb36a7864bf0da099315f874aebcb56103fb8c45f6420e60e4e9e030339e0e76db32f7c49ff64f6faed1ec18c
|
||||
|
Loading…
Reference in New Issue
Block a user