Commit 15cf53c0 authored by Maksim Krasnyanskiy's avatar Maksim Krasnyanskiy

[Bluetooth]

Use very short disconnect timeout for SCO connections. They cannot
be reused and therefor there is no need to keep them around.
parent 236b5445
...@@ -262,7 +262,7 @@ struct hci_conn *hci_connect(struct hci_dev *hdev, int type, bdaddr_t *src); ...@@ -262,7 +262,7 @@ struct hci_conn *hci_connect(struct hci_dev *hdev, int type, bdaddr_t *src);
int hci_conn_auth(struct hci_conn *conn); int hci_conn_auth(struct hci_conn *conn);
int hci_conn_encrypt(struct hci_conn *conn); int hci_conn_encrypt(struct hci_conn *conn);
static inline void hci_conn_set_timer(struct hci_conn *conn, long timeout) static inline void hci_conn_set_timer(struct hci_conn *conn, unsigned long timeout)
{ {
mod_timer(&conn->timer, jiffies + timeout); mod_timer(&conn->timer, jiffies + timeout);
} }
...@@ -280,8 +280,11 @@ static inline void hci_conn_hold(struct hci_conn *conn) ...@@ -280,8 +280,11 @@ static inline void hci_conn_hold(struct hci_conn *conn)
static inline void hci_conn_put(struct hci_conn *conn) static inline void hci_conn_put(struct hci_conn *conn)
{ {
if (atomic_dec_and_test(&conn->refcnt) && conn->out) if (atomic_dec_and_test(&conn->refcnt) && conn->out) {
hci_conn_set_timer(conn, HCI_DISCONN_TIMEOUT); unsigned long timeo = (conn->type == ACL_LINK) ?
HCI_DISCONN_TIMEOUT : HZ / 100;
hci_conn_set_timer(conn, timeo);
}
} }
/* ----- HCI tasks ----- */ /* ----- HCI tasks ----- */
......
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