|
@@ -1394,7 +1394,8 @@ static struct l2cap_chan *l2cap_global_chan_by_psm(int state, __le16 psm,
|
|
return c1;
|
|
return c1;
|
|
}
|
|
}
|
|
|
|
|
|
-int l2cap_chan_connect(struct l2cap_chan *chan, __le16 psm, u16 cid, bdaddr_t *dst)
|
|
|
|
|
|
+int l2cap_chan_connect(struct l2cap_chan *chan, __le16 psm, u16 cid,
|
|
|
|
+ bdaddr_t *dst, u8 dst_type)
|
|
{
|
|
{
|
|
struct sock *sk = chan->sk;
|
|
struct sock *sk = chan->sk;
|
|
bdaddr_t *src = &bt_sk(sk)->src;
|
|
bdaddr_t *src = &bt_sk(sk)->src;
|
|
@@ -1404,8 +1405,8 @@ int l2cap_chan_connect(struct l2cap_chan *chan, __le16 psm, u16 cid, bdaddr_t *d
|
|
__u8 auth_type;
|
|
__u8 auth_type;
|
|
int err;
|
|
int err;
|
|
|
|
|
|
- BT_DBG("%s -> %s psm 0x%2.2x", batostr(src), batostr(dst),
|
|
|
|
- __le16_to_cpu(chan->psm));
|
|
|
|
|
|
+ BT_DBG("%s -> %s (type %u) psm 0x%2.2x", batostr(src), batostr(dst),
|
|
|
|
+ dst_type, __le16_to_cpu(chan->psm));
|
|
|
|
|
|
hdev = hci_get_route(dst, src);
|
|
hdev = hci_get_route(dst, src);
|
|
if (!hdev)
|
|
if (!hdev)
|
|
@@ -1479,10 +1480,10 @@ int l2cap_chan_connect(struct l2cap_chan *chan, __le16 psm, u16 cid, bdaddr_t *d
|
|
auth_type = l2cap_get_auth_type(chan);
|
|
auth_type = l2cap_get_auth_type(chan);
|
|
|
|
|
|
if (chan->dcid == L2CAP_CID_LE_DATA)
|
|
if (chan->dcid == L2CAP_CID_LE_DATA)
|
|
- hcon = hci_connect(hdev, LE_LINK, dst, BDADDR_LE_RANDOM,
|
|
|
|
|
|
+ hcon = hci_connect(hdev, LE_LINK, dst, dst_type,
|
|
chan->sec_level, auth_type);
|
|
chan->sec_level, auth_type);
|
|
else
|
|
else
|
|
- hcon = hci_connect(hdev, ACL_LINK, dst, BDADDR_BREDR,
|
|
|
|
|
|
+ hcon = hci_connect(hdev, ACL_LINK, dst, dst_type,
|
|
chan->sec_level, auth_type);
|
|
chan->sec_level, auth_type);
|
|
|
|
|
|
if (IS_ERR(hcon)) {
|
|
if (IS_ERR(hcon)) {
|