Forráskód Böngészése

Phonet: handle rtnetlink registration failure

Signed-off-by: Rémi Denis-Courmont <remi.denis-courmont@nokia.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
remi.denis-courmont@nokia 16 éve
szülő
commit
660f706d93
3 módosított fájl, 16 hozzáadás és 7 törlés
  1. 1 1
      include/net/phonet/pn_dev.h
  2. 6 2
      net/phonet/pn_dev.c
  3. 9 4
      net/phonet/pn_netlink.c

+ 1 - 1
include/net/phonet/pn_dev.h

@@ -38,7 +38,7 @@ struct phonet_device {
 
 
 int phonet_device_init(void);
 int phonet_device_init(void);
 void phonet_device_exit(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);
 struct net_device *phonet_device_get(struct net *net);
 
 
 int phonet_address_add(struct net_device *dev, u8 addr);
 int phonet_address_add(struct net_device *dev, u8 addr);

+ 6 - 2
net/phonet/pn_dev.c

@@ -190,9 +190,13 @@ static struct notifier_block phonet_device_notifier = {
 /* Initialize Phonet devices list */
 /* Initialize Phonet devices list */
 int __init phonet_device_init(void)
 int __init phonet_device_init(void)
 {
 {
+	int err;
+
 	register_netdevice_notifier(&phonet_device_notifier);
 	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)
 void phonet_device_exit(void)

+ 9 - 4
net/phonet/pn_netlink.c

@@ -160,9 +160,14 @@ out:
 	return skb->len;
 	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;
 }
 }