Commit 555eb282 authored by Stephen Hemminger's avatar Stephen Hemminger

[AX25]: Make sure and hold ref to dev.

The lower layers of ax25 hold a reference to the underlying device
but don't increment the ref count. This is safe because it does the
right thing when UNREGISTER notification comes in, but it is better
to do the right thing.
parent 63ecc7be
...@@ -67,6 +67,7 @@ void ax25_dev_device_up(struct net_device *dev) ...@@ -67,6 +67,7 @@ void ax25_dev_device_up(struct net_device *dev)
dev->ax25_ptr = ax25_dev; dev->ax25_ptr = ax25_dev;
ax25_dev->dev = dev; ax25_dev->dev = dev;
dev_hold(dev);
ax25_dev->forward = NULL; ax25_dev->forward = NULL;
ax25_dev->values[AX25_VALUES_IPDEFMODE] = AX25_DEF_IPDEFMODE; ax25_dev->values[AX25_VALUES_IPDEFMODE] = AX25_DEF_IPDEFMODE;
...@@ -121,6 +122,7 @@ void ax25_dev_device_down(struct net_device *dev) ...@@ -121,6 +122,7 @@ void ax25_dev_device_down(struct net_device *dev)
if ((s = ax25_dev_list) == ax25_dev) { if ((s = ax25_dev_list) == ax25_dev) {
ax25_dev_list = s->next; ax25_dev_list = s->next;
spin_unlock_bh(&ax25_dev_lock); spin_unlock_bh(&ax25_dev_lock);
dev_put(dev);
kfree(ax25_dev); kfree(ax25_dev);
ax25_register_sysctl(); ax25_register_sysctl();
return; return;
...@@ -130,6 +132,7 @@ void ax25_dev_device_down(struct net_device *dev) ...@@ -130,6 +132,7 @@ void ax25_dev_device_down(struct net_device *dev)
if (s->next == ax25_dev) { if (s->next == ax25_dev) {
s->next = ax25_dev->next; s->next = ax25_dev->next;
spin_unlock_bh(&ax25_dev_lock); spin_unlock_bh(&ax25_dev_lock);
dev_put(dev);
kfree(ax25_dev); kfree(ax25_dev);
ax25_register_sysctl(); ax25_register_sysctl();
return; return;
...@@ -196,8 +199,8 @@ void __exit ax25_dev_free(void) ...@@ -196,8 +199,8 @@ void __exit ax25_dev_free(void)
ax25_dev = ax25_dev_list; ax25_dev = ax25_dev_list;
while (ax25_dev != NULL) { while (ax25_dev != NULL) {
s = ax25_dev; s = ax25_dev;
dev_put(ax25_dev->dev);
ax25_dev = ax25_dev->next; ax25_dev = ax25_dev->next;
kfree(s); kfree(s);
} }
ax25_dev_list = NULL; ax25_dev_list = NULL;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment