2.1. What is the major function of the network access layer?
The network access layer is concerned with the exchange of data between a computer and the network
to which it is attached.
2.2. What tasks are performed by the transport layer?
The transport layer is concerned with data reliability and correct sequencing.
2.3. What is a protocol?
A protocol is the set of rules or conventions governing the way in which two entities cooperate to
exchange data.
2.4. What is a protocol data unit (PDU)?
A PDU is the combination of data from the next higher communications layer and control
information.
2.5. What is a protocol architecture?
The software structure that implements the communications function. Typically, the protocol
architecture consists of a layered set of protocols, with one or more protocols at each layer.
2.6. What is TCP/IP?
Transmission Control Protocol/Internet Protocol (TCP/IP) are two protocols originally designed to
provide low level support for internetworking. The term is also used generically to refer to a more
comprehensive collection of protocols developed by the U.S. Department of Defense and the Internet
community.
2.7. What are some advantages to layering as seen in the TCP/IP architecture?
Layering decomposes the overall communications problem into a number of more manageable
subproblems.
2.8. What is a router?
A router is a device that operates at the Network layer of the OSI model to connect dissimilar
networks.
2.9. Which version of IP is the most prevalent today?
IPv4.
2.10. Does all traffic running on the Internet use TCP?
No, other transport layer protocols, such as UDP, are also used. Some traffic uses no transport
protocol, such as ICMP.
2.11. Compare the address space between IPv4 and IPv6. How many bits are used in each?
IPv4 - 32 bits; IPv6 - 128 bits
Problems
2.1. Using the layer models in Figure 2.15, describe the ordering and delivery of a pizza, indicating
the interactions at each level.
The guest effectively places the order with the cook. The host communicates this order to the clerk,
who places the order with the cook. The phone system provides the physical means for the order to
be transported from host to clerk. The cook gives the pizza to the clerk with the order form (acting as
a "header" to the pizza).
The clerk boxes the pizza with the delivery address, and the delivery van encloses all of the orders to
be delivered. The road provides the physical path for delivery.
2.2. a. The French and Chinese prime ministers need to come to an agreement by telephone, but
neither speaks the others language. Further, neither has on hand a translator that can translate to the
language of the other. However, both prime ministers have English translators on their staffs. Draw
a diagram similar to Figure 2.15 to depict the situation, and describe the interaction at each level.
The PMs speak as if they are speaking directly to each other. For example, when the French PM
speaks, he addresses his remarks directly to the Chinese PM. However, the message is actually passed
through two translators via the phone system. The French PM's translator translates his remarks into
English and telephones these to the Chinese PM's translator, who translates these remarks into
Chinese.
b. Now suppose that the Chinese prime ministers translator can translate only into Japanese and that
the French prime minister has a German translator available.
A translator between German and Japanese is available in Germany. Draw a new diagram that reflects
this arrangement and describe the hypothetical phone conversation.
An intermediate node serves to translate the message before passing it on. Note that the intermediate
node handles the message only up to the second level; a minister's level is not needed.
2.3. List the major disadvantages with the layered approach to protocols.
Perhaps the major disadvantage is the processing and data overhead. There is processing overhead
because as many as seven modules (OSI model) are invoked to move data from the application
through the communications software. There is data overhead because of the appending of multiple
headers to the data. Another possible disadvantage is that there must be at least one protocol standard
per layer. With so many layers, it takes a long time to develop and promulgate the standards.
2.4. Two blue armies are each poised on opposite hills preparing to attack a single red army in the
valley. The red army can defeat either of the blue armies separately but will fail to defeat both blue
armies if they attack simultaneously. The blue armies communicate via an unreliable communications
system (a foot soldier). The commander with one of the blue armies would like to attack at noon. His
problem is this: If he sends a message to the other blue army, ordering the attack, he cannot be sure
it will get through. He could ask for acknowledgment, but that might not get through. Is there a
protocol that the two blue armies can use to avoid defeat?
No. There is no way to be assured that the last message gets through, except by acknowledging it.
Thus, either the acknowledgment process continues forever, or one army has to send the last message
and then act with uncertainty.
2.5. A broadcast network is one in which a transmission from any one attached station is received by
all other attached stations over a shared medium. Examples are a bustopology local area network,
such as Ethernet, and a wireless radio network. Discuss the need or lack of need for a network layer
(OSI layer 3) in a broadcast network.
A case could be made either way. First, look at the functions performed at the network layer to deal
with the communications network (hiding the details from the upper layers). The network layer is
responsible for routing data through the network, but with a broadcast network, routing is not needed.
Other functions, such as sequencing, flow control, error control between end systems, can be
accomplished at layer 2, because the link layer will be a protocol directly between the two end
systems, with no intervening switches. So it would seem that a network layer is not needed. Second,
consider the network layer from the point of view of the upper layer using it. The upper layer sees
itself attached to an access point into a network supporting communication with multiple devices.
The layer for assuring that data sent across a network is delivered to one of a number of other end
systems is the network layer. This argues for inclusion of a network layer.
2.6. In Figure 2.5, exactly one protocol data unit (PDU) in layer N is encapsulated in a PDU at layer
1N - 12. It is also possible to break one N-level PDU into multiple 1N - 12-level PDUs (segmentation)
or to group multiple N-level PDUs into one 1N - 12-level PDU (blocking).
a. In the case of segmentation, is it necessary that each 1N - 12-level segment contain a copy of
the N-level header?
No. This would violate the principle of separation of layers. To layer (N 1), the N-level PDU is
simply data. The (N 1) entity does not know about the internal format of the N-level PDU. It breaks
that PDU into fragments and reassembles them in the proper order.
b. In the case of blocking, is it necessary that each N-level PDU retain its own header, or can the
data be consolidated into a single N-level PDU with a single N-level header?
Each N-level PDU must retain its own header, for the same reason given in (a).
2.7. A TCP segment consisting of 1500 bits of data and 160 bits of header is sent to the IP layer,
which appends another 160 bits of header. This is then transmitted through two networks, each of
which uses a 24-bit packet header. The destination network has a maximum packet size of 800 bits.
How many bits, including headers, are delivered to the network layer protocol at the destination?
Data plus transport header plus internet header equals 1820 bits. This data is delivered in a sequence
of packets, each of which contains 24 bits of network header and up to 776 bits of higher-layer headers
and/or data. Three network packets are needed. Total bits delivered = 1820 + 3 24 = 1892 bits.
2.8. Why is UDP needed? Why cant a user program directly access IP?
UDP provides the source and destination port addresses and a checksum that covers the data field.
These functions would not normally be performed by protocols above the transport layer. Thus UDP
provides a useful, though limited, service.
2.9. IP, TCP, and UDP all discard a packet that arrives with a checksum error and do not attempt to
notify the source. Why?
In the case of IP and UDP, these are unreliable protocols that do not guarantee delivery, so they do
not notify the source. TCP does guarantee delivery. However, the technique that is used is a timeout.
If the source does not receive an acknowledgment to data within a given period of time, the source
retransmits.
2.10. Why does the TCP header have a header length field while the UDP header does not?
UDP has a fixed-sized header. The header in TCP is of variable length.
2.11. The previous version of the TFTP specification, RFC 783, included the following statement:
All packets other than those used for termination are acknowledged individually unless a timeout
occurs.
The RFC 1350 specification revises this to say:
All packets other than duplicate ACKs and those used for termination are acknowledged unless a
timeout occurs.
The change was made to fix a problem referred to as the Sorcerers Apprentice.
Deduce and explain the problem.
Suppose that A sends a data packet k to B and the ACK from B is delayed but not lost. A resends
packet k, which B acknowledges. Eventually A receives 2 ACKs to packet k, each of which triggers
transmission of packet (k + 1). B will ACK both copies of packet (k + 1), causing A to send two
copies of packet (k + 2). From now on, 2 copies of every data packet and ACK will be sent.
2.12. What is the limiting factor in the time required to transfer a file using TFTP?
TFTP can transfer a maximum of 512 bytes per round trip (data sent, ACK received). The maximum
throughput is therefore 512 bytes divided by the roundtrip time. Source: [STEV94].
2.13. A user on a UNIX host wants to transfer a 4000-byte text file to a Microsoft Windows host. In
order to do this, he transfers the file by means of TFTP, using the netascii transfer mode. Even though
the transfer was reported as being performed successfully, the Windows host reports the resulting file
size is 4050 bytes, rather than the original 4000 bytes. Does this difference in the file size imply an
error in the data transfer? Why or why not?
The "netascii" transfer mode implies the file data are transmitted as lines of ASCII text terminated by
the character sequence {CR, LF}, and that both systems must convert between this format and the
one they use to store the text files locally.
This means that when the "netascii" transfer mode is employed, the file sizes of the local and the
remote file may differ, without any implication of errors in the data transfer. For example, UNIX
systems terminate lines by means of a single LF character, while other systems, such as Microsoft
Windows, terminate lines by means of the character sequence {CR, LF}. This means that a given text
file will usually occupy more space in a Windows host than in a UNIX system.
2.14. The TFTP specification (RFC 1350) states that the transfer identifiers (TIDs) for a connection
should be randomly chosen, so that the probability that the same number is chosen twice in immediate
succession is very low. What would be the problem of using the same TIDs twice in immediate
succession?
If the same TIDs are used in twice in immediate succession, there's a chance that packets of the first
instance of the connection that were delayed in the network arrive during the life of the second
instance of the connection, and, as they would have the correct TIDs, they could be (mistakenly)
considered as valid.
2.15. In order to be able to retransmit lost packets, TFTP must keep a copy of the data it sends. How
many packets of data must TFTP keep at a time to implement this retransmission mechanism?
TFTP needs to keep a copy of only the last packet it has sent, since the acknowledgement mechanism
it implements guarantees that all the previous packets have been received, and thus will not need to
be retransmitted.
2.16. TFTP, like most protocols, will never send an error packet in response to an error packet it
receives. Why?
This could trigger an "error storm". Suppose host A receives an error packet from host B, and responds
it by sending an error packet back to host B. This packet could trigger another error packet from host
B, which would (again) trigger an error packet at host A. Thus, error messages would bounce from
one host to the other, indefinitely, congesting the network and consuming the resources of the
participating systems.
2.17. We have seen that in order to deal with lost packets, TFTP implements a timeoutand-retransmit
scheme, by setting a retransmission timer when it transmits a packet to the remote host. Most TFTP
implementations set this timer to a fixed value of about 5 seconds. Discuss the advantages and the
disadvantages of using a fixed value for the retransmission timer.
The disadvantage is that using a fixed value for the retransmission timer means the timer will not
reflect the characteristics of the network on which the data transfer is taking place. For example, if
both hosts are on the same local area network, a 5- second timeout is more than enough. On the other
hand, if the transfer is taking place over a (long delay) satellite link, then a 5-second timeout might
be too short, and could trigger unnecessary retransmissions. On the other hand, using a fixed value
for the retransmission timer keeps the TFTP implementation simple, which is the objective the
designers of TFTP had in mind.
2.18. TFTPs timeout-and-retransmission scheme implies that all data packets will eventually
be received by the destination host. Will these data also be received uncorrupted? Why or why not?
TFTP does not implement any error detection mechanism for the transmitted data.
Thus, reliability depends on the service provided by the underlying transport protocol (UDP). While
the UDP includes a checksum for detecting errors, its use is optional. Therefore, if UDP checksums
are not enabled, data could be corrupted without being detected by the destination host.
2.19. This problem concerns material in Appendix E. Based on the principles enunciated in Table
E.1.
a. Design an architecture with eight layers and make a case for it.
The internet protocol can be defined as a separate layer. The functions performed by IP are clearly
distinct from those performed at a network layer and those performed at a transport layer, so this
would make good sense.
b. Design one with six layers and make a case for that.
The session and transport layer both are involved in providing an end-to-end service to the OSI user,
and could easily be combined. This has been done in TCP/IP, which provides a direct application
interface to TCP.