gazelle/0243-virtio_user-check-netif-status.patch
yinbin6 f8c9051310 sync virtio: solve compilation error in 2003sp3
(cherry picked from commit 3cb696fd4a62cdcce26b465c8d911d3a838d3ebf)
2024-08-26 16:00:49 +08:00

74 lines
2.0 KiB
Diff

From 1b994a0e9cd2dfa59076b35e3e4c82b1a18c9e1d Mon Sep 17 00:00:00 2001
From: hkk <hankangkang5@huawei.com>
Date: Mon, 19 Aug 2024 16:34:54 +0800
Subject: [PATCH] virtio_user: check netif status
---
src/lstack/core/lstack_virtio.c | 35 +++++++++++++++++++++++++++++++--
1 file changed, 33 insertions(+), 2 deletions(-)
diff --git a/src/lstack/core/lstack_virtio.c b/src/lstack/core/lstack_virtio.c
index 9862b48..4a91ed7 100644
--- a/src/lstack/core/lstack_virtio.c
+++ b/src/lstack/core/lstack_virtio.c
@@ -26,6 +26,9 @@
#define VIRTIO_DPDK_PARA_LEN 256
#define VIRTIO_TX_RX_RING_SIZE 1024
+#define VIRTIO_NETIF_CHECK_MAX_TIMES 10
+#define VIRTIO_NETIF_CMD_OUTPUT 4096
+
#define VIRTIO_MASK_BITS(mask) (32 - __builtin_clz(mask))
static struct virtio_instance g_virtio_instance = {0};
@@ -123,6 +126,27 @@ static int virtio_set_ipv4_addr(void)
return 0;
}
+static int virtio_ipv6_is_tentative(void)
+{
+ FILE *fp;
+ char output[VIRTIO_NETIF_CMD_OUTPUT] = {0};
+ int not_ready = 0;
+ /* ipv6 tentative state means not ready */
+ const char *cmd = "ip a |grep tentative";
+
+ fp = popen(cmd, "r");
+ if (fp == NULL) {
+ LSTACK_LOG(ERR, LSTACK, "%s execution failed \n", cmd);
+ return -1;
+ }
+
+ if (fgets(output, sizeof(output), fp) != NULL) {
+ not_ready = 1;
+ }
+ pclose(fp);
+ return not_ready;
+}
+
static int virtio_netif_up(void)
{
int sockfd = posix_api->socket_fn(AF_INET, SOCK_DGRAM, 0);
@@ -151,9 +175,16 @@ static int virtio_netif_up(void)
/*
* For virtio_user IPv6 addresses, the kernel will check if they are valid,
* so wait a few seconds for the address status to change from scope global tentative to scope global.
- * 3:systerm check ipv6 addr
*/
- sleep(3);
+ for (int i = 0; i < VIRTIO_NETIF_CHECK_MAX_TIMES; i++) {
+ ret = virtio_ipv6_is_tentative();
+ if (ret == 0) {
+ break;
+ } else if (ret < 0) {
+ return -1;
+ }
+ sleep(1);
+ }
return 0;
}
--
2.33.0