Commit f54cf50e authored by David S. Miller's avatar David S. Miller

[IPSEC]: Use dst_hold unless assigning result to something.

parent bd698d68
...@@ -728,7 +728,7 @@ xfrm_bundle_create(struct xfrm_policy *policy, struct xfrm_state **xfrm, int nx, ...@@ -728,7 +728,7 @@ xfrm_bundle_create(struct xfrm_policy *policy, struct xfrm_state **xfrm, int nx,
else { else {
dst_prev->child = dst1; dst_prev->child = dst1;
dst1->flags |= DST_NOHASH; dst1->flags |= DST_NOHASH;
dst_clone(dst1); dst_hold(dst1);
} }
dst_prev = dst1; dst_prev = dst1;
if (xfrm[i]->props.mode) { if (xfrm[i]->props.mode) {
...@@ -748,7 +748,7 @@ xfrm_bundle_create(struct xfrm_policy *policy, struct xfrm_state **xfrm, int nx, ...@@ -748,7 +748,7 @@ xfrm_bundle_create(struct xfrm_policy *policy, struct xfrm_state **xfrm, int nx,
if (err) if (err)
goto error; goto error;
} else { } else {
dst_clone(&rt->u.dst); dst_hold(&rt->u.dst);
} }
dst_prev->child = &rt->u.dst; dst_prev->child = &rt->u.dst;
for (dst_prev = dst; dst_prev != &rt->u.dst; dst_prev = dst_prev->child) { for (dst_prev = dst; dst_prev != &rt->u.dst; dst_prev = dst_prev->child) {
...@@ -853,7 +853,7 @@ int xfrm_lookup(struct dst_entry **dst_p, struct flowi *fl, ...@@ -853,7 +853,7 @@ int xfrm_lookup(struct dst_entry **dst_p, struct flowi *fl,
xdst->u.rt.fl.fl4_src == fl->fl4_src && xdst->u.rt.fl.fl4_src == fl->fl4_src &&
xdst->u.rt.fl.oif == fl->oif && xdst->u.rt.fl.oif == fl->oif &&
xfrm_bundle_ok(xdst, fl)) { xfrm_bundle_ok(xdst, fl)) {
dst_clone(dst); dst_hold(dst);
break; break;
} }
} }
...@@ -919,7 +919,7 @@ int xfrm_lookup(struct dst_entry **dst_p, struct flowi *fl, ...@@ -919,7 +919,7 @@ int xfrm_lookup(struct dst_entry **dst_p, struct flowi *fl,
} }
dst->next = policy->bundles; dst->next = policy->bundles;
policy->bundles = dst; policy->bundles = dst;
dst_clone(dst); dst_hold(dst);
write_unlock_bh(&policy->lock); write_unlock_bh(&policy->lock);
} }
*dst_p = dst; *dst_p = dst;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment