<p>Server-side implementation of <ahref="http://www.tcpipguide.com/free/t_SimplexFullDuplexandHalfDuplexOperation.htm"target="_blank">TCP Full Duplex Communication</a>
<divclass="center"><divclass="zoom"><iframescrolling="no"frameborder="0"src="../../d2/d42/tcp__full__duplex__server_8c__incl.svg"width="100%"height="393"><p><b>This browser is not able to show SVG: try Firefox, Chrome, Safari, or Opera instead.</b></p></iframe></div>
<trclass="memdesc:a614217d263be1fb1a5f76e2ff7be19a2"><tdclass="mdescLeft"> </td><tdclass="mdescRight">For the type in_addr_t and in_port_t For structures returned by the network database library - formatted internet addresses and port numbers For in_addr and sockaddr_in structures. <ahref="../../d1/d6b/tcp__full__duplex__server_8c.html#a614217d263be1fb1a5f76e2ff7be19a2">More...</a><br/></td></tr>
<trclass="memdesc:a7e15c8e2885871839fc2b820dfbdb4ce"><tdclass="mdescLeft"> </td><tdclass="mdescRight">Utility function used to print an error message to <code>stderr</code>. <ahref="../../d1/d6b/tcp__full__duplex__server_8c.html#a7e15c8e2885871839fc2b820dfbdb4ce">More...</a><br/></td></tr>
<divclass="textblock"><p>Server-side implementation of <ahref="http://www.tcpipguide.com/free/t_SimplexFullDuplexandHalfDuplexOperation.htm"target="_blank">TCP Full Duplex Communication</a></p>
<dlclass="section see"><dt>See also</dt><dd><aclass="el"href="../../d1/d6b/tcp__full__duplex__server_8c.html"title="Server-side implementation of TCP Full Duplex Communication">tcp_full_duplex_server.c</a></dd></dl>
<p>The algorithm is based on the simple TCP client and server model. However, instead of the server only sending and the client only receiving data, The server and client can both send and receive data simultaneously. This is implemented by using the <code>fork</code> function call so that in the server the child process can receive data and parent process can send data, and in the client the child process can send data and the parent process can receive data. It runs an infinite loop and can send and receive messages indefinitely until the user exits the loop. In this way, the Full Duplex Form of communication can be represented using the TCP server-client model & socket programming </p>
<p>For the type in_addr_t and in_port_t For structures returned by the network database library - formatted internet addresses and port numbers For in_addr and sockaddr_in structures. </p>
<p>For specific bit size values of variables Variable types, several macros, and various functions for performing input and output Variable types, several macros, and various functions for performing general functions Various functions for manipulating arrays of characters For macro definitions related to the creation of sockets For definitions to allow for the porting of BSD programs For miscellaneous symbolic constants and types, and miscellaneous functions </p>
<p>Utility function used to print an error message to <code>stderr</code>. </p>
<p>It prints <code>str</code> and an implementation-defined error message corresponding to the global variable <code>errno</code>. </p><dlclass="section return"><dt>Returns</dt><dd>void </dd></dl>
<p>The TCP socket is created using the socket function</p>
<p>AF_INET (Family) - it is an address family that is used to designate the type of addresses that your socket can communicate with</p>
<p>SOCK_STREAM (Type) - Indicates TCP Connection - A stream socket provides for the bidirectional, reliable, sequenced, and unduplicated flow of data without record boundaries. Aside from the bidirectionality of data flow, a pair of connected stream sockets provides an interface nearly identical to pipes</p>
<p>0 (Protocol) - Specifies a particular protocol to be used with the socket. Specifying a protocol of 0 causes socket() to use an unspecified default protocol appropriate for the requested socket type</p>
<p>< Error if the socket descriptor has a value lower than 0 - socket wasnt created</p>
<p>Server Address Information</p>
<p>The bzero() function erases the data in the n bytes of the memory starting at the location pointed to, by writing zeros (bytes containing '\0') to that area</p>
<p>We bind the server_addr to the internet address and port number thus giving our socket an identity with an address and port where it can listen for connections</p>
<p>htons - The htons() function translates a short integer from host byte order to network byte order</p>
<p>htonl - The htonl() function translates a long integer from host byte order to network byte order</p>
<p>These functions are necessary so that the binding of address and port takes place with data in the correct format</p>
<p>This binds the socket descriptor to the server thus enabling the server to listen for connections and communicate with other clients</p>
<p>If binding is unsuccessful</p>
<p>This is to listen for clients or connections made to the server</p>
<p>The limit is currently at 5 but can be increased to listen for more connections</p>
<p>It listens to connections through the socket descriptor</p>
<p>When a connection is found, a socket is created and connection is accepted and established through the socket descriptor</p>
<p>Communication between client and server</p>
<p>The bzero() function erases the data in the n bytes of the memory starting at the location pointed to, by writing zeros (bytes containing '\0') to that area. The variables are emptied and then ready for use</p>
<p>The fork function call is used to create a child and parent process which run and execute code simultaneously</p>
<p>The child process is used to receive data and after doing so sleeps for 5 seconds to wait for the parent to send data</p>
<p>The parent process is used to send data and after doing so sleeps for 5 seconds to wait for the child to receive data</p>
<p>The server and client can communicate indefinitely till one of them exits the connection</p>
<p>Since the exchange of information between the server and client takes place simultaneously this represents FULL DUPLEX COMMUNICATION</p>
<divclass="line"><spanclass="lineno"> 55</span> sendbuff[1024]; <spanclass="comment">///< character arrays to read and store string data</span><spanclass="comment"></span></div>
<divclass="line"><spanclass="lineno"> 56</span><spanclass="comment"> /// for communication</span></div>
<divclass="line"><spanclass="lineno"> 59</span> client_addr; <spanclass="comment">///< basic structures for all syscalls and functions that</span><spanclass="comment"></span></div>
<divclass="line"><spanclass="lineno"> 60</span><spanclass="comment"> /// deal with internet addresses. Structures for handling</span></div>
<divclass="line"><spanclass="lineno"> 61</span><spanclass="comment"> /// internet addresses</span></div>
<divclass="line"><spanclass="lineno"> 62</span><spanclass="comment"></span> socklen_t ClientLen; <spanclass="comment">/// size of address</span></div>
<divclass="line"><spanclass="lineno"> 67</span><spanclass="comment"> * AF_INET (Family) - it is an address family that is used to designate the</span></div>
<divclass="line"><spanclass="lineno"> 68</span><spanclass="comment"> * type of addresses that your socket can communicate with</span></div>
<divclass="line"><spanclass="lineno"> 71</span><spanclass="comment"> * for the bidirectional, reliable, sequenced, and unduplicated flow of data</span></div>
<divclass="line"><spanclass="lineno"> 72</span><spanclass="comment"> * without record boundaries. Aside from the bidirectionality of data flow,</span></div>
<divclass="line"><spanclass="lineno"> 73</span><spanclass="comment"> * a pair of connected stream sockets provides an interface nearly identical</span></div>
<divclass="line"><spanclass="lineno"> 74</span><spanclass="comment"> * to pipes</span></div>
<divclass="line"><spanclass="lineno"> 76</span><spanclass="comment"> * 0 (Protocol) - Specifies a particular protocol to be used with the</span></div>
<divclass="line"><spanclass="lineno"> 77</span><spanclass="comment"> * socket. Specifying a protocol of 0 causes socket() to use an unspecified</span></div>
<divclass="line"><spanclass="lineno"> 78</span><spanclass="comment"> * default protocol appropriate for the requested socket type</span></div>
<divclass="line"><spanclass="lineno"> 82</span><aclass="code hl_function"href="../../d1/d6b/tcp__full__duplex__server_8c.html#a7e15c8e2885871839fc2b820dfbdb4ce">error</a>(); <spanclass="comment">///< Error if the socket descriptor has a value lower than 0 -</span><spanclass="comment"></span></div>
<divclass="line"><spanclass="lineno"> 93</span><spanclass="comment"> * We bind the server_addr to the internet address and port number thus</span></div>
<divclass="line"><spanclass="lineno"> 94</span><spanclass="comment"> * giving our socket an identity with an address and port where it can</span></div>
<divclass="line"><spanclass="lineno"> 95</span><spanclass="comment"> * listen for connections</span></div>
<divclass="line"><spanclass="lineno"> 97</span><spanclass="comment"> * htons - The htons() function translates a short integer from host byte</span></div>
<divclass="line"><spanclass="lineno"> 98</span><spanclass="comment"> * order to network byte order</span></div>
<divclass="line"><spanclass="lineno"> 100</span><spanclass="comment"> * htonl - The htonl() function translates a long integer from host byte</span></div>
<divclass="line"><spanclass="lineno"> 101</span><spanclass="comment"> * order to network byte order</span></div>
<divclass="line"><spanclass="lineno"> 103</span><spanclass="comment"> * These functions are necessary so that the binding of address and port</span></div>
<divclass="line"><spanclass="lineno"> 104</span><spanclass="comment"> * takes place with data in the correct format</span></div>
<divclass="line"><spanclass="lineno"> 114</span><spanclass="comment"> * This binds the socket descriptor to the server thus enabling the server</span></div>
<divclass="line"><spanclass="lineno"> 115</span><spanclass="comment"> * to listen for connections and communicate with other clients</span></div>
<divclass="line"><spanclass="lineno"> 119</span><aclass="code hl_function"href="../../d1/d6b/tcp__full__duplex__server_8c.html#a7e15c8e2885871839fc2b820dfbdb4ce">error</a>(); <spanclass="comment">/// If binding is unsuccessful</span></div>
<divclass="line"><spanclass="lineno"> 144</span><spanclass="comment"> * The bzero() function erases the data in the n bytes of the memory</span></div>
<divclass="line"><spanclass="lineno"> 145</span><spanclass="comment"> * starting at the location pointed to, by writing zeros (bytes</span></div>
<divclass="line"><spanclass="lineno"> 146</span><spanclass="comment"> * containing '\0') to that area. The variables are emptied and then</span></div>
<divclass="line"><spanclass="lineno"> 147</span><spanclass="comment"> * ready for use</span></div>
<divclass="line"><spanclass="lineno"> 149</span><spanclass="comment"> * The fork function call is used to create a child and parent process</span></div>
<divclass="line"><spanclass="lineno"> 150</span><spanclass="comment"> * which run and execute code simultaneously</span></div>
<divclass="line"><spanclass="lineno"> 158</span><spanclass="comment"> * The server and client can communicate indefinitely till one of them</span></div>
<divclass="line"><spanclass="lineno"> 159</span><spanclass="comment"> * exits the connection</span></div>
<divclass="line"><spanclass="lineno"> 161</span><spanclass="comment"> * Since the exchange of information between the server and client takes</span></div>
<divclass="line"><spanclass="lineno"> 162</span><spanclass="comment"> * place simultaneously this represents FULL DUPLEX COMMUNICATION</span></div>
<divclass="line"><spanclass="lineno"> 166</span><spanclass="keywordflow">if</span> (<aclass="code hl_struct"href="../../d0/d43/structpid.html">pid</a> == 0) <spanclass="comment">/// Value of 0 is for child process</span></div>
<divclass="ttc"id="atcp__full__duplex__server_8c_html_a614217d263be1fb1a5f76e2ff7be19a2"><divclass="ttname"><ahref="../../d1/d6b/tcp__full__duplex__server_8c.html#a614217d263be1fb1a5f76e2ff7be19a2">PORT</a></div><divclass="ttdeci">#define PORT</div><divclass="ttdoc">For the type in_addr_t and in_port_t For structures returned by the network database library - format...</div><divclass="ttdef"><b>Definition:</b> tcp_full_duplex_server.c:31</div></div>
<divclass="ttc"id="atcp__full__duplex__server_8c_html_a7e15c8e2885871839fc2b820dfbdb4ce"><divclass="ttname"><ahref="../../d1/d6b/tcp__full__duplex__server_8c.html#a7e15c8e2885871839fc2b820dfbdb4ce">error</a></div><divclass="ttdeci">void error()</div><divclass="ttdoc">Utility function used to print an error message to stderr.</div><divclass="ttdef"><b>Definition:</b> tcp_full_duplex_server.c:39</div></div>
<divclass="center"><iframescrolling="no"frameborder="0"src="../../d1/d6b/tcp__full__duplex__server_8c_ae66f6b31b5ad750f1fe042a706a4e3d4_cgraph.svg"width="158"height="36"><p><b>This browser is not able to show SVG: try Firefox, Chrome, Safari, or Opera instead.</b></p></iframe>
<liclass="footer">Generated by <ahref="https://www.doxygen.org/index.html"><imgclass="footer"src="../../doxygen.svg"width="104"height="31"alt="doxygen"/></a> 1.9.5 </li>