Message ID | 20220414091943.3000372-2-steffen.klassert@secunet.com (mailing list archive) |
---|---|
State | Accepted |
Commit | 748b82c23e25310fec54e1eff2cb63936f391b24 |
Delegated to: | Netdev Maintainers |
Headers | show |
Series | [1/2] xfrm: Pass flowi_oif or l3mdev as oif to xfrm_dst_lookup | expand |
Hello: This series was applied to netdev/net.git (master) by Steffen Klassert <steffen.klassert@secunet.com>: On Thu, 14 Apr 2022 11:19:42 +0200 you wrote: > From: David Ahern <dsahern@kernel.org> > > The commit referenced in the Fixes tag no longer changes the > flow oif to the l3mdev ifindex. A xfrm use case was expecting > the flowi_oif to be the VRF if relevant and the change broke > that test. Update xfrm_bundle_create to pass oif if set and any > potential flowi_l3mdev if oif is not set. > > [...] Here is the summary with links: - [1/2] xfrm: Pass flowi_oif or l3mdev as oif to xfrm_dst_lookup https://git.kernel.org/netdev/net/c/748b82c23e25 - [2/2] esp: limit skb_page_frag_refill use to a single page https://git.kernel.org/netdev/net/c/5bd8baab087d You are awesome, thank you!
diff --git a/net/xfrm/xfrm_policy.c b/net/xfrm/xfrm_policy.c index 19aa994f5d2c..00bd0ecff5a1 100644 --- a/net/xfrm/xfrm_policy.c +++ b/net/xfrm/xfrm_policy.c @@ -2593,12 +2593,14 @@ static struct dst_entry *xfrm_bundle_create(struct xfrm_policy *policy, if (xfrm[i]->props.mode != XFRM_MODE_TRANSPORT) { __u32 mark = 0; + int oif; if (xfrm[i]->props.smark.v || xfrm[i]->props.smark.m) mark = xfrm_smark_get(fl->flowi_mark, xfrm[i]); family = xfrm[i]->props.family; - dst = xfrm_dst_lookup(xfrm[i], tos, fl->flowi_oif, + oif = fl->flowi_oif ? : fl->flowi_l3mdev; + dst = xfrm_dst_lookup(xfrm[i], tos, oif, &saddr, &daddr, family, mark); err = PTR_ERR(dst); if (IS_ERR(dst))