Bluetooth: Move clock offset reading into hci_disconnect()
authorJohan Hedberg <johan.hedberg@intel.com>
Mon, 18 Aug 2014 17:33:34 +0000 (20:33 +0300)
committerMarcel Holtmann <marcel@holtmann.org>
Mon, 8 Sep 2014 17:07:55 +0000 (19:07 +0200)
To give all hci_disconnect() users the advantage of getting the clock
offset read automatically this patch moves the necessary code from
hci_conn_timeout() into hci_disconnect(). This way we pretty much always
update the clock offset when disconnecting.

Signed-off-by: Johan Hedberg <johan.hedberg@intel.com>
Signed-off-by: Marcel Holtmann <marcel@holtmann.org>
net/bluetooth/hci_conn.c

index dd2df20b0f7d49d12736a4b6ec8825819b484b2b..e3d7ae9e2edd601da19b9f98927b3f933c697986 100644 (file)
@@ -128,6 +128,19 @@ int hci_disconnect(struct hci_conn *conn, __u8 reason)
 
        BT_DBG("hcon %p", conn);
 
+       /* When we are master of an established connection and it enters
+        * the disconnect timeout, then go ahead and try to read the
+        * current clock offset.  Processing of the result is done
+        * within the event handling and hci_clock_offset_evt function.
+        */
+       if (conn->type == ACL_LINK && conn->role == HCI_ROLE_MASTER) {
+               struct hci_dev *hdev = conn->hdev;
+               struct hci_cp_read_clock_offset cp;
+
+               cp.handle = cpu_to_le16(conn->handle);
+               hci_send_cmd(hdev, HCI_OP_READ_CLOCK_OFFSET, sizeof(cp), &cp);
+       }
+
        conn->state = BT_DISCONN;
 
        cp.handle = cpu_to_le16(conn->handle);
@@ -325,25 +338,6 @@ static void hci_conn_timeout(struct work_struct *work)
                        hci_amp_disconn(conn);
                } else {
                        __u8 reason = hci_proto_disconn_ind(conn);
-
-                       /* When we are master of an established connection
-                        * and it enters the disconnect timeout, then go
-                        * ahead and try to read the current clock offset.
-                        *
-                        * Processing of the result is done within the
-                        * event handling and hci_clock_offset_evt function.
-                        */
-                       if (conn->type == ACL_LINK &&
-                           conn->role == HCI_ROLE_MASTER) {
-                               struct hci_dev *hdev = conn->hdev;
-                               struct hci_cp_read_clock_offset cp;
-
-                               cp.handle = cpu_to_le16(conn->handle);
-
-                               hci_send_cmd(hdev, HCI_OP_READ_CLOCK_OFFSET,
-                                            sizeof(cp), &cp);
-                       }
-
                        hci_disconnect(conn, reason);
                }
                break;