Hi Marcelo, On Wed, Dec 30, 2015 at 09:49:18AM -0200, Marcelo Ricardo Leitner wrote: > Please don't. Currently there is no other way to do it. The check I want > to add only works on a corner case of what we already have, on which we > can do better. It's just that. The way Michal handled the state > transitions is very good and the fact that the conntrack entries are > created as NEW, makes them pass the same user validation rules as a real > new association would do. So there can't be any hitch-hicking... > > And for vtag probing, that's not an issue either because SCTP just drops > such heartbeat requests with invalid vtags (at sctp_sf_beat_8_3). > > The only vector of attack I can think of that the initial multi-homing > support would allow is a DoS, a flood of incoming heartbeat requests. > Such flood would _not_ end up on the association buffer because if the > transport tuple (src ip, dst ip, src port, dst port) doesn't match a > known association, it's discarded. It's just as any other DoS, but as > they pass the same user validation rules, there should be rules > restricting the rate or IP range or something like that if user is > worried with that. Nothing that could jeopardize the original > association. > > Note that the transport validation is performed before the vtag one, and > the stack behavior is to also drop out of the blue packets silently. > Meaning that even if the attacker get a hit at the 32-bit vtag, it will > be discarded by the transport validation firstly. Makes sense indeed, thanks for explaining. Then we have to find a incremental path to extend Michal change to make it fit into what we have. > So what my patch add to it, it pulls/adds this vtag check to an earlier > moment, from the stack itself to the firewall, so that the peer > firewall will be a bit more stateful. Please check if you can fit part of this logic into l4proto->error(), just like ICMP v4 protocol tracker. BTW, I think these new flows should enter as RELATED, not as NEW, just like ICMP protocol tracker does. Your patch basically looks to me like an ad-hoc expectation infrastructure to handle this case. Thanks. -- 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