diff options
author | Johan Hedberg <johan.hedberg@intel.com> | 2012-02-09 08:26:12 -0500 |
---|---|---|
committer | Johan Hedberg <johan.hedberg@intel.com> | 2012-02-13 10:01:36 -0500 |
commit | 272d90df2d4d065e782cafb08358bd8918bf703a (patch) | |
tree | a39907ac765574b8b0bf087a7aa0f37cc580d5a7 /net | |
parent | 88c3df13ca06718e5a8f509ae9cbb1228c10d537 (diff) |
Bluetooth: Add address type to user_confirm and user_passkey messages
This patch upadate the user confirm and user passkey mgmt messages to
match the latest API specification by adding an address type parameter
to them.
Signed-off-by: Johan Hedberg <johan.hedberg@intel.com>
Acked-by: Marcel Holtmann <marcel@holtmann.org>
Diffstat (limited to 'net')
-rw-r--r-- | net/bluetooth/hci_event.c | 14 | ||||
-rw-r--r-- | net/bluetooth/mgmt.c | 98 | ||||
-rw-r--r-- | net/bluetooth/smp.c | 4 |
3 files changed, 61 insertions, 55 deletions
diff --git a/net/bluetooth/hci_event.c b/net/bluetooth/hci_event.c index f0c822db28d9..3bf3f4d59bcc 100644 --- a/net/bluetooth/hci_event.c +++ b/net/bluetooth/hci_event.c | |||
@@ -960,8 +960,8 @@ static void hci_cc_user_confirm_reply(struct hci_dev *hdev, struct sk_buff *skb) | |||
960 | hci_dev_lock(hdev); | 960 | hci_dev_lock(hdev); |
961 | 961 | ||
962 | if (test_bit(HCI_MGMT, &hdev->dev_flags)) | 962 | if (test_bit(HCI_MGMT, &hdev->dev_flags)) |
963 | mgmt_user_confirm_reply_complete(hdev, &rp->bdaddr, | 963 | mgmt_user_confirm_reply_complete(hdev, &rp->bdaddr, ACL_LINK, |
964 | rp->status); | 964 | 0, rp->status); |
965 | 965 | ||
966 | hci_dev_unlock(hdev); | 966 | hci_dev_unlock(hdev); |
967 | } | 967 | } |
@@ -977,6 +977,7 @@ static void hci_cc_user_confirm_neg_reply(struct hci_dev *hdev, | |||
977 | 977 | ||
978 | if (test_bit(HCI_MGMT, &hdev->dev_flags)) | 978 | if (test_bit(HCI_MGMT, &hdev->dev_flags)) |
979 | mgmt_user_confirm_neg_reply_complete(hdev, &rp->bdaddr, | 979 | mgmt_user_confirm_neg_reply_complete(hdev, &rp->bdaddr, |
980 | ACL_LINK, 0, | ||
980 | rp->status); | 981 | rp->status); |
981 | 982 | ||
982 | hci_dev_unlock(hdev); | 983 | hci_dev_unlock(hdev); |
@@ -991,8 +992,8 @@ static void hci_cc_user_passkey_reply(struct hci_dev *hdev, struct sk_buff *skb) | |||
991 | hci_dev_lock(hdev); | 992 | hci_dev_lock(hdev); |
992 | 993 | ||
993 | if (test_bit(HCI_MGMT, &hdev->dev_flags)) | 994 | if (test_bit(HCI_MGMT, &hdev->dev_flags)) |
994 | mgmt_user_passkey_reply_complete(hdev, &rp->bdaddr, | 995 | mgmt_user_passkey_reply_complete(hdev, &rp->bdaddr, ACL_LINK, |
995 | rp->status); | 996 | 0, rp->status); |
996 | 997 | ||
997 | hci_dev_unlock(hdev); | 998 | hci_dev_unlock(hdev); |
998 | } | 999 | } |
@@ -1008,6 +1009,7 @@ static void hci_cc_user_passkey_neg_reply(struct hci_dev *hdev, | |||
1008 | 1009 | ||
1009 | if (test_bit(HCI_MGMT, &hdev->dev_flags)) | 1010 | if (test_bit(HCI_MGMT, &hdev->dev_flags)) |
1010 | mgmt_user_passkey_neg_reply_complete(hdev, &rp->bdaddr, | 1011 | mgmt_user_passkey_neg_reply_complete(hdev, &rp->bdaddr, |
1012 | ACL_LINK, 0, | ||
1011 | rp->status); | 1013 | rp->status); |
1012 | 1014 | ||
1013 | hci_dev_unlock(hdev); | 1015 | hci_dev_unlock(hdev); |
@@ -3123,7 +3125,7 @@ static inline void hci_user_confirm_request_evt(struct hci_dev *hdev, | |||
3123 | } | 3125 | } |
3124 | 3126 | ||
3125 | confirm: | 3127 | confirm: |
3126 | mgmt_user_confirm_request(hdev, &ev->bdaddr, ev->passkey, | 3128 | mgmt_user_confirm_request(hdev, &ev->bdaddr, ACL_LINK, 0, ev->passkey, |
3127 | confirm_hint); | 3129 | confirm_hint); |
3128 | 3130 | ||
3129 | unlock: | 3131 | unlock: |
@@ -3140,7 +3142,7 @@ static inline void hci_user_passkey_request_evt(struct hci_dev *hdev, | |||
3140 | hci_dev_lock(hdev); | 3142 | hci_dev_lock(hdev); |
3141 | 3143 | ||
3142 | if (test_bit(HCI_MGMT, &hdev->dev_flags)) | 3144 | if (test_bit(HCI_MGMT, &hdev->dev_flags)) |
3143 | mgmt_user_passkey_request(hdev, &ev->bdaddr); | 3145 | mgmt_user_passkey_request(hdev, &ev->bdaddr, ACL_LINK, 0); |
3144 | 3146 | ||
3145 | hci_dev_unlock(hdev); | 3147 | hci_dev_unlock(hdev); |
3146 | } | 3148 | } |
diff --git a/net/bluetooth/mgmt.c b/net/bluetooth/mgmt.c index f1257ee5afbc..16fc828096f6 100644 --- a/net/bluetooth/mgmt.c +++ b/net/bluetooth/mgmt.c | |||
@@ -1629,7 +1629,8 @@ unlock: | |||
1629 | } | 1629 | } |
1630 | 1630 | ||
1631 | static int user_pairing_resp(struct sock *sk, u16 index, bdaddr_t *bdaddr, | 1631 | static int user_pairing_resp(struct sock *sk, u16 index, bdaddr_t *bdaddr, |
1632 | u16 mgmt_op, u16 hci_op, __le32 passkey) | 1632 | u8 type, u16 mgmt_op, u16 hci_op, |
1633 | __le32 passkey) | ||
1633 | { | 1634 | { |
1634 | struct pending_cmd *cmd; | 1635 | struct pending_cmd *cmd; |
1635 | struct hci_dev *hdev; | 1636 | struct hci_dev *hdev; |
@@ -1648,24 +1649,18 @@ static int user_pairing_resp(struct sock *sk, u16 index, bdaddr_t *bdaddr, | |||
1648 | goto done; | 1649 | goto done; |
1649 | } | 1650 | } |
1650 | 1651 | ||
1651 | /* | 1652 | if (type == MGMT_ADDR_BREDR) |
1652 | * Check for an existing ACL link, if present pair via | 1653 | conn = hci_conn_hash_lookup_ba(hdev, ACL_LINK, bdaddr); |
1653 | * HCI commands. | 1654 | else |
1654 | * | ||
1655 | * If no ACL link is present, check for an LE link and if | ||
1656 | * present, pair via the SMP engine. | ||
1657 | * | ||
1658 | * If neither ACL nor LE links are present, fail with error. | ||
1659 | */ | ||
1660 | conn = hci_conn_hash_lookup_ba(hdev, ACL_LINK, bdaddr); | ||
1661 | if (!conn) { | ||
1662 | conn = hci_conn_hash_lookup_ba(hdev, LE_LINK, bdaddr); | 1655 | conn = hci_conn_hash_lookup_ba(hdev, LE_LINK, bdaddr); |
1663 | if (!conn) { | 1656 | |
1664 | err = cmd_status(sk, index, mgmt_op, | 1657 | if (!conn) { |
1658 | err = cmd_status(sk, index, mgmt_op, | ||
1665 | MGMT_STATUS_NOT_CONNECTED); | 1659 | MGMT_STATUS_NOT_CONNECTED); |
1666 | goto done; | 1660 | goto done; |
1667 | } | 1661 | } |
1668 | 1662 | ||
1663 | if (type == MGMT_ADDR_LE_PUBLIC || type == MGMT_ADDR_LE_RANDOM) { | ||
1669 | /* Continue with pairing via SMP */ | 1664 | /* Continue with pairing via SMP */ |
1670 | err = smp_user_confirm_reply(conn, mgmt_op, passkey); | 1665 | err = smp_user_confirm_reply(conn, mgmt_op, passkey); |
1671 | 1666 | ||
@@ -1715,9 +1710,9 @@ static int user_confirm_reply(struct sock *sk, u16 index, void *data, u16 len) | |||
1715 | return cmd_status(sk, index, MGMT_OP_USER_CONFIRM_REPLY, | 1710 | return cmd_status(sk, index, MGMT_OP_USER_CONFIRM_REPLY, |
1716 | MGMT_STATUS_INVALID_PARAMS); | 1711 | MGMT_STATUS_INVALID_PARAMS); |
1717 | 1712 | ||
1718 | return user_pairing_resp(sk, index, &cp->bdaddr, | 1713 | return user_pairing_resp(sk, index, &cp->addr.bdaddr, cp->addr.type, |
1719 | MGMT_OP_USER_CONFIRM_REPLY, | 1714 | MGMT_OP_USER_CONFIRM_REPLY, |
1720 | HCI_OP_USER_CONFIRM_REPLY, 0); | 1715 | HCI_OP_USER_CONFIRM_REPLY, 0); |
1721 | } | 1716 | } |
1722 | 1717 | ||
1723 | static int user_confirm_neg_reply(struct sock *sk, u16 index, void *data, | 1718 | static int user_confirm_neg_reply(struct sock *sk, u16 index, void *data, |
@@ -1731,9 +1726,9 @@ static int user_confirm_neg_reply(struct sock *sk, u16 index, void *data, | |||
1731 | return cmd_status(sk, index, MGMT_OP_USER_CONFIRM_NEG_REPLY, | 1726 | return cmd_status(sk, index, MGMT_OP_USER_CONFIRM_NEG_REPLY, |
1732 | MGMT_STATUS_INVALID_PARAMS); | 1727 | MGMT_STATUS_INVALID_PARAMS); |
1733 | 1728 | ||
1734 | return user_pairing_resp(sk, index, &cp->bdaddr, | 1729 | return user_pairing_resp(sk, index, &cp->addr.bdaddr, cp->addr.type, |
1735 | MGMT_OP_USER_CONFIRM_NEG_REPLY, | 1730 | MGMT_OP_USER_CONFIRM_NEG_REPLY, |
1736 | HCI_OP_USER_CONFIRM_NEG_REPLY, 0); | 1731 | HCI_OP_USER_CONFIRM_NEG_REPLY, 0); |
1737 | } | 1732 | } |
1738 | 1733 | ||
1739 | static int user_passkey_reply(struct sock *sk, u16 index, void *data, u16 len) | 1734 | static int user_passkey_reply(struct sock *sk, u16 index, void *data, u16 len) |
@@ -1746,9 +1741,10 @@ static int user_passkey_reply(struct sock *sk, u16 index, void *data, u16 len) | |||
1746 | return cmd_status(sk, index, MGMT_OP_USER_PASSKEY_REPLY, | 1741 | return cmd_status(sk, index, MGMT_OP_USER_PASSKEY_REPLY, |
1747 | EINVAL); | 1742 | EINVAL); |
1748 | 1743 | ||
1749 | return user_pairing_resp(sk, index, &cp->bdaddr, | 1744 | return user_pairing_resp(sk, index, &cp->addr.bdaddr, cp->addr.type, |
1750 | MGMT_OP_USER_PASSKEY_REPLY, | 1745 | MGMT_OP_USER_PASSKEY_REPLY, |
1751 | HCI_OP_USER_PASSKEY_REPLY, cp->passkey); | 1746 | HCI_OP_USER_PASSKEY_REPLY, |
1747 | cp->passkey); | ||
1752 | } | 1748 | } |
1753 | 1749 | ||
1754 | static int user_passkey_neg_reply(struct sock *sk, u16 index, void *data, | 1750 | static int user_passkey_neg_reply(struct sock *sk, u16 index, void *data, |
@@ -1762,9 +1758,9 @@ static int user_passkey_neg_reply(struct sock *sk, u16 index, void *data, | |||
1762 | return cmd_status(sk, index, MGMT_OP_USER_PASSKEY_NEG_REPLY, | 1758 | return cmd_status(sk, index, MGMT_OP_USER_PASSKEY_NEG_REPLY, |
1763 | EINVAL); | 1759 | EINVAL); |
1764 | 1760 | ||
1765 | return user_pairing_resp(sk, index, &cp->bdaddr, | 1761 | return user_pairing_resp(sk, index, &cp->addr.bdaddr, cp->addr.type, |
1766 | MGMT_OP_USER_PASSKEY_NEG_REPLY, | 1762 | MGMT_OP_USER_PASSKEY_NEG_REPLY, |
1767 | HCI_OP_USER_PASSKEY_NEG_REPLY, 0); | 1763 | HCI_OP_USER_PASSKEY_NEG_REPLY, 0); |
1768 | } | 1764 | } |
1769 | 1765 | ||
1770 | static int set_local_name(struct sock *sk, u16 index, void *data, | 1766 | static int set_local_name(struct sock *sk, u16 index, void *data, |
@@ -2765,13 +2761,15 @@ int mgmt_pin_code_neg_reply_complete(struct hci_dev *hdev, bdaddr_t *bdaddr, | |||
2765 | } | 2761 | } |
2766 | 2762 | ||
2767 | int mgmt_user_confirm_request(struct hci_dev *hdev, bdaddr_t *bdaddr, | 2763 | int mgmt_user_confirm_request(struct hci_dev *hdev, bdaddr_t *bdaddr, |
2768 | __le32 value, u8 confirm_hint) | 2764 | u8 link_type, u8 addr_type, __le32 value, |
2765 | u8 confirm_hint) | ||
2769 | { | 2766 | { |
2770 | struct mgmt_ev_user_confirm_request ev; | 2767 | struct mgmt_ev_user_confirm_request ev; |
2771 | 2768 | ||
2772 | BT_DBG("%s", hdev->name); | 2769 | BT_DBG("%s", hdev->name); |
2773 | 2770 | ||
2774 | bacpy(&ev.bdaddr, bdaddr); | 2771 | bacpy(&ev.addr.bdaddr, bdaddr); |
2772 | ev.addr.type = link_to_mgmt(link_type, addr_type); | ||
2775 | ev.confirm_hint = confirm_hint; | 2773 | ev.confirm_hint = confirm_hint; |
2776 | put_unaligned_le32(value, &ev.value); | 2774 | put_unaligned_le32(value, &ev.value); |
2777 | 2775 | ||
@@ -2779,20 +2777,23 @@ int mgmt_user_confirm_request(struct hci_dev *hdev, bdaddr_t *bdaddr, | |||
2779 | NULL); | 2777 | NULL); |
2780 | } | 2778 | } |
2781 | 2779 | ||
2782 | int mgmt_user_passkey_request(struct hci_dev *hdev, bdaddr_t *bdaddr) | 2780 | int mgmt_user_passkey_request(struct hci_dev *hdev, bdaddr_t *bdaddr, |
2781 | u8 link_type, u8 addr_type) | ||
2783 | { | 2782 | { |
2784 | struct mgmt_ev_user_passkey_request ev; | 2783 | struct mgmt_ev_user_passkey_request ev; |
2785 | 2784 | ||
2786 | BT_DBG("%s", hdev->name); | 2785 | BT_DBG("%s", hdev->name); |
2787 | 2786 | ||
2788 | bacpy(&ev.bdaddr, bdaddr); | 2787 | bacpy(&ev.addr.bdaddr, bdaddr); |
2788 | ev.addr.type = link_to_mgmt(link_type, addr_type); | ||
2789 | 2789 | ||
2790 | return mgmt_event(MGMT_EV_USER_PASSKEY_REQUEST, hdev, &ev, sizeof(ev), | 2790 | return mgmt_event(MGMT_EV_USER_PASSKEY_REQUEST, hdev, &ev, sizeof(ev), |
2791 | NULL); | 2791 | NULL); |
2792 | } | 2792 | } |
2793 | 2793 | ||
2794 | static int user_pairing_resp_complete(struct hci_dev *hdev, bdaddr_t *bdaddr, | 2794 | static int user_pairing_resp_complete(struct hci_dev *hdev, bdaddr_t *bdaddr, |
2795 | u8 status, u8 opcode) | 2795 | u8 link_type, u8 addr_type, u8 status, |
2796 | u8 opcode) | ||
2796 | { | 2797 | { |
2797 | struct pending_cmd *cmd; | 2798 | struct pending_cmd *cmd; |
2798 | struct mgmt_rp_user_confirm_reply rp; | 2799 | struct mgmt_rp_user_confirm_reply rp; |
@@ -2802,7 +2803,8 @@ static int user_pairing_resp_complete(struct hci_dev *hdev, bdaddr_t *bdaddr, | |||
2802 | if (!cmd) | 2803 | if (!cmd) |
2803 | return -ENOENT; | 2804 | return -ENOENT; |
2804 | 2805 | ||
2805 | bacpy(&rp.bdaddr, bdaddr); | 2806 | bacpy(&rp.addr.bdaddr, bdaddr); |
2807 | rp.addr.type = link_to_mgmt(link_type, addr_type); | ||
2806 | rp.status = mgmt_status(status); | 2808 | rp.status = mgmt_status(status); |
2807 | err = cmd_complete(cmd->sk, hdev->id, opcode, &rp, sizeof(rp)); | 2809 | err = cmd_complete(cmd->sk, hdev->id, opcode, &rp, sizeof(rp)); |
2808 | 2810 | ||
@@ -2812,31 +2814,31 @@ static int user_pairing_resp_complete(struct hci_dev *hdev, bdaddr_t *bdaddr, | |||
2812 | } | 2814 | } |
2813 | 2815 | ||
2814 | int mgmt_user_confirm_reply_complete(struct hci_dev *hdev, bdaddr_t *bdaddr, | 2816 | int mgmt_user_confirm_reply_complete(struct hci_dev *hdev, bdaddr_t *bdaddr, |
2815 | u8 status) | 2817 | u8 link_type, u8 addr_type, u8 status) |
2816 | { | 2818 | { |
2817 | return user_pairing_resp_complete(hdev, bdaddr, status, | 2819 | return user_pairing_resp_complete(hdev, bdaddr, link_type, addr_type, |
2818 | MGMT_OP_USER_CONFIRM_REPLY); | 2820 | status, MGMT_OP_USER_CONFIRM_REPLY); |
2819 | } | 2821 | } |
2820 | 2822 | ||
2821 | int mgmt_user_confirm_neg_reply_complete(struct hci_dev *hdev, | 2823 | int mgmt_user_confirm_neg_reply_complete(struct hci_dev *hdev, bdaddr_t *bdaddr, |
2822 | bdaddr_t *bdaddr, u8 status) | 2824 | u8 link_type, u8 addr_type, u8 status) |
2823 | { | 2825 | { |
2824 | return user_pairing_resp_complete(hdev, bdaddr, status, | 2826 | return user_pairing_resp_complete(hdev, bdaddr, link_type, addr_type, |
2825 | MGMT_OP_USER_CONFIRM_NEG_REPLY); | 2827 | status, MGMT_OP_USER_CONFIRM_NEG_REPLY); |
2826 | } | 2828 | } |
2827 | 2829 | ||
2828 | int mgmt_user_passkey_reply_complete(struct hci_dev *hdev, bdaddr_t *bdaddr, | 2830 | int mgmt_user_passkey_reply_complete(struct hci_dev *hdev, bdaddr_t *bdaddr, |
2829 | u8 status) | 2831 | u8 link_type, u8 addr_type, u8 status) |
2830 | { | 2832 | { |
2831 | return user_pairing_resp_complete(hdev, bdaddr, status, | 2833 | return user_pairing_resp_complete(hdev, bdaddr, link_type, addr_type, |
2832 | MGMT_OP_USER_PASSKEY_REPLY); | 2834 | status, MGMT_OP_USER_PASSKEY_REPLY); |
2833 | } | 2835 | } |
2834 | 2836 | ||
2835 | int mgmt_user_passkey_neg_reply_complete(struct hci_dev *hdev, | 2837 | int mgmt_user_passkey_neg_reply_complete(struct hci_dev *hdev, bdaddr_t *bdaddr, |
2836 | bdaddr_t *bdaddr, u8 status) | 2838 | u8 link_type, u8 addr_type, u8 status) |
2837 | { | 2839 | { |
2838 | return user_pairing_resp_complete(hdev, bdaddr, status, | 2840 | return user_pairing_resp_complete(hdev, bdaddr, link_type, addr_type, |
2839 | MGMT_OP_USER_PASSKEY_NEG_REPLY); | 2841 | status, MGMT_OP_USER_PASSKEY_NEG_REPLY); |
2840 | } | 2842 | } |
2841 | 2843 | ||
2842 | int mgmt_auth_failed(struct hci_dev *hdev, bdaddr_t *bdaddr, u8 status) | 2844 | int mgmt_auth_failed(struct hci_dev *hdev, bdaddr_t *bdaddr, u8 status) |
diff --git a/net/bluetooth/smp.c b/net/bluetooth/smp.c index 0563f737779a..589766d06f22 100644 --- a/net/bluetooth/smp.c +++ b/net/bluetooth/smp.c | |||
@@ -349,9 +349,11 @@ static int tk_request(struct l2cap_conn *conn, u8 remote_oob, u8 auth, | |||
349 | hci_dev_lock(hcon->hdev); | 349 | hci_dev_lock(hcon->hdev); |
350 | 350 | ||
351 | if (method == REQ_PASSKEY) | 351 | if (method == REQ_PASSKEY) |
352 | ret = mgmt_user_passkey_request(hcon->hdev, conn->dst); | 352 | ret = mgmt_user_passkey_request(hcon->hdev, conn->dst, |
353 | hcon->type, hcon->dst_type); | ||
353 | else | 354 | else |
354 | ret = mgmt_user_confirm_request(hcon->hdev, conn->dst, | 355 | ret = mgmt_user_confirm_request(hcon->hdev, conn->dst, |
356 | hcon->type, hcon->dst_type, | ||
355 | cpu_to_le32(passkey), 0); | 357 | cpu_to_le32(passkey), 0); |
356 | 358 | ||
357 | hci_dev_unlock(hcon->hdev); | 359 | hci_dev_unlock(hcon->hdev); |