diff --git a/CHANGES b/CHANGES index 4401569..5fa0328 100644 --- a/CHANGES +++ b/CHANGES @@ -144,6 +144,11 @@ new features: feature of newer OpenSSL versions. Thanks to Michael Hanselmann for providing this contribution (sponsored by Google Inc.) +docu + minor corrections in docu (thanks to Paggas) + + client process -> child process + ####################### V 2.0.0-b7: security: diff --git a/doc/socat.yo b/doc/socat.yo index 1a7cf78..2db98c3 100644 --- a/doc/socat.yo +++ b/doc/socat.yo @@ -383,7 +383,7 @@ label(ADDRESS_GOPEN)dit(bf(tt(GOPEN:))) link(UNIX-CONNECT)(ADDRESS_UNIX_CONNECT) label(ADDRESS_IP_SENDTO)dit(bf(tt(IP-SENDTO::))) - Opens a raw IP socket. Depending on host specification or option link(pf)(OPTION_PROTOCOL_FAMILY), IP procotol version + Opens a raw IP socket. Depending on host specification or option link(pf)(OPTION_PROTOCOL_FAMILY), IP protocol version 4 or 6 is used. It uses link()(TYPE_PROTOCOL) to send packets to [link(IP address)(TYPE_IP_ADDRESS)] and receives packets from host, ignores packets from other hosts. @@ -454,7 +454,7 @@ label(ADDRESS_IP6_DATAGRAM)dit(bf(tt(IP6-DATAGRAM::))) Option groups: link(FD)(GROUP_FD),link(SOCKET)(GROUP_SOCKET),link(IP6)(GROUP_IP6),link(RANGE)(GROUP_RANGE) nl() label(ADDRESS_IP_RECVFROM)dit(bf(tt(IP-RECVFROM:))) - Opens a raw IP socket of link()(TYPE_PROTOCOL). Depending on option link(pf)(OPTION_PROTOCOL_FAMILY), IP procotol version + Opens a raw IP socket of link()(TYPE_PROTOCOL). Depending on option link(pf)(OPTION_PROTOCOL_FAMILY), IP protocol version 4 or 6 is used. It receives one packet from an unspecified peer and may send one or more answer packets to that peer. This mode is particularly useful with fork option where each arriving packet - from arbitrary peers - is handled by its own sub process. This allows a behaviour similar to typical UDP based servers like ntpd or @@ -487,7 +487,7 @@ label(ADDRESS_IP6_RECVFROM)dit(bf(tt(IP6-RECVFROM:))) Option groups: link(FD)(GROUP_FD),link(SOCKET)(GROUP_SOCKET),link(IP6)(GROUP_IP6),link(CHILD)(GROUP_CHILD),link(RANGE)(GROUP_RANGE) nl() label(ADDRESS_IP_RECV)dit(bf(tt(IP-RECV:))) - Opens a raw IP socket of link()(TYPE_PROTOCOL). Depending on option link(pf)(OPTION_PROTOCOL_FAMILY), IP procotol version + Opens a raw IP socket of link()(TYPE_PROTOCOL). Depending on option link(pf)(OPTION_PROTOCOL_FAMILY), IP protocol version 4 or 6 is used. It receives packets from multiple unspecified peers and merges the data. No replies are possible. It can be, e.g., addressed by socat() IP-SENDTO address peers. @@ -3336,12 +3336,10 @@ label(EXAMPLE_ADDRESS_TUN) dit(bf(tt(socat TCP:host2:4443 TUN:192.168.255.1/24,up))) establishes one side of a virtual (but not private!) network with host2 where a -similar process might run, with TCP-L and tun address 192.168.255.2. They -can reach each other using the addresses 192.168.255.1 and -192.168.255.2. Substitute the TCP link with an SSL connection protected by -client and server authentication (see OpenSSL -link(client)(EXAMPLE_ADDRESS_OPENSSL_CONNECT) and -link(server)(EXAMPLE_ADDRESS_OPENSSL_LISTEN)). +similar process might run, with UDP-L and tun address 192.168.255.2. They can +reach each other using the addresses 192.168.255.1 and 192.168.255.2. Note that +streaming eg. via TCP or SSL does not guarantee to retain packet boundaries and +may thus cause packet loss. label(EXAMPLE_INTERFACE) diff --git a/xio-listen.c b/xio-listen.c index 0559890..00fbd25 100644 --- a/xio-listen.c +++ b/xio-listen.c @@ -315,7 +315,7 @@ int _xioopen_listen(struct single *xfd, int xioflags, struct sockaddr *us, sockl pid_t cpid = Getpid(); Sigprocmask(SIG_UNBLOCK, &mask_sigchld, NULL); - Info1("just born: client process "F_pid, cpid); + Info1("just born: child process "F_pid, cpid); xiosetenvulong("PID", cpid, 1); if (Close(xfd->rfd) < 0) { diff --git a/xio-socket.c b/xio-socket.c index df8bc0f..7a0ff1e 100644 --- a/xio-socket.c +++ b/xio-socket.c @@ -1135,7 +1135,7 @@ int _xioopen_dgram_sendto(/* them is already in xfd->peersa */ packet in the IP stacks input queue and forks a sub process. The sub process then reads this packet for processing its data. There is a problem because the parent process would find the same packet - again if it calls select()/poll() before the client process reads the + again if it calls select()/poll() before the child process reads the packet. To solve this problem we implement the following mechanism: The sub process sends a SIGUSR1 when it has read the packet (or a SIGCHLD if diff --git a/xioinitialize.c b/xioinitialize.c index e80cd9c..05c2dc7 100644 --- a/xioinitialize.c +++ b/xioinitialize.c @@ -258,7 +258,7 @@ pid_t xio_fork(bool subchild, int level) { if (pid == 0) { /* child process */ pid_t cpid = Getpid(); - Info1("just born: client process "F_pid, cpid); + Info1("just born: child process "F_pid, cpid); if (!subchild) { /* set SOCAT_PID to new value */ xiosetenvulong("PID", pid, 1);