wm_hfp_hsp_client.c 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472
  1. /*****************************************************************************
  2. **
  3. ** Name: wm_hfp_hsp_client.c
  4. **
  5. ** Description: This file contains the sample functions for bluetooth hand-free/hand-set profile client application
  6. **
  7. *****************************************************************************/
  8. #include <string.h>
  9. #include <stdint.h>
  10. #include <stdbool.h>
  11. #include <assert.h>
  12. #include "wm_bt_config.h"
  13. #if (WM_BTA_HFP_HSP_INCLUDED == CFG_ON)
  14. #include "wm_bt_hf_client.h"
  15. #include "wm_hfp_hsp_client.h"
  16. #include "wm_bt_util.h"
  17. #if (WM_AUDIO_BOARD_INCLUDED == CFG_ON)
  18. #include "audio.h"
  19. #endif
  20. const char *dump_hf_client_call_state(tls_bthf_client_call_state_t event);
  21. const char *dump_hf_client_call(tls_bthf_client_call_t event);
  22. const char *dump_hf_client_callsetup(tls_bthf_client_callsetup_t event);
  23. const char *dump_hf_client_callheld(tls_bthf_client_callheld_t event);
  24. const char *dump_hf_client_resp_and_hold(tls_bthf_client_resp_and_hold_t event);
  25. const char *dump_hf_client_call_direction(uint16_t event);
  26. const char *dump_hf_client_conn_state(tls_bthf_client_connection_state_t event);
  27. const char *dump_hf_client_audio_state(tls_bthf_client_audio_state_t event);
  28. #if (WM_AUDIO_BOARD_INCLUDED == CFG_ON)
  29. static uint32_t Stereo2Mono(void *audio_buf, uint32_t len, int LR)
  30. {
  31. if (!audio_buf || !len || len % 4) {
  32. printf( "%s arg err\n", __func__);
  33. return 0;
  34. }
  35. int16_t *buf = audio_buf;
  36. uint32_t i = 0;
  37. LR = LR ? 1 : 0;
  38. for (i = 0; i < len / 4; i++) {
  39. buf[i] = buf[i * 2 + LR];
  40. }
  41. return len / 2;
  42. }
  43. static void dump_sco_data(uint8_t *p_data,uint16_t length)
  44. {
  45. int i = 0;
  46. for(i=0; i<32; i++)
  47. {
  48. printf("%02x ", p_data[i]);
  49. }
  50. printf("\r\n");
  51. }
  52. /*SCO data to application*/
  53. int btif_co_sco_data_incoming(uint8_t type, uint8_t *p_data,uint16_t length)
  54. {
  55. dump_sco_data(p_data, length);
  56. FifoWrite(p_data, length);
  57. return length;
  58. }
  59. /*SCO data sent over HCI*/
  60. int btif_co_sco_data_outgoing(uint8_t type, uint8_t *p_data,uint16_t length)
  61. {
  62. memset(p_data, 0, length);
  63. return length;
  64. }
  65. #else
  66. /*SCO data to application*/
  67. int btif_co_sco_data_incoming(uint8_t type, uint8_t *p_data,uint16_t length)
  68. {
  69. return length;
  70. }
  71. /*SCO data sent over HCI*/
  72. int btif_co_sco_data_outgoing(uint8_t type, uint8_t *p_data,uint16_t length)
  73. {
  74. memset(p_data, 0, length);
  75. return length;
  76. }
  77. #endif
  78. void hfp_client_connection_state_cb(tls_bthf_client_connection_state_t state,
  79. unsigned int peer_feat,
  80. unsigned int chld_feat,
  81. tls_bt_addr_t *bd_addr)
  82. {
  83. TLS_BT_APPL_TRACE_DEBUG("hfp_client_connection_state_cb: state=%s\r\n", dump_hf_client_conn_state(state));
  84. }
  85. void hfp_client_audio_state_cb(tls_bthf_client_audio_state_t state,
  86. tls_bt_addr_t *bd_addr)
  87. {
  88. TLS_BT_APPL_TRACE_DEBUG("hfp_client_audio_state_cb: state=%s\r\n", dump_hf_client_audio_state(state));
  89. switch(state)
  90. {
  91. case WM_BTHF_CLIENT_AUDIO_STATE_DISCONNECTED:
  92. #if (WM_AUDIO_BOARD_INCLUDED == CFG_ON)
  93. PlayStop();
  94. #endif
  95. break;
  96. case WM_BTHF_CLIENT_AUDIO_STATE_CONNECTING:
  97. break;
  98. case WM_BTHF_CLIENT_AUDIO_STATE_CONNECTED:
  99. //break;
  100. case WM_BTHF_CLIENT_AUDIO_STATE_CONNECTED_MSBC:
  101. #if (WM_AUDIO_BOARD_INCLUDED == CFG_ON)
  102. PlayStart(8000, 16, 2);
  103. #endif
  104. break;
  105. }
  106. }
  107. void hfp_client_vr_cmd_cb(tls_bthf_client_vr_state_t state)
  108. {
  109. TLS_BT_APPL_TRACE_DEBUG("hfp_client_vr_cmd_cb: state=%d\r\n", state);
  110. }
  111. /** Callback for network state change
  112. */
  113. void hfp_client_network_state_cb(tls_bthf_client_network_state_t state)
  114. {
  115. TLS_BT_APPL_TRACE_DEBUG("hfp_client_network_state_cb: state=%d\r\n", state);
  116. }
  117. /** Callback for network roaming status change
  118. */
  119. void hfp_client_network_roaming_cb(tls_bthf_client_service_type_t type)
  120. {
  121. TLS_BT_APPL_TRACE_DEBUG("hfp_client_network_roaming_cb, type=%d\r\n", type);
  122. }
  123. /** Callback for signal strength indication
  124. */
  125. void hfp_client_network_signal_cb(int signal_strength)
  126. {
  127. TLS_BT_APPL_TRACE_DEBUG("hfp_client_network_signal_cb(%d)\r\n", signal_strength);
  128. }
  129. /** Callback for battery level indication
  130. */
  131. void hfp_client_battery_level_cb(int battery_level)
  132. {
  133. TLS_BT_APPL_TRACE_DEBUG("hfp_client_battery_level_cb, battery_level=%d\r\n", battery_level);
  134. }
  135. /** Callback for current operator name
  136. */
  137. void hfp_client_current_operator_cb(const char *name)
  138. {
  139. TLS_BT_APPL_TRACE_DEBUG("hfp_client_current_operator_cb, name=%s\r\n", name);
  140. }
  141. /** Callback for call indicator
  142. */
  143. void hfp_client_call_cb(tls_bthf_client_call_t call)
  144. {
  145. TLS_BT_APPL_TRACE_DEBUG("hfp_client_call_cb,call=%s\r\n", dump_hf_client_call(call));
  146. }
  147. /** Callback for callsetup indicator
  148. */
  149. void hfp_client_callsetup_cb(tls_bthf_client_callsetup_t callsetup)
  150. {
  151. TLS_BT_APPL_TRACE_DEBUG("hfp_client_callsetup_cb, callsetup=%s\r\n", dump_hf_client_callsetup(callsetup));
  152. ;
  153. }
  154. /** Callback for callheld indicator
  155. */
  156. void hfp_client_callheld_cb(tls_bthf_client_callheld_t callheld)
  157. {
  158. TLS_BT_APPL_TRACE_DEBUG("hfp_client_callheld_cb, callheld=%s\r\n", dump_hf_client_callheld(callheld));
  159. }
  160. /** Callback for response and hold
  161. */
  162. void hfp_client_resp_and_hold_cb(tls_bthf_client_resp_and_hold_t resp_and_hold)
  163. {
  164. TLS_BT_APPL_TRACE_DEBUG("hfp_client_resp_and_hold_cb, resp_and_hold=%s\r\n", dump_hf_client_resp_and_hold(resp_and_hold));
  165. }
  166. /** Callback for Calling Line Identification notification
  167. * Will be called only when there is an incoming call and number is provided.
  168. */
  169. void hfp_client_clip_cb(const char *number)
  170. {
  171. TLS_BT_APPL_TRACE_DEBUG("hfp_client_clip_cb, number=%s\r\n", number);
  172. }
  173. /**
  174. * Callback for Call Waiting notification
  175. */
  176. void hfp_client_call_waiting_cb(const char *number)
  177. {
  178. TLS_BT_APPL_TRACE_DEBUG("hfp_client_call_waiting_cb, number=%s\r\n", number);
  179. }
  180. /**
  181. * Callback for listing current calls. Can be called multiple time.
  182. * If number is unknown NULL is passed.
  183. */
  184. void hfp_client_current_calls_cb(int index, tls_bthf_client_call_direction_t dir,
  185. tls_bthf_client_call_state_t state,
  186. tls_bthf_client_call_mpty_type_t mpty,
  187. const char *number)
  188. {
  189. TLS_BT_APPL_TRACE_DEBUG("hfp_client_current_calls_cb, bthf_client_call_state_t=%s, number=%s\r\n", dump_hf_client_call_state(state), number);
  190. }
  191. /** Callback for audio volume change
  192. */
  193. void hfp_client_volume_change_cb(tls_bthf_client_volume_type_t type, int volume)
  194. {
  195. TLS_BT_APPL_TRACE_DEBUG("hfp_client_volume_change_cb, type=%d, volume=%d\r\n", type, volume);
  196. }
  197. /** Callback for command complete event
  198. * cme is valid only for BTHF_CLIENT_CMD_COMPLETE_ERROR_CME type
  199. */
  200. void hfp_client_cmd_complete_cb(tls_bthf_client_cmd_complete_t type, int cme)
  201. {
  202. TLS_BT_APPL_TRACE_DEBUG("hfp_client_cmd_complete_cb, type=%d\r\n", type);
  203. }
  204. /** Callback for subscriber information
  205. */
  206. void hfp_client_subscriber_info_cb(const char *name,
  207. tls_bthf_client_subscriber_service_type_t type)
  208. {
  209. TLS_BT_APPL_TRACE_DEBUG("hfp_client_subscriber_info_cb, name=%s, type=%d\r\n", name, type);
  210. }
  211. /** Callback for in-band ring tone settings
  212. */
  213. void hfp_client_in_band_ring_tone_cb(tls_bthf_client_in_band_ring_state_t state)
  214. {
  215. TLS_BT_APPL_TRACE_DEBUG("hfp_client_in_band_ring_tone_cb, in_band_ring_state=%d\r\n", state);
  216. }
  217. /**
  218. * Callback for requested number from AG
  219. */
  220. void hfp_client_last_voice_tag_number_cb(const char *number)
  221. {
  222. TLS_BT_APPL_TRACE_DEBUG("hfp_client_last_voice_tag_number_cb\r\n");
  223. }
  224. /**
  225. * Callback for sending ring indication to app
  226. */
  227. void hfp_client_ring_indication_cb(void)
  228. {
  229. TLS_BT_APPL_TRACE_DEBUG("hfp_client_ring_indication_cb\r\n");
  230. }
  231. static void wm_bt_hfp_client_callback(tls_bthf_client_evt_t evt, tls_bthf_client_msg_t *msg)
  232. {
  233. switch(evt)
  234. {
  235. case WM_BTHF_CLIENT_CONNECTION_STATE_EVT:
  236. hfp_client_connection_state_cb(msg->connection_state_msg.state, msg->connection_state_msg.peer_feat, msg->connection_state_msg.chld_feat, msg->connection_state_msg.bd_addr);
  237. break;
  238. case WM_BTHF_CLIENT_AUDIO_STATE_EVT:
  239. hfp_client_audio_state_cb(msg->audio_state_msg.state, msg->audio_state_msg.bd_addr);
  240. break;
  241. case WM_BTHF_CLIENT_VR_CMD_EVT:
  242. hfp_client_vr_cmd_cb(msg->vr_cmd_msg.state);
  243. break;
  244. case WM_BTHF_CLIENT_NETWORK_STATE_EVT:
  245. hfp_client_network_state_cb(msg->network_state_msg.state);
  246. break;
  247. case WM_BTHF_CLIENT_NETWORK_ROAMING_EVT:
  248. hfp_client_network_roaming_cb(msg->network_roaming_msg.type);
  249. break;
  250. case WM_BTHF_CLIENT_NETWORK_SIGNAL_EVT:
  251. hfp_client_network_signal_cb(msg->network_signal_msg.signal_strength);
  252. break;
  253. case WM_BTHF_CLIENT_BATTERY_LEVEL_EVT:
  254. hfp_client_battery_level_cb(msg->battery_level_msg.battery_level);
  255. break;
  256. case WM_BTHF_CLIENT_CURRENT_OPERATOR_EVT:
  257. hfp_client_current_operator_cb(msg->current_operator_msg.name);
  258. break;
  259. case WM_BTHF_CLIENT_CALL_EVT:
  260. hfp_client_call_cb(msg->call_msg.call);
  261. break;
  262. case WM_BTHF_CLIENT_CALLSETUP_EVT:
  263. hfp_client_callsetup_cb(msg->callsetup_msg.callsetup);
  264. break;
  265. case WM_BTHF_CLIENT_CALLHELD_EVT:
  266. hfp_client_callheld_cb(msg->callheld_msg.callheld);
  267. break;
  268. case WM_BTHF_CLIENT_RESP_AND_HOLD_EVT:
  269. hfp_client_resp_and_hold_cb(msg->resp_and_hold_msg.resp_and_hold);
  270. break;
  271. case WM_BTHF_CLIENT_CLIP_EVT:
  272. hfp_client_clip_cb(msg->clip_msg.number);
  273. break;
  274. case WM_BTHF_CLIENT_CALL_WAITING_EVT:
  275. hfp_client_call_waiting_cb(msg->call_waiting_msg.number);
  276. break;
  277. case WM_BTHF_CLIENT_CURRENT_CALLS_EVT:
  278. hfp_client_current_calls_cb(msg->current_calls_msg.index, msg->current_calls_msg.dir, msg->current_calls_msg.state, msg->current_calls_msg.mpty, msg->current_calls_msg.number);
  279. break;
  280. case WM_BTHF_CLIENT_VOLUME_CHANGE_EVT:
  281. hfp_client_volume_change_cb(msg->volume_change_msg.type, msg->volume_change_msg.volume);
  282. break;
  283. case WM_BTHF_CLIENT_CMD_COMPLETE_EVT:
  284. hfp_client_cmd_complete_cb(msg->cmd_complete_msg.type, msg->cmd_complete_msg.cme);
  285. break;
  286. case WM_BTHF_CLIENT_SUBSCRIBER_INFO_EVT:
  287. hfp_client_subscriber_info_cb(msg->subscriber_info_msg.name, msg->subscriber_info_msg.type);
  288. break;
  289. case WM_BTHF_CLIENT_IN_BAND_RING_TONE_EVT:
  290. hfp_client_in_band_ring_tone_cb(msg->in_band_ring_tone_msg.state);
  291. break;
  292. case WM_BTHF_CLIENT_LAST_VOICE_TAG_NUMBER_EVT:
  293. hfp_client_last_voice_tag_number_cb(msg->last_voice_tag_number_msg.number);
  294. break;
  295. case WM_BTHF_CLIENT_RING_INDICATION_EVT:
  296. hfp_client_ring_indication_cb();
  297. break;
  298. default:
  299. TLS_BT_APPL_TRACE_WARNING("Unknown hfp client callback evt:%d\r\n", evt);
  300. break;
  301. }
  302. }
  303. tls_bt_status_t tls_bt_enable_hfp_client()
  304. {
  305. tls_bt_status_t status;
  306. status = tls_bt_hf_client_init(wm_bt_hfp_client_callback);
  307. return status;
  308. }
  309. tls_bt_status_t tls_bt_disable_hfp_client()
  310. {
  311. tls_bt_status_t status;
  312. status = tls_bt_hf_client_deinit();
  313. return status;
  314. }
  315. tls_bt_status_t tls_bt_dial_number(const char* number)
  316. {
  317. TLS_BT_APPL_TRACE_DEBUG("tls_bt_dial_number:%s\r\n", number);
  318. return tls_bt_hf_client_dial(number);
  319. }
  320. #ifndef CASE_RETURN_STR
  321. #define CASE_RETURN_STR(const) case const: return #const;
  322. #endif
  323. const char *dump_hf_client_call_state(tls_bthf_client_call_state_t event)
  324. {
  325. switch(event)
  326. {
  327. CASE_RETURN_STR(WM_BTHF_CLIENT_CALL_STATE_ACTIVE)
  328. CASE_RETURN_STR(WM_BTHF_CLIENT_CALL_STATE_HELD)
  329. CASE_RETURN_STR(WM_BTHF_CLIENT_CALL_STATE_DIALING)
  330. CASE_RETURN_STR(WM_BTHF_CLIENT_CALL_STATE_ALERTING)
  331. CASE_RETURN_STR(WM_BTHF_CLIENT_CALL_STATE_INCOMING)
  332. CASE_RETURN_STR(WM_BTHF_CLIENT_CALL_STATE_WAITING)
  333. CASE_RETURN_STR(WM_BTHF_CLIENT_CALL_STATE_HELD_BY_RESP_HOLD)
  334. default:
  335. return "UNKNOWN MSG ID(call_state)";
  336. }
  337. }
  338. const char *dump_hf_client_call(tls_bthf_client_call_t event)
  339. {
  340. switch(event)
  341. {
  342. CASE_RETURN_STR(WM_BTHF_CLIENT_CALL_NO_CALLS_IN_PROGRESS)
  343. CASE_RETURN_STR(WM_BTHF_CLIENT_CALL_CALLS_IN_PROGRESS)
  344. default:
  345. return "UNKNOWN MSG ID(call)";
  346. }
  347. }
  348. const char *dump_hf_client_callsetup(tls_bthf_client_callsetup_t event)
  349. {
  350. switch(event)
  351. {
  352. CASE_RETURN_STR(WM_BTHF_CLIENT_CALLSETUP_NONE)
  353. CASE_RETURN_STR(WM_BTHF_CLIENT_CALLSETUP_INCOMING)
  354. CASE_RETURN_STR(WM_BTHF_CLIENT_CALLSETUP_OUTGOING)
  355. CASE_RETURN_STR(WM_BTHF_CLIENT_CALLSETUP_ALERTING)
  356. default:
  357. return "UNKNOWN MSG ID(callheld)";
  358. }
  359. }
  360. const char *dump_hf_client_callheld(tls_bthf_client_callheld_t event)
  361. {
  362. switch(event)
  363. {
  364. CASE_RETURN_STR(WM_BTHF_CLIENT_CALLHELD_NONE)
  365. CASE_RETURN_STR(WM_BTHF_CLIENT_CALLHELD_HOLD_AND_ACTIVE)
  366. CASE_RETURN_STR(WM_BTHF_CLIENT_CALLHELD_HOLD)
  367. default:
  368. return "UNKNOWN MSG ID(callheld)";
  369. }
  370. }
  371. const char *dump_hf_client_resp_and_hold(tls_bthf_client_resp_and_hold_t event)
  372. {
  373. switch(event)
  374. {
  375. CASE_RETURN_STR(WM_BTHF_CLIENT_RESP_AND_HOLD_HELD)
  376. CASE_RETURN_STR(WM_BTRH_CLIENT_RESP_AND_HOLD_ACCEPT)
  377. CASE_RETURN_STR(WM_BTRH_CLIENT_RESP_AND_HOLD_REJECT)
  378. default:
  379. return "UNKNOWN MSG ID(hf_client_resp_and_hold)";
  380. }
  381. }
  382. const char *dump_hf_client_call_direction(uint16_t event)
  383. {
  384. switch(event)
  385. {
  386. CASE_RETURN_STR(WM_BTHF_CLIENT_CALL_DIRECTION_OUTGOING)
  387. CASE_RETURN_STR(WM_BTHF_CLIENT_CALL_DIRECTION_INCOMING)
  388. default:
  389. return "UNKNOWN MSG ID(hf_client_call_direction)";
  390. }
  391. }
  392. const char *dump_hf_client_conn_state(tls_bthf_client_connection_state_t event)
  393. {
  394. switch(event)
  395. {
  396. CASE_RETURN_STR(WM_BTHF_CLIENT_CONNECTION_STATE_DISCONNECTED)
  397. CASE_RETURN_STR(WM_BTHF_CLIENT_CONNECTION_STATE_CONNECTING)
  398. CASE_RETURN_STR(WM_BTHF_CLIENT_CONNECTION_STATE_CONNECTED)
  399. CASE_RETURN_STR(WM_BTHF_CLIENT_CONNECTION_STATE_SLC_CONNECTED)
  400. CASE_RETURN_STR(WM_BTHF_CLIENT_CONNECTION_STATE_DISCONNECTING)
  401. default:
  402. return "UNKNOWN MSG ID(hf_client_conn_state)";
  403. }
  404. }
  405. const char *dump_hf_client_audio_state(tls_bthf_client_audio_state_t event)
  406. {
  407. switch(event)
  408. {
  409. CASE_RETURN_STR(WM_BTHF_CLIENT_AUDIO_STATE_DISCONNECTED)
  410. CASE_RETURN_STR(WM_BTHF_CLIENT_AUDIO_STATE_CONNECTING)
  411. CASE_RETURN_STR(WM_BTHF_CLIENT_AUDIO_STATE_CONNECTED)
  412. CASE_RETURN_STR(WM_BTHF_CLIENT_AUDIO_STATE_CONNECTED_MSBC)
  413. default:
  414. return "UNKNOWN MSG ID(hf_client_audio_state)";
  415. }
  416. }
  417. #endif