|
@@ -2913,15 +2913,19 @@ static int __net_init xfrm_net_init(struct net *net)
|
|
rv = xfrm_sysctl_init(net);
|
|
rv = xfrm_sysctl_init(net);
|
|
if (rv < 0)
|
|
if (rv < 0)
|
|
goto out_sysctl;
|
|
goto out_sysctl;
|
|
|
|
+ rv = flow_cache_init(net);
|
|
|
|
+ if (rv < 0)
|
|
|
|
+ goto out;
|
|
|
|
|
|
/* Initialize the per-net locks here */
|
|
/* Initialize the per-net locks here */
|
|
spin_lock_init(&net->xfrm.xfrm_state_lock);
|
|
spin_lock_init(&net->xfrm.xfrm_state_lock);
|
|
rwlock_init(&net->xfrm.xfrm_policy_lock);
|
|
rwlock_init(&net->xfrm.xfrm_policy_lock);
|
|
mutex_init(&net->xfrm.xfrm_cfg_mutex);
|
|
mutex_init(&net->xfrm.xfrm_cfg_mutex);
|
|
|
|
|
|
- flow_cache_init(net);
|
|
|
|
return 0;
|
|
return 0;
|
|
|
|
|
|
|
|
+out:
|
|
|
|
+ xfrm_sysctl_fini(net);
|
|
out_sysctl:
|
|
out_sysctl:
|
|
xfrm_policy_fini(net);
|
|
xfrm_policy_fini(net);
|
|
out_policy:
|
|
out_policy:
|
|
@@ -2934,6 +2938,7 @@ out_statistics:
|
|
|
|
|
|
static void __net_exit xfrm_net_exit(struct net *net)
|
|
static void __net_exit xfrm_net_exit(struct net *net)
|
|
{
|
|
{
|
|
|
|
+ flow_cache_fini(net);
|
|
xfrm_sysctl_fini(net);
|
|
xfrm_sysctl_fini(net);
|
|
xfrm_policy_fini(net);
|
|
xfrm_policy_fini(net);
|
|
xfrm_state_fini(net);
|
|
xfrm_state_fini(net);
|