<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
<HTML><HEAD>
<META http-equiv=Content-Type content="text/html; charset=iso-8859-1">
<META content="MSHTML 6.00.6000.16674" name=GENERATOR>
<STYLE></STYLE>
</HEAD>
<BODY bgColor=#ffffff>
<DIV><FONT face=Arial size=2>dear michael,</FONT></DIV>
<DIV><FONT face=Arial size=2></FONT>&nbsp;</DIV>
<DIV><FONT face=Arial size=2>you are missing main points here: </FONT></DIV>
<DIV><FONT face=Arial size=2></FONT>&nbsp;</DIV>
<DIV><FONT face=Arial size=2>1. flow control is aimed at avoiding overflow of 
the receiver buffer. the receiver buffer is assigned on a per-flow base, i.e. it 
is not a shared resource. This makes &nbsp;flow control a mechanism that is 100% 
perfect from the point of&nbsp; view of control, i mean&nbsp; &nbsp;that all the 
feedback required for perfect control is available;</FONT></DIV>
<DIV><FONT face=Arial size=2></FONT>&nbsp;</DIV>
<DIV><FONT face=Arial size=2>2. congestion control does not know buffer 
available at routers because they are shared; this is the reason you need a 
probing mechanism to estimate cwnd. you do not need this probing mechanism with 
the receiver buffer since the advertised window tells you the exact available 
buffer.</FONT></DIV>
<DIV><FONT face=Arial size=2></FONT>&nbsp;</DIV>
<DIV><FONT face=Arial size=2>this is why we need flow control. moreover,&nbsp; 
saturating cwnd with receiver-buffer size (f.i. &nbsp;64Kb) avoids that any 
single flow congest network using probing.</FONT></DIV>
<DIV><FONT face=Arial size=2></FONT>&nbsp;</DIV>
<DIV><FONT face=Arial size=2>best</FONT></DIV>
<DIV><FONT face=Arial size=2></FONT>&nbsp;</DIV>
<DIV><FONT face=Arial size=2>saverio</DIV>
<DIV><BR><BR></DIV>
<DIV class=gmail_quote>On Fri, Jun 27, 2008 at 10:08 AM, Michael Scharf 
&lt;michael.scharf@ikr.uni-stuttgart.de&gt; wrote:<BR>
<BLOCKQUOTE class=gmail_quote 
style="PADDING-LEFT: 1ex; MARGIN: 0pt 0pt 0pt 0.8ex; BORDER-LEFT: rgb(204,204,204) 1px solid">
  <DIV>
  <DIV></DIV>
  <DIV class=Wj3C7c>On Thu, 26 Jun 2008 at 07:52:35, Craig Partridge 
  wrote:<BR>&gt; &gt;Instead of reducing rwnd, an overloaded receiver running 
  out of buffer<BR>&gt; &gt;space could simply drop (or mark) new arriving 
  packets, or just<BR>&gt; &gt;refrain from sending 
  acknowledgements.<BR>&gt;<BR>&gt; So, try the thought 
  experiment.<BR>&gt;<BR>&gt; Suppose the receiver does drop the newly arriving 
  segment. &nbsp;Eventually<BR>&gt; the segment is retransmitted. &nbsp;Two 
  (non-exclusive) situations to consider:<BR>&gt;<BR>&gt; &nbsp; &nbsp; * the 
  segment's packet encounters congestion and causes another packet<BR>&gt; 
  &nbsp; &nbsp; &nbsp; to be dropped -- now the decision by the receiver to drop 
  the<BR>&gt; &nbsp; &nbsp; &nbsp; original transmission has caused a third 
  party harm...<BR>&gt; &nbsp; &nbsp; &nbsp; (See the Floyd/Romanow paper from 
  SIGCOMM several years back for<BR>&gt; &nbsp; &nbsp; &nbsp; an analogous 
  situation in ATM and the harm it causes).<BR>&gt;<BR>&gt; &nbsp; &nbsp; * the 
  segment's packet fails to get to the receiver (congestion loss or<BR>&gt; 
  &nbsp; &nbsp; &nbsp; transmission error) -- this can be repeated for each 
  retransmission,<BR>&gt; &nbsp; &nbsp; &nbsp; such that the receiver's decision 
  to drop the original segment means<BR>&gt; &nbsp; &nbsp; &nbsp; it never gets 
  the segment and the connection dies...<BR>&gt;<BR>&gt; So dropping a segment 
  is bad. &nbsp;Let's try retaining but not sending acks...<BR>&gt;<BR>&gt; 
  &nbsp; &nbsp; * without an ack, the sender eventually retransmits and the 
  retransmitted<BR>&gt; &nbsp; &nbsp; &nbsp; segment can, in a case of 
  congestion, again cause loss for a third<BR>&gt; &nbsp; &nbsp; &nbsp; party 
  (to no purpose, as the retransmission is clearly redundant --<BR>&gt; &nbsp; 
  &nbsp; &nbsp; if only the receiver had acked...)<BR>&gt;<BR>&gt; &nbsp; &nbsp; 
  * if acks are suppressed too long, the sender times out the connection<BR>&gt; 
  &nbsp; &nbsp; &nbsp; and the connection fails<BR>&gt;<BR>&gt; &nbsp; &nbsp; * 
  another consequence is that the sender increases its round-trip<BR>&gt; &nbsp; 
  &nbsp; &nbsp; timeout, so when a true loss occurs later in the connection, 
  the<BR>&gt; &nbsp; &nbsp; &nbsp; sender will respond less promptly (harming 
  performance).<BR>&gt;<BR>&gt; In conclusion, the receiver needs to ack, and 
  ack promptly. &nbsp;But the<BR>&gt; receiver is not ready for more 
  data...<BR><BR></DIV></DIV>Instead of dropping arriving packets or not sending 
  acks, the receiver<BR>could also send an ack with ECN marking (assuming ECN 
  usage is<BR>negotiated). This would also throttle the sender, but not require 
  a<BR>retransmission. To my understanding, ECN marking would not cause 
  all<BR>these problems.<BR><BR>Thus, a receiver running out of buffer space 
  could just use ECN<BR>instead of shrinking rwnd. (Of course, the ECN solution 
  is more coarse<BR>grained and does not offer certain features, such as zero 
  window<BR>updates.)<BR><FONT 
color=#888888><BR>Michael<BR></FONT></BLOCKQUOTE></DIV>
<DIV><BR><BR clear=all><BR>-- <BR>Prof. Saverio Mascolo<BR>Dipartimento di 
Elettrotecnica ed Elettronica<BR>Politecnico di Bari<BR>Tel. +39 080 
5963621<BR>Fax. +39 080 
5963410<BR>email:mascolo@poliba.it<BR><BR>http://www-dee.poliba.it/dee-web/Personale/mascolo.html</FONT></DIV></BODY></HTML>