xfrm: fix policy unreferencing on larval drop
authorTimo Teras <timo.teras@iki.fi>
Sun, 16 May 2010 06:49:26 +0000 (23:49 -0700)
committerDavid S. Miller <davem@davemloft.net>
Sun, 16 May 2010 06:49:26 +0000 (23:49 -0700)
I mistakenly had the error path to use num_pols to decide how
many policies we need to drop (cruft from earlier patch set
version which did not handle socket policies right).

This is wrong since normally we do not keep explicit references
(instead we hold reference to the cache entry which holds references
to policies). drop_pols is set to num_pols if we are holding the
references, so use that. Otherwise we eventually BUG_ON inside
xfrm_policy_destroy due to premature policy deletion.

Signed-off-by: Timo Teras <timo.teras@iki.fi>
Signed-off-by: David S. Miller <davem@davemloft.net>
net/xfrm/xfrm_policy.c

index 31f4ba43b48fdcb77d617b28dca40c1dc5d6258b..f4ea3a08e5a1369cf930110b28dfb85bab45fb1b 100644 (file)
@@ -1805,7 +1805,7 @@ restart:
                        /* EREMOTE tells the caller to generate
                         * a one-shot blackhole route. */
                        dst_release(dst);
-                       xfrm_pols_put(pols, num_pols);
+                       xfrm_pols_put(pols, drop_pols);
                        XFRM_INC_STATS(net, LINUX_MIB_XFRMOUTNOSTATES);
                        return -EREMOTE;
                }