Re: [bluetooth-next 06/15] Bluetooth: Add SMP confirmation structs

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Hi Vinicius,

* Vinicius Costa Gomes <vinicius.gomes@xxxxxxxxxxxxx> [2011-04-05 22:51:47 -0300]:

> From: Anderson Briglia <anderson.briglia@xxxxxxxxxxxxx>
> 
> This patch adds initial support for verifying the confirmation value
> that the remote side has sent.
> 
> Signed-off-by: Anderson Briglia <anderson.briglia@xxxxxxxxxxxxx>
> Signed-off-by: Vinicius Costa Gomes <vinicius.gomes@xxxxxxxxxxxxx>
> ---
>  include/net/bluetooth/l2cap.h |    5 +++++
>  net/bluetooth/smp.c           |   17 +++++++++++++++++
>  2 files changed, 22 insertions(+), 0 deletions(-)
> 
> diff --git a/include/net/bluetooth/l2cap.h b/include/net/bluetooth/l2cap.h
> index 2b9ca0d..dc4aa63 100644
> --- a/include/net/bluetooth/l2cap.h
> +++ b/include/net/bluetooth/l2cap.h
> @@ -305,6 +305,11 @@ struct l2cap_conn {
>  
>  	__u8		disc_reason;
>  
> +	__u8		preq[7]; /* SMP Pairing Request */
> +	__u8		prsp[7]; /* SMP Pairing Response */
> +	__u8		prnd[16]; /* SMP Pairing Random */
> +	__u8		pcnf[16]; /* SMP Pairing Confirm */
> +
>  	struct l2cap_chan_list chan_list;
>  };
>  
> diff --git a/net/bluetooth/smp.c b/net/bluetooth/smp.c
> index 58047e8..7fa3542 100644
> --- a/net/bluetooth/smp.c
> +++ b/net/bluetooth/smp.c
> @@ -192,6 +192,8 @@ static void smp_cmd_pairing_req(struct l2cap_conn *conn, struct sk_buff *skb)
>  
>  	BT_DBG("conn %p", conn);
>  
> +	conn->preq[0] = SMP_CMD_PAIRING_REQ;
> +	memcpy(&conn->preq[1], rp, sizeof(*rp));
>  	skb_pull(skb, sizeof(*rp));
>  
>  	rp->io_capability = 0x00;
> @@ -201,17 +203,25 @@ static void smp_cmd_pairing_req(struct l2cap_conn *conn, struct sk_buff *skb)
>  	rp->resp_key_dist = 0x00;
>  	rp->auth_req &= (SMP_AUTH_BONDING | SMP_AUTH_MITM);
>  
> +	conn->prsp[0] = SMP_CMD_PAIRING_RSP;
> +	memcpy(&conn->prsp[1], rp, sizeof(*rp));
> +
>  	smp_send_cmd(conn, SMP_CMD_PAIRING_RSP, sizeof(*rp), rp);
>  }
>  
>  static void smp_cmd_pairing_rsp(struct l2cap_conn *conn, struct sk_buff *skb)
>  {
> +	struct smp_cmd_pairing *rp = (void *) skb->data;

No need for cast here.

-- 
Gustavo F. Padovan
http://profusion.mobi
--
To unsubscribe from this list: send the line "unsubscribe linux-bluetooth" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html


[Index of Archives]     [Bluez Devel]     [Linux Wireless Networking]     [Linux Wireless Personal Area Networking]     [Linux ATH6KL]     [Linux USB Devel]     [Linux Media Drivers]     [Linux Audio Users]     [Linux Kernel]     [Linux SCSI]     [Big List of Linux Books]

  Powered by Linux