--- lbbs/src/fork.c 2004/10/19 02:12:28 1.5 +++ lbbs/src/fork.c 2005/05/07 12:08:28 1.11 @@ -16,41 +16,63 @@ ***************************************************************************/ #include "common.h" +#include "io.h" +#include int -fork_server(int sock_server, int sock_client, struct sockaddr_in * p_sin) +fork_server () { int pid; - + if (pid = fork ()) + { + SYS_child_process_count ++; + log_std ("Child process (%d) start\n", pid); return 0; + } else if (pid < 0) return -1; - log_std ("Child process start\n"); - - if (close(sock_server) == -1) + + if (close (socket_server) == -1) + { + log_error ("Close server socket failed\n"); + return -2; + } + + //Redirect Input + close (0); + if (dup2 (socket_client, 0) == -1) { - log_error("Close server socket failed\n"); + log_error ("Redirect stdin to client socket failed\n"); + return -3; } - - socket_client = sock_client; - strcpy(hostaddr_client,inet_ntoa(p_sin->sin_addr)); - port_client = ntohs(p_sin->sin_port); - - bbs_main(); - - if (close(sock_client) == -1) + + //Redirect Output + close (1); + if (dup2 (socket_client, 1) == -1) { - log_error("Close client socket failed\n"); + log_error ("Redirect stdout to client socket failed\n"); + return -4; } - log_std ("Child process exit\n"); + bbs_main (); + + if (close (socket_client) == -1) + { + log_error ("Close client socket failed\n"); + } + + //Close Input and Output for client + close (0); + close (1); + + log_std ("Process exit normally\n"); - log_end(); + log_end (); //Exit child process normally - exit(0); + exit (0); return 0; }