X-Git-Url: https://gapil.gnulinux.it/gitweb/?p=gapil.git;a=blobdiff_plain;f=sources%2FTCP_echod.c;h=333a5450b9df067e62444a8e36b646e112982e7c;hp=cca49332ade78b32be343a7d57dea39f64cc4f67;hb=fa15a3f1ecd64efd8440e46d398fd9976abc3d25;hpb=b51bcef6bcf8c8622107b8ab8a22626dbdf6ba96 diff --git a/sources/TCP_echod.c b/sources/TCP_echod.c index cca4933..333a545 100644 --- a/sources/TCP_echod.c +++ b/sources/TCP_echod.c @@ -26,23 +26,21 @@ * * Usage: echod -h give all info * - * $Id$ - * ****************************************************************/ /* * Include needed headers */ -#include /* predefined types */ -#include /* include unix standard library */ -#include /* IP addresses conversion utiliites */ -#include /* socket library */ -#include /* include standard I/O library */ -#include +#include /* primitive system data types */ +#include /* unix standard library */ +#include /* IP addresses conversion utilities */ +#include /* socket constants, types and functions */ +#include /* standard I/O library */ +#include /* date and time constants, types and functions */ #include /* syslog system functions */ -#include /* signal functions */ -#include /* error code */ -#include /* error strings */ -#include +#include /* signal constants, types and functions */ +#include /* error definitions and routines */ +#include /* C strings library */ +#include /* C standard library */ #include "Gapil.h" @@ -62,6 +60,8 @@ int main(int argc, char *argv[]) */ int list_fd, conn_fd; int waiting = 0; + int keepalive = 0; + int reuse = 0; int compat = 0; pid_t pid; struct sockaddr_in cli_add; @@ -73,7 +73,7 @@ int main(int argc, char *argv[]) */ int i; opterr = 0; /* don't want writing to stderr */ - while ( (i = getopt(argc, argv, "hdicw:")) != -1) { + while ( (i = getopt(argc, argv, "hkrdicw:")) != -1) { switch (i) { /* * Handling options @@ -86,6 +86,12 @@ int main(int argc, char *argv[]) case 'i': demonize = 0; break; + case 'k': + keepalive = 1; + break; + case 'r': + reuse = 1; + break; case 'c': compat = 1; break; @@ -116,7 +122,8 @@ int main(int argc, char *argv[]) SignalRestart(SIGCHLD, HandSigCHLD); /* restarting handler */ } /* create and bind socket */ - if ( (list_fd = sockbind(argv[optind], "echo", 6, SOCK_STREAM)) < 0) { + if ( (list_fd = sockbindopt(argv[optind], "echo", 6, + SOCK_STREAM, reuse)) < 0) { return 1; } /* release privileges and go daemon */ @@ -167,6 +174,10 @@ int main(int argc, char *argv[]) } if (pid == 0) { /* child */ close(list_fd); /* close listening socket */ + if (keepalive) { /* enable keepalive ? */ + setsockopt(conn_fd, SOL_SOCKET, SO_KEEPALIVE, + &keepalive, sizeof(keepalive)); + } ServEcho(conn_fd); /* handle echo */ if (debugging) { snprintf(debug, MAXLINE, "Closed connection %s\n", ipaddr); @@ -193,6 +204,8 @@ void usage(void) { printf(" echod [-h] \n"); printf(" -h print this help\n"); printf(" -d write debug info\n"); + printf(" -k enable SO_KEEPALIVE\n"); + printf(" -r enable SO_REUSEADDR\n"); printf(" -i use interactively\n"); printf(" -c disable BSD semantics\n"); printf(" -w N wait N sec. before calling accept\n");