Vakul Garg <vakul.g...@nxp.com> wrote:
> Hi
> 
> With kernel 4.14.122, I am getting a kernel softlockup while running single 
> static ipsec tunnel.
> The problem reproduces mostly after running 8-10 hours of ipsec encap test 
> (on my dual core arm board).
> 
> I found that in function xfrm_policy_lookup_bytype(), the policy in variable 
> 'ret' shows refcnt=0 under problem situation.
> This creates an infinite loop in  xfrm_policy_lookup_bytype() and hence the 
> lockup.
> 
> Can some body please provide me pointers about 'refcnt'?
> Is it legitimate for 'refcnt' to become '0'? Under what condition can it 
> become '0'?

Yes, when policy is destroyed and the last user calls
xfrm_pol_put() which will invoke call_rcu to free the structure.

Reply via email to