| | 
 24.1 OverviewThe protocol units that exchange TCP instances in this way are called segments, and the protocol units of the IP protocol instances are called IP packets or datagrams.
 
 24.1.1 Requirements on TCPThe TCP protocol was developed in the beginning of the eighties to run on top of the IP protocol and provide a byte-oriented, reliable, connection-oriented transport service. The requirements on such a protocol are as follows [Pete00]:to guarantee transmission of byte streams;to maintain the transmission order when delivering byte streams;congestion: to deliver not more than one single copy of each data unit passed for transmission;to transport data for an arbitrary length;to support synchronization between sender and receiver;to support flow control at the receiver's end; andto support several application processes in one system.
 To meet these requirements, the TCP protocol provides a reliable, connection-oriented, byte-oriented full-duplex transport service allowing two applications to set up a connection, to send data in both directions reliably, and to finally close this connection. Each TCP connection is set up and terminated gracefully, and all data are delivered before a connection is torn down, provided that the IP protocol behaves in a service-compliant way. From an application's view, the TCP service can be divided into the following properties [Pete00, Come00]:Connection orientation: TCP provides connection-oriented service where an application must first request a connection to a destination and then use the connection to transfer data.Peer-to-peer communication: Each TCP connection has exactly two endpoints.Complete reliability: TCP guarantees that the data sent across a connection will be delivered exactly as sent, with no data missing or out of order.Full-duplex communication: A TCP connection allows data to flow in either direction and allows either application program to send data at any time. TCP can buffer outgoing and incoming data in both directions, making it possible for an application to send data and then to continue computation while the data is being transferred.Byte-stream interface: We say that TCP provides a stream interface in which an application sends a continuous sequence of octets across a connection. That is, TCP does not provide a notion of records, and does not guarantee that data will be delivered to the receiving application in pieces of the same size in which it was transferred by the sending application.Reliable connection startup: TCP requires that, when two applications create a connection, both must agree to the new connection; duplicate packets used in previous connections will not appear to be valid responses or otherwise interfere with the new connection.Graceful connection shutdown: An application program can open a connection, send arbitrary amounts of data, and then request that the connection be shut down. TCP guarantees to deliver all the data reliably before closing the connection.
 
 
 24.1.2 The TCP Packet FormatChapter 25.)The 16-bit URGENT POINTER (URGPTR) field points to the last byte of important data.The OPTIONS field is variable and can contain, for example, the maximum segment size.
 
 
 
  | 
 |