vti: Simplify error handling in module init and exit
The error handling in the module init and exit functions can be shortened to safe us some code. 1/ Remove the code duplications in the init function, jump straight to the existing cleanup code by adding some labels. Also give the error message some more value by telling the reason why loading the module has failed. Furthermore fix the "IPSec" typo -- it should be "IPsec" instead. 2/ Remove the error handling in the exit function as the only legitimate reason xfrm4_protocol_deregister() might fail is inet_del_protocol() returning -1. That, in turn, means some other protocol handler had been registered for this very protocol in the meantime. But that essentially means we haven't been handling that protocol any more, anyway. What it definitely means not is that we "can't deregister tunnel". Therefore just get rid of that bogus warning. It's plain wrong. Signed-off-by: Mathias Krause <minipli@googlemail.com> Signed-off-by: Steffen Klassert <steffen.klassert@secunet.com>
This commit is contained in:
parent
e59d82fd33
commit
1990e4f883
1 changed files with 21 additions and 33 deletions
|
@ -534,40 +534,28 @@ static struct rtnl_link_ops vti_link_ops __read_mostly = {
|
||||||
|
|
||||||
static int __init vti_init(void)
|
static int __init vti_init(void)
|
||||||
{
|
{
|
||||||
|
const char *msg;
|
||||||
int err;
|
int err;
|
||||||
|
|
||||||
pr_info("IPv4 over IPSec tunneling driver\n");
|
pr_info("IPv4 over IPsec tunneling driver\n");
|
||||||
|
|
||||||
|
msg = "tunnel device";
|
||||||
err = register_pernet_device(&vti_net_ops);
|
err = register_pernet_device(&vti_net_ops);
|
||||||
if (err < 0)
|
if (err < 0)
|
||||||
return err;
|
goto pernet_dev_failed;
|
||||||
|
|
||||||
|
msg = "tunnel protocols";
|
||||||
err = xfrm4_protocol_register(&vti_esp4_protocol, IPPROTO_ESP);
|
err = xfrm4_protocol_register(&vti_esp4_protocol, IPPROTO_ESP);
|
||||||
if (err < 0) {
|
if (err < 0)
|
||||||
unregister_pernet_device(&vti_net_ops);
|
goto xfrm_proto_esp_failed;
|
||||||
pr_info("vti init: can't register tunnel\n");
|
|
||||||
|
|
||||||
return err;
|
|
||||||
}
|
|
||||||
|
|
||||||
err = xfrm4_protocol_register(&vti_ah4_protocol, IPPROTO_AH);
|
err = xfrm4_protocol_register(&vti_ah4_protocol, IPPROTO_AH);
|
||||||
if (err < 0) {
|
if (err < 0)
|
||||||
xfrm4_protocol_deregister(&vti_esp4_protocol, IPPROTO_ESP);
|
goto xfrm_proto_ah_failed;
|
||||||
unregister_pernet_device(&vti_net_ops);
|
|
||||||
pr_info("vti init: can't register tunnel\n");
|
|
||||||
|
|
||||||
return err;
|
|
||||||
}
|
|
||||||
|
|
||||||
err = xfrm4_protocol_register(&vti_ipcomp4_protocol, IPPROTO_COMP);
|
err = xfrm4_protocol_register(&vti_ipcomp4_protocol, IPPROTO_COMP);
|
||||||
if (err < 0) {
|
if (err < 0)
|
||||||
xfrm4_protocol_deregister(&vti_ah4_protocol, IPPROTO_AH);
|
goto xfrm_proto_comp_failed;
|
||||||
xfrm4_protocol_deregister(&vti_esp4_protocol, IPPROTO_ESP);
|
|
||||||
unregister_pernet_device(&vti_net_ops);
|
|
||||||
pr_info("vti init: can't register tunnel\n");
|
|
||||||
|
|
||||||
return err;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
msg = "netlink interface";
|
||||||
err = rtnl_link_register(&vti_link_ops);
|
err = rtnl_link_register(&vti_link_ops);
|
||||||
if (err < 0)
|
if (err < 0)
|
||||||
goto rtnl_link_failed;
|
goto rtnl_link_failed;
|
||||||
|
@ -576,23 +564,23 @@ static int __init vti_init(void)
|
||||||
|
|
||||||
rtnl_link_failed:
|
rtnl_link_failed:
|
||||||
xfrm4_protocol_deregister(&vti_ipcomp4_protocol, IPPROTO_COMP);
|
xfrm4_protocol_deregister(&vti_ipcomp4_protocol, IPPROTO_COMP);
|
||||||
|
xfrm_proto_comp_failed:
|
||||||
xfrm4_protocol_deregister(&vti_ah4_protocol, IPPROTO_AH);
|
xfrm4_protocol_deregister(&vti_ah4_protocol, IPPROTO_AH);
|
||||||
|
xfrm_proto_ah_failed:
|
||||||
xfrm4_protocol_deregister(&vti_esp4_protocol, IPPROTO_ESP);
|
xfrm4_protocol_deregister(&vti_esp4_protocol, IPPROTO_ESP);
|
||||||
|
xfrm_proto_esp_failed:
|
||||||
unregister_pernet_device(&vti_net_ops);
|
unregister_pernet_device(&vti_net_ops);
|
||||||
|
pernet_dev_failed:
|
||||||
|
pr_err("vti init: failed to register %s\n", msg);
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void __exit vti_fini(void)
|
static void __exit vti_fini(void)
|
||||||
{
|
{
|
||||||
rtnl_link_unregister(&vti_link_ops);
|
rtnl_link_unregister(&vti_link_ops);
|
||||||
if (xfrm4_protocol_deregister(&vti_ipcomp4_protocol, IPPROTO_COMP))
|
xfrm4_protocol_deregister(&vti_ipcomp4_protocol, IPPROTO_COMP);
|
||||||
pr_info("vti close: can't deregister tunnel\n");
|
xfrm4_protocol_deregister(&vti_ah4_protocol, IPPROTO_AH);
|
||||||
if (xfrm4_protocol_deregister(&vti_ah4_protocol, IPPROTO_AH))
|
xfrm4_protocol_deregister(&vti_esp4_protocol, IPPROTO_ESP);
|
||||||
pr_info("vti close: can't deregister tunnel\n");
|
|
||||||
if (xfrm4_protocol_deregister(&vti_esp4_protocol, IPPROTO_ESP))
|
|
||||||
pr_info("vti close: can't deregister tunnel\n");
|
|
||||||
|
|
||||||
|
|
||||||
unregister_pernet_device(&vti_net_ops);
|
unregister_pernet_device(&vti_net_ops);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue