Bluetooth: Correctly acquire module ref
We provide a device-object to other subsystems and we provide our own release-function. Therefore, the device-object must own a reference to our module, otherwise the release-function may get deleted before the device-object does. Signed-off-by: David Herrmann <dh.herrmann@googlemail.com> Acked-by: Marcel Holtmann <marcel@holtmann.org> Signed-off-by: Johan Hedberg <johan.hedberg@intel.com>
This commit is contained in:
committed by
Johan Hedberg
parent
587ae086f6
commit
46e06531a5
@@ -372,6 +372,7 @@ static void bt_host_release(struct device *dev)
|
|||||||
{
|
{
|
||||||
void *data = dev_get_drvdata(dev);
|
void *data = dev_get_drvdata(dev);
|
||||||
kfree(data);
|
kfree(data);
|
||||||
|
module_put(THIS_MODULE);
|
||||||
}
|
}
|
||||||
|
|
||||||
static struct device_type bt_host = {
|
static struct device_type bt_host = {
|
||||||
@@ -523,6 +524,7 @@ void hci_init_sysfs(struct hci_dev *hdev)
|
|||||||
dev->type = &bt_host;
|
dev->type = &bt_host;
|
||||||
dev->class = bt_class;
|
dev->class = bt_class;
|
||||||
|
|
||||||
|
__module_get(THIS_MODULE);
|
||||||
dev_set_drvdata(dev, hdev);
|
dev_set_drvdata(dev, hdev);
|
||||||
device_initialize(dev);
|
device_initialize(dev);
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user