From: Loic Poulain Date: Thu, 21 May 2015 14:46:41 +0000 (+0200) Subject: Bluetooth: Reorder HCI user channel socket release X-Git-Tag: v4.2-rc1~130^2~29^2~82 X-Git-Url: https://www.infradead.org/git/?a=commitdiff_plain;h=9380f9eacfbbee701daa416edd6625efcd3e29e1;p=users%2Fgriffoul%2Flinux.git Bluetooth: Reorder HCI user channel socket release The hci close method needs to know if we are in user channel context. Only add the index to mgmt once close is performed. Signed-off-by: Loic Poulain Signed-off-by: Marcel Holtmann --- diff --git a/net/bluetooth/hci_sock.c b/net/bluetooth/hci_sock.c index 5b14dcafcd08..9467545e5c97 100644 --- a/net/bluetooth/hci_sock.c +++ b/net/bluetooth/hci_sock.c @@ -503,9 +503,9 @@ static int hci_sock_release(struct socket *sock) if (hdev) { if (hci_pi(sk)->channel == HCI_CHANNEL_USER) { - mgmt_index_added(hdev); - hci_dev_clear_flag(hdev, HCI_USER_CHANNEL); hci_dev_close(hdev->id); + hci_dev_clear_flag(hdev, HCI_USER_CHANNEL); + mgmt_index_added(hdev); } atomic_dec(&hdev->promisc);