[XFRM]: Fix wildcard as tunnel source
Hashing SAs by source address breaks templates with wildcards as tunnel source since the source address used for hashing/lookup is still 0/0. Move source address lookup to xfrm_tmpl_resolve_one() so we can use the real address in the lookup. Signed-off-by: Patrick McHardy <kaber@trash.net> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
committed by
David S. Miller
parent
1ef9696c90
commit
a1e59abf82
@ -42,21 +42,6 @@ __xfrm4_init_tempsel(struct xfrm_state *x, struct flowi *fl,
|
||||
x->props.saddr = tmpl->saddr;
|
||||
if (x->props.saddr.a4 == 0)
|
||||
x->props.saddr.a4 = saddr->a4;
|
||||
if (tmpl->mode == XFRM_MODE_TUNNEL && x->props.saddr.a4 == 0) {
|
||||
struct rtable *rt;
|
||||
struct flowi fl_tunnel = {
|
||||
.nl_u = {
|
||||
.ip4_u = {
|
||||
.daddr = x->id.daddr.a4,
|
||||
}
|
||||
}
|
||||
};
|
||||
if (!xfrm_dst_lookup((struct xfrm_dst **)&rt,
|
||||
&fl_tunnel, AF_INET)) {
|
||||
x->props.saddr.a4 = rt->rt_src;
|
||||
dst_release(&rt->u.dst);
|
||||
}
|
||||
}
|
||||
x->props.mode = tmpl->mode;
|
||||
x->props.reqid = tmpl->reqid;
|
||||
x->props.family = AF_INET;
|
||||
|
Reference in New Issue
Block a user