diff options
| author | Dave Young <hidave.darkstar@gmail.com> | 2007-12-29 22:17:47 -0500 |
|---|---|---|
| committer | David S. Miller <davem@davemloft.net> | 2007-12-29 22:17:47 -0500 |
| commit | 38b7da09cfdb2202f08476d6fb22a47649a177ec (patch) | |
| tree | 1f83cbc232b36282d7ed94104d8ae47fe9c55756 /net | |
| parent | 2072c228c9a05c004a230620196da7607cdcc5b6 (diff) | |
[BLUETOOTH]: put_device before device_del fix
Because of workqueue delay, the put_device could be called before
device_del, so move it to del_conn.
Signed-off-by: Dave Young <hidave.darkstar@gmail.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net')
| -rw-r--r-- | net/bluetooth/hci_conn.c | 10 | ||||
| -rw-r--r-- | net/bluetooth/hci_sysfs.c | 1 |
2 files changed, 2 insertions, 9 deletions
diff --git a/net/bluetooth/hci_conn.c b/net/bluetooth/hci_conn.c index 9483320f6dad..34d1a3c822bf 100644 --- a/net/bluetooth/hci_conn.c +++ b/net/bluetooth/hci_conn.c | |||
| @@ -259,22 +259,14 @@ int hci_conn_del(struct hci_conn *conn) | |||
| 259 | } | 259 | } |
| 260 | 260 | ||
| 261 | tasklet_disable(&hdev->tx_task); | 261 | tasklet_disable(&hdev->tx_task); |
| 262 | |||
| 263 | hci_conn_del_sysfs(conn); | ||
| 264 | |||
| 265 | hci_conn_hash_del(hdev, conn); | 262 | hci_conn_hash_del(hdev, conn); |
| 266 | if (hdev->notify) | 263 | if (hdev->notify) |
| 267 | hdev->notify(hdev, HCI_NOTIFY_CONN_DEL); | 264 | hdev->notify(hdev, HCI_NOTIFY_CONN_DEL); |
| 268 | |||
| 269 | tasklet_enable(&hdev->tx_task); | 265 | tasklet_enable(&hdev->tx_task); |
| 270 | |||
| 271 | skb_queue_purge(&conn->data_q); | 266 | skb_queue_purge(&conn->data_q); |
| 272 | 267 | hci_conn_del_sysfs(conn); | |
| 273 | hci_dev_put(hdev); | 268 | hci_dev_put(hdev); |
| 274 | 269 | ||
| 275 | /* will free via device release */ | ||
| 276 | put_device(&conn->dev); | ||
| 277 | |||
| 278 | return 0; | 270 | return 0; |
| 279 | } | 271 | } |
| 280 | 272 | ||
diff --git a/net/bluetooth/hci_sysfs.c b/net/bluetooth/hci_sysfs.c index cef1e3e1881c..cad510309dcf 100644 --- a/net/bluetooth/hci_sysfs.c +++ b/net/bluetooth/hci_sysfs.c | |||
| @@ -320,6 +320,7 @@ static void del_conn(struct work_struct *work) | |||
| 320 | { | 320 | { |
| 321 | struct hci_conn *conn = container_of(work, struct hci_conn, work); | 321 | struct hci_conn *conn = container_of(work, struct hci_conn, work); |
| 322 | device_del(&conn->dev); | 322 | device_del(&conn->dev); |
| 323 | put_device(&conn->dev); | ||
| 323 | } | 324 | } |
| 324 | 325 | ||
| 325 | void hci_conn_del_sysfs(struct hci_conn *conn) | 326 | void hci_conn_del_sysfs(struct hci_conn *conn) |
