mirror of https://gitee.com/openkylin/linux.git
Bluetooth: Use address type info from user-space
In order to establish a LE connection we need the address type information. User-space already pass this information to kernel through struct sockaddr_l2. This patch adds the dst_type parameter to l2cap_chan_connect so we are able to pass the address type info from user-space down to hci_conn layer. Signed-off-by: Andre Guedes <andre.guedes@openbossa.org> Acked-by: Johan Hedberg <johan.hedberg@intel.com> Signed-off-by: Marcel Holtmann <marcel@holtmann.org>
This commit is contained in:
parent
b12f62cfd9
commit
8e9f98921c
|
@ -922,7 +922,7 @@ struct l2cap_chan *l2cap_chan_create(void);
|
||||||
void l2cap_chan_close(struct l2cap_chan *chan, int reason);
|
void l2cap_chan_close(struct l2cap_chan *chan, int reason);
|
||||||
void l2cap_chan_destroy(struct l2cap_chan *chan);
|
void l2cap_chan_destroy(struct l2cap_chan *chan);
|
||||||
int l2cap_chan_connect(struct l2cap_chan *chan, __le16 psm, u16 cid,
|
int l2cap_chan_connect(struct l2cap_chan *chan, __le16 psm, u16 cid,
|
||||||
bdaddr_t *dst);
|
bdaddr_t *dst, u8 dst_type);
|
||||||
int l2cap_chan_send(struct l2cap_chan *chan, struct msghdr *msg, size_t len,
|
int l2cap_chan_send(struct l2cap_chan *chan, struct msghdr *msg, size_t len,
|
||||||
u32 priority);
|
u32 priority);
|
||||||
void l2cap_chan_busy(struct l2cap_chan *chan, int busy);
|
void l2cap_chan_busy(struct l2cap_chan *chan, int busy);
|
||||||
|
|
|
@ -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),
|
BT_DBG("%s -> %s (type %u) psm 0x%2.2x", batostr(src), batostr(dst),
|
||||||
__le16_to_cpu(chan->psm));
|
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)) {
|
||||||
|
|
|
@ -124,7 +124,7 @@ static int l2cap_sock_connect(struct socket *sock, struct sockaddr *addr, int al
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
|
|
||||||
err = l2cap_chan_connect(chan, la.l2_psm, __le16_to_cpu(la.l2_cid),
|
err = l2cap_chan_connect(chan, la.l2_psm, __le16_to_cpu(la.l2_cid),
|
||||||
&la.l2_bdaddr);
|
&la.l2_bdaddr, la.l2_bdaddr_type);
|
||||||
if (err)
|
if (err)
|
||||||
return err;
|
return err;
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue