+Il codice del client è riportato in \nfig, anche esso ricalca la struttura del
+precedente client per il servizio \texttt{daytime} (vedi
+\secref{sec:net_cli_sample}) ma, come per il server, lo si è diviso in due
+parti, inserendo la parte relativa alle operazioni specifiche previste per il
+protocollo \texttt{echo} in una funzione a parte.
+\begin{figure}[!htb]
+ \footnotesize
+ \begin{lstlisting}{}
+int main(int argc, char *argv[])
+{
+/*
+ * Variables definition
+ */
+ int sock_fd, i;
+ struct sockaddr_in serv_add;
+ ...
+ /* create socket */
+ if ( (sock_fd = socket(AF_INET, SOCK_STREAM, 0)) < 0) {
+ perror("Socket creation error");
+ return -1;
+ }
+ /* initialize address */
+ memset((void *) &serv_add, 0, sizeof(serv_add)); /* clear server address */
+ serv_add.sin_family = AF_INET; /* address type is INET */
+ serv_add.sin_port = htons(7); /* echo port is 7 */
+ /* build address using inet_pton */
+ if ( (inet_pton(AF_INET, argv[optind], &serv_add.sin_addr)) <= 0) {
+ perror("Address creation error");
+ return -1;
+ }
+ /* extablish connection */
+ if (connect(sock_fd, (struct sockaddr *)&serv_add, sizeof(serv_add)) < 0) {
+ perror("Connection error");
+ return -1;
+ }
+ /* read daytime from server */
+ EchoClient(stdin, sock_fd);
+ /* normal exit */
+ return 0;
+}
+ \end{lstlisting}
+ \caption{Codice della prima versione del client \texttt{echo}.}
+ \label{fig:TCPsimpl_sockecho_code}
+\end{figure}
+
+La funzione \texttt{main} si occupa della creazione del socket e della
+connessione (linee \texttt{\small 10--27}) secondo la stessa modalità spiegata
+in \secref{sec:net_cli_sample}, il client si connette sulla porta 7
+all'indirizzo specificato dalla linea di comando (a cui si è aggiunta una
+elementare gestione delle opzioni non riportata in figura).
+
+Completata la connessione (quando la funzione \texttt{connect} ritorna) La
+funzione \texttt{EchoClient}, riportata in \nfig, si preoccupa di gestire la
+comunicazione, leggendo una riga alla volta dallo \texttt{stdin}, scrivendola
+sul socket e ristampando su \texttt{stdout} quanto ricevuto in risposta dal
+server.
+
+\begin{figure}[!htb]
+ \footnotesize
+ \begin{lstlisting}{}
+void EchoClient(FILE * filein, int socket)
+{
+ char sendbuff[MAXLINE], recvbuff[MAXLINE];
+ int nread;
+ while (fgets(sendbuff, MAXLINE, filein) != NULL) {
+ SockWrite(socket, sendbuff, strlen(sendbuff));
+ nread = SockRead(socket, recvbuff, strlen(sendbuff));
+ recvbuff[nread] = 0;
+ fputs(recvbuff, stdout);
+ }
+ return;
+}
+ \end{lstlisting}
+ \caption{Codice della prima versione della funzione \texttt{EchoClient} per
+ la gestione del servizio \texttt{echo}.}
+ \label{fig:TCPsimpl_sockecho_code}
+\end{figure}
+
+La funzione utilizza due buffer per gestire i dati inviati e letti sul socket
+(\texttt{\small 3}). La comunicazione viene gestita all'interno di un ciclo
+(linee \texttt{\small 5--10}), i dati da inviare sulla connessione vengono
+presi dallo \texttt{stdin} usando la funzione \texttt{fgets} che legge una
+linea di testo (terminata da un \texttt{CR} e fino al massimo di
+\texttt{MAXLINE} caratteri) e la salva sul buffer di invio, la funzione
+\texttt{SockWrite} (\texttt{\small 3}) scrive detti dati sul socket (gestendo
+l'invio multiplo, qualora una singola \texttt{write} non basta, come spiegato
+in \secref{sec:sock_io_behav}).
+
+I dati che vengono riletti indietro con una \texttt{SockRead} sul buffer di
+ricezione e viene inserita la terminazione della stringa (\texttt{\small
+ 7--8}) e per poter usare la funzione \texttt{fputs} per scriverli su
+\texttt{stdout}.
+
+Un end of file inviato su \texttt{stdin} causa il ritorno di \texttt{fgets}
+con un puntatore nullo e l'uscita dal ciclo, al che la subroutine ritorna ed
+il client esce.
+
+
+\section{Il funzionamento del servizio}
+\label{sec:TCPsimpl_normal_work}
+
+Benché il codice dell'esempio precedente sia molto ridotto, esso ci permetterà
+di considerare in dettaglio tutte le problematiche che si possono incontrare
+nello scrivere una applicazione di rete; infatti attraverso l'esame delle sue
+modalità di funzionamento normali, all'avvio e alla terminazione, e di quello
+che avviene nelle varie situazioni limite da una parte potremo approfondire la
+comprensione del protocollo TCP/IP e dall'altra ricavare le indicazioni
+necessarie per essere in gradi di scrivere applicazioni robuste, in grado di
+gestire anche i casi limite.
+
+
+\subsection{L'avvio e il funzionamento}
+\label{sec:TCPsimpl_startup}
+
+Il primo passo è compilare e lanciare il server (da root, per poter usare la
+porta 7 che è riservata), alla partenza esso eseguirà l'apertura passiva con
+la sequenza delle chiamate a \texttt{socket}, \texttt{bind}, \texttt{listen} e
+poi si bloccherà nella \texttt{accept}. A questo punto si potrà controllarne
+lo stato con \texttt{netstat}:
+
+\begin{verbatim}
+[piccardi@roke piccardi]$ netstat -ant
+Active Internet connections (servers and established)
+Proto Recv-Q Send-Q Local Address Foreign Address State
+...
+tcp 0 0 *:echo *:* LISTEN
+...
+\end{verbatim} %$
+
+che ci mostra come il socket sia in ascolto sulla porta richiesta, accendo
+connessioni da qualunque indirizzo e da qualunque porta e su qualunque
+interfaccia locale.
+
+A questo punto si può lanciare il client, esso chiamerà \texttt{socket} e
+\texttt{connect}, una volta completato il three way handshake la funzione
+\texttt{connect} ritornerà nel client e la \texttt{accept} nel server e la
+connessione è stabilita, usando di nuovo \texttt{netstat} otterremmo:
+\begin{verbatim}
+Active Internet connections (servers and established)
+Proto Recv-Q Send-Q Local Address Foreign Address State
+tcp 0 0 *:echo *:* LISTEN
+tcp 0 0 roke:echo gont:32981 ESTABLISHED
+\end{verbatim}
+
+A questo punto lo stato è il seguente:
+
+
+\begin{itemize}
+\item il client chiama la funzione \texttt{EchoClient} che si blocca sulla
+ \texttt{fgets} dato che non si è ancora scritto nulla sul terminale.
+\item il server eseguirà una \texttt{fork} facendo chiamare al processo figlo
+ la funzione \texttt{SockEcho}, quest'ultima si bloccherà sulla \texttt{read}
+ dal socket sul quale ancora non sono presenti dati.
+\item il
+\end{itemize}
+il server eseguira una \texttt{fork} facendo chiamare al
+processo figlo la funzione \texttt{SockEcho}, la quale eseguirà una read s
+
+
+