提交 40051e46 编写于 作者: M Marcel Holtmann

Bluetooth: Remove unneeded hci_conn_disconnect abstraction

The abstraction of disconnect operation via hci_conn_disconnect is not
needed and it does not add any readability. Handle the difference of
AMP physical channels and BR/EDR/LE connection in the timeout callback.
Signed-off-by: NMarcel Holtmann <marcel@holtmann.org>
Signed-off-by: NJohan Hedberg <johan.hedberg@intel.com>
上级 a2b1976b
...@@ -271,21 +271,6 @@ void hci_sco_setup(struct hci_conn *conn, __u8 status) ...@@ -271,21 +271,6 @@ void hci_sco_setup(struct hci_conn *conn, __u8 status)
} }
} }
static void hci_conn_disconnect(struct hci_conn *conn)
{
__u8 reason;
switch (conn->type) {
case AMP_LINK:
hci_amp_disconn(conn);
break;
default:
reason = hci_proto_disconn_ind(conn);
hci_disconnect(conn, reason);
break;
}
}
static void hci_conn_timeout(struct work_struct *work) static void hci_conn_timeout(struct work_struct *work)
{ {
struct hci_conn *conn = container_of(work, struct hci_conn, struct hci_conn *conn = container_of(work, struct hci_conn,
...@@ -320,7 +305,12 @@ static void hci_conn_timeout(struct work_struct *work) ...@@ -320,7 +305,12 @@ static void hci_conn_timeout(struct work_struct *work)
break; break;
case BT_CONFIG: case BT_CONFIG:
case BT_CONNECTED: case BT_CONNECTED:
hci_conn_disconnect(conn); if (conn->type == AMP_LINK) {
hci_amp_disconn(conn);
} else {
__u8 reason = hci_proto_disconn_ind(conn);
hci_disconnect(conn, reason);
}
break; break;
default: default:
conn->state = BT_CLOSED; conn->state = BT_CLOSED;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册