Warning: foreach() argument must be of type array|object, bool given in /var/www/html/web/app/themes/studypress-core-theme/template-parts/header/mobile-offcanvas.php on line 20

Problem 19

During linear increase, TCP computes an increment to the congestion window as Increment \(=\mathrm{MSS} \times(\mathrm{MSS} /\) CongestionWindow \()\) Explain why computing this increment each time an ACK arrives may not result in the correct increment. Give a more precise definition for this increment. (Hint: A given ACK can acknowledge more or less than one MSS's worth of data.)

Problem 20

Under what circumstances may coarse-grained timeouts still occur in TCP even when the fast retransmit mechanism is being used?

Problem 22

Suppose that between \(A\) and \(B\) there is a router \(R\). The \(A-R\) bandwidth is infinite (that is, packets are not delayed), but the R-B link introduces a bandwidth delay of 1 packet per second (that is, 2 packets take 2 seconds, etc.). Acknowledgments from \(\mathrm{B}\) to \(\mathrm{R}\), though, are sent instantaneously. \(\mathrm{A}\) sends data to \(\mathrm{B}\) over a \(\mathrm{TCP}\) connection, using slow start but with an arbitrarily large window size. R has a queue size of 1 , in addition to the packet it is sending. At each second, the sender first processes any arriving ACKs and then responds to any timeouts. (a) Assuming a fixed TimeOut period of 2 seconds, what is sent and received for \(\mathrm{T}=0,1, \ldots, 6\) seconds? Is the link ever idle due to timeouts? (b) What changes if TimeOut is 3 seconds instead?

Problem 25

Suppose host A reaches host B via routers R1 and R2: A-R1-R2-B. Fast retransmit is not used, and A calculates TimeOut as \(2 \times\) EstimatedRTT. Assume that the A-R1 and \(R 2-B\) links have infinite bandwidth; the \(R 1 \longrightarrow R 2\) link, however, introduces a 1 -second-per-packet bandwidth delay for data packets (though not ACKs). Describe a scenario in which the R1-R2 link is not \(100 \%\) utilized, even though A always has data ready to send. Hint: Suppose A's CongestionWindow increases from \(N\) to \(N+1\), where \(N\) is R1's queue size.

Problem 26

You are an Internet service provider; your client hosts connect directly to your routers. You know some hosts are using experimental TCPs and suspect some may be using a "greedy" TCP with no congestion control. What measurements might you make at your router to establish that a client was not using slow start at all? If a client used slow start on startup but not after a timeout, could you detect that?

Problem 27

Defeating TCP congestion-control mechanisms usually requires the explicit cooperation of the sender. However, consider the receiving end of a large data transfer using a TCP modified to ACK packets that have not yet arrived. It may do this either because not all of the data is necessary or because data that is lost can be recovered in a separate transfer later. What effect does this receiver behavior have on the congestion-control properties of the session? Can you devise a way to modify TCP to avoid the possibility of senders being taken advantage of in this manner?

Problem 29

Suppose you are downloading a large file over a 3-KBps phone link. Your software displays an average-bytes-per-second counter. How will TCP congestion control and occasional packet losses cause this counter to fluctuate? Assume that only a third, say, of the total RTT is spent on the phone link.

Problem 30

Suppose TCP is used over a lossy link that loses on average one segment in four. Assume the bandwidth \(x\) delay window size is considerably larger than four segments. (a) What happens when we start a connection? Do we ever get to the linearincrease phase of congestion avoidance? (b) Without using an explicit feedback mechanism from the routers, would TCP have any way to distinguish such link losses from congestion losses, at least over the short term? (c) Suppose TCP senders did reliably get explicit congestion indications from routers. Assuming links as above were common, would it be feasible to support window sizes much larger than four segments? What would TCP have to do?

Problem 31

Suppose two TCP connections share a path through a router R. The router's queue size is six segments; each connection has a stable congestion window of three segments. No congestion control is used by these connections. A third TCP connection now is attempted, also through R. The third connection does not use congestion control either. Describe a scenario in which, for at least a while, the third connection gets none of the available bandwidth, and the first two connections proceed with \(50 \%\) each. Does it matter if the third connection uses slow start? How does full congestion avoidance on the part of the first two connections help solve this?

Problem 32

Suppose a TCP connection has a window size of eight segments, an RTT of \(800 \mathrm{~ms}\), the sender sends segments at a regular rate of one every \(100 \mathrm{~ms}\), and the receiver sends ACKs back at the same rate without delay. A segment is lost, and the loss is detected by the fast retransmit algorithm on the receipt of the third duplicate \(\mathrm{ACK}\). At the point when the ACK of the retransmitted segment finally arrives, how much total time has the sender lost (compared to lossless transmission) if (a) the sender waits for the ACK from the retransmitted lost packet before sliding the window forward again? (b) the sender uses the continued arrival of each duplicate ACK as an indication it may slide the window forward one segment?

Access millions of textbook solutions in one place

  • Access over 3 million high quality textbook solutions
  • Access our popular flashcard, quiz, mock-exam and notes features
  • Access our smart AI features to upgrade your learning
Get Vaia Premium now
Access millions of textbook solutions in one place

Recommended explanations on Computer Science Textbooks