Now handle signals

This commit is contained in:
Quentin 2019-05-09 11:24:05 +02:00
parent 8b6f5c63f6
commit 163110c814
7 changed files with 66 additions and 1 deletions

View file

@ -77,6 +77,10 @@ void donar_client(struct donar_client_ctx* ctx, struct donar_params* dp) {
}; };
evt_core_init (&(ctx->evts), dp->verbose); evt_core_init (&(ctx->evts), dp->verbose);
signal_init(&ctx->evts);
printf("--- Signal initialized\n");
algo_main_init(&ctx->evts, &ap); algo_main_init(&ctx->evts, &ap);
printf("--- Algorithm initialized\n"); printf("--- Algorithm initialized\n");

View file

@ -8,6 +8,57 @@ void free_udp_t(void* v) {
} }
} }
int on_signal(struct evt_core_ctx* evts, struct evt_core_fdinfo* fdinfo) {
struct signalfd_siginfo fdsi;
int sig_rd = read(fdinfo->fd, &fdsi, sizeof(struct signalfd_siginfo));
if (sig_rd == -1 && errno == EAGAIN) return 1;
if (sig_rd != sizeof(struct signalfd_siginfo)) {
fprintf(stderr, "read size: %d / %ld\n", sig_rd, sizeof(struct signalfd_siginfo));
perror("signal read failed");
exit(EXIT_FAILURE);
}
printf("Signal received: %d\n", fdsi.ssi_signo);
if (fdsi.ssi_signo == SIGINT || fdsi.ssi_signo == SIGQUIT) {
printf("Stop main loop and quit\n");
evts->loop = 0;
}
return 0;
}
void signal_init(struct evt_core_ctx* evts) {
sigset_t mask;
struct evt_core_cat signal_read = {
.name = "signal-read",
.flags = EPOLLIN | EPOLLET | EPOLLRDHUP,
.app_ctx = NULL,
.free_app_ctx = NULL,
.cb = on_signal,
.err_cb = NULL
};
evt_core_add_cat(evts, &signal_read);
sigaddset(&mask, SIGINT);
sigaddset(&mask, SIGQUIT);
if (sigprocmask(SIG_BLOCK, &mask, NULL) == -1) {
perror("sigprocmask");
exit(EXIT_FAILURE);
}
int sigfd = signalfd(-1, &mask, 0);
if (sigfd == -1) {
perror("signalfd failed");
exit(EXIT_FAILURE);
}
struct evt_core_fdinfo fdinfo = {0};
fdinfo.fd = sigfd;
fdinfo.cat = &signal_read;
fdinfo.url = "signal:read:int+quit";
evt_core_add_fd(evts, &fdinfo);
}
void init_udp_remote(char* port, struct evt_core_ctx* evts) { void init_udp_remote(char* port, struct evt_core_ctx* evts) {
int sock1, sock2; int sock1, sock2;
char url[1024]; char url[1024];

View file

@ -2,6 +2,8 @@
#include <stdlib.h> #include <stdlib.h>
#include <stdio.h> #include <stdio.h>
#include <string.h> #include <string.h>
#include <sys/signalfd.h>
#include <errno.h>
#include "net_tools.h" #include "net_tools.h"
#include "evt_core.h" #include "evt_core.h"
#include "packet.h" #include "packet.h"
@ -12,6 +14,7 @@ struct donar_params {
GPtrArray *remote_ports, *exposed_ports; GPtrArray *remote_ports, *exposed_ports;
}; };
void signal_init(struct evt_core_ctx* evts);
void init_udp_remote(char* port, struct evt_core_ctx* evts); void init_udp_remote(char* port, struct evt_core_ctx* evts);
void init_udp_exposed(char* port, struct evt_core_ctx* evts); void init_udp_exposed(char* port, struct evt_core_ctx* evts);
void donar_init_params(struct donar_params* dp); void donar_init_params(struct donar_params* dp);

View file

@ -59,6 +59,10 @@ void donar_server(struct donar_server_ctx* ctx, struct donar_params* dp) {
}; };
evt_core_init (&(ctx->evts), dp->verbose); evt_core_init (&(ctx->evts), dp->verbose);
signal_init(&ctx->evts);
printf("--- Signal initialized\n");
algo_main_init(&ctx->evts, &ap); algo_main_init(&ctx->evts, &ap);
printf("--- Algorithm initialized\n"); printf("--- Algorithm initialized\n");

View file

@ -34,6 +34,7 @@ void evt_core_init(struct evt_core_ctx* ctx, uint8_t verbose) {
exit(EXIT_FAILURE); exit(EXIT_FAILURE);
} }
ctx->verbose = verbose; ctx->verbose = verbose;
ctx->loop = 1;
ctx->catlist = g_hash_table_new_full(g_str_hash, g_str_equal,NULL, free_cat); ctx->catlist = g_hash_table_new_full(g_str_hash, g_str_equal,NULL, free_cat);
ctx->socklist = g_hash_table_new_full(g_int_hash, g_int_equal, NULL, free_fdinfo); ctx->socklist = g_hash_table_new_full(g_int_hash, g_int_equal, NULL, free_fdinfo);
ctx->urltofd = g_hash_table_new_full(g_str_hash, g_str_equal, NULL, NULL); ctx->urltofd = g_hash_table_new_full(g_str_hash, g_str_equal, NULL, NULL);
@ -257,7 +258,7 @@ void evt_core_loop(struct evt_core_ctx* ctx) {
printf("--- Start main loop\n"); printf("--- Start main loop\n");
int num_fd, n = 0; int num_fd, n = 0;
while(1) { while(ctx->loop) {
timing_fx_start(&tfx_epoll); timing_fx_start(&tfx_epoll);
num_fd = epoll_wait(ctx->epollfd, events, EVT_CORE_MAX_EVENTS, -1); num_fd = epoll_wait(ctx->epollfd, events, EVT_CORE_MAX_EVENTS, -1);
timing_fx_stop(&tfx_epoll); timing_fx_stop(&tfx_epoll);

View file

@ -32,6 +32,7 @@ struct evt_core_cat {
struct evt_core_ctx { struct evt_core_ctx {
int epollfd; int epollfd;
uint8_t verbose; uint8_t verbose;
uint8_t loop;
GHashTable* catlist; // name -> category GHashTable* catlist; // name -> category
GHashTable* socklist; // fd -> category GHashTable* socklist; // fd -> category
GHashTable* urltofd; // url -> fd, like "tcp:127.0.0.1:7500" GHashTable* urltofd; // url -> fd, like "tcp:127.0.0.1:7500"

View file

@ -191,6 +191,7 @@ void algo_main_init(struct evt_core_ctx* evt, struct algo_params* ap) {
.cb = main_on_tcp_co, .cb = main_on_tcp_co,
.err_cb = NULL .err_cb = NULL
}; };
ctx->ref_count++;
evt_core_add_cat(evt, &tcp_listen); evt_core_add_cat(evt, &tcp_listen);
struct evt_core_cat tcp_read = { struct evt_core_cat tcp_read = {