smp.h revision cc110922da7e902b62d18641a370fec01a9fa794
1eb492e0169974ac6d168f11d1fc1e2753fe1f3b4Anderson Briglia/*
2eb492e0169974ac6d168f11d1fc1e2753fe1f3b4Anderson Briglia   BlueZ - Bluetooth protocol stack for Linux
3eb492e0169974ac6d168f11d1fc1e2753fe1f3b4Anderson Briglia   Copyright (C) 2011 Nokia Corporation and/or its subsidiary(-ies).
4eb492e0169974ac6d168f11d1fc1e2753fe1f3b4Anderson Briglia
5eb492e0169974ac6d168f11d1fc1e2753fe1f3b4Anderson Briglia   This program is free software; you can redistribute it and/or modify
6eb492e0169974ac6d168f11d1fc1e2753fe1f3b4Anderson Briglia   it under the terms of the GNU General Public License version 2 as
7eb492e0169974ac6d168f11d1fc1e2753fe1f3b4Anderson Briglia   published by the Free Software Foundation;
8eb492e0169974ac6d168f11d1fc1e2753fe1f3b4Anderson Briglia
9eb492e0169974ac6d168f11d1fc1e2753fe1f3b4Anderson Briglia   THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
10eb492e0169974ac6d168f11d1fc1e2753fe1f3b4Anderson Briglia   OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
11eb492e0169974ac6d168f11d1fc1e2753fe1f3b4Anderson Briglia   FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT OF THIRD PARTY RIGHTS.
12eb492e0169974ac6d168f11d1fc1e2753fe1f3b4Anderson Briglia   IN NO EVENT SHALL THE COPYRIGHT HOLDER(S) AND AUTHOR(S) BE LIABLE FOR ANY
13eb492e0169974ac6d168f11d1fc1e2753fe1f3b4Anderson Briglia   CLAIM, OR ANY SPECIAL INDIRECT OR CONSEQUENTIAL DAMAGES, OR ANY DAMAGES
14eb492e0169974ac6d168f11d1fc1e2753fe1f3b4Anderson Briglia   WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
15eb492e0169974ac6d168f11d1fc1e2753fe1f3b4Anderson Briglia   ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
16eb492e0169974ac6d168f11d1fc1e2753fe1f3b4Anderson Briglia   OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
17eb492e0169974ac6d168f11d1fc1e2753fe1f3b4Anderson Briglia
18eb492e0169974ac6d168f11d1fc1e2753fe1f3b4Anderson Briglia   ALL LIABILITY, INCLUDING LIABILITY FOR INFRINGEMENT OF ANY PATENTS,
19eb492e0169974ac6d168f11d1fc1e2753fe1f3b4Anderson Briglia   COPYRIGHTS, TRADEMARKS OR OTHER RIGHTS, RELATING TO USE OF THIS
20eb492e0169974ac6d168f11d1fc1e2753fe1f3b4Anderson Briglia   SOFTWARE IS DISCLAIMED.
21eb492e0169974ac6d168f11d1fc1e2753fe1f3b4Anderson Briglia*/
22eb492e0169974ac6d168f11d1fc1e2753fe1f3b4Anderson Briglia
23aff2cae3546df9f47f9fe24f3e85a7a84e825de8Ville Tervo#ifndef __SMP_H
24aff2cae3546df9f47f9fe24f3e85a7a84e825de8Ville Tervo#define __SMP_H
25aff2cae3546df9f47f9fe24f3e85a7a84e825de8Ville Tervo
26aff2cae3546df9f47f9fe24f3e85a7a84e825de8Ville Tervostruct smp_command_hdr {
27aff2cae3546df9f47f9fe24f3e85a7a84e825de8Ville Tervo	__u8	code;
28aff2cae3546df9f47f9fe24f3e85a7a84e825de8Ville Tervo} __packed;
29aff2cae3546df9f47f9fe24f3e85a7a84e825de8Ville Tervo
30aff2cae3546df9f47f9fe24f3e85a7a84e825de8Ville Tervo#define SMP_CMD_PAIRING_REQ	0x01
31aff2cae3546df9f47f9fe24f3e85a7a84e825de8Ville Tervo#define SMP_CMD_PAIRING_RSP	0x02
32aff2cae3546df9f47f9fe24f3e85a7a84e825de8Ville Tervostruct smp_cmd_pairing {
33aff2cae3546df9f47f9fe24f3e85a7a84e825de8Ville Tervo	__u8	io_capability;
34aff2cae3546df9f47f9fe24f3e85a7a84e825de8Ville Tervo	__u8	oob_flag;
35aff2cae3546df9f47f9fe24f3e85a7a84e825de8Ville Tervo	__u8	auth_req;
36aff2cae3546df9f47f9fe24f3e85a7a84e825de8Ville Tervo	__u8	max_key_size;
37aff2cae3546df9f47f9fe24f3e85a7a84e825de8Ville Tervo	__u8	init_key_dist;
38aff2cae3546df9f47f9fe24f3e85a7a84e825de8Ville Tervo	__u8	resp_key_dist;
39aff2cae3546df9f47f9fe24f3e85a7a84e825de8Ville Tervo} __packed;
40aff2cae3546df9f47f9fe24f3e85a7a84e825de8Ville Tervo
4188ba43b662b6b944c6278ad81a114fa559807776Anderson Briglia#define SMP_IO_DISPLAY_ONLY	0x00
4288ba43b662b6b944c6278ad81a114fa559807776Anderson Briglia#define SMP_IO_DISPLAY_YESNO	0x01
4388ba43b662b6b944c6278ad81a114fa559807776Anderson Briglia#define SMP_IO_KEYBOARD_ONLY	0x02
4488ba43b662b6b944c6278ad81a114fa559807776Anderson Briglia#define SMP_IO_NO_INPUT_OUTPUT	0x03
4588ba43b662b6b944c6278ad81a114fa559807776Anderson Briglia#define SMP_IO_KEYBOARD_DISPLAY	0x04
4688ba43b662b6b944c6278ad81a114fa559807776Anderson Briglia
4788ba43b662b6b944c6278ad81a114fa559807776Anderson Briglia#define SMP_OOB_NOT_PRESENT	0x00
4888ba43b662b6b944c6278ad81a114fa559807776Anderson Briglia#define SMP_OOB_PRESENT		0x01
4988ba43b662b6b944c6278ad81a114fa559807776Anderson Briglia
5088ba43b662b6b944c6278ad81a114fa559807776Anderson Briglia#define SMP_DIST_ENC_KEY	0x01
5188ba43b662b6b944c6278ad81a114fa559807776Anderson Briglia#define SMP_DIST_ID_KEY		0x02
5288ba43b662b6b944c6278ad81a114fa559807776Anderson Briglia#define SMP_DIST_SIGN		0x04
5388ba43b662b6b944c6278ad81a114fa559807776Anderson Briglia
5488ba43b662b6b944c6278ad81a114fa559807776Anderson Briglia#define SMP_AUTH_NONE		0x00
5588ba43b662b6b944c6278ad81a114fa559807776Anderson Briglia#define SMP_AUTH_BONDING	0x01
5688ba43b662b6b944c6278ad81a114fa559807776Anderson Briglia#define SMP_AUTH_MITM		0x04
5788ba43b662b6b944c6278ad81a114fa559807776Anderson Briglia
58aff2cae3546df9f47f9fe24f3e85a7a84e825de8Ville Tervo#define SMP_CMD_PAIRING_CONFIRM	0x03
59aff2cae3546df9f47f9fe24f3e85a7a84e825de8Ville Tervostruct smp_cmd_pairing_confirm {
60aff2cae3546df9f47f9fe24f3e85a7a84e825de8Ville Tervo	__u8	confirm_val[16];
61aff2cae3546df9f47f9fe24f3e85a7a84e825de8Ville Tervo} __packed;
62aff2cae3546df9f47f9fe24f3e85a7a84e825de8Ville Tervo
63aff2cae3546df9f47f9fe24f3e85a7a84e825de8Ville Tervo#define SMP_CMD_PAIRING_RANDOM	0x04
64aff2cae3546df9f47f9fe24f3e85a7a84e825de8Ville Tervostruct smp_cmd_pairing_random {
65aff2cae3546df9f47f9fe24f3e85a7a84e825de8Ville Tervo	__u8	rand_val[16];
66aff2cae3546df9f47f9fe24f3e85a7a84e825de8Ville Tervo} __packed;
67aff2cae3546df9f47f9fe24f3e85a7a84e825de8Ville Tervo
68aff2cae3546df9f47f9fe24f3e85a7a84e825de8Ville Tervo#define SMP_CMD_PAIRING_FAIL	0x05
69aff2cae3546df9f47f9fe24f3e85a7a84e825de8Ville Tervostruct smp_cmd_pairing_fail {
70aff2cae3546df9f47f9fe24f3e85a7a84e825de8Ville Tervo	__u8	reason;
71aff2cae3546df9f47f9fe24f3e85a7a84e825de8Ville Tervo} __packed;
72aff2cae3546df9f47f9fe24f3e85a7a84e825de8Ville Tervo
73aff2cae3546df9f47f9fe24f3e85a7a84e825de8Ville Tervo#define SMP_CMD_ENCRYPT_INFO	0x06
74aff2cae3546df9f47f9fe24f3e85a7a84e825de8Ville Tervostruct smp_cmd_encrypt_info {
75aff2cae3546df9f47f9fe24f3e85a7a84e825de8Ville Tervo	__u8	ltk[16];
76aff2cae3546df9f47f9fe24f3e85a7a84e825de8Ville Tervo} __packed;
77aff2cae3546df9f47f9fe24f3e85a7a84e825de8Ville Tervo
78aff2cae3546df9f47f9fe24f3e85a7a84e825de8Ville Tervo#define SMP_CMD_MASTER_IDENT	0x07
79aff2cae3546df9f47f9fe24f3e85a7a84e825de8Ville Tervostruct smp_cmd_master_ident {
8058115373e74c7ee18d0f54f00831649a6471a899Andrei Emeltchenko	__le16	ediv;
81aff2cae3546df9f47f9fe24f3e85a7a84e825de8Ville Tervo	__u8	rand[8];
82aff2cae3546df9f47f9fe24f3e85a7a84e825de8Ville Tervo} __packed;
83aff2cae3546df9f47f9fe24f3e85a7a84e825de8Ville Tervo
84aff2cae3546df9f47f9fe24f3e85a7a84e825de8Ville Tervo#define SMP_CMD_IDENT_INFO	0x08
85aff2cae3546df9f47f9fe24f3e85a7a84e825de8Ville Tervostruct smp_cmd_ident_info {
86aff2cae3546df9f47f9fe24f3e85a7a84e825de8Ville Tervo	__u8	irk[16];
87aff2cae3546df9f47f9fe24f3e85a7a84e825de8Ville Tervo} __packed;
88aff2cae3546df9f47f9fe24f3e85a7a84e825de8Ville Tervo
89aff2cae3546df9f47f9fe24f3e85a7a84e825de8Ville Tervo#define SMP_CMD_IDENT_ADDR_INFO	0x09
90aff2cae3546df9f47f9fe24f3e85a7a84e825de8Ville Tervostruct smp_cmd_ident_addr_info {
91aff2cae3546df9f47f9fe24f3e85a7a84e825de8Ville Tervo	__u8	addr_type;
92aff2cae3546df9f47f9fe24f3e85a7a84e825de8Ville Tervo	bdaddr_t bdaddr;
93aff2cae3546df9f47f9fe24f3e85a7a84e825de8Ville Tervo} __packed;
94aff2cae3546df9f47f9fe24f3e85a7a84e825de8Ville Tervo
95aff2cae3546df9f47f9fe24f3e85a7a84e825de8Ville Tervo#define SMP_CMD_SIGN_INFO	0x0a
96aff2cae3546df9f47f9fe24f3e85a7a84e825de8Ville Tervostruct smp_cmd_sign_info {
97aff2cae3546df9f47f9fe24f3e85a7a84e825de8Ville Tervo	__u8	csrk[16];
98aff2cae3546df9f47f9fe24f3e85a7a84e825de8Ville Tervo} __packed;
99aff2cae3546df9f47f9fe24f3e85a7a84e825de8Ville Tervo
100aff2cae3546df9f47f9fe24f3e85a7a84e825de8Ville Tervo#define SMP_CMD_SECURITY_REQ	0x0b
101aff2cae3546df9f47f9fe24f3e85a7a84e825de8Ville Tervostruct smp_cmd_security_req {
102aff2cae3546df9f47f9fe24f3e85a7a84e825de8Ville Tervo	__u8	auth_req;
103aff2cae3546df9f47f9fe24f3e85a7a84e825de8Ville Tervo} __packed;
104aff2cae3546df9f47f9fe24f3e85a7a84e825de8Ville Tervo
105aff2cae3546df9f47f9fe24f3e85a7a84e825de8Ville Tervo#define SMP_PASSKEY_ENTRY_FAILED	0x01
106aff2cae3546df9f47f9fe24f3e85a7a84e825de8Ville Tervo#define SMP_OOB_NOT_AVAIL		0x02
107aff2cae3546df9f47f9fe24f3e85a7a84e825de8Ville Tervo#define SMP_AUTH_REQUIREMENTS		0x03
108aff2cae3546df9f47f9fe24f3e85a7a84e825de8Ville Tervo#define SMP_CONFIRM_FAILED		0x04
109aff2cae3546df9f47f9fe24f3e85a7a84e825de8Ville Tervo#define SMP_PAIRING_NOTSUPP		0x05
110aff2cae3546df9f47f9fe24f3e85a7a84e825de8Ville Tervo#define SMP_ENC_KEY_SIZE		0x06
111aff2cae3546df9f47f9fe24f3e85a7a84e825de8Ville Tervo#define SMP_CMD_NOTSUPP		0x07
112aff2cae3546df9f47f9fe24f3e85a7a84e825de8Ville Tervo#define SMP_UNSPECIFIED		0x08
113aff2cae3546df9f47f9fe24f3e85a7a84e825de8Ville Tervo#define SMP_REPEATED_ATTEMPTS		0x09
114aff2cae3546df9f47f9fe24f3e85a7a84e825de8Ville Tervo
1153158c50c33c1acddcfa3c57fab812435aa459750Vinicius Costa Gomes#define SMP_MIN_ENC_KEY_SIZE		7
1163158c50c33c1acddcfa3c57fab812435aa459750Vinicius Costa Gomes#define SMP_MAX_ENC_KEY_SIZE		16
1173158c50c33c1acddcfa3c57fab812435aa459750Vinicius Costa Gomes
1182b64d153a0cc9d2b60e47be013cde8490f16e0a5Brian Gix#define SMP_FLAG_TK_VALID	1
1192b64d153a0cc9d2b60e47be013cde8490f16e0a5Brian Gix#define SMP_FLAG_CFM_PENDING	2
1202b64d153a0cc9d2b60e47be013cde8490f16e0a5Brian Gix#define SMP_FLAG_MITM_AUTH	3
1212b64d153a0cc9d2b60e47be013cde8490f16e0a5Brian Gix
1221c1def09c446aae441410b70e6439ffe44dee866Vinicius Costa Gomesstruct smp_chan {
1238aab47574a7f5b46a4cdbc6fd820ab34e6c5dbf9Vinicius Costa Gomes	struct l2cap_conn *conn;
1241c1def09c446aae441410b70e6439ffe44dee866Vinicius Costa Gomes	u8		preq[7]; /* SMP Pairing Request */
1251c1def09c446aae441410b70e6439ffe44dee866Vinicius Costa Gomes	u8		prsp[7]; /* SMP Pairing Response */
1268aab47574a7f5b46a4cdbc6fd820ab34e6c5dbf9Vinicius Costa Gomes	u8              prnd[16]; /* SMP Pairing Random (local) */
1278aab47574a7f5b46a4cdbc6fd820ab34e6c5dbf9Vinicius Costa Gomes	u8              rrnd[16]; /* SMP Pairing Random (remote) */
1281c1def09c446aae441410b70e6439ffe44dee866Vinicius Costa Gomes	u8		pcnf[16]; /* SMP Pairing Confirm */
1291c1def09c446aae441410b70e6439ffe44dee866Vinicius Costa Gomes	u8		tk[16]; /* SMP Temporary Key */
130f7aa611a0ecf1d22f21e26279e1a3baf1db6b973Vinicius Costa Gomes	u8		enc_key_size;
1312b64d153a0cc9d2b60e47be013cde8490f16e0a5Brian Gix	unsigned long	smp_flags;
1321c1def09c446aae441410b70e6439ffe44dee866Vinicius Costa Gomes	struct crypto_blkcipher	*tfm;
1338aab47574a7f5b46a4cdbc6fd820ab34e6c5dbf9Vinicius Costa Gomes	struct work_struct confirm;
1348aab47574a7f5b46a4cdbc6fd820ab34e6c5dbf9Vinicius Costa Gomes	struct work_struct random;
1358aab47574a7f5b46a4cdbc6fd820ab34e6c5dbf9Vinicius Costa Gomes
1361c1def09c446aae441410b70e6439ffe44dee866Vinicius Costa Gomes};
1371c1def09c446aae441410b70e6439ffe44dee866Vinicius Costa Gomes
138eb492e0169974ac6d168f11d1fc1e2753fe1f3b4Anderson Briglia/* SMP Commands */
139cc110922da7e902b62d18641a370fec01a9fa794Vinicius Costa Gomesint smp_conn_security(struct hci_conn *hcon, __u8 sec_level);
140eb492e0169974ac6d168f11d1fc1e2753fe1f3b4Anderson Brigliaint smp_sig_channel(struct l2cap_conn *conn, struct sk_buff *skb);
1417034b911af1aa571995b56db3ed71a25daf00373Vinicius Costa Gomesint smp_distribute_keys(struct l2cap_conn *conn, __u8 force);
1422b64d153a0cc9d2b60e47be013cde8490f16e0a5Brian Gixint smp_user_confirm_reply(struct hci_conn *conn, u16 mgmt_op, __le32 passkey);
143eb492e0169974ac6d168f11d1fc1e2753fe1f3b4Anderson Briglia
1448aab47574a7f5b46a4cdbc6fd820ab34e6c5dbf9Vinicius Costa Gomesvoid smp_chan_destroy(struct l2cap_conn *conn);
1458aab47574a7f5b46a4cdbc6fd820ab34e6c5dbf9Vinicius Costa Gomes
146aff2cae3546df9f47f9fe24f3e85a7a84e825de8Ville Tervo#endif /* __SMP_H */
147