smp_main.cc 39 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038
  1. /******************************************************************************
  2. *
  3. * Copyright 2003-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. #include "bt_target.h"
  19. #include <log/log.h>
  20. #include <string.h>
  21. #include "smp_int.h"
  22. const char* const smp_state_name[] = {
  23. "SMP_STATE_IDLE",
  24. "SMP_STATE_WAIT_APP_RSP",
  25. "SMP_STATE_SEC_REQ_PENDING",
  26. "SMP_STATE_PAIR_REQ_RSP",
  27. "SMP_STATE_WAIT_CONFIRM",
  28. "SMP_STATE_CONFIRM",
  29. "SMP_STATE_RAND",
  30. "SMP_STATE_PUBLIC_KEY_EXCH",
  31. "SMP_STATE_SEC_CONN_PHS1_START",
  32. "SMP_STATE_WAIT_COMMITMENT",
  33. "SMP_STATE_WAIT_NONCE",
  34. "SMP_STATE_SEC_CONN_PHS2_START",
  35. "SMP_STATE_WAIT_DHK_CHECK",
  36. "SMP_STATE_DHK_CHECK",
  37. "SMP_STATE_ENCRYPTION_PENDING",
  38. "SMP_STATE_BOND_PENDING",
  39. "SMP_STATE_CREATE_LOCAL_SEC_CONN_OOB_DATA",
  40. "SMP_STATE_MAX"};
  41. const char* const smp_event_name[] = {"PAIRING_REQ_EVT",
  42. "PAIRING_RSP_EVT",
  43. "CONFIRM_EVT",
  44. "RAND_EVT",
  45. "PAIRING_FAILED_EVT",
  46. "ENC_INFO_EVT",
  47. "MASTER_ID_EVT",
  48. "ID_INFO_EVT",
  49. "ID_ADDR_EVT",
  50. "SIGN_INFO_EVT",
  51. "SECURITY_REQ_EVT",
  52. "PAIR_PUBLIC_KEY_EVT",
  53. "PAIR_DHKEY_CHECK_EVT",
  54. "PAIR_KEYPRESS_NOTIFICATION_EVT",
  55. "PAIR_COMMITMENT_EVT",
  56. "KEY_READY_EVT",
  57. "ENCRYPTED_EVT",
  58. "L2CAP_CONN_EVT",
  59. "L2CAP_DISCONN_EVT",
  60. "API_IO_RSP_EVT",
  61. "API_SEC_GRANT_EVT",
  62. "TK_REQ_EVT",
  63. "AUTH_CMPL_EVT",
  64. "ENC_REQ_EVT",
  65. "BOND_REQ_EVT",
  66. "DISCARD_SEC_REQ_EVT",
  67. "PUBLIC_KEY_EXCHANGE_REQ_EVT",
  68. "LOCAL_PUBLIC_KEY_CRTD_EVT",
  69. "BOTH_PUBLIC_KEYS_RCVD_EVT",
  70. "SEC_CONN_DHKEY_COMPLETE_EVT",
  71. "HAVE_LOCAL_NONCE_EVT",
  72. "SEC_CONN_PHASE1_CMPLT_EVT",
  73. "SEC_CONN_CALC_NC_EVT",
  74. "SEC_CONN_DISPLAY_NC_EVT",
  75. "SEC_CONN_OK_EVT",
  76. "SEC_CONN_2_DHCK_CHECKS_PRESENT_EVT",
  77. "SEC_CONN_KEY_READY_EVT",
  78. "KEYPRESS_NOTIFICATION_EVT",
  79. "SEC_CONN_OOB_DATA_EVT",
  80. "CREATE_LOCAL_SEC_CONN_OOB_DATA_EVT",
  81. "OUT_OF_RANGE_EVT"};
  82. const char* smp_get_event_name(tSMP_EVENT event);
  83. const char* smp_get_state_name(tSMP_STATE state);
  84. #define SMP_SM_IGNORE 0
  85. #define SMP_NUM_ACTIONS 2
  86. #define SMP_SME_NEXT_STATE 2
  87. #define SMP_SM_NUM_COLS 3
  88. typedef const uint8_t (*tSMP_SM_TBL)[SMP_SM_NUM_COLS];
  89. enum {
  90. SMP_PROC_SEC_REQ,
  91. SMP_SEND_PAIR_REQ,
  92. SMP_SEND_PAIR_RSP,
  93. SMP_SEND_CONFIRM,
  94. SMP_SEND_PAIR_FAIL,
  95. SMP_SEND_RAND,
  96. SMP_SEND_ENC_INFO,
  97. SMP_SEND_ID_INFO,
  98. SMP_SEND_LTK_REPLY,
  99. SMP_PROC_PAIR_CMD,
  100. SMP_PROC_PAIR_FAIL,
  101. SMP_PROC_CONFIRM,
  102. SMP_PROC_RAND,
  103. SMP_PROC_ENC_INFO,
  104. SMP_PROC_MASTER_ID,
  105. SMP_PROC_ID_INFO,
  106. SMP_PROC_ID_ADDR,
  107. SMP_PROC_SRK_INFO,
  108. SMP_PROC_SEC_GRANT,
  109. SMP_PROC_SL_KEY,
  110. SMP_PROC_COMPARE,
  111. SMP_PROC_IO_RSP,
  112. SMP_GENERATE_COMPARE,
  113. SMP_GENERATE_CONFIRM,
  114. SMP_GENERATE_STK,
  115. SMP_KEY_DISTRIBUTE,
  116. SMP_START_ENC,
  117. SMP_PAIRING_CMPL,
  118. SMP_DECIDE_ASSO_MODEL,
  119. SMP_SEND_APP_CBACK,
  120. SMP_CHECK_AUTH_REQ,
  121. SMP_PAIR_TERMINATE,
  122. SMP_ENC_CMPL,
  123. SMP_PROC_DISCARD,
  124. SMP_CREATE_PRIVATE_KEY,
  125. SMP_USE_OOB_PRIVATE_KEY,
  126. SMP_SEND_PAIR_PUBLIC_KEY,
  127. SMP_PROCESS_PAIR_PUBLIC_KEY,
  128. SMP_HAVE_BOTH_PUBLIC_KEYS,
  129. SMP_START_SEC_CONN_PHASE1,
  130. SMP_PROCESS_LOCAL_NONCE,
  131. SMP_SEND_COMMITMENT,
  132. SMP_PROCESS_PAIRING_COMMITMENT,
  133. SMP_PROCESS_PEER_NONCE,
  134. SMP_CALCULATE_LOCAL_DHKEY_CHECK,
  135. SMP_SEND_DHKEY_CHECK,
  136. SMP_PROCESS_DHKEY_CHECK,
  137. SMP_CALCULATE_PEER_DHKEY_CHECK,
  138. SMP_MATCH_DHKEY_CHECKS,
  139. SMP_CALCULATE_NUMERIC_COMPARISON_DISPLAY_NUMBER,
  140. SMP_MOVE_TO_SEC_CONN_PHASE2,
  141. SMP_PH2_DHKEY_CHECKS_ARE_PRESENT,
  142. SMP_WAIT_FOR_BOTH_PUBLIC_KEYS,
  143. SMP_START_PASSKEY_VERIFICATION,
  144. SMP_SEND_KEYPRESS_NOTIFICATION,
  145. SMP_PROCESS_KEYPRESS_NOTIFICATION,
  146. SMP_PROCESS_SECURE_CONNECTION_OOB_DATA,
  147. SMP_SET_LOCAL_OOB_KEYS,
  148. SMP_SET_LOCAL_OOB_RAND_COMMITMENT,
  149. SMP_IDLE_TERMINATE,
  150. SMP_SM_NO_ACTION
  151. };
  152. static const tSMP_ACT smp_sm_action[] = {
  153. smp_proc_sec_req,
  154. smp_send_pair_req,
  155. smp_send_pair_rsp,
  156. smp_send_confirm,
  157. smp_send_pair_fail,
  158. smp_send_rand,
  159. smp_send_enc_info,
  160. smp_send_id_info,
  161. smp_send_ltk_reply,
  162. smp_proc_pair_cmd,
  163. smp_proc_pair_fail,
  164. smp_proc_confirm,
  165. smp_proc_rand,
  166. smp_proc_enc_info,
  167. smp_proc_master_id,
  168. smp_proc_id_info,
  169. smp_proc_id_addr,
  170. smp_proc_srk_info,
  171. smp_proc_sec_grant,
  172. smp_proc_sl_key,
  173. smp_proc_compare,
  174. smp_process_io_response,
  175. smp_generate_compare,
  176. smp_generate_srand_mrand_confirm,
  177. smp_generate_stk,
  178. smp_key_distribution,
  179. smp_start_enc,
  180. smp_pairing_cmpl,
  181. smp_decide_association_model,
  182. smp_send_app_cback,
  183. smp_check_auth_req,
  184. smp_pair_terminate,
  185. smp_enc_cmpl,
  186. smp_proc_discard,
  187. smp_create_private_key,
  188. smp_use_oob_private_key,
  189. smp_send_pair_public_key,
  190. smp_process_pairing_public_key,
  191. smp_both_have_public_keys,
  192. smp_start_secure_connection_phase1,
  193. smp_process_local_nonce,
  194. smp_send_commitment,
  195. smp_process_pairing_commitment,
  196. smp_process_peer_nonce,
  197. smp_calculate_local_dhkey_check,
  198. smp_send_dhkey_check,
  199. smp_process_dhkey_check,
  200. smp_calculate_peer_dhkey_check,
  201. smp_match_dhkey_checks,
  202. smp_calculate_numeric_comparison_display_number,
  203. smp_move_to_secure_connections_phase2,
  204. smp_phase_2_dhkey_checks_are_present,
  205. smp_wait_for_both_public_keys,
  206. smp_start_passkey_verification,
  207. smp_send_keypress_notification,
  208. smp_process_keypress_notification,
  209. smp_process_secure_connection_oob_data,
  210. smp_set_local_oob_keys,
  211. smp_set_local_oob_random_commitment,
  212. smp_idle_terminate};
  213. /************ SMP Master FSM State/Event Indirection Table **************/
  214. static const uint8_t smp_master_entry_map[][SMP_STATE_MAX] = {
  215. /* state name: */
  216. /* Idle, WaitApp Rsp, SecReq Pend, Pair ReqRsp, Wait Cfm, Confirm, Rand,
  217. PublKey Exch, SCPhs1 Strt, Wait Cmtm, Wait Nonce, SCPhs2 Strt, Wait
  218. DHKChk, DHKChk, Enc Pend, Bond Pend, CrLocSc OobData */
  219. /* PAIR_REQ */
  220. {0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0},
  221. /* PAIR_RSP */
  222. {0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0},
  223. /* CONFIRM */
  224. {0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0},
  225. /* RAND */
  226. {0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0},
  227. /* PAIR_FAIL */
  228. {0, 0x81, 0, 0x81, 0x81, 0x81, 0x81, 0x81, 0x81, 0x81, 0x81, 0x81, 0x81,
  229. 0x81, 0, 0x81, 0},
  230. /* ENC_INFO */
  231. {0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0},
  232. /* MASTER_ID */
  233. {0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 4, 0},
  234. /* ID_INFO */
  235. {0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 2, 0},
  236. /* ID_ADDR */
  237. {0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 5, 0},
  238. /* SIGN_INFO */
  239. {0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 3, 0},
  240. /* SEC_REQ */
  241. {2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0},
  242. /* PAIR_PUBLIC_KEY */
  243. {0, 0, 0, 0, 0, 0, 0, 2, 0, 0, 0, 0, 0, 0, 0, 0, 0},
  244. /* PAIR_DHKEY_CHCK */
  245. {0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0},
  246. /* PAIR_KEYPR_NOTIF */
  247. {0, 8, 0, 0, 0, 0, 0, 0, 5, 2, 0, 0, 0, 0, 0, 0, 0},
  248. /* PAIR_COMMITM */
  249. {0, 0, 0, 0, 0, 0, 0, 0, 6, 1, 0, 0, 0, 0, 0, 0, 0},
  250. /* KEY_READY */
  251. {0, 3, 0, 3, 1, 0, 2, 0, 4, 0, 0, 0, 0, 0, 1, 6, 0},
  252. /* ENC_CMPL */
  253. {0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 2, 0, 0},
  254. /* L2C_CONN */
  255. {1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0},
  256. /* L2C_DISC */
  257. {3, 0x83, 0, 0x83, 0x83, 0x83, 0x83, 0x83, 0x83, 0x83, 0x83, 0x83, 0x83,
  258. 0x83, 0x83, 0x83, 0},
  259. /* IO_RSP */
  260. {0, 2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0},
  261. /* SEC_GRANT */
  262. {0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0},
  263. /* TK_REQ */
  264. {0, 0, 0, 2, 0, 0, 0, 0, 3, 0, 0, 0, 0, 0, 0, 0, 0},
  265. /* AUTH_CMPL */
  266. {4, 0x82, 0, 0x82, 0x82, 0x82, 0x82, 0x82, 0x82, 0x82, 0x82, 0x82, 0x82,
  267. 0x82, 0x82, 0x82, 0},
  268. /* ENC_REQ */
  269. {0, 4, 0, 0, 0, 0, 3, 0, 0, 0, 0, 0, 0, 2, 0, 0, 0},
  270. /* BOND_REQ */
  271. {0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 3, 0, 0},
  272. /* DISCARD_SEC_REQ */
  273. {0, 5, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 3, 0, 0},
  274. /* PUBL_KEY_EXCH_REQ */
  275. {0, 0, 0, 4, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0},
  276. /* LOC_PUBL_KEY_CRTD */
  277. {0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1},
  278. /* BOTH_PUBL_KEYS_RCVD */
  279. {0, 0, 0, 0, 0, 0, 0, 3, 0, 0, 0, 0, 0, 0, 0, 0, 0},
  280. /* SC_DHKEY_CMPLT */
  281. {0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0},
  282. /* HAVE_LOC_NONCE */
  283. {0, 0, 0, 0, 0, 0, 0, 0, 2, 0, 0, 0, 0, 0, 0, 0, 2},
  284. /* SC_PHASE1_CMPLT */
  285. {0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0},
  286. /* SC_CALC_NC */
  287. {0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 2, 0, 0, 0, 0, 0, 0},
  288. /* SC_DSPL_NC */
  289. {0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 3, 0, 0, 0, 0, 0, 0},
  290. /* SC_NC_OK */
  291. {0, 6, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0},
  292. /* SC_2_DHCK_CHKS_PRES */
  293. {0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0},
  294. /* SC_KEY_READY */
  295. {0, 7, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0},
  296. /* KEYPR_NOTIF */
  297. {0, 9, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0},
  298. /* SC_OOB_DATA */
  299. {0, 10, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0},
  300. /* CR_LOC_SC_OOB_DATA */
  301. {5, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0},
  302. };
  303. static const uint8_t smp_all_table[][SMP_SM_NUM_COLS] = {
  304. /* Event Action Next State */
  305. /* PAIR_FAIL */
  306. {SMP_PROC_PAIR_FAIL, SMP_PAIRING_CMPL, SMP_STATE_IDLE},
  307. /* AUTH_CMPL */
  308. {SMP_SEND_PAIR_FAIL, SMP_PAIRING_CMPL, SMP_STATE_IDLE},
  309. /* L2C_DISC */
  310. {SMP_PAIR_TERMINATE, SMP_SM_NO_ACTION, SMP_STATE_IDLE}};
  311. static const uint8_t smp_master_idle_table[][SMP_SM_NUM_COLS] = {
  312. /* Event Action Next State */
  313. /* L2C_CONN */
  314. {SMP_SEND_APP_CBACK, SMP_SM_NO_ACTION, SMP_STATE_WAIT_APP_RSP},
  315. /* SEC_REQ */
  316. {SMP_PROC_SEC_REQ, SMP_SEND_APP_CBACK, SMP_STATE_WAIT_APP_RSP},
  317. /* L2C_DISC */
  318. {SMP_IDLE_TERMINATE, SMP_SM_NO_ACTION, SMP_STATE_IDLE},
  319. /* AUTH_CMPL */
  320. {SMP_PAIRING_CMPL, SMP_SM_NO_ACTION, SMP_STATE_IDLE},
  321. /* CR_LOC_SC_OOB_DATA */
  322. {SMP_CREATE_PRIVATE_KEY, SMP_SM_NO_ACTION,
  323. SMP_STATE_CREATE_LOCAL_SEC_CONN_OOB_DATA}
  324. };
  325. static const uint8_t smp_master_wait_for_app_response_table[][SMP_SM_NUM_COLS] =
  326. {
  327. /* Event Action Next State */
  328. /* SEC_GRANT */
  329. {SMP_PROC_SEC_GRANT, SMP_SEND_APP_CBACK, SMP_STATE_WAIT_APP_RSP},
  330. /* IO_RSP */
  331. {SMP_SEND_PAIR_REQ, SMP_SM_NO_ACTION, SMP_STATE_PAIR_REQ_RSP},
  332. /* TK ready */
  333. /* KEY_READY */
  334. {SMP_GENERATE_CONFIRM, SMP_SM_NO_ACTION, SMP_STATE_WAIT_CONFIRM},
  335. /* start enc mode setup */
  336. /* ENC_REQ */
  337. {SMP_START_ENC, SMP_SM_NO_ACTION, SMP_STATE_ENCRYPTION_PENDING},
  338. /* DISCARD_SEC_REQ */
  339. {SMP_PROC_DISCARD, SMP_SM_NO_ACTION, SMP_STATE_IDLE}
  340. /* user confirms NC 'OK', i.e. phase 1 is completed */
  341. /* SC_NC_OK */,
  342. {SMP_MOVE_TO_SEC_CONN_PHASE2, SMP_SM_NO_ACTION,
  343. SMP_STATE_SEC_CONN_PHS2_START},
  344. /* user-provided passkey is rcvd */
  345. /* SC_KEY_READY */
  346. {SMP_START_PASSKEY_VERIFICATION, SMP_SM_NO_ACTION,
  347. SMP_STATE_SEC_CONN_PHS1_START},
  348. /* PAIR_KEYPR_NOTIF */
  349. {SMP_PROCESS_KEYPRESS_NOTIFICATION, SMP_SEND_APP_CBACK,
  350. SMP_STATE_WAIT_APP_RSP},
  351. /* KEYPR_NOTIF */
  352. {SMP_SEND_KEYPRESS_NOTIFICATION, SMP_SM_NO_ACTION,
  353. SMP_STATE_WAIT_APP_RSP},
  354. /* SC_OOB_DATA */
  355. {SMP_USE_OOB_PRIVATE_KEY, SMP_SM_NO_ACTION, SMP_STATE_PUBLIC_KEY_EXCH}};
  356. static const uint8_t smp_master_pair_request_response_table[][SMP_SM_NUM_COLS] =
  357. {
  358. /* Event Action Next State */
  359. /* PAIR_RSP */
  360. {SMP_PROC_PAIR_CMD, SMP_SM_NO_ACTION, SMP_STATE_PAIR_REQ_RSP},
  361. /* TK_REQ */
  362. {SMP_SEND_APP_CBACK, SMP_SM_NO_ACTION, SMP_STATE_WAIT_APP_RSP},
  363. /* TK ready */
  364. /* KEY_READY */
  365. {SMP_GENERATE_CONFIRM, SMP_SM_NO_ACTION, SMP_STATE_WAIT_CONFIRM}
  366. /* PUBL_KEY_EXCH_REQ */,
  367. {SMP_CREATE_PRIVATE_KEY, SMP_SM_NO_ACTION, SMP_STATE_PUBLIC_KEY_EXCH}};
  368. static const uint8_t smp_master_wait_for_confirm_table[][SMP_SM_NUM_COLS] = {
  369. /* Event Action Next State */
  370. /* KEY_READY*/
  371. /* CONFIRM ready */
  372. {SMP_SEND_CONFIRM, SMP_SM_NO_ACTION, SMP_STATE_CONFIRM}};
  373. static const uint8_t smp_master_confirm_table[][SMP_SM_NUM_COLS] = {
  374. /* Event Action Next State */
  375. /* CONFIRM */
  376. {SMP_PROC_CONFIRM, SMP_SEND_RAND, SMP_STATE_RAND}};
  377. static const uint8_t smp_master_rand_table[][SMP_SM_NUM_COLS] = {
  378. /* Event Action Next State */
  379. /* RAND */
  380. {SMP_PROC_RAND, SMP_GENERATE_COMPARE, SMP_STATE_RAND},
  381. /* KEY_READY */
  382. {SMP_PROC_COMPARE, SMP_SM_NO_ACTION, SMP_STATE_RAND}, /* Compare ready */
  383. /* ENC_REQ */
  384. {SMP_GENERATE_STK, SMP_SM_NO_ACTION, SMP_STATE_ENCRYPTION_PENDING}};
  385. static const uint8_t smp_master_public_key_exchange_table[][SMP_SM_NUM_COLS] = {
  386. /* Event Action Next State */
  387. /* LOC_PUBL_KEY_CRTD */
  388. {SMP_SEND_PAIR_PUBLIC_KEY, SMP_SM_NO_ACTION, SMP_STATE_PUBLIC_KEY_EXCH},
  389. /* PAIR_PUBLIC_KEY */
  390. {SMP_PROCESS_PAIR_PUBLIC_KEY, SMP_SM_NO_ACTION, SMP_STATE_PUBLIC_KEY_EXCH},
  391. /* BOTH_PUBL_KEYS_RCVD */
  392. {SMP_HAVE_BOTH_PUBLIC_KEYS, SMP_SM_NO_ACTION,
  393. SMP_STATE_SEC_CONN_PHS1_START},
  394. };
  395. static const uint8_t smp_master_sec_conn_phs1_start_table[][SMP_SM_NUM_COLS] = {
  396. /* Event Action Next State */
  397. /* SC_DHKEY_CMPLT */
  398. {SMP_START_SEC_CONN_PHASE1, SMP_SM_NO_ACTION,
  399. SMP_STATE_SEC_CONN_PHS1_START},
  400. /* HAVE_LOC_NONCE */
  401. {SMP_PROCESS_LOCAL_NONCE, SMP_SM_NO_ACTION, SMP_STATE_WAIT_COMMITMENT},
  402. /* TK_REQ */
  403. {SMP_SEND_APP_CBACK, SMP_SM_NO_ACTION, SMP_STATE_WAIT_APP_RSP},
  404. /* SMP_MODEL_SEC_CONN_PASSKEY_DISP model, passkey is sent up to display,*/
  405. /* It's time to start commitment calculation */
  406. /* KEY_READY */
  407. {SMP_START_PASSKEY_VERIFICATION, SMP_SM_NO_ACTION,
  408. SMP_STATE_SEC_CONN_PHS1_START},
  409. /* PAIR_KEYPR_NOTIF */
  410. {SMP_PROCESS_KEYPRESS_NOTIFICATION, SMP_SEND_APP_CBACK,
  411. SMP_STATE_SEC_CONN_PHS1_START},
  412. /* PAIR_COMMITM */
  413. {SMP_PROCESS_PAIRING_COMMITMENT, SMP_SM_NO_ACTION,
  414. SMP_STATE_SEC_CONN_PHS1_START},
  415. };
  416. static const uint8_t smp_master_wait_commitment_table[][SMP_SM_NUM_COLS] = {
  417. /* Event Action Next State */
  418. /* PAIR_COMMITM */
  419. {SMP_PROCESS_PAIRING_COMMITMENT, SMP_SEND_RAND, SMP_STATE_WAIT_NONCE},
  420. /* PAIR_KEYPR_NOTIF */
  421. {SMP_PROCESS_KEYPRESS_NOTIFICATION, SMP_SEND_APP_CBACK,
  422. SMP_STATE_WAIT_COMMITMENT},
  423. };
  424. static const uint8_t smp_master_wait_nonce_table[][SMP_SM_NUM_COLS] = {
  425. /* Event Action Next State */
  426. /* peer nonce is received */
  427. /* RAND */
  428. {SMP_PROC_RAND, SMP_PROCESS_PEER_NONCE, SMP_STATE_SEC_CONN_PHS2_START},
  429. /* NC model, time to calculate number for NC */
  430. /* SC_CALC_NC */
  431. {SMP_CALCULATE_NUMERIC_COMPARISON_DISPLAY_NUMBER, SMP_SM_NO_ACTION,
  432. SMP_STATE_WAIT_NONCE},
  433. /* NC model, time to display calculated number for NC to the user */
  434. /* SC_DSPL_NC */
  435. {SMP_SEND_APP_CBACK, SMP_SM_NO_ACTION, SMP_STATE_WAIT_APP_RSP},
  436. };
  437. static const uint8_t smp_master_sec_conn_phs2_start_table[][SMP_SM_NUM_COLS] = {
  438. /* Event Action Next State */
  439. /* SC_PHASE1_CMPLT */
  440. {SMP_CALCULATE_LOCAL_DHKEY_CHECK, SMP_SEND_DHKEY_CHECK,
  441. SMP_STATE_WAIT_DHK_CHECK},
  442. };
  443. static const uint8_t smp_master_wait_dhk_check_table[][SMP_SM_NUM_COLS] = {
  444. /* Event Action Next State */
  445. /* PAIR_DHKEY_CHCK */
  446. {SMP_PROCESS_DHKEY_CHECK, SMP_CALCULATE_PEER_DHKEY_CHECK,
  447. SMP_STATE_DHK_CHECK},
  448. };
  449. static const uint8_t smp_master_dhk_check_table[][SMP_SM_NUM_COLS] = {
  450. /* Event Action Next State */
  451. /* locally calculated peer dhkey check is ready -> compare it withs DHKey
  452. * Check
  453. * actually received from peer */
  454. /* SC_KEY_READY */
  455. {SMP_MATCH_DHKEY_CHECKS, SMP_SM_NO_ACTION, SMP_STATE_DHK_CHECK},
  456. /* locally calculated peer dhkey check is ready -> calculate STK, go to
  457. * sending
  458. */
  459. /* HCI LE Start Encryption command */
  460. /* ENC_REQ */
  461. {SMP_GENERATE_STK, SMP_SM_NO_ACTION, SMP_STATE_ENCRYPTION_PENDING},
  462. };
  463. static const uint8_t smp_master_enc_pending_table[][SMP_SM_NUM_COLS] = {
  464. /* Event Action Next State */
  465. /* STK ready */
  466. /* KEY_READY */
  467. {SMP_START_ENC, SMP_SM_NO_ACTION, SMP_STATE_ENCRYPTION_PENDING},
  468. /* ENCRYPTED */
  469. {SMP_CHECK_AUTH_REQ, SMP_SM_NO_ACTION, SMP_STATE_ENCRYPTION_PENDING},
  470. /* BOND_REQ */
  471. {SMP_KEY_DISTRIBUTE, SMP_SM_NO_ACTION, SMP_STATE_BOND_PENDING}};
  472. static const uint8_t smp_master_bond_pending_table[][SMP_SM_NUM_COLS] = {
  473. /* Event Action Next State */
  474. /* ENC_INFO */
  475. {SMP_PROC_ENC_INFO, SMP_SM_NO_ACTION, SMP_STATE_BOND_PENDING},
  476. /* ID_INFO */
  477. {SMP_PROC_ID_INFO, SMP_SM_NO_ACTION, SMP_STATE_BOND_PENDING},
  478. /* SIGN_INFO */
  479. {SMP_PROC_SRK_INFO, SMP_SM_NO_ACTION, SMP_STATE_BOND_PENDING},
  480. /* MASTER_ID */
  481. {SMP_PROC_MASTER_ID, SMP_SM_NO_ACTION, SMP_STATE_BOND_PENDING},
  482. /* ID_ADDR */
  483. {SMP_PROC_ID_ADDR, SMP_SM_NO_ACTION, SMP_STATE_BOND_PENDING},
  484. /* KEY_READY */
  485. /* LTK ready */
  486. {SMP_SEND_ENC_INFO, SMP_SM_NO_ACTION, SMP_STATE_BOND_PENDING}};
  487. static const uint8_t
  488. smp_master_create_local_sec_conn_oob_data[][SMP_SM_NUM_COLS] = {
  489. /* Event Action Next State */
  490. /* LOC_PUBL_KEY_CRTD */
  491. {SMP_SET_LOCAL_OOB_KEYS, SMP_SM_NO_ACTION,
  492. SMP_STATE_CREATE_LOCAL_SEC_CONN_OOB_DATA},
  493. /* HAVE_LOC_NONCE */
  494. {SMP_SET_LOCAL_OOB_RAND_COMMITMENT, SMP_SM_NO_ACTION, SMP_STATE_IDLE}};
  495. /************ SMP Slave FSM State/Event Indirection Table **************/
  496. static const uint8_t smp_slave_entry_map[][SMP_STATE_MAX] = {
  497. /* state name: */
  498. /* Idle, WaitApp Rsp, SecReq Pend, Pair ReqRsp, Wait Cfm, Confirm, Rand,
  499. PublKey Exch, SCPhs1 Strt, Wait Cmtm, Wait Nonce, SCPhs2 Strt, Wait
  500. DHKChk, DHKChk, Enc Pend, Bond Pend, CrLocSc OobData */
  501. /* PAIR_REQ */
  502. {2, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0},
  503. /* PAIR_RSP */
  504. {0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0},
  505. /* CONFIRM */
  506. {0, 4, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0},
  507. /* RAND */
  508. {0, 0, 0, 0, 0, 1, 2, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0},
  509. /* PAIR_FAIL */
  510. {0, 0x81, 0x81, 0x81, 0x81, 0x81, 0x81, 0x81, 0x81, 0x81, 0x81, 0x81, 0x81,
  511. 0x81, 0x81, 0, 0},
  512. /* ENC_INFO */
  513. {0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 3, 0},
  514. /* MASTER_ID */
  515. {0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 5, 0},
  516. /* ID_INFO */
  517. {0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 4, 0},
  518. /* ID_ADDR */
  519. {0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 6, 0},
  520. /* SIGN_INFO */
  521. {0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 2, 0},
  522. /* SEC_REQ */
  523. {0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0},
  524. /* PAIR_PUBLIC_KEY */
  525. {0, 0, 0, 5, 0, 0, 0, 2, 0, 0, 0, 0, 0, 0, 0, 0, 0},
  526. /* PAIR_DHKEY_CHCK */
  527. {0, 5, 0, 0, 0, 0, 0, 0, 0, 0, 0, 2, 1, 2, 0, 0, 0},
  528. /* PAIR_KEYPR_NOTIF */
  529. {0, 9, 0, 0, 0, 0, 0, 0, 5, 2, 0, 0, 0, 0, 0, 0, 0},
  530. /* PAIR_COMMITM */
  531. {0, 8, 0, 0, 0, 0, 0, 0, 6, 1, 0, 0, 0, 0, 0, 0, 0},
  532. /* KEY_READY */
  533. {0, 3, 0, 3, 2, 2, 1, 0, 4, 0, 0, 0, 0, 0, 2, 1, 0},
  534. /* ENC_CMPL */
  535. {0, 0, 2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 3, 0, 0},
  536. /* L2C_CONN */
  537. {1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0},
  538. /* L2C_DISC */
  539. {0, 0x83, 0x83, 0x83, 0x83, 0x83, 0x83, 0x83, 0x83, 0x83, 0x83, 0x83, 0x83,
  540. 0x83, 0x83, 0x83, 0},
  541. /* IO_RSP */
  542. {0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0},
  543. /* SEC_GRANT */
  544. {0, 2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0},
  545. /* TK_REQ */
  546. {0, 0, 0, 2, 0, 0, 0, 0, 3, 0, 0, 0, 0, 0, 0, 0, 0},
  547. /* AUTH_CMPL */
  548. {0, 0x82, 0x82, 0x82, 0x82, 0x82, 0x82, 0x82, 0x82, 0x82, 0x82, 0x82, 0x82,
  549. 0x82, 0x82, 0x82, 0},
  550. /* ENC_REQ */
  551. {0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0},
  552. /* BOND_REQ */
  553. {0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 4, 0, 0},
  554. /* DISCARD_SEC_REQ */
  555. {0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0},
  556. /* PUBL_KEY_EXCH_REQ */
  557. {0, 0, 0, 4, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0},
  558. /* LOC_PUBL_KEY_CRTD */
  559. {0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1},
  560. /* BOTH_PUBL_KEYS_RCVD */
  561. {0, 0, 0, 0, 0, 0, 0, 3, 0, 0, 0, 0, 0, 0, 0, 0, 0},
  562. /* SC_DHKEY_CMPLT */
  563. {0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0},
  564. /* HAVE_LOC_NONCE */
  565. {0, 0, 0, 0, 0, 0, 0, 0, 2, 0, 0, 0, 0, 0, 0, 0, 2},
  566. /* SC_PHASE1_CMPLT */
  567. {0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0},
  568. /* SC_CALC_NC */
  569. {0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 2, 0, 0, 0, 0, 0, 0},
  570. /* SC_DSPL_NC */
  571. {0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 3, 0, 0, 0, 0, 0, 0},
  572. /* SC_NC_OK */
  573. {0, 6, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0},
  574. /* SC_2_DHCK_CHKS_PRES */
  575. {0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 2, 0, 0, 0, 0},
  576. /* SC_KEY_READY */
  577. {0, 7, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0},
  578. /* KEYPR_NOTIF */
  579. {0, 10, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0},
  580. /* SC_OOB_DATA */
  581. {0, 11, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0},
  582. /* CR_LOC_SC_OOB_DATA */
  583. {3, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0},
  584. };
  585. static const uint8_t smp_slave_idle_table[][SMP_SM_NUM_COLS] = {
  586. /* Event Action Next State */
  587. /* L2C_CONN */
  588. {SMP_SEND_APP_CBACK, SMP_SM_NO_ACTION, SMP_STATE_WAIT_APP_RSP},
  589. /* PAIR_REQ */
  590. {SMP_PROC_PAIR_CMD, SMP_SEND_APP_CBACK, SMP_STATE_WAIT_APP_RSP},
  591. /* CR_LOC_SC_OOB_DATA */
  592. {SMP_CREATE_PRIVATE_KEY, SMP_SM_NO_ACTION,
  593. SMP_STATE_CREATE_LOCAL_SEC_CONN_OOB_DATA}};
  594. static const uint8_t smp_slave_wait_for_app_response_table[][SMP_SM_NUM_COLS] =
  595. {
  596. /* Event Action Next State */
  597. /* IO_RSP */
  598. {SMP_PROC_IO_RSP, SMP_SM_NO_ACTION, SMP_STATE_PAIR_REQ_RSP},
  599. /* SEC_GRANT */
  600. {SMP_PROC_SEC_GRANT, SMP_SEND_APP_CBACK, SMP_STATE_WAIT_APP_RSP},
  601. /* TK ready */
  602. /* KEY_READY */
  603. {SMP_PROC_SL_KEY, SMP_SM_NO_ACTION, SMP_STATE_WAIT_APP_RSP},
  604. /* CONFIRM */
  605. {SMP_PROC_CONFIRM, SMP_SM_NO_ACTION, SMP_STATE_CONFIRM},
  606. /* DHKey Check from master is received before phase 1 is completed -
  607. race */
  608. /* PAIR_DHKEY_CHCK */
  609. {SMP_PROCESS_DHKEY_CHECK, SMP_SM_NO_ACTION, SMP_STATE_WAIT_APP_RSP},
  610. /* user confirms NC 'OK', i.e. phase 1 is completed */
  611. /* SC_NC_OK */
  612. {SMP_MOVE_TO_SEC_CONN_PHASE2, SMP_SM_NO_ACTION,
  613. SMP_STATE_SEC_CONN_PHS2_START},
  614. /* user-provided passkey is rcvd */
  615. /* SC_KEY_READY */
  616. {SMP_START_PASSKEY_VERIFICATION, SMP_SM_NO_ACTION,
  617. SMP_STATE_SEC_CONN_PHS1_START},
  618. /* PAIR_COMMITM */
  619. {SMP_PROCESS_PAIRING_COMMITMENT, SMP_SM_NO_ACTION,
  620. SMP_STATE_WAIT_APP_RSP},
  621. /* PAIR_KEYPR_NOTIF */
  622. {SMP_PROCESS_KEYPRESS_NOTIFICATION, SMP_SEND_APP_CBACK,
  623. SMP_STATE_WAIT_APP_RSP},
  624. /* KEYPR_NOTIF */
  625. {SMP_SEND_KEYPRESS_NOTIFICATION, SMP_SM_NO_ACTION,
  626. SMP_STATE_WAIT_APP_RSP},
  627. /* SC_OOB_DATA */
  628. {SMP_SEND_PAIR_RSP, SMP_SM_NO_ACTION, SMP_STATE_PAIR_REQ_RSP},
  629. };
  630. static const uint8_t smp_slave_sec_request_table[][SMP_SM_NUM_COLS] = {
  631. /* Event Action Next State */
  632. /* PAIR_REQ */
  633. {SMP_PROC_PAIR_CMD, SMP_SM_NO_ACTION, SMP_STATE_PAIR_REQ_RSP},
  634. /* ENCRYPTED*/
  635. {SMP_ENC_CMPL, SMP_SM_NO_ACTION, SMP_STATE_PAIR_REQ_RSP},
  636. };
  637. static const uint8_t smp_slave_pair_request_response_table[][SMP_SM_NUM_COLS] =
  638. {
  639. /* Event Action Next State */
  640. /* CONFIRM */
  641. {SMP_PROC_CONFIRM, SMP_SM_NO_ACTION, SMP_STATE_CONFIRM},
  642. /* TK_REQ */
  643. {SMP_SEND_APP_CBACK, SMP_SM_NO_ACTION, SMP_STATE_WAIT_APP_RSP},
  644. /* TK/Confirm ready */
  645. /* KEY_READY */
  646. {SMP_PROC_SL_KEY, SMP_SM_NO_ACTION, SMP_STATE_PAIR_REQ_RSP},
  647. /* PUBL_KEY_EXCH_REQ */
  648. {SMP_CREATE_PRIVATE_KEY, SMP_SM_NO_ACTION, SMP_STATE_PUBLIC_KEY_EXCH},
  649. /* PAIR_PUBLIC_KEY */
  650. {SMP_PROCESS_PAIR_PUBLIC_KEY, SMP_SM_NO_ACTION, SMP_STATE_PAIR_REQ_RSP},
  651. };
  652. static const uint8_t smp_slave_wait_confirm_table[][SMP_SM_NUM_COLS] = {
  653. /* Event Action Next State */
  654. /* CONFIRM */
  655. {SMP_PROC_CONFIRM, SMP_SEND_CONFIRM, SMP_STATE_CONFIRM},
  656. /* KEY_READY*/
  657. {SMP_PROC_SL_KEY, SMP_SM_NO_ACTION, SMP_STATE_WAIT_CONFIRM}};
  658. static const uint8_t smp_slave_confirm_table[][SMP_SM_NUM_COLS] = {
  659. /* Event Action Next State */
  660. /* RAND */
  661. {SMP_PROC_RAND, SMP_GENERATE_COMPARE, SMP_STATE_RAND},
  662. /* TK/Confirm ready */
  663. /* KEY_READY*/
  664. {SMP_PROC_SL_KEY, SMP_SM_NO_ACTION, SMP_STATE_CONFIRM}};
  665. static const uint8_t smp_slave_rand_table[][SMP_SM_NUM_COLS] = {
  666. /* Event Action Next State */
  667. /* KEY_READY */
  668. {SMP_PROC_COMPARE, SMP_SM_NO_ACTION, SMP_STATE_RAND}, /* compare match */
  669. /* RAND */
  670. {SMP_SEND_RAND, SMP_SM_NO_ACTION, SMP_STATE_ENCRYPTION_PENDING}};
  671. static const uint8_t smp_slave_public_key_exch_table[][SMP_SM_NUM_COLS] = {
  672. /* Event Action Next State */
  673. /* LOC_PUBL_KEY_CRTD */
  674. {SMP_WAIT_FOR_BOTH_PUBLIC_KEYS, SMP_SM_NO_ACTION,
  675. SMP_STATE_PUBLIC_KEY_EXCH},
  676. /* PAIR_PUBLIC_KEY */
  677. {SMP_PROCESS_PAIR_PUBLIC_KEY, SMP_SM_NO_ACTION, SMP_STATE_PUBLIC_KEY_EXCH},
  678. /* BOTH_PUBL_KEYS_RCVD */
  679. {SMP_HAVE_BOTH_PUBLIC_KEYS, SMP_SM_NO_ACTION,
  680. SMP_STATE_SEC_CONN_PHS1_START},
  681. };
  682. static const uint8_t smp_slave_sec_conn_phs1_start_table[][SMP_SM_NUM_COLS] = {
  683. /* Event Action Next State */
  684. /* SC_DHKEY_CMPLT */
  685. {SMP_START_SEC_CONN_PHASE1, SMP_SM_NO_ACTION,
  686. SMP_STATE_SEC_CONN_PHS1_START},
  687. /* HAVE_LOC_NONCE */
  688. {SMP_PROCESS_LOCAL_NONCE, SMP_SM_NO_ACTION, SMP_STATE_WAIT_COMMITMENT},
  689. /* TK_REQ */
  690. {SMP_SEND_APP_CBACK, SMP_SM_NO_ACTION, SMP_STATE_WAIT_APP_RSP},
  691. /* SMP_MODEL_SEC_CONN_PASSKEY_DISP model, passkey is sent up to display,
  692. * it's
  693. * time to start */
  694. /* commitment calculation */
  695. /* KEY_READY */
  696. {SMP_START_PASSKEY_VERIFICATION, SMP_SM_NO_ACTION,
  697. SMP_STATE_SEC_CONN_PHS1_START},
  698. /* PAIR_KEYPR_NOTIF */
  699. {SMP_PROCESS_KEYPRESS_NOTIFICATION, SMP_SEND_APP_CBACK,
  700. SMP_STATE_SEC_CONN_PHS1_START},
  701. /*COMMIT*/
  702. {SMP_PROCESS_PAIRING_COMMITMENT, SMP_SM_NO_ACTION,
  703. SMP_STATE_SEC_CONN_PHS1_START},
  704. };
  705. static const uint8_t smp_slave_wait_commitment_table[][SMP_SM_NUM_COLS] = {
  706. /* Event Action Next State */
  707. /* PAIR_COMMITM */
  708. {SMP_PROCESS_PAIRING_COMMITMENT, SMP_SEND_COMMITMENT, SMP_STATE_WAIT_NONCE},
  709. /* PAIR_KEYPR_NOTIF */
  710. {SMP_PROCESS_KEYPRESS_NOTIFICATION, SMP_SEND_APP_CBACK,
  711. SMP_STATE_WAIT_COMMITMENT},
  712. };
  713. static const uint8_t smp_slave_wait_nonce_table[][SMP_SM_NUM_COLS] = {
  714. /* Event Action Next State */
  715. /* peer nonce is received */
  716. /* RAND */
  717. {SMP_PROC_RAND, SMP_PROCESS_PEER_NONCE, SMP_STATE_SEC_CONN_PHS2_START},
  718. /* NC model, time to calculate number for NC */
  719. /* SC_CALC_NC */
  720. {SMP_CALCULATE_NUMERIC_COMPARISON_DISPLAY_NUMBER, SMP_SM_NO_ACTION,
  721. SMP_STATE_WAIT_NONCE},
  722. /* NC model, time to display calculated number for NC to the user */
  723. /* SC_DSPL_NC */
  724. {SMP_SEND_APP_CBACK, SMP_SM_NO_ACTION, SMP_STATE_WAIT_APP_RSP},
  725. };
  726. static const uint8_t smp_slave_sec_conn_phs2_start_table[][SMP_SM_NUM_COLS] = {
  727. /* Event Action Next State */
  728. /* SC_PHASE1_CMPLT */
  729. {SMP_CALCULATE_LOCAL_DHKEY_CHECK, SMP_PH2_DHKEY_CHECKS_ARE_PRESENT,
  730. SMP_STATE_WAIT_DHK_CHECK},
  731. /* DHKey Check from master is received before slave DHKey calculation is
  732. * completed - race */
  733. /* PAIR_DHKEY_CHCK */
  734. {SMP_PROCESS_DHKEY_CHECK, SMP_SM_NO_ACTION, SMP_STATE_SEC_CONN_PHS2_START},
  735. };
  736. static const uint8_t smp_slave_wait_dhk_check_table[][SMP_SM_NUM_COLS] = {
  737. /* Event Action Next State */
  738. /* PAIR_DHKEY_CHCK */
  739. {SMP_PROCESS_DHKEY_CHECK, SMP_CALCULATE_PEER_DHKEY_CHECK,
  740. SMP_STATE_DHK_CHECK},
  741. /* DHKey Check from master was received before slave came to this state */
  742. /* SC_2_DHCK_CHKS_PRES */
  743. {SMP_CALCULATE_PEER_DHKEY_CHECK, SMP_SM_NO_ACTION, SMP_STATE_DHK_CHECK},
  744. };
  745. static const uint8_t smp_slave_dhk_check_table[][SMP_SM_NUM_COLS] = {
  746. /* Event Action Next State */
  747. /* locally calculated peer dhkey check is ready -> compare it withs DHKey
  748. * Check
  749. */
  750. /* actually received from peer */
  751. /* SC_KEY_READY */
  752. {SMP_MATCH_DHKEY_CHECKS, SMP_SM_NO_ACTION, SMP_STATE_DHK_CHECK},
  753. /* dhkey checks match -> send local dhkey check to master, go to wait for
  754. * HCI LE
  755. */
  756. /* Long Term Key Request Event */
  757. /* PAIR_DHKEY_CHCK */
  758. {SMP_SEND_DHKEY_CHECK, SMP_SM_NO_ACTION, SMP_STATE_ENCRYPTION_PENDING},
  759. };
  760. static const uint8_t smp_slave_enc_pending_table[][SMP_SM_NUM_COLS] = {
  761. /* Event Action Next State */
  762. /* ENC_REQ */
  763. {SMP_GENERATE_STK, SMP_SM_NO_ACTION, SMP_STATE_ENCRYPTION_PENDING},
  764. /* STK ready */
  765. /* KEY_READY */
  766. {SMP_SEND_LTK_REPLY, SMP_SM_NO_ACTION, SMP_STATE_ENCRYPTION_PENDING},
  767. /* ENCRYPTED */
  768. {SMP_CHECK_AUTH_REQ, SMP_SM_NO_ACTION, SMP_STATE_ENCRYPTION_PENDING},
  769. /* BOND_REQ */
  770. {SMP_KEY_DISTRIBUTE, SMP_SM_NO_ACTION, SMP_STATE_BOND_PENDING}};
  771. static const uint8_t smp_slave_bond_pending_table[][SMP_SM_NUM_COLS] = {
  772. /* Event Action Next State */
  773. /* LTK ready */
  774. /* KEY_READY */
  775. {SMP_SEND_ENC_INFO, SMP_SM_NO_ACTION, SMP_STATE_BOND_PENDING},
  776. /* rev SRK */
  777. /* SIGN_INFO */
  778. {SMP_PROC_SRK_INFO, SMP_SM_NO_ACTION, SMP_STATE_BOND_PENDING},
  779. /* ENC_INFO */
  780. {SMP_PROC_ENC_INFO, SMP_SM_NO_ACTION, SMP_STATE_BOND_PENDING},
  781. /* ID_INFO */
  782. {SMP_PROC_ID_INFO, SMP_SM_NO_ACTION, SMP_STATE_BOND_PENDING},
  783. /* MASTER_ID*/
  784. {SMP_PROC_MASTER_ID, SMP_SM_NO_ACTION, SMP_STATE_BOND_PENDING},
  785. /* ID_ADDR */
  786. {SMP_PROC_ID_ADDR, SMP_SM_NO_ACTION, SMP_STATE_BOND_PENDING}
  787. };
  788. static const uint8_t
  789. smp_slave_create_local_sec_conn_oob_data[][SMP_SM_NUM_COLS] = {
  790. /* Event Action Next State */
  791. /* LOC_PUBL_KEY_CRTD */
  792. {SMP_SET_LOCAL_OOB_KEYS, SMP_SM_NO_ACTION,
  793. SMP_STATE_CREATE_LOCAL_SEC_CONN_OOB_DATA},
  794. /* HAVE_LOC_NONCE */
  795. {SMP_SET_LOCAL_OOB_RAND_COMMITMENT, SMP_SM_NO_ACTION, SMP_STATE_IDLE}};
  796. static const tSMP_SM_TBL smp_state_table[][2] = {
  797. /* SMP_STATE_IDLE */
  798. {smp_master_idle_table, smp_slave_idle_table},
  799. /* SMP_STATE_WAIT_APP_RSP */
  800. {smp_master_wait_for_app_response_table,
  801. smp_slave_wait_for_app_response_table},
  802. /* SMP_STATE_SEC_REQ_PENDING */
  803. {NULL, smp_slave_sec_request_table},
  804. /* SMP_STATE_PAIR_REQ_RSP */
  805. {smp_master_pair_request_response_table,
  806. smp_slave_pair_request_response_table},
  807. /* SMP_STATE_WAIT_CONFIRM */
  808. {smp_master_wait_for_confirm_table, smp_slave_wait_confirm_table},
  809. /* SMP_STATE_CONFIRM */
  810. {smp_master_confirm_table, smp_slave_confirm_table},
  811. /* SMP_STATE_RAND */
  812. {smp_master_rand_table, smp_slave_rand_table},
  813. /* SMP_STATE_PUBLIC_KEY_EXCH */
  814. {smp_master_public_key_exchange_table, smp_slave_public_key_exch_table},
  815. /* SMP_STATE_SEC_CONN_PHS1_START */
  816. {smp_master_sec_conn_phs1_start_table, smp_slave_sec_conn_phs1_start_table},
  817. /* SMP_STATE_WAIT_COMMITMENT */
  818. {smp_master_wait_commitment_table, smp_slave_wait_commitment_table},
  819. /* SMP_STATE_WAIT_NONCE */
  820. {smp_master_wait_nonce_table, smp_slave_wait_nonce_table},
  821. /* SMP_STATE_SEC_CONN_PHS2_START */
  822. {smp_master_sec_conn_phs2_start_table, smp_slave_sec_conn_phs2_start_table},
  823. /* SMP_STATE_WAIT_DHK_CHECK */
  824. {smp_master_wait_dhk_check_table, smp_slave_wait_dhk_check_table},
  825. /* SMP_STATE_DHK_CHECK */
  826. {smp_master_dhk_check_table, smp_slave_dhk_check_table},
  827. /* SMP_STATE_ENCRYPTION_PENDING */
  828. {smp_master_enc_pending_table, smp_slave_enc_pending_table},
  829. /* SMP_STATE_BOND_PENDING */
  830. {smp_master_bond_pending_table, smp_slave_bond_pending_table},
  831. /* SMP_STATE_CREATE_LOCAL_SEC_CONN_OOB_DATA */
  832. {smp_master_create_local_sec_conn_oob_data,
  833. smp_slave_create_local_sec_conn_oob_data}};
  834. typedef const uint8_t (*tSMP_ENTRY_TBL)[SMP_STATE_MAX];
  835. static const tSMP_ENTRY_TBL smp_entry_table[] = {smp_master_entry_map,
  836. smp_slave_entry_map};
  837. tSMP_CB smp_cb;
  838. #define SMP_ALL_TBL_MASK 0x80
  839. /*******************************************************************************
  840. * Function smp_set_state
  841. * Returns None
  842. ******************************************************************************/
  843. void smp_set_state(tSMP_STATE state) {
  844. if (state < SMP_STATE_MAX) {
  845. SMP_TRACE_DEBUG("State change: %s(%d) ==> %s(%d)",
  846. smp_get_state_name(smp_cb.state), smp_cb.state,
  847. smp_get_state_name(state), state);
  848. smp_cb.state = state;
  849. } else {
  850. SMP_TRACE_DEBUG("smp_set_state invalid state =%d", state);
  851. }
  852. }
  853. /*******************************************************************************
  854. * Function smp_get_state
  855. * Returns The smp state
  856. ******************************************************************************/
  857. tSMP_STATE smp_get_state(void) { return smp_cb.state; }
  858. /*******************************************************************************
  859. *
  860. * Function smp_sm_event
  861. *
  862. * Description Handle events to the state machine. It looks up the entry
  863. * in the smp_entry_table array.
  864. * If it is a valid entry, it gets the state table. Set the next
  865. * state, if not NULL state. Execute the action function according
  866. * to the state table. If the state returned by action function is
  867. * not NULL state, adjust the new state to the returned state. If
  868. * (api_evt != MAX), call callback function.
  869. *
  870. * Returns void.
  871. *
  872. ******************************************************************************/
  873. void smp_sm_event(tSMP_CB* p_cb, tSMP_EVENT event, tSMP_INT_DATA* p_data) {
  874. uint8_t curr_state = p_cb->state;
  875. tSMP_SM_TBL state_table;
  876. uint8_t action, entry, i;
  877. if (p_cb->role >= 2) {
  878. SMP_TRACE_DEBUG("Invalid role: %d", p_cb->role);
  879. android_errorWriteLog(0x534e4554, "74121126");
  880. return;
  881. }
  882. tSMP_ENTRY_TBL entry_table = smp_entry_table[p_cb->role];
  883. SMP_TRACE_EVENT("main smp_sm_event");
  884. if (curr_state >= SMP_STATE_MAX) {
  885. SMP_TRACE_DEBUG("Invalid state: %d", curr_state);
  886. return;
  887. }
  888. SMP_TRACE_DEBUG("SMP Role: %s State: [%s (%d)], Event: [%s (%d)]",
  889. (p_cb->role == 0x01) ? "Slave" : "Master",
  890. smp_get_state_name(p_cb->state), p_cb->state,
  891. smp_get_event_name(event), event);
  892. /* look up the state table for the current state */
  893. /* lookup entry /w event & curr_state */
  894. /* If entry is ignore, return.
  895. * Otherwise, get state table (according to curr_state or all_state) */
  896. if ((event <= SMP_MAX_EVT) &&
  897. ((entry = entry_table[event - 1][curr_state]) != SMP_SM_IGNORE)) {
  898. if (entry & SMP_ALL_TBL_MASK) {
  899. entry &= ~SMP_ALL_TBL_MASK;
  900. state_table = smp_all_table;
  901. } else
  902. state_table = smp_state_table[curr_state][p_cb->role];
  903. } else {
  904. SMP_TRACE_DEBUG("Ignore event [%s (%d)] in state [%s (%d)]",
  905. smp_get_event_name(event), event,
  906. smp_get_state_name(curr_state), curr_state);
  907. return;
  908. }
  909. /* Get possible next state from state table. */
  910. smp_set_state(state_table[entry - 1][SMP_SME_NEXT_STATE]);
  911. /* If action is not ignore, clear param, exec action and get next state.
  912. * The action function may set the Param for cback.
  913. * Depending on param, call cback or free buffer. */
  914. /* execute action */
  915. /* execute action functions */
  916. for (i = 0; i < SMP_NUM_ACTIONS; i++) {
  917. action = state_table[entry - 1][i];
  918. if (action != SMP_SM_NO_ACTION) {
  919. (*smp_sm_action[action])(p_cb, p_data);
  920. } else {
  921. break;
  922. }
  923. }
  924. SMP_TRACE_DEBUG("result state = %s", smp_get_state_name(p_cb->state));
  925. }
  926. /*******************************************************************************
  927. * Function smp_get_state_name
  928. * Returns The smp state name.
  929. ******************************************************************************/
  930. const char* smp_get_state_name(tSMP_STATE state) {
  931. const char* p_str = smp_state_name[SMP_STATE_MAX];
  932. if (state < SMP_STATE_MAX) {
  933. p_str = smp_state_name[state];
  934. }
  935. return p_str;
  936. }
  937. /*******************************************************************************
  938. * Function smp_get_event_name
  939. * Returns The smp event name.
  940. ******************************************************************************/
  941. const char* smp_get_event_name(tSMP_EVENT event) {
  942. const char* p_str = smp_event_name[SMP_MAX_EVT];
  943. if (event <= SMP_MAX_EVT) {
  944. p_str = smp_event_name[event - 1];
  945. }
  946. return p_str;
  947. }