Re: Correct timeout value for nofeedback timer?

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



My hypothesis (based on Colin's suggestion) is that you shouldn't need
a minimum value to reduce processing load if you are careful how you
code this, because you don't need a real timer that can go off
"asynchronously".  It's possible you might want a minimum for other
reasons, but not to reduce processing load.

However, my guess from the discussion (I haven't checked the code) is
that the current Linux code probably uses a TCP RTO-like mechanism,
and that would be problematic with very small RTTs.   If you code it
that way then you probably do want to implement a minimum value, with
a default minimum of around 100ms probably not being too catastrophic.

Note though that this is just a hypothesis at this point, until
someone has turned it into code and tested it :-)

- Mark



On 12/6/06, Gorry Fairhurst <gorry@xxxxxxxxxxxxxx> wrote:

So, I see the PATCH discussion has reached a compromise, but would like
the protocol people to reflect on what TFRC really say about the
nofeedback timer values:



I can see two things I'd like to understand:

1) What should be the INITIAL value for the timer? RFC 3448 says 2
seconds (section 4.2), but why was this 2, rather than 3, seconds?

- one rationale is that Linux already uses 2 secs for intial RTO in
Linux, but RFC 1122 Section 4.2.3.1 (and RFC2998) says it should be 3
seconds. 3 seconds provides more headroom for paths that may have
variable properties, especially at start-up (a "classic" example is ISDN).

- QUESTION: Should TFRC agree with TCP or the Linux value?



2) Should TFRC define a MINIMUM value for the timer?

- Some arguments for a small timer value include faster congestion
responses to loss, lower cost (if processing can be co-incident with
other protocol activity - but Mark suggested we only need to check in
the send-code anyway?)
- Some arguments for a larger timer include more tollerence to sudden
changes in path characteristics (TCP uses a min RTO of 1 sec, RFC2988)
e.g. mobility changes or routing changes, and lower load on processing,
especially at higher bit rates.



Any thoughts on these issues?


Gorry

P.S. the starting quote was:

"The TFRC nofeedback timer normally expires after the maximum of 4
RTTs and twice the current send interval (RFC 3448, 4.3). On LANs
with a small RTT this can mean a high processing load and reduced
performance, since then the nofeedback timer is triggered very
frequently. As a result, the sending rate quickly converges towards
zero."



[Index of Archives]     [Linux Kernel Development]     [Linux DCCP]     [IETF Annouce]     [Linux Networking]     [Git]     [Security]     [Linux Assembly]     [Bugtraq]     [Yosemite]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Linux SCSI]     [DDR & Rambus]

  Powered by Linux