diff options
author | Dimitri Staessens <dimitri@ouroboros.rocks> | 2022-07-08 16:55:51 +0200 |
---|---|---|
committer | Sander Vrijders <sander@ouroboros.rocks> | 2022-07-13 08:56:02 +0200 |
commit | 763227aee4a3d86e718c3665fe5fa13055f67f03 (patch) | |
tree | 837a603731335d950e45e7bc2aada9d2448d7a6b /src/ipcpd/local/main.c | |
parent | b9d674dc5a63b0206d96ff67366ed84c6d5d2962 (diff) | |
download | ouroboros-763227aee4a3d86e718c3665fe5fa13055f67f03.tar.gz ouroboros-763227aee4a3d86e718c3665fe5fa13055f67f03.zip |
ipcpd: Refactor main functions
The structure of main functions of the IPCPs was a bit strange with a
ipcp_shutdown() call that combined waiting for a terminating signal
with stopping the internal threads. This is now revised into a
symmetrical design of
ipcp_start(), which now includes the create response towards the IRMd.
ipcp_sigwait(), which waits for a shutdown signal
ipcp_stop() that then stops the internal threads.
Now the main() functions of the IPCPs will make sense without checking
what that ipcp_shutdown() functions actually does.
Signed-off-by: Dimitri Staessens <dimitri@ouroboros.rocks>
Signed-off-by: Sander Vrijders <sander@ouroboros.rocks>
Diffstat (limited to 'src/ipcpd/local/main.c')
-rw-r--r-- | src/ipcpd/local/main.c | 22 |
1 files changed, 8 insertions, 14 deletions
diff --git a/src/ipcpd/local/main.c b/src/ipcpd/local/main.c index 15b6128b..b6aaa81b 100644 --- a/src/ipcpd/local/main.c +++ b/src/ipcpd/local/main.c @@ -360,36 +360,30 @@ int main(int argc, goto fail_data_init; } - if (ipcp_boot() < 0) { - log_err("Failed to boot IPCP."); - goto fail_boot; + if (ipcp_start() < 0) { + log_err("Failed to start IPCP."); + goto fail_start; } - if (ipcp_create_r(0)) { - log_err("Failed to notify IRMd we are initialized."); - goto fail_create_r; - } - - ipcp_shutdown(); + ipcp_sigwait(); if (ipcp_get_state() == IPCP_SHUTDOWN) { pthread_cancel(local_data.packet_loop); pthread_join(local_data.packet_loop, NULL); } + ipcp_stop(); + ipcp_fini(); local_data_fini(); exit(EXIT_SUCCESS); - fail_create_r: - ipcp_set_state(IPCP_NULL); - ipcp_shutdown(); - fail_boot: + + fail_start: local_data_fini(); fail_data_init: ipcp_fini(); fail_init: - ipcp_create_r(-1); exit(EXIT_FAILURE); } |