esp_gap_bt_api.c 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430
  1. // Copyright 2015-2016 Espressif Systems (Shanghai) PTE LTD
  2. //
  3. // Licensed under the Apache License, Version 2.0 (the "License");
  4. // you may not use this file except in compliance with the License.
  5. // You may obtain a copy of the License at
  6. // http://www.apache.org/licenses/LICENSE-2.0
  7. //
  8. // Unless required by applicable law or agreed to in writing, software
  9. // distributed under the License is distributed on an "AS IS" BASIS,
  10. // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  11. // See the License for the specific language governing permissions and
  12. // limitations under the License.
  13. #include "common/bt_target.h"
  14. #include <string.h>
  15. #include "esp_bt_main.h"
  16. #include "esp_gap_bt_api.h"
  17. #include "common/bt_trace.h"
  18. #include "bta/bta_api.h"
  19. #include "btc/btc_manage.h"
  20. #include "btc_gap_bt.h"
  21. #include "btc/btc_storage.h"
  22. #if (BTC_GAP_BT_INCLUDED == TRUE)
  23. esp_err_t esp_bt_gap_register_callback(esp_bt_gap_cb_t callback)
  24. {
  25. if (esp_bluedroid_get_status() != ESP_BLUEDROID_STATUS_ENABLED) {
  26. return ESP_ERR_INVALID_STATE;
  27. }
  28. if (callback == NULL) {
  29. return ESP_FAIL;
  30. }
  31. btc_profile_cb_set(BTC_PID_GAP_BT, callback);
  32. return ESP_OK;
  33. }
  34. esp_err_t esp_bt_gap_set_scan_mode(esp_bt_connection_mode_t c_mode, esp_bt_discovery_mode_t d_mode)
  35. {
  36. btc_msg_t msg;
  37. btc_gap_bt_args_t arg;
  38. if (esp_bluedroid_get_status() != ESP_BLUEDROID_STATUS_ENABLED) {
  39. return ESP_ERR_INVALID_STATE;
  40. }
  41. msg.sig = BTC_SIG_API_CALL;
  42. msg.pid = BTC_PID_GAP_BT;
  43. msg.act = BTC_GAP_BT_ACT_SET_SCAN_MODE;
  44. arg.set_scan_mode.c_mode = c_mode;
  45. arg.set_scan_mode.d_mode = d_mode;
  46. return (btc_transfer_context(&msg, &arg, sizeof(btc_gap_bt_args_t), NULL) == BT_STATUS_SUCCESS ? ESP_OK : ESP_FAIL);
  47. }
  48. esp_err_t esp_bt_gap_start_discovery(esp_bt_inq_mode_t mode, uint8_t inq_len, uint8_t num_rsps)
  49. {
  50. btc_msg_t msg;
  51. btc_gap_bt_args_t arg;
  52. if (esp_bluedroid_get_status() != ESP_BLUEDROID_STATUS_ENABLED) {
  53. return ESP_ERR_INVALID_STATE;
  54. }
  55. if (mode != ESP_BT_INQ_MODE_GENERAL_INQUIRY &&
  56. mode != ESP_BT_INQ_MODE_LIMITED_INQUIRY) {
  57. return ESP_ERR_INVALID_ARG;
  58. }
  59. if (inq_len < ESP_BT_GAP_MIN_INQ_LEN ||
  60. inq_len > ESP_BT_GAP_MAX_INQ_LEN) {
  61. return ESP_ERR_INVALID_ARG;
  62. }
  63. msg.sig = BTC_SIG_API_CALL;
  64. msg.pid = BTC_PID_GAP_BT;
  65. msg.act = BTC_GAP_BT_ACT_START_DISCOVERY;
  66. arg.start_disc.mode = mode;
  67. arg.start_disc.inq_len = inq_len;
  68. arg.start_disc.num_rsps = num_rsps;
  69. return (btc_transfer_context(&msg, &arg, sizeof(btc_gap_bt_args_t), NULL) == BT_STATUS_SUCCESS ? ESP_OK : ESP_FAIL);
  70. }
  71. esp_err_t esp_bt_gap_cancel_discovery(void)
  72. {
  73. btc_msg_t msg;
  74. if (esp_bluedroid_get_status() != ESP_BLUEDROID_STATUS_ENABLED) {
  75. return ESP_ERR_INVALID_STATE;
  76. }
  77. msg.sig = BTC_SIG_API_CALL;
  78. msg.pid = BTC_PID_GAP_BT;
  79. msg.act = BTC_GAP_BT_ACT_CANCEL_DISCOVERY;
  80. return (btc_transfer_context(&msg, NULL, 0, NULL) == BT_STATUS_SUCCESS ? ESP_OK : ESP_FAIL);
  81. }
  82. esp_err_t esp_bt_gap_get_remote_services(esp_bd_addr_t remote_bda)
  83. {
  84. btc_msg_t msg;
  85. btc_gap_bt_args_t arg;
  86. if (esp_bluedroid_get_status() != ESP_BLUEDROID_STATUS_ENABLED) {
  87. return ESP_ERR_INVALID_STATE;
  88. }
  89. msg.sig = BTC_SIG_API_CALL;
  90. msg.pid = BTC_PID_GAP_BT;
  91. msg.act = BTC_GAP_BT_ACT_GET_REMOTE_SERVICES;
  92. memcpy(&arg.bda, remote_bda, sizeof(bt_bdaddr_t));
  93. return (btc_transfer_context(&msg, &arg, sizeof(btc_gap_bt_args_t), NULL) == BT_STATUS_SUCCESS ? ESP_OK : ESP_FAIL);
  94. }
  95. esp_err_t esp_bt_gap_get_remote_service_record(esp_bd_addr_t remote_bda, esp_bt_uuid_t *uuid)
  96. {
  97. btc_msg_t msg;
  98. btc_gap_bt_args_t arg;
  99. if (esp_bluedroid_get_status() != ESP_BLUEDROID_STATUS_ENABLED) {
  100. return ESP_ERR_INVALID_STATE;
  101. }
  102. msg.sig = BTC_SIG_API_CALL;
  103. msg.pid = BTC_PID_GAP_BT;
  104. msg.act = BTC_GAP_BT_ACT_GET_REMOTE_SERVICE_RECORD;
  105. memcpy(&arg.get_rmt_srv_rcd.bda, remote_bda, sizeof(bt_bdaddr_t));
  106. memcpy(&arg.get_rmt_srv_rcd.uuid, uuid, sizeof(esp_bt_uuid_t));
  107. return (btc_transfer_context(&msg, &arg, sizeof(btc_gap_bt_args_t), NULL) == BT_STATUS_SUCCESS ? ESP_OK : ESP_FAIL);
  108. }
  109. uint8_t *esp_bt_gap_resolve_eir_data(uint8_t *eir, esp_bt_eir_type_t type, uint8_t *length)
  110. {
  111. if (!eir) {
  112. return NULL;
  113. }
  114. return BTM_CheckEirData(eir, type, length);
  115. }
  116. esp_err_t esp_bt_gap_config_eir_data(esp_bt_eir_data_t *eir_data)
  117. {
  118. btc_msg_t msg;
  119. btc_gap_bt_args_t arg;
  120. if (esp_bluedroid_get_status() != ESP_BLUEDROID_STATUS_ENABLED) {
  121. return ESP_ERR_INVALID_STATE;
  122. }
  123. if (eir_data == NULL) {
  124. return ESP_ERR_INVALID_ARG;
  125. }
  126. if (eir_data->manufacturer_len > ESP_BT_EIR_MAX_LEN
  127. || eir_data->url_len > ESP_BT_EIR_MAX_LEN) {
  128. return ESP_ERR_INVALID_ARG;
  129. }
  130. if ((eir_data->manufacturer_len > 0 && eir_data->p_manufacturer_data == NULL)
  131. || (eir_data->url_len > 0 && eir_data->p_url == NULL)) {
  132. return ESP_ERR_INVALID_ARG;
  133. }
  134. msg.sig = BTC_SIG_API_CALL;
  135. msg.pid = BTC_PID_GAP_BT;
  136. msg.act = BTC_GAP_BT_ACT_CONFIG_EIR;
  137. memcpy(&arg.config_eir, eir_data, sizeof(esp_bt_eir_data_t));
  138. return (btc_transfer_context(&msg, &arg, sizeof(btc_gap_bt_args_t), btc_gap_bt_arg_deep_copy) == BT_STATUS_SUCCESS ? ESP_OK : ESP_FAIL);
  139. }
  140. esp_err_t esp_bt_gap_set_cod(esp_bt_cod_t cod, esp_bt_cod_mode_t mode)
  141. {
  142. btc_msg_t msg;
  143. btc_gap_bt_args_t arg;
  144. if (esp_bluedroid_get_status() != ESP_BLUEDROID_STATUS_ENABLED) {
  145. return ESP_ERR_INVALID_STATE;
  146. }
  147. switch (mode) {
  148. case ESP_BT_SET_COD_MAJOR_MINOR:
  149. case ESP_BT_SET_COD_SERVICE_CLASS:
  150. case ESP_BT_CLR_COD_SERVICE_CLASS:
  151. case ESP_BT_SET_COD_ALL:
  152. case ESP_BT_INIT_COD:
  153. break;
  154. default:
  155. return ESP_ERR_INVALID_ARG;
  156. break;
  157. }
  158. msg.sig = BTC_SIG_API_CALL;
  159. msg.pid = BTC_PID_GAP_BT;
  160. msg.act = BTC_GAP_BT_ACT_SET_COD;
  161. arg.set_cod.mode = mode;
  162. memcpy(&arg.set_cod.cod, &cod, sizeof(esp_bt_cod_t));
  163. return (btc_transfer_context(&msg, &arg, sizeof(btc_gap_bt_args_t), NULL) == BT_STATUS_SUCCESS ? ESP_OK : ESP_FAIL);
  164. }
  165. esp_err_t esp_bt_gap_get_cod(esp_bt_cod_t *cod)
  166. {
  167. return btc_gap_bt_get_cod(cod);
  168. }
  169. esp_err_t esp_bt_gap_read_rssi_delta(esp_bd_addr_t remote_addr)
  170. {
  171. btc_msg_t msg;
  172. btc_gap_bt_args_t arg;
  173. msg.sig = BTC_SIG_API_CALL;
  174. msg.pid = BTC_PID_GAP_BT;
  175. msg.act = BTC_GAP_BT_ACT_READ_RSSI_DELTA;
  176. memcpy(arg.read_rssi_delta.bda.address, remote_addr, sizeof(esp_bd_addr_t));
  177. return (btc_transfer_context(&msg, &arg, sizeof(btc_gap_bt_args_t), NULL) == BT_STATUS_SUCCESS ? ESP_OK : ESP_FAIL);
  178. }
  179. esp_err_t esp_bt_gap_remove_bond_device(esp_bd_addr_t bd_addr)
  180. {
  181. btc_msg_t msg;
  182. btc_gap_bt_args_t arg;
  183. if (esp_bluedroid_get_status() != ESP_BLUEDROID_STATUS_ENABLED) {
  184. return ESP_ERR_INVALID_STATE;
  185. }
  186. msg.sig = BTC_SIG_API_CALL;
  187. msg.pid = BTC_PID_GAP_BT;
  188. msg.act = BTC_GAP_BT_ACT_REMOVE_BOND_DEVICE;
  189. memcpy(arg.rm_bond_device.bda.address, bd_addr, sizeof(esp_bd_addr_t));
  190. return (btc_transfer_context(&msg, &arg, sizeof(btc_gap_bt_args_t), NULL) == BT_STATUS_SUCCESS ? ESP_OK : ESP_FAIL);
  191. }
  192. int esp_bt_gap_get_bond_device_num(void)
  193. {
  194. if (esp_bluedroid_get_status() != ESP_BLUEDROID_STATUS_ENABLED) {
  195. return ESP_ERR_INVALID_STATE;
  196. }
  197. return btc_storage_get_num_bt_bond_devices();
  198. }
  199. esp_err_t esp_bt_gap_get_bond_device_list(int *dev_num, esp_bd_addr_t *dev_list)
  200. {
  201. int ret;
  202. if (dev_num == NULL || dev_list == NULL) {
  203. return ESP_ERR_INVALID_ARG;
  204. }
  205. if (esp_bluedroid_get_status() != ESP_BLUEDROID_STATUS_ENABLED) {
  206. return ESP_ERR_INVALID_STATE;
  207. }
  208. ret = btc_storage_get_bonded_bt_devices_list((bt_bdaddr_t *)dev_list, dev_num);
  209. return (ret == BT_STATUS_SUCCESS ? ESP_OK : ESP_FAIL);
  210. }
  211. esp_err_t esp_bt_gap_set_pin(esp_bt_pin_type_t pin_type, uint8_t pin_code_len, esp_bt_pin_code_t pin_code)
  212. {
  213. btc_msg_t msg;
  214. btc_gap_bt_args_t arg;
  215. if (esp_bluedroid_get_status() != ESP_BLUEDROID_STATUS_ENABLED) {
  216. return ESP_ERR_INVALID_STATE;
  217. }
  218. msg.sig = BTC_SIG_API_CALL;
  219. msg.pid = BTC_PID_GAP_BT;
  220. msg.act = BTC_GAP_BT_ACT_SET_PIN_TYPE;
  221. arg.set_pin_type.pin_type = pin_type;
  222. if (pin_type == ESP_BT_PIN_TYPE_FIXED){
  223. arg.set_pin_type.pin_code_len = pin_code_len;
  224. memcpy(arg.set_pin_type.pin_code, pin_code, pin_code_len);
  225. } else {
  226. arg.set_pin_type.pin_code_len = 0;
  227. memset(arg.set_pin_type.pin_code, 0, ESP_BT_PIN_CODE_LEN);
  228. }
  229. return (btc_transfer_context(&msg, &arg, sizeof(btc_gap_bt_args_t), btc_gap_bt_arg_deep_copy)
  230. == BT_STATUS_SUCCESS ? ESP_OK : ESP_FAIL);
  231. }
  232. esp_err_t esp_bt_gap_pin_reply(esp_bd_addr_t bd_addr, bool accept, uint8_t pin_code_len, esp_bt_pin_code_t pin_code)
  233. {
  234. btc_msg_t msg;
  235. btc_gap_bt_args_t arg;
  236. if (esp_bluedroid_get_status() != ESP_BLUEDROID_STATUS_ENABLED) {
  237. return ESP_ERR_INVALID_STATE;
  238. }
  239. msg.sig = BTC_SIG_API_CALL;
  240. msg.pid = BTC_PID_GAP_BT;
  241. msg.act = BTC_GAP_BT_ACT_PIN_REPLY;
  242. arg.pin_reply.accept = accept;
  243. arg.pin_reply.pin_code_len = pin_code_len;
  244. memcpy(arg.pin_reply.bda.address, bd_addr, sizeof(esp_bd_addr_t));
  245. memcpy(arg.pin_reply.pin_code, pin_code, pin_code_len);
  246. return (btc_transfer_context(&msg, &arg, sizeof(btc_gap_bt_args_t), btc_gap_bt_arg_deep_copy)
  247. == BT_STATUS_SUCCESS ? ESP_OK : ESP_FAIL);
  248. }
  249. #if (BT_SSP_INCLUDED == TRUE)
  250. esp_err_t esp_bt_gap_set_security_param(esp_bt_sp_param_t param_type,
  251. void *value, uint8_t len)
  252. {
  253. btc_msg_t msg;
  254. btc_gap_bt_args_t arg;
  255. if (esp_bluedroid_get_status() != ESP_BLUEDROID_STATUS_ENABLED) {
  256. return ESP_ERR_INVALID_STATE;
  257. }
  258. msg.sig = BTC_SIG_API_CALL;
  259. msg.pid = BTC_PID_GAP_BT;
  260. msg.act = BTC_GAP_BT_ACT_SET_SECURITY_PARAM;
  261. arg.set_security_param.param_type = param_type;
  262. arg.set_security_param.len = len;
  263. arg.set_security_param.value = value;
  264. return (btc_transfer_context(&msg, &arg, sizeof(btc_gap_bt_args_t), btc_gap_bt_arg_deep_copy)
  265. == BT_STATUS_SUCCESS ? ESP_OK : ESP_FAIL);
  266. }
  267. esp_err_t esp_bt_gap_ssp_passkey_reply(esp_bd_addr_t bd_addr, bool accept, uint32_t passkey)
  268. {
  269. btc_msg_t msg;
  270. btc_gap_bt_args_t arg;
  271. if (esp_bluedroid_get_status() != ESP_BLUEDROID_STATUS_ENABLED) {
  272. return ESP_ERR_INVALID_STATE;
  273. }
  274. msg.sig = BTC_SIG_API_CALL;
  275. msg.pid = BTC_PID_GAP_BT;
  276. msg.act = BTC_GAP_BT_ACT_PASSKEY_REPLY;
  277. arg.passkey_reply.accept = accept;
  278. arg.passkey_reply.passkey = passkey;
  279. memcpy(arg.passkey_reply.bda.address, bd_addr, sizeof(esp_bd_addr_t));
  280. return (btc_transfer_context(&msg, &arg, sizeof(btc_gap_bt_args_t), btc_gap_bt_arg_deep_copy)
  281. == BT_STATUS_SUCCESS ? ESP_OK : ESP_FAIL);
  282. }
  283. esp_err_t esp_bt_gap_ssp_confirm_reply(esp_bd_addr_t bd_addr, bool accept)
  284. {
  285. btc_msg_t msg;
  286. btc_gap_bt_args_t arg;
  287. if (esp_bluedroid_get_status() != ESP_BLUEDROID_STATUS_ENABLED) {
  288. return ESP_ERR_INVALID_STATE;
  289. }
  290. msg.sig = BTC_SIG_API_CALL;
  291. msg.pid = BTC_PID_GAP_BT;
  292. msg.act = BTC_GAP_BT_ACT_CONFIRM_REPLY;
  293. arg.confirm_reply.accept = accept;
  294. memcpy(arg.confirm_reply.bda.address, bd_addr, sizeof(esp_bd_addr_t));
  295. return (btc_transfer_context(&msg, &arg, sizeof(btc_gap_bt_args_t), btc_gap_bt_arg_deep_copy)
  296. == BT_STATUS_SUCCESS ? ESP_OK : ESP_FAIL);
  297. }
  298. #endif /*(BT_SSP_INCLUDED == TRUE)*/
  299. esp_err_t esp_bt_gap_set_afh_channels(esp_bt_gap_afh_channels channels)
  300. {
  301. btc_msg_t msg;
  302. btc_gap_bt_args_t arg;
  303. if (esp_bluedroid_get_status() != ESP_BLUEDROID_STATUS_ENABLED) {
  304. return ESP_ERR_INVALID_STATE;
  305. }
  306. msg.sig = BTC_SIG_API_CALL;
  307. msg.pid = BTC_PID_GAP_BT;
  308. msg.act = BTC_GAP_BT_ACT_SET_AFH_CHANNELS;
  309. memcpy(&arg.set_afh_channels.channels, channels, ESP_BT_GAP_AFH_CHANNELS_LEN);
  310. arg.set_afh_channels.channels[ESP_BT_GAP_AFH_CHANNELS_LEN -1] &= 0x7F;
  311. return (btc_transfer_context(&msg, &arg, sizeof(btc_gap_bt_args_t), NULL) == BT_STATUS_SUCCESS ? ESP_OK : ESP_FAIL);
  312. }
  313. esp_err_t esp_bt_gap_read_remote_name(esp_bd_addr_t remote_bda)
  314. {
  315. btc_msg_t msg;
  316. btc_gap_bt_args_t arg;
  317. if (esp_bluedroid_get_status() != ESP_BLUEDROID_STATUS_ENABLED) {
  318. return ESP_ERR_INVALID_STATE;
  319. }
  320. msg.sig = BTC_SIG_API_CALL;
  321. msg.pid = BTC_PID_GAP_BT;
  322. msg.act = BTC_GAP_BT_ACT_READ_REMOTE_NAME;
  323. memcpy(&arg.rmt_name_bda, remote_bda, sizeof(bt_bdaddr_t));
  324. return (btc_transfer_context(&msg, &arg, sizeof(btc_gap_bt_args_t), NULL) == BT_STATUS_SUCCESS ? ESP_OK : ESP_FAIL);
  325. }
  326. esp_err_t esp_bt_gap_set_qos(esp_bd_addr_t remote_bda, uint32_t t_poll)
  327. {
  328. btc_msg_t msg;
  329. btc_gap_bt_args_t arg;
  330. if (esp_bluedroid_get_status() != ESP_BLUEDROID_STATUS_ENABLED) {
  331. return ESP_ERR_INVALID_STATE;
  332. }
  333. msg.sig = BTC_SIG_API_CALL;
  334. msg.pid = BTC_PID_GAP_BT;
  335. msg.act = BTC_GAP_BT_ACT_SET_QOS;
  336. memcpy(&arg.set_qos.bda, remote_bda, sizeof(bt_bdaddr_t));
  337. arg.set_qos.t_poll = t_poll;
  338. return (btc_transfer_context(&msg, &arg, sizeof(btc_gap_bt_args_t), NULL) == BT_STATUS_SUCCESS ? ESP_OK : ESP_FAIL);
  339. }
  340. #endif /* #if BTC_GAP_BT_INCLUDED == TRUE */