From: Gustavo Padovan <padovan@profusion.mobi>
To: Brian Gix <bgix@codeaurora.org>
Cc: linux-bluetooth@vger.kernel.org
Subject: Re: [PATCH 3/9] Bluetooth: User Pairing Response restructuring
Date: Wed, 16 Nov 2011 16:49:03 -0200 [thread overview]
Message-ID: <20111116184903.GI16865@joana> (raw)
In-Reply-To: <1321164079-2216-4-git-send-email-bgix@codeaurora.org>
Hi Brian,
* Brian Gix <bgix@codeaurora.org> [2011-11-12 22:01:13 -0800]:
> There are 4 possible User Responses to pairing requests,
> and they all share the same checks and handling. This
> restructures the handling of the two Confirm responses
> in preperation for the second two.
>
> Signed-off-by: Brian Gix <bgix@codeaurora.org>
> ---
> net/bluetooth/mgmt.c | 96 ++++++++++++++++++++++++++++++++++++--------------
> 1 files changed, 69 insertions(+), 27 deletions(-)
>
> diff --git a/net/bluetooth/mgmt.c b/net/bluetooth/mgmt.c
> index 5562c21..b1d4f05 100644
> --- a/net/bluetooth/mgmt.c
> +++ b/net/bluetooth/mgmt.c
> @@ -1438,28 +1438,14 @@ unlock:
> return err;
> }
>
> -static int user_confirm_reply(struct sock *sk, u16 index, unsigned char *data,
> - u16 len, int success)
> +static int user_pairing_resp(struct sock *sk, u16 index, bdaddr_t *bdaddr,
> + u16 mgmt_op, u16 hci_op, __le32 passkey)
> {
> - struct mgmt_cp_user_confirm_reply *cp = (void *) data;
> - u16 mgmt_op, hci_op;
> struct pending_cmd *cmd;
> struct hci_dev *hdev;
> + struct hci_conn *conn;
> int err;
>
> - BT_DBG("");
> -
> - if (success) {
> - mgmt_op = MGMT_OP_USER_CONFIRM_REPLY;
> - hci_op = HCI_OP_USER_CONFIRM_REPLY;
> - } else {
> - mgmt_op = MGMT_OP_USER_CONFIRM_NEG_REPLY;
> - hci_op = HCI_OP_USER_CONFIRM_NEG_REPLY;
> - }
> -
> - if (len != sizeof(*cp))
> - return cmd_status(sk, index, mgmt_op, EINVAL);
> -
> hdev = hci_dev_get(index);
> if (!hdev)
> return cmd_status(sk, index, mgmt_op, ENODEV);
> @@ -1468,26 +1454,81 @@ static int user_confirm_reply(struct sock *sk, u16 index, unsigned char *data,
>
> if (!test_bit(HCI_UP, &hdev->flags)) {
> err = cmd_status(sk, index, mgmt_op, ENETDOWN);
> - goto failed;
> + goto done;
> }
>
> - cmd = mgmt_pending_add(sk, mgmt_op, hdev, data, len);
> + /*
> + * Check for an existing ACL link, if present pair via
> + * HCI commands.
> + *
> + * If no ACL link is present, check for an LE link and if
> + * present, pair via the SMP engine.
> + *
> + * If neither ACL nor LE links are present, fail with error.
> + */
> + conn = hci_conn_hash_lookup_ba(hdev, ACL_LINK, bdaddr);
> + if (!conn) {
> + conn = hci_conn_hash_lookup_ba(hdev, LE_LINK, bdaddr);
> + if (!conn) {
> + err = cmd_status(sk, index, mgmt_op, ENOTCONN);
> + goto done;
> + }
> +
> + /* Continue with pairing via SMP */
> +
> + err = cmd_status(sk, index, mgmt_op, 0);
> + goto done;
> + }
> +
Please split this patch in two, one the does the user_pairing_resp
restructuring and the other that actually add new code.
Gustavo
next prev parent reply other threads:[~2011-11-16 18:49 UTC|newest]
Thread overview: 12+ messages / expand[flat|nested] mbox.gz Atom feed top
2011-11-13 6:01 [PATCH 0/9] Bluetooth: Add MITM protection to LE-SMP Brian Gix
2011-11-13 6:01 ` [PATCH 1/9] Bluetooth: Add HCI defines for User Passkey entry Brian Gix
2011-11-13 6:01 ` [PATCH 2/9] Bluetooth: Add MGMT opcodes for Passkey Entry Brian Gix
2011-11-13 6:01 ` [PATCH 3/9] Bluetooth: User Pairing Response restructuring Brian Gix
2011-11-16 18:49 ` Gustavo Padovan [this message]
2011-11-13 6:01 ` [PATCH 4/9] Bluetooth: Add User Passkey Response handling Brian Gix
2011-11-13 6:01 ` [PATCH 5/9] Bluetooth: Add HCI User Passkey Req Evt handling Brian Gix
2011-11-13 6:01 ` [PATCH 6/9] Bluetooth: Cleanup blkcipher on SMP termination Brian Gix
2011-11-13 6:01 ` [PATCH 7/9] Bluetooth: Centralize SMP pairing failure handling Brian Gix
2011-11-13 6:01 ` [PATCH 8/9] Bluetooth: Add MITM mechanism to LE-SMP Brian Gix
2011-11-13 6:01 ` [PATCH 9/9] Bluetooth: Add SMP to User Passkey and Confirm Brian Gix
-- strict thread matches above, loose matches on Subject: below --
2011-11-16 0:32 [PATCH 0/9] Bluetooth: Add MITM protection to LE-SMP Brian Gix
2011-11-16 0:32 ` [PATCH 3/9] Bluetooth: User Pairing Response restructuring Brian Gix
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20111116184903.GI16865@joana \
--to=padovan@profusion.mobi \
--cc=bgix@codeaurora.org \
--cc=linux-bluetooth@vger.kernel.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).