diff options
author | David S. Miller <davem@davemloft.net> | 2013-12-19 18:37:49 -0500 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2013-12-19 18:37:49 -0500 |
commit | 1669cb9855050fe9d2a13391846f9aceccf42559 (patch) | |
tree | 80a2f1229902e9db7fd1552ee770372b351f2036 /net/sctp | |
parent | cb4eae3d525abbe408e7e0efd7841b5c3c13cd0f (diff) | |
parent | b3c6efbc36e2c5ac820b1a800ac17cc3e040de0c (diff) |
Merge branch 'master' of git://git.kernel.org/pub/scm/linux/kernel/git/klassert/ipsec-next
Steffen Klassert says:
====================
pull request (net-next): ipsec-next 2013-12-19
1) Use the user supplied policy index instead of a generated one
if present. From Fan Du.
2) Make xfrm migration namespace aware. From Fan Du.
3) Make the xfrm state and policy locks namespace aware. From Fan Du.
4) Remove ancient sleeping when the SA is in acquire state,
we now queue packets to the policy instead. This replaces the
sleeping code.
5) Remove FLOWI_FLAG_CAN_SLEEP. This was used to notify xfrm about the
posibility to sleep. The sleeping code is gone, so remove it.
6) Check user specified spi for IPComp. Thr spi for IPcomp is only
16 bit wide, so check for a valid value. From Fan Du.
7) Export verify_userspi_info to check for valid user supplied spi ranges
with pfkey and netlink. From Fan Du.
8) RFC3173 states that if the total size of a compressed payload and the IPComp
header is not smaller than the size of the original payload, the IP datagram
must be sent in the original non-compressed form. These packets are dropped
by the inbound policy check because they are not transformed. Document the need
to set 'level use' for IPcomp to receive such packets anyway. From Fan Du.
Please pull or let me know if there are problems.
====================
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/sctp')
-rw-r--r-- | net/sctp/ipv6.c | 4 |
1 files changed, 2 insertions, 2 deletions
diff --git a/net/sctp/ipv6.c b/net/sctp/ipv6.c index 32db816ffbaa..317e13eb2c56 100644 --- a/net/sctp/ipv6.c +++ b/net/sctp/ipv6.c | |||
@@ -262,7 +262,7 @@ static void sctp_v6_get_dst(struct sctp_transport *t, union sctp_addr *saddr, | |||
262 | } | 262 | } |
263 | 263 | ||
264 | final_p = fl6_update_dst(fl6, np->opt, &final); | 264 | final_p = fl6_update_dst(fl6, np->opt, &final); |
265 | dst = ip6_dst_lookup_flow(sk, fl6, final_p, false); | 265 | dst = ip6_dst_lookup_flow(sk, fl6, final_p); |
266 | if (!asoc || saddr) | 266 | if (!asoc || saddr) |
267 | goto out; | 267 | goto out; |
268 | 268 | ||
@@ -321,7 +321,7 @@ static void sctp_v6_get_dst(struct sctp_transport *t, union sctp_addr *saddr, | |||
321 | fl6->saddr = baddr->v6.sin6_addr; | 321 | fl6->saddr = baddr->v6.sin6_addr; |
322 | fl6->fl6_sport = baddr->v6.sin6_port; | 322 | fl6->fl6_sport = baddr->v6.sin6_port; |
323 | final_p = fl6_update_dst(fl6, np->opt, &final); | 323 | final_p = fl6_update_dst(fl6, np->opt, &final); |
324 | dst = ip6_dst_lookup_flow(sk, fl6, final_p, false); | 324 | dst = ip6_dst_lookup_flow(sk, fl6, final_p); |
325 | } | 325 | } |
326 | 326 | ||
327 | out: | 327 | out: |