Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 3cabbfda authored by Andrei Emeltchenko's avatar Andrei Emeltchenko Committed by Johan Hedberg
Browse files

Bluetooth: A2MP: Do not reference hci_conn



Make A2MP channel special channel which do not reference hci_conn.
This prevents from keeping ACL connection open when all L2CAP
channels got closed.

hci_conn_hold and hci_conn_put are not reference counts on the
hci_conn structure in the typical way.  They are reference counts for
the ACL.  When you do the last hci_conn_put, the ACL is disconnected
after a timeout.

Reported-by: default avatarMat Martineau <mathewm@codeaurora.org>
Signed-off-by: default avatarAndrei Emeltchenko <andrei.emeltchenko@intel.com>
Signed-off-by: default avatarGustavo Padovan <gustavo.padovan@collabora.co.uk>
parent fd83e2c2
Loading
Loading
Loading
Loading
+0 −2
Original line number Original line Diff line number Diff line
@@ -481,8 +481,6 @@ static struct l2cap_chan *a2mp_chan_open(struct l2cap_conn *conn)


	BT_DBG("chan %p", chan);
	BT_DBG("chan %p", chan);


	hci_conn_hold(conn->hcon);

	chan->chan_type = L2CAP_CHAN_CONN_FIX_A2MP;
	chan->chan_type = L2CAP_CHAN_CONN_FIX_A2MP;
	chan->flush_to = L2CAP_DEFAULT_FLUSH_TO;
	chan->flush_to = L2CAP_DEFAULT_FLUSH_TO;


+3 −1
Original line number Original line Diff line number Diff line
@@ -514,6 +514,8 @@ void l2cap_chan_del(struct l2cap_chan *chan, int err)
		l2cap_chan_put(chan);
		l2cap_chan_put(chan);


		chan->conn = NULL;
		chan->conn = NULL;

		if (chan->chan_type != L2CAP_CHAN_CONN_FIX_A2MP)
			hci_conn_put(conn->hcon);
			hci_conn_put(conn->hcon);
	}
	}