diff options
author | Vlad Yasevich <vladislav.yasevich@hp.com> | 2010-04-30 22:41:10 -0400 |
---|---|---|
committer | Vlad Yasevich <vladislav.yasevich@hp.com> | 2010-04-30 22:41:10 -0400 |
commit | 65883371894be2631603d5d412f90f8c09290fef (patch) | |
tree | dbd95cdce0d32544428f26de68b2738a56a70764 | |
parent | cf9b4812e18aab6f86ff998bd7425a9e823269c3 (diff) |
sctp: rwnd_press should be cumulative
rwnd_press tracks the pressure on the recieve window. Every
timer the receive buffer overlows, we truncate the receive
window and then grow it back. However, if we don't track
the cumulative presser, it's possible to reach a situation
when receive buffer is empty, but rwnd stays truncated.
Signed-off-by: Vlad Yasevich <vladislav.yasevich@hp.com>
-rw-r--r-- | net/sctp/associola.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/net/sctp/associola.c b/net/sctp/associola.c index 37753cd48be3..65f9a7cdf466 100644 --- a/net/sctp/associola.c +++ b/net/sctp/associola.c | |||
@@ -1482,7 +1482,7 @@ void sctp_assoc_rwnd_decrease(struct sctp_association *asoc, unsigned len) | |||
1482 | if (asoc->rwnd >= len) { | 1482 | if (asoc->rwnd >= len) { |
1483 | asoc->rwnd -= len; | 1483 | asoc->rwnd -= len; |
1484 | if (over) { | 1484 | if (over) { |
1485 | asoc->rwnd_press = asoc->rwnd; | 1485 | asoc->rwnd_press += asoc->rwnd; |
1486 | asoc->rwnd = 0; | 1486 | asoc->rwnd = 0; |
1487 | } | 1487 | } |
1488 | } else { | 1488 | } else { |