linux-bluetooth.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
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

  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).