esp_spp_api.c 6.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209
  1. /*
  2. * SPDX-FileCopyrightText: 2015-2021 Espressif Systems (Shanghai) CO LTD
  3. *
  4. * SPDX-License-Identifier: Apache-2.0
  5. */
  6. #include <string.h>
  7. #include "esp_bt_main.h"
  8. #include "btc/btc_manage.h"
  9. #include "btc_spp.h"
  10. #include "esp_spp_api.h"
  11. #include "common/bt_target.h"
  12. #if (defined BTC_SPP_INCLUDED && BTC_SPP_INCLUDED == TRUE)
  13. static const uint8_t UUID_SPP[16] = {0x00, 0x00, 0x11, 0x01, 0x00, 0x00, 0x10, 0x00,
  14. 0x80, 0x00, 0x00, 0x80, 0x5F, 0x9B, 0x34, 0xFB
  15. };
  16. static tSDP_UUID sdp_uuid;
  17. esp_err_t esp_spp_register_callback(esp_spp_cb_t callback)
  18. {
  19. ESP_BLUEDROID_STATUS_CHECK(ESP_BLUEDROID_STATUS_ENABLED);
  20. if (callback == NULL) {
  21. return ESP_FAIL;
  22. }
  23. btc_profile_cb_set(BTC_PID_SPP, callback);
  24. return ESP_OK;
  25. }
  26. esp_err_t esp_spp_init(esp_spp_mode_t mode)
  27. {
  28. btc_msg_t msg;
  29. btc_spp_args_t arg;
  30. ESP_BLUEDROID_STATUS_CHECK(ESP_BLUEDROID_STATUS_ENABLED);
  31. msg.sig = BTC_SIG_API_CALL;
  32. msg.pid = BTC_PID_SPP;
  33. msg.act = BTC_SPP_ACT_INIT;
  34. arg.init.mode = mode;
  35. return (btc_transfer_context(&msg, &arg, sizeof(btc_spp_args_t), NULL) == BT_STATUS_SUCCESS ? ESP_OK : ESP_FAIL);
  36. }
  37. esp_err_t esp_spp_deinit(void)
  38. {
  39. btc_msg_t msg;
  40. btc_spp_args_t arg;
  41. ESP_BLUEDROID_STATUS_CHECK(ESP_BLUEDROID_STATUS_ENABLED);
  42. msg.sig = BTC_SIG_API_CALL;
  43. msg.pid = BTC_PID_SPP;
  44. msg.act = BTC_SPP_ACT_UNINIT;
  45. return (btc_transfer_context(&msg, &arg, sizeof(btc_spp_args_t), NULL) == BT_STATUS_SUCCESS ? ESP_OK : ESP_FAIL);
  46. }
  47. esp_err_t esp_spp_start_discovery(esp_bd_addr_t bd_addr)
  48. {
  49. sdp_uuid.len = 16;
  50. memcpy(sdp_uuid.uu.uuid128, UUID_SPP, sizeof(sdp_uuid.uu.uuid128));
  51. btc_msg_t msg;
  52. btc_spp_args_t arg;
  53. ESP_BLUEDROID_STATUS_CHECK(ESP_BLUEDROID_STATUS_ENABLED);
  54. msg.sig = BTC_SIG_API_CALL;
  55. msg.pid = BTC_PID_SPP;
  56. msg.act = BTC_SPP_ACT_START_DISCOVERY;
  57. memcpy(arg.start_discovery.bd_addr, bd_addr, ESP_BD_ADDR_LEN);
  58. arg.start_discovery.num_uuid = 1;
  59. arg.start_discovery.p_uuid_list = &sdp_uuid;
  60. return (btc_transfer_context(&msg, &arg, sizeof(btc_spp_args_t), btc_spp_arg_deep_copy) == BT_STATUS_SUCCESS ? ESP_OK : ESP_FAIL);
  61. }
  62. esp_err_t esp_spp_connect(esp_spp_sec_t sec_mask,
  63. esp_spp_role_t role, uint8_t remote_scn, esp_bd_addr_t peer_bd_addr)
  64. {
  65. btc_msg_t msg;
  66. btc_spp_args_t arg;
  67. ESP_BLUEDROID_STATUS_CHECK(ESP_BLUEDROID_STATUS_ENABLED);
  68. if (sec_mask != ESP_SPP_SEC_NONE && sec_mask != ESP_SPP_SEC_AUTHORIZE && sec_mask != ESP_SPP_SEC_AUTHENTICATE) {
  69. LOG_WARN("Suggest to use ESP_SPP_SEC_NONE, ESP_SPP_SEC_AUTHORIZE or ESP_SPP_SEC_AUTHENTICATE only\n");
  70. }
  71. msg.sig = BTC_SIG_API_CALL;
  72. msg.pid = BTC_PID_SPP;
  73. msg.act = BTC_SPP_ACT_CONNECT;
  74. arg.connect.sec_mask = sec_mask;
  75. arg.connect.role = role;
  76. arg.connect.remote_scn = remote_scn;
  77. memcpy(arg.connect.peer_bd_addr, peer_bd_addr, ESP_BD_ADDR_LEN);
  78. return (btc_transfer_context(&msg, &arg, sizeof(btc_spp_args_t), NULL) == BT_STATUS_SUCCESS ? ESP_OK : ESP_FAIL);
  79. }
  80. esp_err_t esp_spp_disconnect(uint32_t handle)
  81. {
  82. btc_msg_t msg;
  83. btc_spp_args_t arg;
  84. ESP_BLUEDROID_STATUS_CHECK(ESP_BLUEDROID_STATUS_ENABLED);
  85. msg.sig = BTC_SIG_API_CALL;
  86. msg.pid = BTC_PID_SPP;
  87. msg.act = BTC_SPP_ACT_DISCONNECT;
  88. arg.disconnect.handle = handle;
  89. return (btc_transfer_context(&msg, &arg, sizeof(btc_spp_args_t), NULL) == BT_STATUS_SUCCESS ? ESP_OK : ESP_FAIL);
  90. }
  91. esp_err_t esp_spp_start_srv(esp_spp_sec_t sec_mask,
  92. esp_spp_role_t role, uint8_t local_scn, const char *name)
  93. {
  94. btc_msg_t msg;
  95. btc_spp_args_t arg;
  96. ESP_BLUEDROID_STATUS_CHECK(ESP_BLUEDROID_STATUS_ENABLED);
  97. if (name == NULL || strlen(name) > ESP_SPP_SERVER_NAME_MAX) {
  98. LOG_ERROR("Invalid server name!\n");
  99. return ESP_ERR_INVALID_ARG;
  100. }
  101. if (sec_mask != ESP_SPP_SEC_NONE && sec_mask != ESP_SPP_SEC_AUTHORIZE && sec_mask != ESP_SPP_SEC_AUTHENTICATE) {
  102. LOG_WARN("Suggest to use ESP_SPP_SEC_NONE, ESP_SPP_SEC_AUTHORIZE or ESP_SPP_SEC_AUTHENTICATE only\n");
  103. }
  104. msg.sig = BTC_SIG_API_CALL;
  105. msg.pid = BTC_PID_SPP;
  106. msg.act = BTC_SPP_ACT_START_SRV;
  107. arg.start_srv.sec_mask = sec_mask;
  108. arg.start_srv.role = role;
  109. arg.start_srv.local_scn = local_scn;
  110. arg.start_srv.max_session = ESP_SPP_MAX_SESSION;
  111. strcpy(arg.start_srv.name, name);
  112. return (btc_transfer_context(&msg, &arg, sizeof(btc_spp_args_t), NULL) == BT_STATUS_SUCCESS ? ESP_OK : ESP_FAIL);
  113. }
  114. esp_err_t esp_spp_stop_srv(void)
  115. {
  116. btc_msg_t msg;
  117. btc_spp_args_t arg;
  118. ESP_BLUEDROID_STATUS_CHECK(ESP_BLUEDROID_STATUS_ENABLED);
  119. msg.sig = BTC_SIG_API_CALL;
  120. msg.pid = BTC_PID_SPP;
  121. msg.act = BTC_SPP_ACT_STOP_SRV;
  122. arg.stop_srv.scn = BTC_SPP_INVALID_SCN;
  123. return (btc_transfer_context(&msg, &arg, sizeof(btc_spp_args_t), NULL) == BT_STATUS_SUCCESS ? ESP_OK : ESP_FAIL);
  124. }
  125. esp_err_t esp_spp_stop_srv_scn(uint8_t scn)
  126. {
  127. btc_msg_t msg;
  128. btc_spp_args_t arg;
  129. ESP_BLUEDROID_STATUS_CHECK(ESP_BLUEDROID_STATUS_ENABLED);
  130. if ((scn == 0) || (scn >= PORT_MAX_RFC_PORTS)) {
  131. LOG_ERROR("Invalid SCN!\n");
  132. return ESP_ERR_INVALID_ARG;
  133. }
  134. msg.sig = BTC_SIG_API_CALL;
  135. msg.pid = BTC_PID_SPP;
  136. msg.act = BTC_SPP_ACT_STOP_SRV;
  137. arg.stop_srv.scn = scn;
  138. return (btc_transfer_context(&msg, &arg, sizeof(btc_spp_args_t), NULL) == BT_STATUS_SUCCESS ? ESP_OK : ESP_FAIL);
  139. }
  140. esp_err_t esp_spp_write(uint32_t handle, int len, uint8_t *p_data)
  141. {
  142. btc_msg_t msg;
  143. btc_spp_args_t arg;
  144. ESP_BLUEDROID_STATUS_CHECK(ESP_BLUEDROID_STATUS_ENABLED);
  145. msg.sig = BTC_SIG_API_CALL;
  146. msg.pid = BTC_PID_SPP;
  147. msg.act = BTC_SPP_ACT_WRITE;
  148. arg.write.handle = handle;
  149. arg.write.len = len;
  150. arg.write.p_data = p_data;
  151. return (btc_transfer_context(&msg, &arg, sizeof(btc_spp_args_t), btc_spp_arg_deep_copy) == BT_STATUS_SUCCESS ? ESP_OK : ESP_FAIL);
  152. }
  153. esp_err_t esp_spp_vfs_register(void)
  154. {
  155. ESP_BLUEDROID_STATUS_CHECK(ESP_BLUEDROID_STATUS_ENABLED);
  156. return btc_spp_vfs_register();
  157. }
  158. #endif ///defined BTC_SPP_INCLUDED && BTC_SPP_INCLUDED == TRUE