138 lines
4.2 KiB
Diff
138 lines
4.2 KiB
Diff
|
|
From f17b74371b14b97521462724069812fc9728b9ed Mon Sep 17 00:00:00 2001
|
|||
|
|
From: kircher <majun65@huawei.com>
|
|||
|
|
Date: Tue, 21 Mar 2023 15:36:52 +0800
|
|||
|
|
Subject: [PATCH] waiting when primary process not start already
|
|||
|
|
|
|||
|
|
---
|
|||
|
|
src/common/gazelle_opt.h | 1 +
|
|||
|
|
src/lstack/api/lstack_signal.c | 7 +++--
|
|||
|
|
src/lstack/core/lstack_control_plane.c | 6 ++++
|
|||
|
|
src/lstack/core/lstack_init.c | 34 +++++++++++++++++++++++
|
|||
|
|
src/lstack/include/lstack_control_plane.h | 1 +
|
|||
|
|
5 files changed, 47 insertions(+), 2 deletions(-)
|
|||
|
|
|
|||
|
|
diff --git a/src/common/gazelle_opt.h b/src/common/gazelle_opt.h
|
|||
|
|
index 4c0eef3..fe0483b 100644
|
|||
|
|
--- a/src/common/gazelle_opt.h
|
|||
|
|
+++ b/src/common/gazelle_opt.h
|
|||
|
|
@@ -85,6 +85,7 @@
|
|||
|
|
#define GAZELLE_SOCK_FILENAME_MAXLEN 128
|
|||
|
|
|
|||
|
|
#define GAZELLE_RUN_DIR "/var/run/gazelle/"
|
|||
|
|
+#define GAZELLE_PRIMARY_START_PATH "/var/run/gazelle/gazelle_primary"
|
|||
|
|
#define GAZELLE_FILE_PERMISSION 0700
|
|||
|
|
|
|||
|
|
#define SEND_TIME_WAIT_NS 20000
|
|||
|
|
diff --git a/src/lstack/api/lstack_signal.c b/src/lstack/api/lstack_signal.c
|
|||
|
|
index e73bc61..03118f5 100644
|
|||
|
|
--- a/src/lstack/api/lstack_signal.c
|
|||
|
|
+++ b/src/lstack/api/lstack_signal.c
|
|||
|
|
@@ -57,12 +57,15 @@ static inline bool match_hijack_signal(int sig)
|
|||
|
|
static void lstack_sig_default_handler(int sig)
|
|||
|
|
{
|
|||
|
|
LSTACK_LOG(ERR, LSTACK, "lstack dumped,caught signal:%d\n", sig);
|
|||
|
|
- dump_stack();
|
|||
|
|
- lwip_exit();
|
|||
|
|
+ if (get_global_cfg_params() && get_global_cfg_params()->is_primary) {
|
|||
|
|
+ delete_primary_path();
|
|||
|
|
+ }
|
|||
|
|
if (!use_ltran()) {
|
|||
|
|
dpdk_kni_release();
|
|||
|
|
}
|
|||
|
|
control_fd_close();
|
|||
|
|
+ dump_stack();
|
|||
|
|
+ lwip_exit();
|
|||
|
|
(void)kill(getpid(), sig);
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
diff --git a/src/lstack/core/lstack_control_plane.c b/src/lstack/core/lstack_control_plane.c
|
|||
|
|
index bc2c55d..e705cae 100644
|
|||
|
|
--- a/src/lstack/core/lstack_control_plane.c
|
|||
|
|
+++ b/src/lstack/core/lstack_control_plane.c
|
|||
|
|
@@ -473,6 +473,12 @@ void control_fd_close(void)
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
+void delete_primary_path(void) {
|
|||
|
|
+ if (!remove(GAZELLE_PRIMARY_START_PATH)) {
|
|||
|
|
+ LSTACK_LOG(ERR, LSTACK, "delete %s failed\n", GAZELLE_PRIMARY_START_PATH);
|
|||
|
|
+ }
|
|||
|
|
+}
|
|||
|
|
+
|
|||
|
|
int32_t control_init_client(bool is_reconnect)
|
|||
|
|
{
|
|||
|
|
int32_t ret;
|
|||
|
|
diff --git a/src/lstack/core/lstack_init.c b/src/lstack/core/lstack_init.c
|
|||
|
|
index e8fa0dc..3537002 100644
|
|||
|
|
--- a/src/lstack/core/lstack_init.c
|
|||
|
|
+++ b/src/lstack/core/lstack_init.c
|
|||
|
|
@@ -151,6 +151,32 @@ bool select_thread_path(void)
|
|||
|
|
return true;
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
+static void check_process_start(void) {
|
|||
|
|
+ if (get_global_cfg_params()->is_primary) {
|
|||
|
|
+ return;
|
|||
|
|
+ }
|
|||
|
|
+
|
|||
|
|
+ while (!fopen(GAZELLE_PRIMARY_START_PATH, "r")) {
|
|||
|
|
+ printf("please make sure the primary process start already!\n");
|
|||
|
|
+ sleep(1);
|
|||
|
|
+ }
|
|||
|
|
+}
|
|||
|
|
+
|
|||
|
|
+static int32_t set_process_start_flag(void) {
|
|||
|
|
+ if (!get_global_cfg_params()->is_primary) {
|
|||
|
|
+ return 0;
|
|||
|
|
+ }
|
|||
|
|
+
|
|||
|
|
+ FILE *fp = NULL;
|
|||
|
|
+ fp = fopen(GAZELLE_PRIMARY_START_PATH, "w");
|
|||
|
|
+ if (fp == NULL) {
|
|||
|
|
+ LSTACK_PRE_LOG(LSTACK_ERR, "set primary proceaa start flag failed!\n");
|
|||
|
|
+ return -1;
|
|||
|
|
+ }
|
|||
|
|
+ (void)fclose(fp);
|
|||
|
|
+ return 0;
|
|||
|
|
+}
|
|||
|
|
+
|
|||
|
|
static int32_t check_process_conflict(void)
|
|||
|
|
{
|
|||
|
|
int32_t ret;
|
|||
|
|
@@ -340,6 +366,10 @@ __attribute__((constructor)) void gazelle_network_init(void)
|
|||
|
|
}
|
|||
|
|
LSTACK_PRE_LOG(LSTACK_INFO, "cfg_init success\n");
|
|||
|
|
|
|||
|
|
+ /*
|
|||
|
|
+ * check primary process start */
|
|||
|
|
+ check_process_start();
|
|||
|
|
+
|
|||
|
|
/*
|
|||
|
|
* check conflict */
|
|||
|
|
if (check_process_conflict() < 0) {
|
|||
|
|
@@ -402,6 +432,10 @@ __attribute__((constructor)) void gazelle_network_init(void)
|
|||
|
|
set_kni_ip_mac();
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
+ if (set_process_start_flag() != 0) {
|
|||
|
|
+ LSTACK_EXIT(1, "set_process_start_flag failed\n");
|
|||
|
|
+ }
|
|||
|
|
+
|
|||
|
|
posix_api->ues_posix = 0;
|
|||
|
|
LSTACK_LOG(INFO, LSTACK, "gazelle_network_init success\n");
|
|||
|
|
rte_smp_mb();
|
|||
|
|
diff --git a/src/lstack/include/lstack_control_plane.h b/src/lstack/include/lstack_control_plane.h
|
|||
|
|
index d631ea6..aed5443 100644
|
|||
|
|
--- a/src/lstack/include/lstack_control_plane.h
|
|||
|
|
+++ b/src/lstack/include/lstack_control_plane.h
|
|||
|
|
@@ -32,5 +32,6 @@ bool get_register_state(void);
|
|||
|
|
void thread_register_phase1(struct rpc_msg *msg);
|
|||
|
|
void thread_register_phase2(struct rpc_msg *msg);
|
|||
|
|
void control_fd_close(void);
|
|||
|
|
+void delete_primary_path(void);
|
|||
|
|
|
|||
|
|
#endif /* GAZELLE_CONTROL_PLANE_H */
|
|||
|
|
--
|
|||
|
|
2.33.0
|
|||
|
|
|