Re: HB.Max.Burst

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

 



On 03/21/2014 08:11 AM, Karl Heiss wrote:
> On Thu, Mar 20, 2014 at 3:55 PM, Vlad Yasevich <vyasevich@xxxxxxxxx> wrote:
>> On 03/20/2014 09:31 AM, Karl Heiss wrote:
>>> I have a question about the HB.Max.Burst parameter for the LKSCTP
>>> stack.  I notice that there is no explicit parameter for this value
>>> and the alternative from RFC 5062 (only one HB per RTT) does not
>>> appear to be implemented either (see excerpt below).  The only
>>> limiting factor appears to be max.burst.  Am I missing something
>>> obvious or should there be some other form of limiting heartbeats to
>>> mitigate some of the issues outlined in RFC 5062?
>>
>> Not sure what you mean by "there is no explicit parameter".
>>
>> There is a system tunable /proc/sys/net/sctp/max_burst that can be
>> changed.
>>
>> The value may also be controlled by application through the
>> SCTP_MAX_BURST socket option.
>>
>> Additionally, lksctp will only send one HB per RTT.
>>
> 
> I did not realize that it would only send one HB per RTT.  I do see
> now that max_burst does indeed apply to control chunks, as I was
> originally under the wrong impression that it only applied to data
> chunks.

Ooops.  My mistake here, and you are correct.  max_burst applies only
to data chunks and I wasn't careful enough to not that you are talking
about Heartbeats.

It does appear that we do not have a limiter for heartbeats.  So,
if the association is started with 10 unconfirmed addresses, there
will be 10 HBs sent.  The only slight mitigation factor we have is
that they will be jittered at +/-50% of rto.

> 
> However, from what I can see in the source, it appears that
> sctp_sf_sendbeat_8_3 is only limited by asoc->max_retrans and
> SPP_HB_ENABLE.  Thus I would think that every time the heartbeat timer
> expires, we would queue up a heartbeat, assuming that are have not hit
> max_burst and other constraints.  Is it limited somewhere later in the
> stack or am I just being obtuse?

No, it's not limited by anything else.  The nice thing is that each
transport has it's own HB timer separate from RTO and it is jittered
even for UNCONFIRMED addresses.  So, HB will not show up as bursting,
but it appears that we still need a limit for # of outstanding HB to
UNCONFIRMED addresses.

Let me see if I can work something up.

Thanks
-vlad
> 
> Karl
> 
>> What do you thinks is missing?
>>
>> Thanks
>> -vlad
>>
>>>
>>> 6.3.  Mitigation Option
>>>
>>>    To limit the effectiveness of this attack, the new parameter
>>>    HB.Max.Burst was introduced in [RFC4960] and an endpoint should:
>>>
>>>    1) not allow very large cookie lifetimes, even if they are requested.
>>>
>>>    2) not use larger HB.Max.Burst parameter values than recommended.
>>>       Note that an endpoint may decide to send only one Heartbeat per
>>>       RTT instead of the maximum (i.e., HB.Max.Burst).  An endpoint that
>>>       chooses this approach will however slow down detection of
>>>       endpoints camping on valid addresses.
>>>
>>>    3) not use large HEARTBEATs for path confirmation.
>>>
>>>
>>> Karl
>>> --
>>> To unsubscribe from this list: send the line "unsubscribe linux-sctp" in
>>> the body of a message to majordomo@xxxxxxxxxxxxxxx
>>> More majordomo info at  http://vger.kernel.org/majordomo-info.html
>>>
>>

--
To unsubscribe from this list: send the line "unsubscribe linux-sctp" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html




[Index of Archives]     [Linux Networking Development]     [Linux OMAP]     [Linux USB Devel]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]

  Powered by Linux