1 /******************************************************************************
2 *
3 * Copyright (C) 1999-2012 Broadcom Corporation
4 *
5 * Licensed under the Apache License, Version 2.0 (the "License");
6 * you may not use this file except in compliance with the License.
7 * You may obtain a copy of the License at:
8 *
9 * http://www.apache.org/licenses/LICENSE-2.0
10 *
11 * Unless required by applicable law or agreed to in writing, software
12 * distributed under the License is distributed on an "AS IS" BASIS,
13 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14 * See the License for the specific language governing permissions and
15 * limitations under the License.
16 *
17 ******************************************************************************/
18
19 /******************************************************************************
20 *
21 * This file contains functions for the SMP L2CAP utility functions
22 *
23 ******************************************************************************/
24 #include "common/bt_target.h"
25
26 #if SMP_INCLUDED == 1
27
28 #include "stack/bt_types.h"
29 //#include "bt_utils.h"
30 #include <string.h>
31 //#include <ctype.h>
32 #include "stack/hcidefs.h"
33 #include "stack/btm_ble_api.h"
34 #include "stack/l2c_api.h"
35 #include "l2c_int.h"
36 #include "smp_int.h"
37 #include "device/controller.h"
38 #include "btm_int.h"
39 #include "common/bte_appl.h"
40
41 #define SMP_PAIRING_REQ_SIZE 7
42 #define SMP_CONFIRM_CMD_SIZE (BT_OCTET16_LEN + 1)
43 #define SMP_RAND_CMD_SIZE (BT_OCTET16_LEN + 1)
44 #define SMP_INIT_CMD_SIZE (BT_OCTET16_LEN + 1)
45 #define SMP_ENC_INFO_SIZE (BT_OCTET16_LEN + 1)
46 #define SMP_MASTER_ID_SIZE (BT_OCTET8_LEN + 2 + 1)
47 #define SMP_ID_INFO_SIZE (BT_OCTET16_LEN + 1)
48 #define SMP_ID_ADDR_SIZE (BD_ADDR_LEN + 1 + 1)
49 #define SMP_SIGN_INFO_SIZE (BT_OCTET16_LEN + 1)
50 #define SMP_PAIR_FAIL_SIZE 2
51 #define SMP_SECURITY_REQUEST_SIZE 2
52 #define SMP_PAIR_PUBL_KEY_SIZE (1 /* opcode */ + (2*BT_OCTET32_LEN))
53 #define SMP_PAIR_COMMITM_SIZE (1 /* opcode */ + BT_OCTET16_LEN /*Commitment*/)
54 #define SMP_PAIR_DHKEY_CHECK_SIZE (1 /* opcode */ + BT_OCTET16_LEN /*DHKey Check*/)
55 #define SMP_PAIR_KEYPR_NOTIF_SIZE (1 /* opcode */ + 1 /*Notif Type*/)
56
57 /* SMP command sizes per spec */
58 static const UINT8 smp_cmd_size_per_spec[] = {
59 0,
60 SMP_PAIRING_REQ_SIZE, /* 0x01: pairing request */
61 SMP_PAIRING_REQ_SIZE, /* 0x02: pairing response */
62 SMP_CONFIRM_CMD_SIZE, /* 0x03: pairing confirm */
63 SMP_RAND_CMD_SIZE, /* 0x04: pairing random */
64 SMP_PAIR_FAIL_SIZE, /* 0x05: pairing failed */
65 SMP_ENC_INFO_SIZE, /* 0x06: encryption information */
66 SMP_MASTER_ID_SIZE, /* 0x07: master identification */
67 SMP_ID_INFO_SIZE, /* 0x08: identity information */
68 SMP_ID_ADDR_SIZE, /* 0x09: identity address information */
69 SMP_SIGN_INFO_SIZE, /* 0x0A: signing information */
70 SMP_SECURITY_REQUEST_SIZE, /* 0x0B: security request */
71 SMP_PAIR_PUBL_KEY_SIZE, /* 0x0C: pairing public key */
72 SMP_PAIR_DHKEY_CHECK_SIZE, /* 0x0D: pairing dhkey check */
73 SMP_PAIR_KEYPR_NOTIF_SIZE, /* 0x0E: pairing keypress notification */
74 SMP_PAIR_COMMITM_SIZE /* 0x0F: pairing commitment */
75 };
76
77 static BOOLEAN smp_parameter_unconditionally_valid(tSMP_CB *p_cb);
78 static BOOLEAN smp_parameter_unconditionally_invalid(tSMP_CB *p_cb);
79
80 /* type for SMP command length validation functions */
81 typedef BOOLEAN (*tSMP_CMD_LEN_VALID)(tSMP_CB *p_cb);
82
83 static BOOLEAN smp_command_has_valid_fixed_length(tSMP_CB *p_cb);
84
85 static const tSMP_CMD_LEN_VALID smp_cmd_len_is_valid[] = {
86 smp_parameter_unconditionally_invalid,
87 smp_command_has_valid_fixed_length, /* 0x01: pairing request */
88 smp_command_has_valid_fixed_length, /* 0x02: pairing response */
89 smp_command_has_valid_fixed_length, /* 0x03: pairing confirm */
90 smp_command_has_valid_fixed_length, /* 0x04: pairing random */
91 smp_command_has_valid_fixed_length, /* 0x05: pairing failed */
92 smp_command_has_valid_fixed_length, /* 0x06: encryption information */
93 smp_command_has_valid_fixed_length, /* 0x07: master identification */
94 smp_command_has_valid_fixed_length, /* 0x08: identity information */
95 smp_command_has_valid_fixed_length, /* 0x09: identity address information */
96 smp_command_has_valid_fixed_length, /* 0x0A: signing information */
97 smp_command_has_valid_fixed_length, /* 0x0B: security request */
98 smp_command_has_valid_fixed_length, /* 0x0C: pairing public key */
99 smp_command_has_valid_fixed_length, /* 0x0D: pairing dhkey check */
100 smp_command_has_valid_fixed_length, /* 0x0E: pairing keypress notification */
101 smp_command_has_valid_fixed_length /* 0x0F: pairing commitment */
102 };
103
104 /* type for SMP command parameter ranges validation functions */
105 typedef BOOLEAN (*tSMP_CMD_PARAM_RANGES_VALID)(tSMP_CB *p_cb);
106
107 static BOOLEAN smp_pairing_request_response_parameters_are_valid(tSMP_CB *p_cb);
108 static BOOLEAN smp_pairing_keypress_notification_is_valid(tSMP_CB *p_cb);
109
110 static const tSMP_CMD_PARAM_RANGES_VALID smp_cmd_param_ranges_are_valid[] = {
111 smp_parameter_unconditionally_invalid,
112 smp_pairing_request_response_parameters_are_valid, /* 0x01: pairing request */
113 smp_pairing_request_response_parameters_are_valid, /* 0x02: pairing response */
114 smp_parameter_unconditionally_valid, /* 0x03: pairing confirm */
115 smp_parameter_unconditionally_valid, /* 0x04: pairing random */
116 smp_parameter_unconditionally_valid, /* 0x05: pairing failed */
117 smp_parameter_unconditionally_valid, /* 0x06: encryption information */
118 smp_parameter_unconditionally_valid, /* 0x07: master identification */
119 smp_parameter_unconditionally_valid, /* 0x08: identity information */
120 smp_parameter_unconditionally_valid, /* 0x09: identity address information */
121 smp_parameter_unconditionally_valid, /* 0x0A: signing information */
122 smp_parameter_unconditionally_valid, /* 0x0B: security request */
123 smp_parameter_unconditionally_valid, /* 0x0C: pairing public key */
124 smp_parameter_unconditionally_valid, /* 0x0D: pairing dhkey check */
125 smp_pairing_keypress_notification_is_valid, /* 0x0E: pairing keypress notification */
126 smp_parameter_unconditionally_valid /* 0x0F: pairing commitment */
127 };
128
129 /* type for action functions */
130 typedef BT_HDR *(*tSMP_CMD_ACT)(UINT8 cmd_code, tSMP_CB *p_cb);
131
132 static BT_HDR *smp_build_pairing_cmd(UINT8 cmd_code, tSMP_CB *p_cb);
133 static BT_HDR *smp_build_confirm_cmd(UINT8 cmd_code, tSMP_CB *p_cb);
134 static BT_HDR *smp_build_rand_cmd(UINT8 cmd_code, tSMP_CB *p_cb);
135 static BT_HDR *smp_build_pairing_fail(UINT8 cmd_code, tSMP_CB *p_cb);
136 static BT_HDR *smp_build_identity_info_cmd(UINT8 cmd_code, tSMP_CB *p_cb);
137 static BT_HDR *smp_build_encrypt_info_cmd(UINT8 cmd_code, tSMP_CB *p_cb);
138 static BT_HDR *smp_build_security_request(UINT8 cmd_code, tSMP_CB *p_cb);
139 static BT_HDR *smp_build_signing_info_cmd(UINT8 cmd_code, tSMP_CB *p_cb);
140 static BT_HDR *smp_build_master_id_cmd(UINT8 cmd_code, tSMP_CB *p_cb);
141 static BT_HDR *smp_build_id_addr_cmd(UINT8 cmd_code, tSMP_CB *p_cb);
142 static BT_HDR *smp_build_pair_public_key_cmd(UINT8 cmd_code, tSMP_CB *p_cb);
143 static BT_HDR *smp_build_pairing_commitment_cmd(UINT8 cmd_code, tSMP_CB *p_cb);
144 static BT_HDR *smp_build_pair_dhkey_check_cmd(UINT8 cmd_code, tSMP_CB *p_cb);
145 static BT_HDR *smp_build_pairing_keypress_notification_cmd(UINT8 cmd_code, tSMP_CB *p_cb);
146
147 static const tSMP_CMD_ACT smp_cmd_build_act[] = {
148 NULL,
149 smp_build_pairing_cmd, /* 0x01: pairing request */
150 smp_build_pairing_cmd, /* 0x02: pairing response */
151 smp_build_confirm_cmd, /* 0x03: pairing confirm */
152 smp_build_rand_cmd, /* 0x04: pairing random */
153 smp_build_pairing_fail, /* 0x05: pairing failure */
154 smp_build_encrypt_info_cmd, /* 0x06: encryption information */
155 smp_build_master_id_cmd, /* 0x07: master identification */
156 smp_build_identity_info_cmd, /* 0x08: identity information */
157 smp_build_id_addr_cmd, /* 0x09: identity address information */
158 smp_build_signing_info_cmd, /* 0x0A: signing information */
159 smp_build_security_request, /* 0x0B: security request */
160 smp_build_pair_public_key_cmd, /* 0x0C: pairing public key */
161 smp_build_pair_dhkey_check_cmd, /* 0x0D: pairing DHKey check */
162 smp_build_pairing_keypress_notification_cmd, /* 0x0E: pairing keypress notification */
163 smp_build_pairing_commitment_cmd /* 0x0F: pairing commitment */
164 };
165
166 static const UINT8 smp_association_table[2][SMP_IO_CAP_MAX][SMP_IO_CAP_MAX] = {
167 /* display only */ /* Display Yes/No */ /* keyboard only */
168 /* No Input/Output */ /* keyboard display */
169
170 /* initiator */
171 /* model = tbl[peer_io_caps][loc_io_caps] */
172 /* Display Only */
173 { {
174 SMP_MODEL_ENCRYPTION_ONLY, SMP_MODEL_ENCRYPTION_ONLY, SMP_MODEL_PASSKEY,
175 SMP_MODEL_ENCRYPTION_ONLY, SMP_MODEL_PASSKEY
176 },
177
178 /* Display Yes/No */
179 {
180 SMP_MODEL_ENCRYPTION_ONLY, SMP_MODEL_ENCRYPTION_ONLY, SMP_MODEL_PASSKEY,
181 SMP_MODEL_ENCRYPTION_ONLY, SMP_MODEL_PASSKEY
182 },
183
184 /* Keyboard only */
185 {
186 SMP_MODEL_KEY_NOTIF, SMP_MODEL_KEY_NOTIF, SMP_MODEL_PASSKEY,
187 SMP_MODEL_ENCRYPTION_ONLY, SMP_MODEL_KEY_NOTIF
188 },
189
190 /* No Input No Output */
191 {
192 SMP_MODEL_ENCRYPTION_ONLY, SMP_MODEL_ENCRYPTION_ONLY, SMP_MODEL_ENCRYPTION_ONLY,
193 SMP_MODEL_ENCRYPTION_ONLY, SMP_MODEL_ENCRYPTION_ONLY
194 },
195
196 /* keyboard display */
197 {
198 SMP_MODEL_KEY_NOTIF, SMP_MODEL_KEY_NOTIF, SMP_MODEL_PASSKEY,
199 SMP_MODEL_ENCRYPTION_ONLY, SMP_MODEL_KEY_NOTIF
200 }
201 },
202
203 /* responder */
204 /* model = tbl[loc_io_caps][peer_io_caps] */
205 /* Display Only */
206 { {
207 SMP_MODEL_ENCRYPTION_ONLY, SMP_MODEL_ENCRYPTION_ONLY, SMP_MODEL_KEY_NOTIF,
208 SMP_MODEL_ENCRYPTION_ONLY, SMP_MODEL_KEY_NOTIF
209 },
210
211 /* Display Yes/No */
212 {
213 SMP_MODEL_ENCRYPTION_ONLY, SMP_MODEL_ENCRYPTION_ONLY, SMP_MODEL_KEY_NOTIF,
214 SMP_MODEL_ENCRYPTION_ONLY, SMP_MODEL_KEY_NOTIF
215 },
216
217 /* keyboard only */
218 {
219 SMP_MODEL_PASSKEY, SMP_MODEL_PASSKEY, SMP_MODEL_PASSKEY,
220 SMP_MODEL_ENCRYPTION_ONLY, SMP_MODEL_PASSKEY
221 },
222
223 /* No Input No Output */
224 {
225 SMP_MODEL_ENCRYPTION_ONLY, SMP_MODEL_ENCRYPTION_ONLY, SMP_MODEL_ENCRYPTION_ONLY,
226 SMP_MODEL_ENCRYPTION_ONLY, SMP_MODEL_ENCRYPTION_ONLY
227 },
228
229 /* keyboard display */
230 {
231 SMP_MODEL_PASSKEY, SMP_MODEL_PASSKEY, SMP_MODEL_KEY_NOTIF,
232 SMP_MODEL_ENCRYPTION_ONLY, SMP_MODEL_PASSKEY
233 }
234 }
235 };
236
237 static const UINT8 smp_association_table_sc[2][SMP_IO_CAP_MAX][SMP_IO_CAP_MAX] = {
238 /* display only */ /* Display Yes/No */ /* keyboard only */
239 /* No InputOutput */ /* keyboard display */
240
241 /* initiator */
242 /* model = tbl[peer_io_caps][loc_io_caps] */
243
244 /* Display Only */
245 { {
246 SMP_MODEL_SEC_CONN_JUSTWORKS, SMP_MODEL_SEC_CONN_JUSTWORKS, SMP_MODEL_SEC_CONN_PASSKEY_ENT,
247 SMP_MODEL_SEC_CONN_JUSTWORKS, SMP_MODEL_SEC_CONN_PASSKEY_ENT
248 },
249
250 /* Display Yes/No */
251 {
252 SMP_MODEL_SEC_CONN_JUSTWORKS, SMP_MODEL_SEC_CONN_NUM_COMP, SMP_MODEL_SEC_CONN_PASSKEY_ENT,
253 SMP_MODEL_SEC_CONN_JUSTWORKS, SMP_MODEL_SEC_CONN_NUM_COMP
254 },
255
256 /* keyboard only */
257 {
258 SMP_MODEL_SEC_CONN_PASSKEY_DISP, SMP_MODEL_SEC_CONN_PASSKEY_DISP, SMP_MODEL_SEC_CONN_PASSKEY_ENT,
259 SMP_MODEL_SEC_CONN_JUSTWORKS, SMP_MODEL_SEC_CONN_PASSKEY_DISP
260 },
261
262 /* No Input No Output */
263 {
264 SMP_MODEL_SEC_CONN_JUSTWORKS, SMP_MODEL_SEC_CONN_JUSTWORKS, SMP_MODEL_SEC_CONN_JUSTWORKS,
265 SMP_MODEL_SEC_CONN_JUSTWORKS, SMP_MODEL_SEC_CONN_JUSTWORKS
266 },
267
268 /* keyboard display */
269 {
270 SMP_MODEL_SEC_CONN_PASSKEY_DISP, SMP_MODEL_SEC_CONN_NUM_COMP, SMP_MODEL_SEC_CONN_PASSKEY_ENT,
271 SMP_MODEL_SEC_CONN_JUSTWORKS, SMP_MODEL_SEC_CONN_NUM_COMP
272 }
273 },
274
275 /* responder */
276 /* model = tbl[loc_io_caps][peer_io_caps] */
277
278 /* Display Only */
279 { {
280 SMP_MODEL_SEC_CONN_JUSTWORKS, SMP_MODEL_SEC_CONN_JUSTWORKS, SMP_MODEL_SEC_CONN_PASSKEY_DISP,
281 SMP_MODEL_SEC_CONN_JUSTWORKS, SMP_MODEL_SEC_CONN_PASSKEY_DISP
282 },
283
284 /* Display Yes/No */
285 {
286 SMP_MODEL_SEC_CONN_JUSTWORKS, SMP_MODEL_SEC_CONN_NUM_COMP, SMP_MODEL_SEC_CONN_PASSKEY_DISP,
287 SMP_MODEL_SEC_CONN_JUSTWORKS, SMP_MODEL_SEC_CONN_NUM_COMP
288 },
289
290 /* keyboard only */
291 {
292 SMP_MODEL_SEC_CONN_PASSKEY_ENT, SMP_MODEL_SEC_CONN_PASSKEY_ENT, SMP_MODEL_SEC_CONN_PASSKEY_ENT,
293 SMP_MODEL_SEC_CONN_JUSTWORKS, SMP_MODEL_SEC_CONN_PASSKEY_ENT
294 },
295
296 /* No Input No Output */
297 {
298 SMP_MODEL_SEC_CONN_JUSTWORKS, SMP_MODEL_SEC_CONN_JUSTWORKS, SMP_MODEL_SEC_CONN_JUSTWORKS,
299 SMP_MODEL_SEC_CONN_JUSTWORKS, SMP_MODEL_SEC_CONN_JUSTWORKS
300 },
301
302 /* keyboard display */
303 {
304 SMP_MODEL_SEC_CONN_PASSKEY_ENT, SMP_MODEL_SEC_CONN_NUM_COMP, SMP_MODEL_SEC_CONN_PASSKEY_DISP,
305 SMP_MODEL_SEC_CONN_JUSTWORKS, SMP_MODEL_SEC_CONN_NUM_COMP
306 }
307 }
308 };
309
310 static tSMP_ASSO_MODEL smp_select_legacy_association_model(tSMP_CB *p_cb);
311 static tSMP_ASSO_MODEL smp_select_association_model_secure_connections(tSMP_CB *p_cb);
312
313 /*******************************************************************************
314 **
315 ** Function smp_send_msg_to_L2CAP
316 **
317 ** Description Send message to L2CAP.
318 **
319 *******************************************************************************/
smp_send_msg_to_L2CAP(BD_ADDR rem_bda,BT_HDR * p_toL2CAP)320 BOOLEAN smp_send_msg_to_L2CAP(BD_ADDR rem_bda, BT_HDR *p_toL2CAP)
321 {
322 UINT16 l2cap_ret;
323 UINT16 fixed_cid = L2CAP_SMP_CID;
324
325 if (smp_cb.smp_over_br) {
326 fixed_cid = L2CAP_SMP_BR_CID;
327 }
328
329 SMP_TRACE_EVENT("%s", __FUNCTION__);
330 smp_cb.total_tx_unacked += 1;
331
332 if ((l2cap_ret = L2CA_SendFixedChnlData (fixed_cid, rem_bda, p_toL2CAP)) == L2CAP_DW_FAILED) {
333 smp_cb.total_tx_unacked -= 1;
334 SMP_TRACE_ERROR("SMP failed to pass msg:0x%0x to L2CAP",
335 *((UINT8 *)(p_toL2CAP + 1) + p_toL2CAP->offset));
336 return 0;
337 } else {
338 return 1;
339 }
340 }
341
342 /*******************************************************************************
343 **
344 ** Function smp_send_cmd
345 **
346 ** Description send a SMP command on L2CAP channel.
347 **
348 *******************************************************************************/
smp_send_cmd(UINT8 cmd_code,tSMP_CB * p_cb)349 BOOLEAN smp_send_cmd(UINT8 cmd_code, tSMP_CB *p_cb)
350 {
351 BT_HDR *p_buf;
352 BOOLEAN sent = 0;
353 UINT8 failure = SMP_PAIR_INTERNAL_ERR;
354 SMP_TRACE_EVENT("smp_send_cmd on l2cap cmd_code=0x%x\n", cmd_code);
355 if ( cmd_code <= (SMP_OPCODE_MAX + 1 /* for SMP_OPCODE_PAIR_COMMITM */) &&
356 smp_cmd_build_act[cmd_code] != NULL) {
357 p_buf = (*smp_cmd_build_act[cmd_code])(cmd_code, p_cb);
358
359 if (p_buf != NULL &&
360 smp_send_msg_to_L2CAP(p_cb->pairing_bda, p_buf)) {
361 sent = 1;
362
363 btu_stop_timer (&p_cb->rsp_timer_ent);
364 btu_start_timer (&p_cb->rsp_timer_ent, BTU_TTYPE_SMP_PAIRING_CMD,
365 SMP_WAIT_FOR_RSP_TOUT);
366 }
367 }
368
369 if (!sent) {
370 if (p_cb->smp_over_br) {
371 #if (CLASSIC_BT_INCLUDED == 1)
372 smp_br_state_machine_event(p_cb, SMP_BR_AUTH_CMPL_EVT, &failure);
373 #endif ///CLASSIC_BT_INCLUDED == 1
374 } else {
375 smp_sm_event(p_cb, SMP_AUTH_CMPL_EVT, &failure);
376 }
377 }
378 return sent;
379 }
380
381 /*******************************************************************************
382 **
383 ** Function smp_rsp_timeout
384 **
385 ** Description Called when SMP wait for SMP command response timer expires
386 **
387 ** Returns void
388 **
389 *******************************************************************************/
smp_rsp_timeout(TIMER_LIST_ENT * p_tle)390 void smp_rsp_timeout(TIMER_LIST_ENT *p_tle)
391 {
392 tSMP_CB *p_cb = &smp_cb;
393 UINT8 failure = SMP_RSP_TIMEOUT;
394 UNUSED(p_tle);
395
396 SMP_TRACE_EVENT("%s state:%d br_state:%d", __FUNCTION__, p_cb->state, p_cb->br_state);
397
398 if (p_cb->smp_over_br) {
399 #if (CLASSIC_BT_INCLUDED == 1)
400 smp_br_state_machine_event(p_cb, SMP_BR_AUTH_CMPL_EVT, &failure);
401 #endif ///CLASSIC_BT_INCLUDED == 1
402 } else {
403 smp_sm_event(p_cb, SMP_AUTH_CMPL_EVT, &failure);
404 }
405 }
406
407 /*******************************************************************************
408 **
409 ** Function smp_build_pairing_req_cmd
410 **
411 ** Description Build pairing request command.
412 **
413 *******************************************************************************/
smp_build_pairing_cmd(UINT8 cmd_code,tSMP_CB * p_cb)414 BT_HDR *smp_build_pairing_cmd(UINT8 cmd_code, tSMP_CB *p_cb)
415 {
416 BT_HDR *p_buf = NULL ;
417 UINT8 *p;
418
419 SMP_TRACE_EVENT("smp_build_pairing_cmd");
420 if ((p_buf = (BT_HDR *)osi_malloc(sizeof(BT_HDR) + SMP_PAIRING_REQ_SIZE + L2CAP_MIN_OFFSET)) != NULL) {
421 p = (UINT8 *)(p_buf + 1) + L2CAP_MIN_OFFSET;
422
423 UINT8_TO_STREAM (p, cmd_code);
424 UINT8_TO_STREAM (p, p_cb->local_io_capability);
425 UINT8_TO_STREAM (p, p_cb->loc_oob_flag);
426 UINT8_TO_STREAM (p, p_cb->loc_auth_req);
427 UINT8_TO_STREAM (p, p_cb->loc_enc_size);
428 UINT8_TO_STREAM (p, p_cb->local_i_key);
429 UINT8_TO_STREAM (p, p_cb->local_r_key);
430
431 p_buf->offset = L2CAP_MIN_OFFSET;
432 /* 1B ERR_RSP op code + 1B cmd_op_code + 2B handle + 1B status */
433 p_buf->len = SMP_PAIRING_REQ_SIZE;
434 }
435
436 return p_buf;
437 }
438
439 /*******************************************************************************
440 **
441 ** Function smp_build_confirm_cmd
442 **
443 ** Description Build confirm request command.
444 **
445 *******************************************************************************/
smp_build_confirm_cmd(UINT8 cmd_code,tSMP_CB * p_cb)446 static BT_HDR *smp_build_confirm_cmd(UINT8 cmd_code, tSMP_CB *p_cb)
447 {
448 BT_HDR *p_buf = NULL ;
449 UINT8 *p;
450 UNUSED(cmd_code);
451
452 SMP_TRACE_EVENT("smp_build_confirm_cmd\n");
453 if ((p_buf = (BT_HDR *)osi_malloc(sizeof(BT_HDR) + SMP_CONFIRM_CMD_SIZE + L2CAP_MIN_OFFSET)) != NULL) {
454 p = (UINT8 *)(p_buf + 1) + L2CAP_MIN_OFFSET;
455
456 UINT8_TO_STREAM (p, SMP_OPCODE_CONFIRM);
457 ARRAY_TO_STREAM (p, p_cb->confirm, BT_OCTET16_LEN);
458
459 p_buf->offset = L2CAP_MIN_OFFSET;
460 p_buf->len = SMP_CONFIRM_CMD_SIZE;
461 }
462
463 return p_buf;
464 }
465 /*******************************************************************************
466 **
467 ** Function smp_build_rand_cmd
468 **
469 ** Description Build Random command.
470 **
471 *******************************************************************************/
smp_build_rand_cmd(UINT8 cmd_code,tSMP_CB * p_cb)472 static BT_HDR *smp_build_rand_cmd(UINT8 cmd_code, tSMP_CB *p_cb)
473 {
474 BT_HDR *p_buf = NULL ;
475 UINT8 *p;
476 UNUSED(cmd_code);
477
478 SMP_TRACE_EVENT("%s\n", __func__);
479 if ((p_buf = (BT_HDR *)osi_malloc(sizeof(BT_HDR) + SMP_RAND_CMD_SIZE + L2CAP_MIN_OFFSET))
480 != NULL) {
481 p = (UINT8 *)(p_buf + 1) + L2CAP_MIN_OFFSET;
482
483 UINT8_TO_STREAM (p, SMP_OPCODE_RAND);
484 ARRAY_TO_STREAM (p, p_cb->rand, BT_OCTET16_LEN);
485
486 p_buf->offset = L2CAP_MIN_OFFSET;
487 p_buf->len = SMP_RAND_CMD_SIZE;
488 }
489
490 return p_buf;
491 }
492 /*******************************************************************************
493 **
494 ** Function smp_build_encrypt_info_cmd
495 **
496 ** Description Build security information command.
497 **
498 *******************************************************************************/
smp_build_encrypt_info_cmd(UINT8 cmd_code,tSMP_CB * p_cb)499 static BT_HDR *smp_build_encrypt_info_cmd(UINT8 cmd_code, tSMP_CB *p_cb)
500 {
501 BT_HDR *p_buf = NULL ;
502 UINT8 *p;
503 UNUSED(cmd_code);
504
505 SMP_TRACE_EVENT("smp_build_encrypt_info_cmd\n");
506 if ((p_buf = (BT_HDR *)osi_malloc(sizeof(BT_HDR) + SMP_ENC_INFO_SIZE + L2CAP_MIN_OFFSET)) != NULL) {
507 p = (UINT8 *)(p_buf + 1) + L2CAP_MIN_OFFSET;
508
509 UINT8_TO_STREAM (p, SMP_OPCODE_ENCRYPT_INFO);
510 ARRAY_TO_STREAM (p, p_cb->ltk, BT_OCTET16_LEN);
511
512 p_buf->offset = L2CAP_MIN_OFFSET;
513 p_buf->len = SMP_ENC_INFO_SIZE;
514 }
515
516 return p_buf;
517 }
518
519 /*******************************************************************************
520 **
521 ** Function smp_build_master_id_cmd
522 **
523 ** Description Build security information command.
524 **
525 *******************************************************************************/
smp_build_master_id_cmd(UINT8 cmd_code,tSMP_CB * p_cb)526 static BT_HDR *smp_build_master_id_cmd(UINT8 cmd_code, tSMP_CB *p_cb)
527 {
528 BT_HDR *p_buf = NULL ;
529 UINT8 *p;
530 UNUSED(cmd_code);
531
532 SMP_TRACE_EVENT("%s\n", __func__);
533
534 if ((p_buf = (BT_HDR *)osi_malloc(sizeof(BT_HDR) + SMP_MASTER_ID_SIZE + L2CAP_MIN_OFFSET)) != NULL) {
535 p = (UINT8 *)(p_buf + 1) + L2CAP_MIN_OFFSET;
536
537 UINT8_TO_STREAM (p, SMP_OPCODE_MASTER_ID);
538 UINT16_TO_STREAM (p, p_cb->ediv);
539 ARRAY_TO_STREAM (p, p_cb->enc_rand, BT_OCTET8_LEN);
540
541 p_buf->offset = L2CAP_MIN_OFFSET;
542 p_buf->len = SMP_MASTER_ID_SIZE;
543 }
544
545 return p_buf;
546 }
547
548 /*******************************************************************************
549 **
550 ** Function smp_build_identity_info_cmd
551 **
552 ** Description Build identity information command.
553 **
554 *******************************************************************************/
smp_build_identity_info_cmd(UINT8 cmd_code,tSMP_CB * p_cb)555 static BT_HDR *smp_build_identity_info_cmd(UINT8 cmd_code, tSMP_CB *p_cb)
556 {
557 BT_HDR *p_buf = NULL ;
558 #if (BLE_INCLUDED == 1)
559 UINT8 *p;
560 BT_OCTET16 irk;
561 UNUSED(cmd_code);
562 UNUSED(p_cb);
563
564 SMP_TRACE_EVENT("smp_build_identity_info_cmd\n");
565 if ((p_buf = (BT_HDR *)osi_malloc(sizeof(BT_HDR) + SMP_ID_INFO_SIZE + L2CAP_MIN_OFFSET)) != NULL) {
566 p = (UINT8 *)(p_buf + 1) + L2CAP_MIN_OFFSET;
567
568 BTM_GetDeviceIDRoot(irk);
569
570 UINT8_TO_STREAM (p, SMP_OPCODE_IDENTITY_INFO);
571 ARRAY_TO_STREAM (p, irk, BT_OCTET16_LEN);
572
573 p_buf->offset = L2CAP_MIN_OFFSET;
574 p_buf->len = SMP_ID_INFO_SIZE;
575 }
576
577 #endif ///BLE_INCLUDED == 1
578 return p_buf;
579 }
580
581 /*******************************************************************************
582 **
583 ** Function smp_build_id_addr_cmd
584 **
585 ** Description Build identity address information command.
586 **
587 *******************************************************************************/
smp_build_id_addr_cmd(UINT8 cmd_code,tSMP_CB * p_cb)588 static BT_HDR *smp_build_id_addr_cmd(UINT8 cmd_code, tSMP_CB *p_cb)
589 {
590 BT_HDR *p_buf = NULL;
591 UINT8 *p;
592
593 UNUSED(cmd_code);
594 UNUSED(p_cb);
595 SMP_TRACE_EVENT("smp_build_id_addr_cmd\n");
596 if ((p_buf = (BT_HDR *)osi_malloc(sizeof(BT_HDR) + SMP_ID_ADDR_SIZE + L2CAP_MIN_OFFSET)) != NULL) {
597 p = (UINT8 *)(p_buf + 1) + L2CAP_MIN_OFFSET;
598
599 UINT8_TO_STREAM (p, SMP_OPCODE_ID_ADDR);
600 /* Identity Address Information is used in the Transport Specific Key Distribution phase to distribute
601 its public device address or static random address. if slave using static random address is encrypted,
602 it should distribute its static random address */
603 #if (BLE_INCLUDED == 1)
604 if(btm_cb.ble_ctr_cb.addr_mgnt_cb.own_addr_type == BLE_ADDR_RANDOM && memcmp(btm_cb.ble_ctr_cb.addr_mgnt_cb.static_rand_addr, btm_cb.ble_ctr_cb.addr_mgnt_cb.private_addr,6) == 0) {
605 UINT8_TO_STREAM (p, 0x01);
606 BDADDR_TO_STREAM (p, btm_cb.ble_ctr_cb.addr_mgnt_cb.static_rand_addr);
607 } else
608 #endif ///BLE_INCLUDED == 1
609 {
610 UINT8_TO_STREAM (p, 0);
611 BDADDR_TO_STREAM (p, controller_get_interface()->get_address()->address);
612 }
613
614 p_buf->offset = L2CAP_MIN_OFFSET;
615 p_buf->len = SMP_ID_ADDR_SIZE;
616 }
617
618 return p_buf;
619 }
620
621 /*******************************************************************************
622 **
623 ** Function smp_build_signing_info_cmd
624 **
625 ** Description Build signing information command.
626 **
627 *******************************************************************************/
smp_build_signing_info_cmd(UINT8 cmd_code,tSMP_CB * p_cb)628 static BT_HDR *smp_build_signing_info_cmd(UINT8 cmd_code, tSMP_CB *p_cb)
629 {
630 BT_HDR *p_buf = NULL ;
631 UINT8 *p;
632 UNUSED(cmd_code);
633
634 SMP_TRACE_EVENT("smp_build_signing_info_cmd\n");
635 if ((p_buf = (BT_HDR *)osi_malloc(sizeof(BT_HDR) + SMP_SIGN_INFO_SIZE + L2CAP_MIN_OFFSET)) != NULL) {
636 p = (UINT8 *)(p_buf + 1) + L2CAP_MIN_OFFSET;
637
638 UINT8_TO_STREAM (p, SMP_OPCODE_SIGN_INFO);
639 ARRAY_TO_STREAM (p, p_cb->csrk, BT_OCTET16_LEN);
640
641 p_buf->offset = L2CAP_MIN_OFFSET;
642 p_buf->len = SMP_SIGN_INFO_SIZE;
643 }
644
645 return p_buf;
646 }
647
648 /*******************************************************************************
649 **
650 ** Function smp_build_pairing_fail
651 **
652 ** Description Build Pairing Fail command.
653 **
654 *******************************************************************************/
smp_build_pairing_fail(UINT8 cmd_code,tSMP_CB * p_cb)655 static BT_HDR *smp_build_pairing_fail(UINT8 cmd_code, tSMP_CB *p_cb)
656 {
657 BT_HDR *p_buf = NULL ;
658 UINT8 *p;
659 UNUSED(cmd_code);
660
661 SMP_TRACE_EVENT("%s\n", __func__);
662 if ((p_buf = (BT_HDR *)osi_malloc(sizeof(BT_HDR) + SMP_PAIR_FAIL_SIZE + L2CAP_MIN_OFFSET)) != NULL) {
663 p = (UINT8 *)(p_buf + 1) + L2CAP_MIN_OFFSET;
664
665 UINT8_TO_STREAM (p, SMP_OPCODE_PAIRING_FAILED);
666 UINT8_TO_STREAM (p, p_cb->failure);
667
668 p_buf->offset = L2CAP_MIN_OFFSET;
669 p_buf->len = SMP_PAIR_FAIL_SIZE;
670 }
671
672 return p_buf;
673 }
674
675 /*******************************************************************************
676 **
677 ** Function smp_build_security_request
678 **
679 ** Description Build security request command.
680 **
681 *******************************************************************************/
smp_build_security_request(UINT8 cmd_code,tSMP_CB * p_cb)682 static BT_HDR *smp_build_security_request(UINT8 cmd_code, tSMP_CB *p_cb)
683 {
684 BT_HDR *p_buf = NULL ;
685 UINT8 *p;
686 UNUSED(cmd_code);
687
688 SMP_TRACE_EVENT("%s\n", __func__);
689 if ((p_buf = (BT_HDR *)osi_malloc(sizeof(BT_HDR) + 2 + L2CAP_MIN_OFFSET)) != NULL) {
690 p = (UINT8 *)(p_buf + 1) + L2CAP_MIN_OFFSET;
691
692 UINT8_TO_STREAM (p, SMP_OPCODE_SEC_REQ);
693 UINT8_TO_STREAM (p, p_cb->loc_auth_req);
694
695 p_buf->offset = L2CAP_MIN_OFFSET;
696 p_buf->len = SMP_SECURITY_REQUEST_SIZE;
697
698 SMP_TRACE_EVENT("opcode=%d auth_req=0x%x", SMP_OPCODE_SEC_REQ, p_cb->loc_auth_req );
699 }
700
701 return p_buf;
702
703 }
704
705 /*******************************************************************************
706 **
707 ** Function smp_build_pair_public_key_cmd
708 **
709 ** Description Build pairing public key command.
710 **
711 *******************************************************************************/
smp_build_pair_public_key_cmd(UINT8 cmd_code,tSMP_CB * p_cb)712 static BT_HDR *smp_build_pair_public_key_cmd(UINT8 cmd_code, tSMP_CB *p_cb)
713 {
714 BT_HDR *p_buf = NULL ;
715 UINT8 *p;
716 UINT8 publ_key[2 * BT_OCTET32_LEN];
717 UINT8 *p_publ_key = publ_key;
718 UNUSED(cmd_code);
719
720 SMP_TRACE_EVENT("%s\n", __FUNCTION__);
721
722 memcpy(p_publ_key, p_cb->loc_publ_key.x, BT_OCTET32_LEN);
723 memcpy(p_publ_key + BT_OCTET32_LEN, p_cb->loc_publ_key.y, BT_OCTET32_LEN);
724
725 if ((p_buf = (BT_HDR *)osi_malloc(sizeof(BT_HDR) +
726 SMP_PAIR_PUBL_KEY_SIZE + L2CAP_MIN_OFFSET)) != NULL) {
727 p = (UINT8 *)(p_buf + 1) + L2CAP_MIN_OFFSET;
728
729 UINT8_TO_STREAM (p, SMP_OPCODE_PAIR_PUBLIC_KEY);
730 ARRAY_TO_STREAM (p, p_publ_key, 2 * BT_OCTET32_LEN);
731
732 p_buf->offset = L2CAP_MIN_OFFSET;
733 p_buf->len = SMP_PAIR_PUBL_KEY_SIZE;
734 }
735
736 return p_buf;
737 }
738
739 /*******************************************************************************
740 **
741 ** Function smp_build_pairing_commitment_cmd
742 **
743 ** Description Build pairing commitment command.
744 **
745 *******************************************************************************/
smp_build_pairing_commitment_cmd(UINT8 cmd_code,tSMP_CB * p_cb)746 static BT_HDR *smp_build_pairing_commitment_cmd(UINT8 cmd_code, tSMP_CB *p_cb)
747 {
748 BT_HDR *p_buf = NULL;
749 UINT8 *p;
750 UNUSED(cmd_code);
751
752 SMP_TRACE_EVENT("%s\n", __func__);
753 if ((p_buf = (BT_HDR *)osi_malloc(sizeof(BT_HDR) + SMP_PAIR_COMMITM_SIZE + L2CAP_MIN_OFFSET))
754 != NULL) {
755 p = (UINT8 *)(p_buf + 1) + L2CAP_MIN_OFFSET;
756
757 UINT8_TO_STREAM (p, SMP_OPCODE_CONFIRM);
758 ARRAY_TO_STREAM (p, p_cb->commitment, BT_OCTET16_LEN);
759
760 p_buf->offset = L2CAP_MIN_OFFSET;
761 p_buf->len = SMP_PAIR_COMMITM_SIZE;
762 }
763
764 return p_buf;
765 }
766
767 /*******************************************************************************
768 **
769 ** Function smp_build_pair_dhkey_check_cmd
770 **
771 ** Description Build pairing DHKey check command.
772 **
773 *******************************************************************************/
smp_build_pair_dhkey_check_cmd(UINT8 cmd_code,tSMP_CB * p_cb)774 static BT_HDR *smp_build_pair_dhkey_check_cmd(UINT8 cmd_code, tSMP_CB *p_cb)
775 {
776 BT_HDR *p_buf = NULL;
777 UINT8 *p;
778 UNUSED(cmd_code);
779
780 SMP_TRACE_EVENT("%s\n", __FUNCTION__);
781 if ((p_buf = (BT_HDR *)osi_malloc(sizeof(BT_HDR) +
782 SMP_PAIR_DHKEY_CHECK_SIZE + L2CAP_MIN_OFFSET)) != NULL) {
783 p = (UINT8 *)(p_buf + 1) + L2CAP_MIN_OFFSET;
784
785 UINT8_TO_STREAM (p, SMP_OPCODE_PAIR_DHKEY_CHECK);
786 ARRAY_TO_STREAM (p, p_cb->dhkey_check, BT_OCTET16_LEN);
787
788 p_buf->offset = L2CAP_MIN_OFFSET;
789 p_buf->len = SMP_PAIR_DHKEY_CHECK_SIZE;
790 }
791
792 return p_buf;
793 }
794
795 /*******************************************************************************
796 **
797 ** Function smp_build_pairing_keypress_notification_cmd
798 **
799 ** Description Build keypress notification command.
800 **
801 *******************************************************************************/
smp_build_pairing_keypress_notification_cmd(UINT8 cmd_code,tSMP_CB * p_cb)802 static BT_HDR *smp_build_pairing_keypress_notification_cmd(UINT8 cmd_code, tSMP_CB *p_cb)
803 {
804 BT_HDR *p_buf = NULL ;
805 UINT8 *p;
806 UNUSED(cmd_code);
807
808 SMP_TRACE_EVENT("%s\n", __FUNCTION__);
809 if ((p_buf = (BT_HDR *)osi_malloc(sizeof(BT_HDR)\
810 + SMP_PAIR_KEYPR_NOTIF_SIZE + L2CAP_MIN_OFFSET)) != NULL) {
811 p = (UINT8 *)(p_buf + 1) + L2CAP_MIN_OFFSET;
812
813 UINT8_TO_STREAM (p, SMP_OPCODE_PAIR_KEYPR_NOTIF);
814 UINT8_TO_STREAM (p, p_cb->local_keypress_notification);
815
816 p_buf->offset = L2CAP_MIN_OFFSET;
817 p_buf->len = SMP_PAIR_KEYPR_NOTIF_SIZE;
818 }
819
820 return p_buf;
821 }
822
823 /*******************************************************************************
824 **
825 ** Function smp_convert_string_to_tk
826 **
827 ** Description This function is called to convert a 6 to 16 digits numeric
828 ** character string into SMP TK.
829 **
830 **
831 ** Returns void
832 **
833 *******************************************************************************/
smp_convert_string_to_tk(BT_OCTET16 tk,UINT32 passkey)834 void smp_convert_string_to_tk(BT_OCTET16 tk, UINT32 passkey)
835 {
836 UINT8 *p = tk;
837 tSMP_KEY key;
838 SMP_TRACE_EVENT("smp_convert_string_to_tk\n");
839 UINT32_TO_STREAM(p, passkey);
840
841 key.key_type = SMP_KEY_TYPE_TK;
842 key.p_data = tk;
843
844 smp_sm_event(&smp_cb, SMP_KEY_READY_EVT, &key);
845 }
846
847 /*******************************************************************************
848 **
849 ** Function smp_mask_enc_key
850 **
851 ** Description This function is called to mask off the encryption key based
852 ** on the maximum encryption key size.
853 **
854 **
855 ** Returns void
856 **
857 *******************************************************************************/
smp_mask_enc_key(UINT8 loc_enc_size,UINT8 * p_data)858 void smp_mask_enc_key(UINT8 loc_enc_size, UINT8 *p_data)
859 {
860 SMP_TRACE_EVENT("smp_mask_enc_key\n");
861 if (loc_enc_size < BT_OCTET16_LEN) {
862 for (; loc_enc_size < BT_OCTET16_LEN; loc_enc_size ++) {
863 * (p_data + loc_enc_size) = 0;
864 }
865 }
866 return;
867 }
868
869 /*******************************************************************************
870 **
871 ** Function smp_xor_128
872 **
873 ** Description utility function to do an biteise exclusive-OR of two bit
874 ** strings of the length of BT_OCTET16_LEN.
875 **
876 ** Returns void
877 **
878 *******************************************************************************/
smp_xor_128(BT_OCTET16 a,const BT_OCTET16 b)879 void smp_xor_128(BT_OCTET16 a, const BT_OCTET16 b)
880 {
881 UINT8 i, *aa = a;
882 const UINT8 *bb = b;
883
884 SMP_TRACE_EVENT("smp_xor_128\n");
885 for (i = 0; i < BT_OCTET16_LEN; i++) {
886 aa[i] = aa[i] ^ bb[i];
887 }
888 }
889
890 /*******************************************************************************
891 **
892 ** Function smp_cb_cleanup
893 **
894 ** Description Clean up SMP control block
895 **
896 ** Returns void
897 **
898 *******************************************************************************/
smp_cb_cleanup(tSMP_CB * p_cb)899 void smp_cb_cleanup(tSMP_CB *p_cb)
900 {
901 tSMP_CALLBACK *p_callback = p_cb->p_callback;
902 UINT8 trace_level = p_cb->trace_level;
903 UINT32 static_passkey = p_cb->static_passkey;
904 BOOLEAN use_static_passkey = p_cb->use_static_passkey;
905 SMP_TRACE_EVENT("smp_cb_cleanup\n");
906
907 memset(p_cb, 0, sizeof(tSMP_CB));
908 p_cb->p_callback = p_callback;
909 p_cb->trace_level = trace_level;
910 if(use_static_passkey) {
911 p_cb->use_static_passkey = use_static_passkey;
912 p_cb->static_passkey = static_passkey;
913 }
914 }
915
916 /*******************************************************************************
917 **
918 ** Function smp_remove_fixed_channel
919 **
920 ** Description This function is called to remove the fixed channel
921 **
922 ** Returns void
923 **
924 *******************************************************************************/
smp_remove_fixed_channel(tSMP_CB * p_cb)925 void smp_remove_fixed_channel(tSMP_CB *p_cb)
926 {
927 SMP_TRACE_DEBUG("%s\n", __func__);
928
929 if (p_cb->smp_over_br) {
930 L2CA_RemoveFixedChnl (L2CAP_SMP_BR_CID, p_cb->pairing_bda);
931 } else {
932 L2CA_RemoveFixedChnl (L2CAP_SMP_CID, p_cb->pairing_bda);
933 }
934 }
935
936 /*******************************************************************************
937 **
938 ** Function smp_reset_control_value
939 **
940 ** Description This function is called to reset the control block value when
941 ** pairing procedure finished.
942 **
943 **
944 ** Returns void
945 **
946 *******************************************************************************/
smp_reset_control_value(tSMP_CB * p_cb)947 void smp_reset_control_value(tSMP_CB *p_cb)
948 {
949 SMP_TRACE_EVENT("smp_reset_control_value\n");
950 btu_stop_timer (&p_cb->rsp_timer_ent);
951 p_cb->flags = 0;
952 /* set the link idle timer to drop the link when pairing is done
953 usually service discovery will follow authentication complete, to avoid
954 racing condition for a link down/up, set link idle timer to be
955 SMP_LINK_TOUT_MIN to guarantee SMP key exchange */
956 L2CA_SetIdleTimeoutByBdAddr(p_cb->pairing_bda, SMP_LINK_TOUT_MIN, BT_TRANSPORT_LE);
957
958 /* We can tell L2CAP to remove the fixed channel (if it has one) */
959 smp_remove_fixed_channel(p_cb);
960 smp_cb_cleanup(p_cb);
961 }
962
963 /*******************************************************************************
964 **
965 ** Function smp_proc_pairing_cmpl
966 **
967 ** Description This function is called to process pairing complete
968 **
969 **
970 ** Returns void
971 **
972 *******************************************************************************/
smp_proc_pairing_cmpl(tSMP_CB * p_cb)973 void smp_proc_pairing_cmpl(tSMP_CB *p_cb)
974 {
975 tSMP_EVT_DATA evt_data = {0};
976 tSMP_CALLBACK *p_callback = p_cb->p_callback;
977 BD_ADDR pairing_bda;
978
979 SMP_TRACE_DEBUG ("smp_proc_pairing_cmpl \n");
980
981 evt_data.cmplt.reason = p_cb->status;
982 evt_data.cmplt.smp_over_br = p_cb->smp_over_br;
983 evt_data.cmplt.auth_mode = 0;
984 #if (BLE_INCLUDED == 1)
985 tBTM_SEC_DEV_REC *p_rec = btm_find_dev (p_cb->pairing_bda);
986 if (p_cb->status == SMP_SUCCESS) {
987 evt_data.cmplt.sec_level = p_cb->sec_level;
988 if (p_cb->auth_mode) { // the first encryption
989 evt_data.cmplt.auth_mode = p_cb->auth_mode;
990 if (p_rec) {
991 p_rec->ble.auth_mode = p_cb->auth_mode;
992 }
993 } else if (p_rec) {
994 evt_data.cmplt.auth_mode = p_rec->ble.auth_mode;
995 }
996 }
997 #else
998 if (p_cb->status == SMP_SUCCESS) {
999 evt_data.cmplt.sec_level = p_cb->sec_level;
1000 evt_data.cmplt.auth_mode = p_cb->auth_mode;
1001 }
1002 #endif
1003
1004 evt_data.cmplt.is_pair_cancel = 0;
1005
1006 if (p_cb->is_pair_cancel) {
1007 evt_data.cmplt.is_pair_cancel = 1;
1008 }
1009
1010
1011 SMP_TRACE_DEBUG ("send SMP_COMPLT_EVT reason=0x%0x sec_level=0x%0x\n",
1012 evt_data.cmplt.reason,
1013 evt_data.cmplt.sec_level );
1014
1015 memcpy (pairing_bda, p_cb->pairing_bda, BD_ADDR_LEN);
1016
1017 #if (BLE_INCLUDED == 1)
1018 #if (SMP_SLAVE_CON_PARAMS_UPD_ENABLE == 1)
1019 if (p_cb->role == HCI_ROLE_SLAVE) {
1020 if(p_rec && p_rec->ble.skip_update_conn_param) {
1021 //clear flag
1022 p_rec->ble.skip_update_conn_param = false;
1023 } else {
1024 #if (BT_MULTI_CONNECTION_ENBALE == 0)
1025 L2CA_EnableUpdateBleConnParams(p_cb->pairing_bda, 1);
1026 #endif
1027 }
1028 }
1029
1030 #endif
1031 #endif ///BLE_INCLUDED == 1
1032
1033 smp_reset_control_value(p_cb);
1034
1035 if (p_callback) {
1036 (*p_callback) (SMP_COMPLT_EVT, pairing_bda, &evt_data);
1037 }
1038 }
1039
1040 /*******************************************************************************
1041 **
1042 ** Function smp_command_has_invalid_parameters
1043 **
1044 ** Description Checks if the received SMP command has invalid parameters i.e.
1045 ** if the command length is valid and the command parameters are
1046 ** inside specified range.
1047 ** It returns 1 if the command has invalid parameters.
1048 **
1049 ** Returns 1 if the command has invalid parameters, 0 otherwise.
1050 **
1051 *******************************************************************************/
smp_command_has_invalid_parameters(tSMP_CB * p_cb)1052 BOOLEAN smp_command_has_invalid_parameters(tSMP_CB *p_cb)
1053 {
1054 UINT8 cmd_code = p_cb->rcvd_cmd_code;
1055
1056 SMP_TRACE_DEBUG("%s for cmd code 0x%02x\n", __func__, cmd_code);
1057
1058 if ((cmd_code > (SMP_OPCODE_MAX + 1 /* for SMP_OPCODE_PAIR_COMMITM */)) ||
1059 (cmd_code < SMP_OPCODE_MIN)) {
1060 SMP_TRACE_WARNING("Somehow received command with the RESERVED code 0x%02x\n", cmd_code);
1061 return 1;
1062 }
1063
1064 if (!(*smp_cmd_len_is_valid[cmd_code])(p_cb)) {
1065 return 1;
1066 }
1067
1068 if (!(*smp_cmd_param_ranges_are_valid[cmd_code])(p_cb)) {
1069 return 1;
1070 }
1071
1072 return 0;
1073 }
1074
1075 /*******************************************************************************
1076 **
1077 ** Function smp_command_has_valid_fixed_length
1078 **
1079 ** Description Checks if the received command size is equal to the size
1080 ** according to specs.
1081 **
1082 ** Returns 1 if the command size is as expected, 0 otherwise.
1083 **
1084 ** Note The command is expected to have fixed length.
1085 *******************************************************************************/
smp_command_has_valid_fixed_length(tSMP_CB * p_cb)1086 BOOLEAN smp_command_has_valid_fixed_length(tSMP_CB *p_cb)
1087 {
1088 UINT8 cmd_code = p_cb->rcvd_cmd_code;
1089
1090 SMP_TRACE_DEBUG("%s for cmd code 0x%02x\n", __func__, cmd_code);
1091
1092 if (p_cb->rcvd_cmd_len != smp_cmd_size_per_spec[cmd_code]) {
1093 SMP_TRACE_WARNING("Rcvd from the peer cmd 0x%02x with invalid length\
1094 0x%02x (per spec the length is 0x%02x).\n",
1095 cmd_code, p_cb->rcvd_cmd_len, smp_cmd_size_per_spec[cmd_code]);
1096 return 0;
1097 }
1098
1099 return 1;
1100 }
1101
1102 /*******************************************************************************
1103 **
1104 ** Function smp_pairing_request_response_parameters_are_valid
1105 **
1106 ** Description Validates parameter ranges in the received SMP command
1107 ** pairing request or pairing response.
1108 ** The parameters to validate:
1109 ** IO capability,
1110 ** OOB data flag,
1111 ** Bonding_flags in AuthReq
1112 ** Maximum encryption key size.
1113 ** Returns 0 if at least one of these parameters is out of range.
1114 **
1115 *******************************************************************************/
smp_pairing_request_response_parameters_are_valid(tSMP_CB * p_cb)1116 BOOLEAN smp_pairing_request_response_parameters_are_valid(tSMP_CB *p_cb)
1117 {
1118 UINT8 io_caps = p_cb->peer_io_caps;
1119 UINT8 oob_flag = p_cb->peer_oob_flag;
1120 UINT8 bond_flag = p_cb->peer_auth_req & 0x03; //0x03 is gen bond with appropriate mask
1121 UINT8 enc_size = p_cb->peer_enc_size;
1122
1123 SMP_TRACE_DEBUG("%s for cmd code 0x%02x\n", __func__, p_cb->rcvd_cmd_code);
1124
1125 if (io_caps >= BTM_IO_CAP_MAX) {
1126 SMP_TRACE_WARNING("Rcvd from the peer cmd 0x%02x with IO Capabilty \
1127 value (0x%02x) out of range).\n",
1128 p_cb->rcvd_cmd_code, io_caps);
1129 return 0;
1130 }
1131
1132 if (!((oob_flag == SMP_OOB_NONE) || (oob_flag == SMP_OOB_PRESENT))) {
1133 SMP_TRACE_WARNING("Rcvd from the peer cmd 0x%02x with OOB data flag value \
1134 (0x%02x) out of range).\n",
1135 p_cb->rcvd_cmd_code, oob_flag);
1136 return 0;
1137 }
1138
1139 if (!((bond_flag == SMP_AUTH_NO_BOND) || (bond_flag == SMP_AUTH_BOND))) {
1140 SMP_TRACE_WARNING("Rcvd from the peer cmd 0x%02x with Bonding_Flags value (0x%02x)\
1141 out of range).\n",
1142 p_cb->rcvd_cmd_code, bond_flag);
1143 return 0;
1144 }
1145
1146 /* `bte_appl_cfg.ble_min_enc_key_size` will be `SMP_ENCR_KEY_SIZE_MIN` by
1147 * default if not set explicitly */
1148 #if (BLE_INCLUDED == 1)
1149 if (enc_size < bte_appl_cfg.ble_min_key_size) {
1150 SMP_TRACE_WARNING("Rcvd from the peer cmd 0x%02x with Maximum Encryption \
1151 Key value (0x%02x) less than minimum required key size).\n",
1152 p_cb->rcvd_cmd_code, enc_size);
1153 return 0;
1154 }
1155 #else
1156 if (enc_size < SMP_ENCR_KEY_SIZE_MIN) {
1157 SMP_TRACE_WARNING("Rcvd from the peer cmd 0x%02x with Maximum Encryption \
1158 Key value (0x%02x) less than minimum required key size).\n",
1159 p_cb->rcvd_cmd_code, enc_size);
1160 return 0;
1161 }
1162 #endif
1163
1164 if (enc_size > SMP_ENCR_KEY_SIZE_MAX) {
1165 SMP_TRACE_WARNING("Rcvd from the peer cmd 0x%02x with Maximum Encryption \
1166 Key value (0x%02x) greater than supported by stack).\n",
1167 p_cb->rcvd_cmd_code, enc_size);
1168 return 0;
1169 }
1170
1171 return 1;
1172 }
1173
1174 /*******************************************************************************
1175 **
1176 ** Function smp_pairing_keypress_notification_is_valid
1177 **
1178 ** Description Validates Notification Type parameter range in the received SMP command
1179 ** pairing keypress notification.
1180 ** Returns 0 if this parameter is out of range.
1181 **
1182 *******************************************************************************/
smp_pairing_keypress_notification_is_valid(tSMP_CB * p_cb)1183 BOOLEAN smp_pairing_keypress_notification_is_valid(tSMP_CB *p_cb)
1184 {
1185 tBTM_SP_KEY_TYPE keypress_notification = p_cb->peer_keypress_notification;
1186
1187 SMP_TRACE_DEBUG("%s for cmd code 0x%02x\n", __func__, p_cb->rcvd_cmd_code);
1188
1189 if (keypress_notification >= BTM_SP_KEY_OUT_OF_RANGE) {
1190 SMP_TRACE_WARNING("Rcvd from the peer cmd 0x%02x with Pairing Keypress \
1191 Notification value (0x%02x) out of range).\n",
1192 p_cb->rcvd_cmd_code, keypress_notification);
1193 return 0;
1194 }
1195
1196 return 1;
1197 }
1198
1199 /*******************************************************************************
1200 **
1201 ** Function smp_parameter_unconditionally_valid
1202 **
1203 ** Description Always returns 1.
1204 **
1205 *******************************************************************************/
smp_parameter_unconditionally_valid(tSMP_CB * p_cb)1206 BOOLEAN smp_parameter_unconditionally_valid(tSMP_CB *p_cb)
1207 {
1208 return 1;
1209 }
1210
1211 /*******************************************************************************
1212 **
1213 ** Function smp_parameter_unconditionally_invalid
1214 **
1215 ** Description Always returns 0.
1216 **
1217 *******************************************************************************/
smp_parameter_unconditionally_invalid(tSMP_CB * p_cb)1218 BOOLEAN smp_parameter_unconditionally_invalid(tSMP_CB *p_cb)
1219 {
1220 return 0;
1221 }
1222
1223 /*******************************************************************************
1224 **
1225 ** Function smp_reject_unexpected_pairing_command
1226 **
1227 ** Description send pairing failure to an unexpected pairing command during
1228 ** an active pairing process.
1229 **
1230 ** Returns void
1231 **
1232 *******************************************************************************/
smp_reject_unexpected_pairing_command(BD_ADDR bd_addr)1233 void smp_reject_unexpected_pairing_command(BD_ADDR bd_addr)
1234 {
1235 BT_HDR *p_buf;
1236 UINT8 *p;
1237
1238 SMP_TRACE_DEBUG ("%s\n", __FUNCTION__);
1239
1240 if ((p_buf = (BT_HDR *)osi_malloc(sizeof(BT_HDR) + \
1241 SMP_PAIR_FAIL_SIZE + L2CAP_MIN_OFFSET)) != NULL) {
1242 p = (UINT8 *)(p_buf + 1) + L2CAP_MIN_OFFSET;
1243
1244 UINT8_TO_STREAM (p, SMP_OPCODE_PAIRING_FAILED);
1245 UINT8_TO_STREAM (p, SMP_PAIR_NOT_SUPPORT);
1246
1247 p_buf->offset = L2CAP_MIN_OFFSET;
1248 p_buf->len = SMP_PAIR_FAIL_SIZE;
1249
1250 smp_send_msg_to_L2CAP(bd_addr, p_buf);
1251 }
1252 }
1253
1254 /*******************************************************************************
1255 ** Function smp_select_association_model
1256 **
1257 ** Description This function selects association model to use for STK
1258 ** generation. Selection is based on both sides' io capability,
1259 ** oob data flag and authentication request.
1260 **
1261 ** Note If Secure Connections Only mode is required locally then we
1262 ** come to this point only if both sides support Secure Connections
1263 ** mode, i.e. if p_cb->secure_connections_only_mode_required = 1 then we come
1264 ** to this point only if
1265 ** (p_cb->peer_auth_req & SMP_SC_SUPPORT_BIT) ==
1266 ** (p_cb->loc_auth_req & SMP_SC_SUPPORT_BIT) ==
1267 ** SMP_SC_SUPPORT_BIT
1268 **
1269 *******************************************************************************/
smp_select_association_model(tSMP_CB * p_cb)1270 tSMP_ASSO_MODEL smp_select_association_model(tSMP_CB *p_cb)
1271 {
1272 tSMP_ASSO_MODEL model = SMP_MODEL_OUT_OF_RANGE;
1273 p_cb->le_secure_connections_mode_is_used = 0;
1274
1275 SMP_TRACE_EVENT("%s\n", __FUNCTION__);
1276 SMP_TRACE_DEBUG("%s p_cb->peer_io_caps = %d p_cb->local_io_capability = %d\n",
1277 __FUNCTION__, p_cb->peer_io_caps, p_cb->local_io_capability);
1278 SMP_TRACE_DEBUG("%s p_cb->peer_oob_flag = %d p_cb->loc_oob_flag = %d\n",
1279 __FUNCTION__, p_cb->peer_oob_flag, p_cb->loc_oob_flag);
1280 SMP_TRACE_DEBUG("%s p_cb->peer_auth_req = 0x%02x p_cb->loc_auth_req = 0x%02x\n",
1281 __FUNCTION__, p_cb->peer_auth_req, p_cb->loc_auth_req);
1282 SMP_TRACE_DEBUG("%s p_cb->secure_connections_only_mode_required = %s\n",
1283 __FUNCTION__, p_cb->secure_connections_only_mode_required ?
1284 "1" : "0");
1285
1286 if ((p_cb->peer_auth_req & SMP_SC_SUPPORT_BIT) && (p_cb->loc_auth_req & SMP_SC_SUPPORT_BIT)) {
1287 p_cb->le_secure_connections_mode_is_used = 1;
1288 }
1289
1290 SMP_TRACE_DEBUG("use_sc_process = %d\n", p_cb->le_secure_connections_mode_is_used);
1291
1292 if (p_cb->le_secure_connections_mode_is_used) {
1293 model = smp_select_association_model_secure_connections(p_cb);
1294 } else {
1295 model = smp_select_legacy_association_model(p_cb);
1296 }
1297 return model;
1298 }
1299
1300 /*******************************************************************************
1301 ** Function smp_select_legacy_association_model
1302 **
1303 ** Description This function is called to select association mode if at least
1304 ** one side doesn't support secure connections.
1305 **
1306 *******************************************************************************/
smp_select_legacy_association_model(tSMP_CB * p_cb)1307 tSMP_ASSO_MODEL smp_select_legacy_association_model(tSMP_CB *p_cb)
1308 {
1309 tSMP_ASSO_MODEL model = SMP_MODEL_OUT_OF_RANGE;
1310
1311 SMP_TRACE_DEBUG("%s\n", __func__);
1312 /* if OOB data is present on both devices, then use OOB association model */
1313 if (p_cb->peer_oob_flag == SMP_OOB_PRESENT && p_cb->loc_oob_flag == SMP_OOB_PRESENT) {
1314 return SMP_MODEL_OOB;
1315 }
1316
1317 /* else if neither device requires MITM, then use Just Works association model */
1318 if (SMP_NO_MITM_REQUIRED (p_cb->peer_auth_req) && SMP_NO_MITM_REQUIRED(p_cb->loc_auth_req)) {
1319 return SMP_MODEL_ENCRYPTION_ONLY;
1320 }
1321
1322 /* otherwise use IO capability to select association model */
1323 if (p_cb->peer_io_caps < SMP_IO_CAP_MAX && p_cb->local_io_capability < SMP_IO_CAP_MAX) {
1324 if (p_cb->role == HCI_ROLE_MASTER) {
1325 model = smp_association_table[p_cb->role][p_cb->peer_io_caps]
1326 [p_cb->local_io_capability];
1327 } else {
1328 model = smp_association_table[p_cb->role][p_cb->local_io_capability]
1329 [p_cb->peer_io_caps];
1330 }
1331 }
1332
1333 return model;
1334 }
1335
1336 /*******************************************************************************
1337 ** Function smp_select_association_model_secure_connections
1338 **
1339 ** Description This function is called to select association mode if both
1340 ** sides support secure connections.
1341 **
1342 *******************************************************************************/
smp_select_association_model_secure_connections(tSMP_CB * p_cb)1343 tSMP_ASSO_MODEL smp_select_association_model_secure_connections(tSMP_CB *p_cb)
1344 {
1345 tSMP_ASSO_MODEL model = SMP_MODEL_OUT_OF_RANGE;
1346
1347 SMP_TRACE_DEBUG("%s\n", __func__);
1348 /* if OOB data is present on at least one device, then use OOB association model */
1349 if (p_cb->peer_oob_flag == SMP_OOB_PRESENT || p_cb->loc_oob_flag == SMP_OOB_PRESENT) {
1350 return SMP_MODEL_SEC_CONN_OOB;
1351 }
1352
1353 /* else if neither device requires MITM, then use Just Works association model */
1354 if (SMP_NO_MITM_REQUIRED (p_cb->peer_auth_req) && SMP_NO_MITM_REQUIRED(p_cb->loc_auth_req)) {
1355 return SMP_MODEL_SEC_CONN_JUSTWORKS;
1356 }
1357
1358 /* otherwise use IO capability to select association model */
1359 if (p_cb->peer_io_caps < SMP_IO_CAP_MAX && p_cb->local_io_capability < SMP_IO_CAP_MAX) {
1360 if (p_cb->role == HCI_ROLE_MASTER) {
1361 model = smp_association_table_sc[p_cb->role][p_cb->peer_io_caps]
1362 [p_cb->local_io_capability];
1363 } else {
1364 model = smp_association_table_sc[p_cb->role][p_cb->local_io_capability]
1365 [p_cb->peer_io_caps];
1366 }
1367 }
1368
1369 return model;
1370 }
1371
1372 /*******************************************************************************
1373 ** Function smp_reverse_array
1374 **
1375 ** Description This function reverses array bytes
1376 **
1377 *******************************************************************************/
smp_reverse_array(UINT8 * arr,UINT8 len)1378 void smp_reverse_array(UINT8 *arr, UINT8 len)
1379 {
1380 UINT8 i = 0, tmp;
1381
1382 SMP_TRACE_DEBUG("smp_reverse_array\n");
1383
1384 for (i = 0; i < len / 2; i ++) {
1385 tmp = arr[i];
1386 arr[i] = arr[len - 1 - i];
1387 arr[len - 1 - i] = tmp;
1388 }
1389 }
1390
1391 /*******************************************************************************
1392 ** Function smp_calculate_random_input
1393 **
1394 ** Description This function returns random input value to be used in commitment
1395 ** calculation for SC passkey entry association mode
1396 ** (if bit["round"] in "random" array == 1 then returns 0x81
1397 ** else returns 0x80).
1398 **
1399 ** Returns ri value
1400 **
1401 *******************************************************************************/
smp_calculate_random_input(UINT8 * random,UINT8 round)1402 UINT8 smp_calculate_random_input(UINT8 *random, UINT8 round)
1403 {
1404 UINT8 i = round / 8;
1405 UINT8 j = round % 8;
1406 UINT8 ri;
1407
1408 SMP_TRACE_DEBUG("random: 0x%02x, round: %d, i: %d, j: %d\n", random[i], round, i, j);
1409 ri = ((random[i] >> j) & 1) | 0x80;
1410 SMP_TRACE_DEBUG("%s ri=0x%02x\n", __func__, ri);
1411 return ri;
1412 }
1413
1414 /*******************************************************************************
1415 ** Function smp_collect_local_io_capabilities
1416 **
1417 ** Description This function puts into IOcap array local device
1418 ** IOCapability, OOB data, AuthReq.
1419 **
1420 ** Returns void
1421 **
1422 *******************************************************************************/
smp_collect_local_io_capabilities(UINT8 * iocap,tSMP_CB * p_cb)1423 void smp_collect_local_io_capabilities(UINT8 *iocap, tSMP_CB *p_cb)
1424 {
1425 SMP_TRACE_DEBUG("%s\n", __func__);
1426
1427 iocap[0] = p_cb->local_io_capability;
1428 iocap[1] = p_cb->loc_oob_flag;
1429 iocap[2] = p_cb->loc_auth_req;
1430 }
1431
1432 /*******************************************************************************
1433 ** Function smp_collect_peer_io_capabilities
1434 **
1435 ** Description This function puts into IOcap array peer device
1436 ** IOCapability, OOB data, AuthReq.
1437 **
1438 ** Returns void
1439 **
1440 *******************************************************************************/
smp_collect_peer_io_capabilities(UINT8 * iocap,tSMP_CB * p_cb)1441 void smp_collect_peer_io_capabilities(UINT8 *iocap, tSMP_CB *p_cb)
1442 {
1443 SMP_TRACE_DEBUG("%s\n", __func__);
1444
1445 iocap[0] = p_cb->peer_io_caps;
1446 iocap[1] = p_cb->peer_oob_flag;
1447 iocap[2] = p_cb->peer_auth_req;
1448 }
1449 #if (BLE_INCLUDED == 1)
1450 /*******************************************************************************
1451 ** Function smp_collect_local_ble_address
1452 **
1453 ** Description This function puts into le_addr array local device le address:
1454 ** le_addr[0-5] = local BD ADDR,
1455 ** le_addr[6] = local le address type (PUBLIC/RANDOM).
1456 **
1457 ** Returns void
1458 **
1459 *******************************************************************************/
smp_collect_local_ble_address(UINT8 * le_addr,tSMP_CB * p_cb)1460 void smp_collect_local_ble_address(UINT8 *le_addr, tSMP_CB *p_cb)
1461 {
1462 tBLE_ADDR_TYPE addr_type = 0;
1463 BD_ADDR bda;
1464 UINT8 *p = le_addr;
1465
1466 SMP_TRACE_DEBUG("%s\n", __func__);
1467
1468 BTM_ReadConnectionAddr( p_cb->pairing_bda, bda, &addr_type);
1469 BDADDR_TO_STREAM(p, bda);
1470 UINT8_TO_STREAM(p, addr_type);
1471 }
1472
1473 /*******************************************************************************
1474 ** Function smp_collect_peer_ble_address
1475 **
1476 ** Description This function puts into le_addr array peer device le address:
1477 ** le_addr[0-5] = peer BD ADDR,
1478 ** le_addr[6] = peer le address type (PUBLIC/RANDOM).
1479 **
1480 ** Returns void
1481 **
1482 *******************************************************************************/
smp_collect_peer_ble_address(UINT8 * le_addr,tSMP_CB * p_cb)1483 void smp_collect_peer_ble_address(UINT8 *le_addr, tSMP_CB *p_cb)
1484 {
1485 tBLE_ADDR_TYPE addr_type = 0;
1486 BD_ADDR bda;
1487 UINT8 *p = le_addr;
1488
1489 SMP_TRACE_DEBUG("%s\n", __func__);
1490
1491 if (!BTM_ReadRemoteConnectionAddr(p_cb->pairing_bda, bda, &addr_type)) {
1492 SMP_TRACE_ERROR("can not collect peer le addr information for unknown device\n");
1493 return;
1494 }
1495
1496 BDADDR_TO_STREAM(p, bda);
1497 UINT8_TO_STREAM(p, addr_type);
1498 }
1499
1500 /*******************************************************************************
1501 ** Function smp_check_commitment
1502 **
1503 ** Description This function compares peer commitment values:
1504 ** - expected (i.e. calculated locally),
1505 ** - received from the peer.
1506 **
1507 ** Returns 1 if the values are the same
1508 ** 0 otherwise
1509 **
1510 *******************************************************************************/
smp_check_commitment(tSMP_CB * p_cb)1511 BOOLEAN smp_check_commitment(tSMP_CB *p_cb)
1512 {
1513 BT_OCTET16 expected;
1514
1515 SMP_TRACE_DEBUG("%s\n", __func__);
1516
1517 smp_calculate_peer_commitment(p_cb, expected);
1518 print128(expected, (const UINT8 *)"calculated peer commitment");
1519 print128(p_cb->remote_commitment, (const UINT8 *)"received peer commitment");
1520
1521 if (memcmp(p_cb->remote_commitment, expected, BT_OCTET16_LEN)) {
1522 SMP_TRACE_WARNING("Commitment check fails\n");
1523 return 0;
1524 }
1525
1526 SMP_TRACE_DEBUG("Commitment check succeeds\n");
1527 return 1;
1528 }
1529
1530 /*******************************************************************************
1531 **
1532 ** Function smp_save_secure_connections_long_term_key
1533 **
1534 ** Description The function saves SC LTK as BLE key for future use as local
1535 ** and/or peer key.
1536 **
1537 ** Returns void
1538 **
1539 *******************************************************************************/
smp_save_secure_connections_long_term_key(tSMP_CB * p_cb)1540 void smp_save_secure_connections_long_term_key(tSMP_CB *p_cb)
1541 {
1542 tBTM_LE_LENC_KEYS lle_key;
1543 tBTM_LE_PENC_KEYS ple_key;
1544
1545 SMP_TRACE_DEBUG("%s-Save LTK as local LTK key\n", __func__);
1546 memcpy(lle_key.ltk, p_cb->ltk, BT_OCTET16_LEN);
1547 lle_key.div = 0;
1548 lle_key.key_size = p_cb->loc_enc_size;
1549 lle_key.sec_level = p_cb->sec_level;
1550 btm_sec_save_le_key(p_cb->pairing_bda, BTM_LE_KEY_LENC, (tBTM_LE_KEY_VALUE *)&lle_key, 1);
1551
1552 SMP_TRACE_DEBUG("%s-Save LTK as peer LTK key\n", __func__);
1553 ple_key.ediv = 0;
1554 memset(ple_key.rand, 0, BT_OCTET8_LEN);
1555 memcpy(ple_key.ltk, p_cb->ltk, BT_OCTET16_LEN);
1556 ple_key.sec_level = p_cb->sec_level;
1557 ple_key.key_size = p_cb->loc_enc_size;
1558 btm_sec_save_le_key(p_cb->pairing_bda, BTM_LE_KEY_PENC, (tBTM_LE_KEY_VALUE *)&ple_key, 1);
1559 }
1560
1561 /*******************************************************************************
1562 **
1563 ** Function smp_calculate_f5_mackey_and_long_term_key
1564 **
1565 ** Description The function calculates MacKey and LTK and saves them in CB.
1566 ** To calculate MacKey and LTK it calls smp_calc_f5(...).
1567 ** MacKey is used in dhkey calculation, LTK is used to encrypt
1568 ** the link.
1569 **
1570 ** Returns 0 if out of resources, 1 otherwise.
1571 **
1572 *******************************************************************************/
smp_calculate_f5_mackey_and_long_term_key(tSMP_CB * p_cb)1573 BOOLEAN smp_calculate_f5_mackey_and_long_term_key(tSMP_CB *p_cb)
1574 {
1575 UINT8 a[7];
1576 UINT8 b[7];
1577 UINT8 *p_na;
1578 UINT8 *p_nb;
1579
1580 SMP_TRACE_DEBUG("%s\n", __func__);
1581
1582 if (p_cb->role == HCI_ROLE_MASTER) {
1583 smp_collect_local_ble_address(a, p_cb);
1584 smp_collect_peer_ble_address(b, p_cb);
1585 p_na = p_cb->rand;
1586 p_nb = p_cb->rrand;
1587 } else {
1588 smp_collect_local_ble_address(b, p_cb);
1589 smp_collect_peer_ble_address(a, p_cb);
1590 p_na = p_cb->rrand;
1591 p_nb = p_cb->rand;
1592 }
1593
1594 if (!smp_calculate_f5(p_cb->dhkey, p_na, p_nb, a, b, p_cb->mac_key, p_cb->ltk)) {
1595 SMP_TRACE_ERROR("%s failed\n", __func__);
1596 return 0;
1597 }
1598
1599 SMP_TRACE_EVENT ("%s is completed\n", __func__);
1600 return 1;
1601 }
1602 #endif ///BLE_INCLUDED == 1
1603 /*******************************************************************************
1604 **
1605 ** Function smp_request_oob_data
1606 **
1607 ** Description Requests application to provide OOB data.
1608 **
1609 ** Returns 1 - OOB data has to be provided by application
1610 ** 0 - otherwise (unexpected)
1611 **
1612 *******************************************************************************/
smp_request_oob_data(tSMP_CB * p_cb)1613 BOOLEAN smp_request_oob_data(tSMP_CB *p_cb)
1614 {
1615 tSMP_OOB_DATA_TYPE req_oob_type = SMP_OOB_INVALID_TYPE;
1616
1617 SMP_TRACE_DEBUG("%s\n", __func__);
1618
1619 if (p_cb->peer_oob_flag == SMP_OOB_PRESENT && p_cb->loc_oob_flag == SMP_OOB_PRESENT) {
1620 /* both local and peer rcvd data OOB */
1621 req_oob_type = SMP_OOB_BOTH;
1622 } else if (p_cb->peer_oob_flag == SMP_OOB_PRESENT) {
1623 /* peer rcvd OOB local data, local didn't receive OOB peer data */
1624 req_oob_type = SMP_OOB_LOCAL;
1625 } else if (p_cb->loc_oob_flag == SMP_OOB_PRESENT) {
1626 req_oob_type = SMP_OOB_PEER;
1627 }
1628
1629 SMP_TRACE_DEBUG("req_oob_type = %d\n", req_oob_type);
1630
1631 if (req_oob_type == SMP_OOB_INVALID_TYPE) {
1632 return 0;
1633 }
1634
1635 p_cb->req_oob_type = req_oob_type;
1636 p_cb->cb_evt = SMP_SC_OOB_REQ_EVT;
1637 smp_sm_event(p_cb, SMP_TK_REQ_EVT, &req_oob_type);
1638
1639 return 1;
1640 }
1641
1642
1643 #endif
1644