Phonet: handle rtnetlink registration failure
authorremi.denis-courmont@nokia <remi.denis-courmont@nokia>
Fri, 23 Jan 2009 03:00:28 +0000 (03:00 +0000)
committerDavid S. Miller <davem@davemloft.net>
Tue, 27 Jan 2009 05:03:34 +0000 (21:03 -0800)
Signed-off-by: RĂ©mi Denis-Courmont <remi.denis-courmont@nokia.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
include/net/phonet/pn_dev.h
net/phonet/pn_dev.c
net/phonet/pn_netlink.c

index 59ae628b1111801a251efa090a2ba7d6fc09b37f..4ba2aedaa507e23a43c60e96586184d9f01f1198 100644 (file)
@@ -38,7 +38,7 @@ struct phonet_device {
 
 int phonet_device_init(void);
 void phonet_device_exit(void);
-void phonet_netlink_register(void);
+int phonet_netlink_register(void);
 struct net_device *phonet_device_get(struct net *net);
 
 int phonet_address_add(struct net_device *dev, u8 addr);
index af49db01d634ace9bb3c89e5d4aac2c33d1bc0fe..fd418107652bca5c23790acc8fc44047e954bb85 100644 (file)
@@ -190,9 +190,13 @@ static struct notifier_block phonet_device_notifier = {
 /* Initialize Phonet devices list */
 int __init phonet_device_init(void)
 {
+       int err;
+
        register_netdevice_notifier(&phonet_device_notifier);
-       phonet_netlink_register();
-       return 0;
+       err = phonet_netlink_register();
+       if (err)
+               phonet_device_exit();
+       return err;
 }
 
 void phonet_device_exit(void)
index 242fe8f8c322d5fb048d737a46d36b99797f47aa..918a4f07f24a1786ede1b1eab630ef054857371e 100644 (file)
@@ -160,9 +160,14 @@ out:
        return skb->len;
 }
 
-void __init phonet_netlink_register(void)
+int __init phonet_netlink_register(void)
 {
-       rtnl_register(PF_PHONET, RTM_NEWADDR, addr_doit, NULL);
-       rtnl_register(PF_PHONET, RTM_DELADDR, addr_doit, NULL);
-       rtnl_register(PF_PHONET, RTM_GETADDR, NULL, getaddr_dumpit);
+       int err = __rtnl_register(PF_PHONET, RTM_NEWADDR, addr_doit, NULL);
+       if (err)
+               return err;
+
+       /* Further __rtnl_register() cannot fail */
+       __rtnl_register(PF_PHONET, RTM_DELADDR, addr_doit, NULL);
+       __rtnl_register(PF_PHONET, RTM_GETADDR, NULL, getaddr_dumpit);
+       return 0;
 }