aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorremi.denis-courmont@nokia <remi.denis-courmont@nokia>2009-01-22 22:00:28 -0500
committerDavid S. Miller <davem@davemloft.net>2009-01-27 00:03:34 -0500
commit660f706d931d4795d341805e083a8091af74fa88 (patch)
treeac5cc51b70b0c30c1835362eaf883df965bb27f9
parent76e02cf6945e6faa9f6b546dc0513512197c5966 (diff)
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>
-rw-r--r--include/net/phonet/pn_dev.h2
-rw-r--r--net/phonet/pn_dev.c8
-rw-r--r--net/phonet/pn_netlink.c13
3 files changed, 16 insertions, 7 deletions
diff --git a/include/net/phonet/pn_dev.h b/include/net/phonet/pn_dev.h
index 59ae628b1111..4ba2aedaa507 100644
--- a/include/net/phonet/pn_dev.h
+++ b/include/net/phonet/pn_dev.h
@@ -38,7 +38,7 @@ struct phonet_device {
38 38
39int phonet_device_init(void); 39int phonet_device_init(void);
40void phonet_device_exit(void); 40void phonet_device_exit(void);
41void phonet_netlink_register(void); 41int phonet_netlink_register(void);
42struct net_device *phonet_device_get(struct net *net); 42struct net_device *phonet_device_get(struct net *net);
43 43
44int phonet_address_add(struct net_device *dev, u8 addr); 44int phonet_address_add(struct net_device *dev, u8 addr);
diff --git a/net/phonet/pn_dev.c b/net/phonet/pn_dev.c
index af49db01d634..fd418107652b 100644
--- a/net/phonet/pn_dev.c
+++ b/net/phonet/pn_dev.c
@@ -190,9 +190,13 @@ static struct notifier_block phonet_device_notifier = {
190/* Initialize Phonet devices list */ 190/* Initialize Phonet devices list */
191int __init phonet_device_init(void) 191int __init phonet_device_init(void)
192{ 192{
193 int err;
194
193 register_netdevice_notifier(&phonet_device_notifier); 195 register_netdevice_notifier(&phonet_device_notifier);
194 phonet_netlink_register(); 196 err = phonet_netlink_register();
195 return 0; 197 if (err)
198 phonet_device_exit();
199 return err;
196} 200}
197 201
198void phonet_device_exit(void) 202void phonet_device_exit(void)
diff --git a/net/phonet/pn_netlink.c b/net/phonet/pn_netlink.c
index 242fe8f8c322..918a4f07f24a 100644
--- a/net/phonet/pn_netlink.c
+++ b/net/phonet/pn_netlink.c
@@ -160,9 +160,14 @@ out:
160 return skb->len; 160 return skb->len;
161} 161}
162 162
163void __init phonet_netlink_register(void) 163int __init phonet_netlink_register(void)
164{ 164{
165 rtnl_register(PF_PHONET, RTM_NEWADDR, addr_doit, NULL); 165 int err = __rtnl_register(PF_PHONET, RTM_NEWADDR, addr_doit, NULL);
166 rtnl_register(PF_PHONET, RTM_DELADDR, addr_doit, NULL); 166 if (err)
167 rtnl_register(PF_PHONET, RTM_GETADDR, NULL, getaddr_dumpit); 167 return err;
168
169 /* Further __rtnl_register() cannot fail */
170 __rtnl_register(PF_PHONET, RTM_DELADDR, addr_doit, NULL);
171 __rtnl_register(PF_PHONET, RTM_GETADDR, NULL, getaddr_dumpit);
172 return 0;
168} 173}