|
@@ -29,7 +29,7 @@ int fib_default_rule_add(struct fib_rules_ops *ops,
|
|
|
r->pref = pref;
|
|
|
r->table = table;
|
|
|
r->flags = flags;
|
|
|
- r->fr_net = ops->fro_net;
|
|
|
+ r->fr_net = hold_net(ops->fro_net);
|
|
|
|
|
|
/* The lock is not required here, the list in unreacheable
|
|
|
* at the moment this function is called */
|
|
@@ -243,7 +243,7 @@ static int fib_nl_newrule(struct sk_buff *skb, struct nlmsghdr* nlh, void *arg)
|
|
|
err = -ENOMEM;
|
|
|
goto errout;
|
|
|
}
|
|
|
- rule->fr_net = net;
|
|
|
+ rule->fr_net = hold_net(net);
|
|
|
|
|
|
if (tb[FRA_PRIORITY])
|
|
|
rule->pref = nla_get_u32(tb[FRA_PRIORITY]);
|
|
@@ -344,6 +344,7 @@ static int fib_nl_newrule(struct sk_buff *skb, struct nlmsghdr* nlh, void *arg)
|
|
|
return 0;
|
|
|
|
|
|
errout_free:
|
|
|
+ release_net(rule->fr_net);
|
|
|
kfree(rule);
|
|
|
errout:
|
|
|
rules_ops_put(ops);
|