Skip to content

Commit

Permalink
Phonet: allow phonet_device_init() to fail, put it to __init section
Browse files Browse the repository at this point in the history
Signed-off-by: Rémi Denis-Courmont <remi.denis-courmont@nokia.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
  • Loading branch information
remi.denis-courmont@nokia authored and David S. Miller committed Jan 27, 2009
1 parent 4b8f704 commit 76e02cf
Show file tree
Hide file tree
Showing 4 changed files with 11 additions and 6 deletions.
1 change: 0 additions & 1 deletion include/net/phonet/phonet.h
Original file line number Diff line number Diff line change
Expand Up @@ -105,7 +105,6 @@ void phonet_proto_unregister(int protocol, struct phonet_protocol *pp);

int phonet_sysctl_init(void);
void phonet_sysctl_exit(void);
void phonet_netlink_register(void);
int isi_register(void);
void isi_unregister(void);

Expand Down
3 changes: 2 additions & 1 deletion include/net/phonet/pn_dev.h
Original file line number Diff line number Diff line change
Expand Up @@ -36,8 +36,9 @@ struct phonet_device {
DECLARE_BITMAP(addrs, 64);
};

void phonet_device_init(void);
int phonet_device_init(void);
void phonet_device_exit(void);
void phonet_netlink_register(void);
struct net_device *phonet_device_get(struct net *net);

int phonet_address_add(struct net_device *dev, u8 addr);
Expand Down
9 changes: 6 additions & 3 deletions net/phonet/af_phonet.c
Original file line number Diff line number Diff line change
Expand Up @@ -426,16 +426,18 @@ static int __init phonet_init(void)
{
int err;

err = phonet_device_init();
if (err)
return err;

err = sock_register(&phonet_proto_family);
if (err) {
printk(KERN_ALERT
"phonet protocol family initialization failed\n");
return err;
goto err_sock;
}

phonet_device_init();
dev_add_pack(&phonet_packet_type);
phonet_netlink_register();
phonet_sysctl_init();

err = isi_register();
Expand All @@ -447,6 +449,7 @@ static int __init phonet_init(void)
phonet_sysctl_exit();
sock_unregister(PF_PHONET);
dev_remove_pack(&phonet_packet_type);
err_sock:
phonet_device_exit();
return err;
}
Expand Down
4 changes: 3 additions & 1 deletion net/phonet/pn_dev.c
Original file line number Diff line number Diff line change
Expand Up @@ -188,9 +188,11 @@ static struct notifier_block phonet_device_notifier = {
};

/* Initialize Phonet devices list */
void phonet_device_init(void)
int __init phonet_device_init(void)
{
register_netdevice_notifier(&phonet_device_notifier);
phonet_netlink_register();
return 0;
}

void phonet_device_exit(void)
Expand Down

0 comments on commit 76e02cf

Please sign in to comment.