From: Yu Watanabe Date: Thu, 31 Oct 2024 19:56:12 +0000 (+0900) Subject: network/netdev: always queue request of creating netdev then process it later X-Git-Tag: v257-rc2~18^2~6 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=259125d53d98541623b69e83000b5543f2352f5e;p=thirdparty%2Fsystemd.git network/netdev: always queue request of creating netdev then process it later After PR #34909, networkd tries to update an existing netdev interface if possible. But, when .netdev files are loaded on start, we have not enumerate interfaces, so we do not know if the corresponding interface exists or not. Let's delay processing request a bit. --- diff --git a/src/network/netdev/netdev.c b/src/network/netdev/netdev.c index 67a98576fd6..32050ecf60d 100644 --- a/src/network/netdev/netdev.c +++ b/src/network/netdev/netdev.c @@ -965,21 +965,9 @@ static int netdev_request_to_create(NetDev *netdev) { if (netdev->state != NETDEV_STATE_LOADING) return 0; /* Already configured (at least tried previously). Not necessary to reconfigure. */ - r = netdev_is_ready_to_create(netdev, NULL); + r = netdev_queue_request(netdev, independent_netdev_process_request, NULL); if (r < 0) - return r; - if (r > 0) { - /* If the netdev has no dependency, then create it now. */ - r = independent_netdev_create(netdev); - if (r < 0) - return log_netdev_warning_errno(netdev, r, "Failed to create netdev: %m"); - - } else { - /* Otherwise, wait for the dependencies being resolved. */ - r = netdev_queue_request(netdev, independent_netdev_process_request, NULL); - if (r < 0) - return log_netdev_warning_errno(netdev, r, "Failed to request to create netdev: %m"); - } + return log_netdev_warning_errno(netdev, r, "Failed to request to create netdev: %m"); return 0; }