From 7273e70e79f400ad1f8472aff00cbf9933a6aef2 Mon Sep 17 00:00:00 2001 From: fadhil riyanto Date: Sun, 6 Oct 2024 19:54:10 +0700 Subject: add signal SIG_PIPE ignore Signed-off-by: fadhil riyanto --- main2.c | 21 +++++++++++++++++---- 1 file changed, 17 insertions(+), 4 deletions(-) (limited to 'main2.c') diff --git a/main2.c b/main2.c index 5962a70..e4f6a73 100644 --- a/main2.c +++ b/main2.c @@ -1,6 +1,7 @@ #include #include +#include #include #include #include @@ -249,7 +250,11 @@ static int create_sock_ret_fd(struct sockaddr_storage *ss_addr) static void signal_cb(int signum) { printf("signal detected, exiting...\n"); -g_need_exit = 1; + + if (signum == SIGINT) { + g_need_exit = 1; + } + } @@ -267,6 +272,8 @@ static int server_reg_sigaction(void) return -1; } + ret = sigaction(SIGPIPE, &sa, NULL); + return 0; } @@ -645,6 +652,7 @@ static int create_server2server_conn(int *fdptr, int atyp, u_int8_t *addr, u_int * 0: no problem * 1: conn closed by client * 2: recv client error + * 3: client close connection */ static int start_exchange_data(int client_fd, int target_fd) @@ -657,11 +665,13 @@ static int start_exchange_data(int client_fd, int target_fd) int total_srv_read = 0; const u_int8_t *bufptr; + int sd, v; + do { printf("start sending\n"); memset(buf, 0, 4096); - fcntl(client_fd, F_SETFL, O_NONBLOCK); + // fcntl(client_fd, F_SETFL, O_NONBLOCK); /* recv data from socket client */ @@ -701,7 +711,8 @@ do_send_target: } /* read response from server */ - + + readbuf_server: memset(srvbuf, 0, 4096); *srvbuf = 0; @@ -727,10 +738,12 @@ readbuf_server: } else { // *srvbuf = *srvbuf + ret; // total_srv_read += ret; - ret = send(client_fd, srvbuf, ret, 0); + ret = send(client_fd, srvbuf, ret, MSG_NOSIGNAL); if (ret == -1) { perror("send() to client from srv"); + close(client_fd); + return 3; } goto readbuf_server; } -- cgit v1.2.3