slave.c 50 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618
  1. #include "ble_comm.h"
  2. #include "ble_advertising.h"
  3. #include "ble_conn_params.h"
  4. #include "nrf_ble_qwr.h"
  5. #include "nrf_fstorage.h"
  6. #include "nrf_soc.h"
  7. #include "ble_nus.h"
  8. #include "bsp_time.h"
  9. #include "system.h"
  10. #include "app_flash.h"
  11. // <<< Use Configuration Wizard in Context Menu >>>\r\n
  12. #define APP_ADV_INTERVAL 320 /**< The advertising interval (in units of 0.625 ms). This value corresponds to 187.5 ms. */
  13. #define APP_ADV_DURATION 18000 /**< The advertising duration (180 seconds) in units of 10 milliseconds. */
  14. #define FIRST_CONN_PARAMS_UPDATE_DELAY APP_TIMER_TICKS(1000) /**< Time from initiating event (connect or start of notification) to first time sd_ble_gap_conn_param_update is called (5 seconds). */
  15. #define NEXT_CONN_PARAMS_UPDATE_DELAY APP_TIMER_TICKS(5000) /**< Time between each call to sd_ble_gap_conn_param_update after the first call (30 seconds). */
  16. #define MAX_CONN_PARAMS_UPDATE_COUNT 1
  17. static char DEVICE_NAME[TARFET_LEN_MAX] = "SH";
  18. #if USE_LADDR == 1
  19. char BleReallyName[TARFET_LEN_MAX] = {0};
  20. #endif
  21. #define MIN_CONN_INTERVAL MSEC_TO_UNITS(7.5, UNIT_1_25_MS) /**< Minimum acceptable connection interval (20 ms), Connection interval uses 1.25 ms units. */
  22. #define MAX_CONN_INTERVAL MSEC_TO_UNITS(1.25 * 1599, UNIT_1_25_MS) /**< Maximum acceptable connection interval (75 ms), Connection interval uses 1.25 ms units. */
  23. #define SLAVE_LATENCY 0 /**< Slave latency. */
  24. #define CONN_SUP_TIMEOUT MSEC_TO_UNITS(4000, UNIT_10_MS)
  25. #define NUS_SERVICE_UUID_TYPE BLE_UUID_TYPE_VENDOR_BEGIN
  26. static ble_uuid_t m_adv_uuids[] =
  27. {
  28. {BLE_UUID_NUS_SERVICE, NUS_SERVICE_UUID_TYPE}};
  29. static unsigned char connect_to_client = 0;
  30. static Ble_receive_handler_t Rec_h = NULL;
  31. BLE_NUS_DEF(m_nus, NRF_SDH_BLE_TOTAL_LINK_COUNT);
  32. BLE_ADVERTISING_DEF(m_advertising);
  33. NRF_BLE_QWRS_DEF(m_qwr, NRF_SDH_BLE_TOTAL_LINK_COUNT);
  34. uint16_t m_conn_handle = BLE_CONN_HANDLE_INVALID;
  35. ble_gap_conn_params_t slave_conn_params = {0};
  36. static void nrf_qwr_error_handler(uint32_t nrf_error) //?óáDD′′í?ó2ù×÷
  37. {
  38. APP_ERROR_HANDLER(nrf_error);
  39. }
  40. //′ó BLE ?óêüêy?Y
  41. static void nus_data_handler(ble_nus_evt_t *p_evt)
  42. {
  43. if (p_evt->type == BLE_NUS_EVT_RX_DATA)
  44. {
  45. Rec_h((unsigned char *)(p_evt->params.rx_data.p_data), p_evt->params.rx_data.length);
  46. }
  47. }
  48. static void services_init(void) //·t??3?ê??ˉ
  49. {
  50. uint32_t err_code;
  51. ble_nus_init_t nus_init;
  52. nrf_ble_qwr_init_t qwr_init = {0};
  53. // Initialize Queued Write Module.
  54. qwr_init.error_handler = nrf_qwr_error_handler;
  55. for (uint32_t i = 0; i < NRF_SDH_BLE_TOTAL_LINK_COUNT; i++)
  56. {
  57. err_code = nrf_ble_qwr_init(&m_qwr[i], &qwr_init);
  58. APP_ERROR_CHECK(err_code);
  59. }
  60. // Initialize NUS.
  61. memset(&nus_init, 0, sizeof(nus_init));
  62. nus_init.data_handler = nus_data_handler;
  63. err_code = ble_nus_init(&m_nus, &nus_init);
  64. APP_ERROR_CHECK(err_code);
  65. }
  66. static void on_adv_evt(ble_adv_evt_t ble_adv_evt) //1?2¥ê??t
  67. {
  68. switch (ble_adv_evt)
  69. {
  70. case BLE_ADV_EVT_FAST:
  71. {
  72. BLE_PRINT("Fast advertising.\r\n");
  73. }
  74. break;
  75. case BLE_ADV_EVT_IDLE:
  76. {
  77. BLE_PRINT("on_adv_evt->BLE_ADV_EVT_IDLE\r\n");
  78. ret_code_t err_code = ble_advertising_start(&m_advertising, BLE_ADV_MODE_FAST); //?aê?1?2¥
  79. APP_ERROR_CHECK(err_code);
  80. }
  81. break;
  82. default:
  83. // No implementation needed.
  84. break;
  85. }
  86. }
  87. static void advertising_init(void)
  88. {
  89. uint32_t err_code;
  90. ble_advertising_init_t init;
  91. int8_t txpower = 4;
  92. memset(&init, 0, sizeof(init));
  93. init.advdata.name_type = BLE_ADVDATA_FULL_NAME;
  94. init.advdata.include_appearance = false;
  95. init.advdata.flags = BLE_GAP_ADV_FLAGS_LE_ONLY_LIMITED_DISC_MODE;
  96. init.advdata.p_tx_power_level = &txpower;
  97. init.srdata.uuids_complete.uuid_cnt = sizeof(m_adv_uuids) / sizeof(m_adv_uuids[0]);
  98. init.srdata.uuids_complete.p_uuids = m_adv_uuids;
  99. init.config.ble_adv_fast_enabled = true;
  100. init.config.ble_adv_fast_interval = APP_ADV_INTERVAL;
  101. init.config.ble_adv_fast_timeout = APP_ADV_DURATION;
  102. init.evt_handler = on_adv_evt;
  103. err_code = ble_advertising_init(&m_advertising, &init);
  104. APP_ERROR_CHECK(err_code);
  105. ble_advertising_conn_cfg_tag_set(&m_advertising, APP_BLE_CONN_CFG_TAG);
  106. }
  107. static void conn_params_error_handler(uint32_t nrf_error)
  108. {
  109. APP_ERROR_HANDLER(nrf_error);
  110. }
  111. static void conn_params_init(void)
  112. {
  113. ret_code_t err_code;
  114. ble_conn_params_init_t cp_init;
  115. memset(&cp_init, 0, sizeof(cp_init));
  116. cp_init.p_conn_params = NULL;
  117. cp_init.first_conn_params_update_delay = FIRST_CONN_PARAMS_UPDATE_DELAY;
  118. cp_init.next_conn_params_update_delay = NEXT_CONN_PARAMS_UPDATE_DELAY;
  119. cp_init.max_conn_params_update_count = MAX_CONN_PARAMS_UPDATE_COUNT;
  120. cp_init.start_on_notify_cccd_handle = BLE_CONN_HANDLE_INVALID; // Start upon connection.
  121. cp_init.disconnect_on_fail = true;
  122. cp_init.evt_handler = NULL; // Ignore events.
  123. cp_init.error_handler = conn_params_error_handler;
  124. err_code = ble_conn_params_init(&cp_init);
  125. APP_ERROR_CHECK(err_code);
  126. }
  127. void advertising_start(void)
  128. {
  129. ret_code_t err_code;
  130. err_code = ble_advertising_start(&m_advertising, BLE_ADV_MODE_FAST); //同时开始广播
  131. APP_ERROR_CHECK(err_code);
  132. }
  133. void advertising_stop(void)
  134. {
  135. ret_code_t err_code;
  136. err_code = sd_ble_gap_adv_stop(m_advertising.adv_handle); //停止广播
  137. APP_ERROR_CHECK(err_code);
  138. }
  139. bool ble_evt_is_advertising_timeout(ble_evt_t const *p_ble_evt)
  140. {
  141. return (p_ble_evt->header.evt_id == BLE_GAP_EVT_ADV_SET_TERMINATED);
  142. }
  143. static void multi_qwr_conn_handle_assign(uint16_t conn_handle)
  144. {
  145. for (uint32_t i = 0; i < NRF_SDH_BLE_TOTAL_LINK_COUNT; i++)
  146. {
  147. if (m_qwr[i].conn_handle == BLE_CONN_HANDLE_INVALID)
  148. {
  149. ret_code_t err_code = nrf_ble_qwr_conn_handle_assign(&m_qwr[i], conn_handle);
  150. APP_ERROR_CHECK(err_code);
  151. break;
  152. }
  153. }
  154. }
  155. #define slave_connected_evt_num_max 16
  156. static uint8_t slave_connected_evt_num = 0;
  157. static Ble_evt_cb ble_Slave_evt_cb[slave_connected_evt_num_max] = {0};
  158. int Ble_Slave_Connectd_Evt_Regist(Ble_evt_cb cb)
  159. {
  160. for (int i = 0; i < slave_connected_evt_num_max; i++)
  161. {
  162. if (ble_Slave_evt_cb[i] == cb)
  163. return -1;
  164. if (ble_Slave_evt_cb[i] == 0)
  165. {
  166. slave_connected_evt_num++;
  167. ble_Slave_evt_cb[i] = cb; //??μ÷oˉêy
  168. return 0;
  169. }
  170. }
  171. DEBUG_LOG( "ble_evt_Regist -> too many!\n");
  172. return -2;
  173. }
  174. void ble_slave_connected_evt_pcs(void)
  175. {
  176. for (int i = 0; i < slave_connected_evt_num; i++)
  177. { //DEBUG_LOG("time_cb[%d]=%d\n",i,time_cb[i]);
  178. if (ble_Slave_evt_cb[i])
  179. {
  180. ble_Slave_evt_cb[i](); //??μ÷oˉêy
  181. }
  182. }
  183. }
  184. #define slave_disconn_evt_num_max 16
  185. static uint8_t slave_disconn_evt_num = 0;
  186. static Ble_evt_cb ble_Slave_disconn_evt_cb[slave_disconn_evt_num_max] = {0};
  187. int Ble_Slave_Disconn_Evt_Regist(Ble_evt_cb cb)
  188. {
  189. for (int i = 0; i < slave_disconn_evt_num_max; i++)
  190. {
  191. if (ble_Slave_disconn_evt_cb[i] == cb)
  192. return -1;
  193. if (ble_Slave_disconn_evt_cb[i] == 0)
  194. {
  195. slave_disconn_evt_num++;
  196. ble_Slave_disconn_evt_cb[i] = cb; //??μ÷oˉêy
  197. return 0;
  198. }
  199. }
  200. DEBUG_LOG( "Ble_Slave_Disconn_Evt_Regist -> too many!\r\n");
  201. return -2;
  202. }
  203. void ble_slave_dicconn_evt_pcs(void)
  204. {
  205. for (int i = 0; i < slave_disconn_evt_num; i++)
  206. { //DEBUG_LOG("time_cb[%d]=%d\n",i,time_cb[i]);
  207. if (ble_Slave_disconn_evt_cb[i])
  208. {
  209. ble_Slave_disconn_evt_cb[i](); //??μ÷oˉêy
  210. }
  211. }
  212. }
  213. unsigned char slave_update_conn_interval_request_sta = 0;
  214. static ble_gap_phys_t const phys =
  215. {
  216. .rx_phys = BLE_GAP_PHY_1MBPS,
  217. .tx_phys = BLE_GAP_PHY_1MBPS,
  218. };
  219. static uint8_t _7_5ms_intervalFlag =0;
  220. uint8_t Slave_Get7_5ms_interval(void){
  221. return _7_5ms_intervalFlag;
  222. }
  223. void on_ble_peripheral_evt(ble_evt_t const *p_ble_evt) //×÷?a′óéè±?μ?′|àí
  224. {
  225. ret_code_t err_code;
  226. ble_gap_evt_t const *p_gap_evt = &p_ble_evt->evt.gap_evt;
  227. switch (p_ble_evt->header.evt_id)
  228. {
  229. case BLE_GAP_EVT_CONNECTED:{
  230. BLE_PRINT("on_ble_peripheral_evt -> BLE_GAP_EVT_CONNECTED\r\n");
  231. m_conn_handle = p_ble_evt->evt.gap_evt.conn_handle;
  232. multi_qwr_conn_handle_assign(p_ble_evt->evt.gap_evt.conn_handle); //QWR句柄分配
  233. err_code = sd_ble_gap_tx_power_set(BLE_GAP_TX_POWER_ROLE_CONN,m_conn_handle,4);
  234. APP_ERROR_CHECK(err_code);
  235. connect_to_client = 1;
  236. ble_slave_connected_evt_pcs();
  237. #if 1
  238. BLE_PRINT("PHY update request.");
  239. err_code = sd_ble_gap_phy_update(p_gap_evt->conn_handle, &phys);
  240. APP_ERROR_CHECK(err_code);
  241. #endif
  242. BLE_PRINT("Connection 0x%x Received ble gap evt data length update request.", p_ble_evt->evt.gap_evt.conn_handle);
  243. ble_gap_data_length_params_t dlp =
  244. {
  245. .max_rx_time_us= BLE_GAP_DATA_LENGTH_AUTO,
  246. .max_tx_time_us= BLE_GAP_DATA_LENGTH_AUTO,
  247. .max_rx_octets = BLE_GAP_DATA_LENGTH_AUTO,
  248. .max_tx_octets = BLE_GAP_DATA_LENGTH_AUTO,
  249. };
  250. err_code = sd_ble_gap_data_length_update(p_ble_evt->evt.gap_evt.conn_handle, &dlp, NULL);
  251. APP_ERROR_CHECK(err_code);
  252. sd_ble_gap_rssi_start(m_conn_handle, BLE_GAP_RSSI_THRESHOLD_INVALID, 0);
  253. }
  254. break;
  255. case BLE_GAP_EVT_DISCONNECTED:
  256. connect_to_client = 0;
  257. ble_slave_dicconn_evt_pcs();
  258. sd_ble_gap_rssi_stop(m_conn_handle);
  259. _7_5ms_intervalFlag =0;
  260. BLE_PRINT("on_ble_peripheral_evt -> BLE_GAP_EVT_DISCONNECTED,reason:%d\r\n",p_gap_evt->params.disconnected.reason);
  261. break;
  262. case BLE_GAP_EVT_PHY_UPDATE_REQUEST:
  263. {
  264. BLE_PRINT("on_ble_peripheral_evt -> BLE_GAP_EVT_PHY_UPDATE_REQUEST\r\n");
  265. err_code = sd_ble_gap_phy_update(p_ble_evt->evt.gap_evt.conn_handle, &phys);
  266. APP_ERROR_CHECK(err_code);
  267. }
  268. break;
  269. case BLE_GATTC_EVT_TIMEOUT:
  270. // Disconnect on GATT Client timeout event.
  271. BLE_PRINT("on_ble_peripheral_evt -> BLE_GATTC_EVT_TIMEOUT\r\n");
  272. err_code = sd_ble_gap_disconnect(p_ble_evt->evt.gattc_evt.conn_handle,
  273. BLE_HCI_REMOTE_USER_TERMINATED_CONNECTION);
  274. APP_ERROR_CHECK(err_code);
  275. break;
  276. case BLE_GATTS_EVT_TIMEOUT:
  277. // Disconnect on GATT Server timeout event.
  278. BLE_PRINT("on_ble_peripheral_evt -> BLE_GATTS_EVT_TIMEOUT\r\n");
  279. err_code = sd_ble_gap_disconnect(p_ble_evt->evt.gatts_evt.conn_handle,
  280. BLE_HCI_REMOTE_USER_TERMINATED_CONNECTION);
  281. APP_ERROR_CHECK(err_code);
  282. break;
  283. case BLE_GAP_EVT_CONN_PARAM_UPDATE:
  284. {
  285. BLE_PRINT("on_ble_peripheral_evt -> BLE_GAP_EVT_CONN_PARAM_UPDATE\r\n");
  286. slave_update_conn_interval_request_sta = 0;
  287. memcpy(&slave_conn_params, &p_gap_evt->params.conn_param_update_request.conn_params, sizeof(ble_gap_conn_params_t));
  288. BLE_PRINT("min_conn_interval : %d * 1.25 ms\r\n", p_gap_evt->params.conn_param_update_request.conn_params.min_conn_interval);
  289. BLE_PRINT("max_conn_interval : %d * 1.25 ms\r\n", p_gap_evt->params.conn_param_update_request.conn_params.max_conn_interval);
  290. BLE_PRINT("slave_latency : %d\r\n", p_gap_evt->params.conn_param_update_request.conn_params.slave_latency);
  291. BLE_PRINT("conn_sup_timeout : %d * 10 ms\r\n", p_gap_evt->params.conn_param_update_request.conn_params.conn_sup_timeout);
  292. if(6 == p_gap_evt->params.conn_param_update_request.conn_params.min_conn_interval && 6 == p_gap_evt->params.conn_param_update_request.conn_params.max_conn_interval)
  293. _7_5ms_intervalFlag =1;
  294. else _7_5ms_intervalFlag =0;
  295. }BLE_PRINT("_7_5ms_intervalFlag : %d\r\n", _7_5ms_intervalFlag);
  296. break;
  297. case BLE_GAP_EVT_CONN_PARAM_UPDATE_REQUEST:
  298. {
  299. BLE_PRINT("on_ble_peripheral_evt -> BLE_GAP_EVT_CONN_PARAM_UPDATE_REQUEST\r\n");
  300. ble_gap_conn_params_t params;
  301. params = p_gap_evt->params.conn_param_update_request.conn_params;
  302. err_code = sd_ble_gap_conn_param_update(p_gap_evt->conn_handle, &params);
  303. BLE_PRINT("=====>BLE_GAP_EVT_CONN_PARAM_UPDATE_REQUEST error:%d\r\n",err_code);
  304. APP_ERROR_CHECK(err_code);
  305. memcpy(&slave_conn_params, &p_gap_evt->params.conn_param_update_request.conn_params, sizeof(ble_gap_conn_params_t));
  306. BLE_PRINT("min_conn_interval : %d * 1.25 ms\r\n", p_gap_evt->params.conn_param_update_request.conn_params.min_conn_interval);
  307. BLE_PRINT("max_conn_interval : %d * 1.25 ms\r\n", p_gap_evt->params.conn_param_update_request.conn_params.max_conn_interval);
  308. BLE_PRINT("slave_latency : %d\r\n", p_gap_evt->params.conn_param_update_request.conn_params.slave_latency);
  309. BLE_PRINT("conn_sup_timeout : %d * 10 ms\r\n", p_gap_evt->params.conn_param_update_request.conn_params.conn_sup_timeout);
  310. } break;
  311. case BLE_GAP_EVT_RSSI_CHANGED:
  312. BLE_PRINT("on_ble_peripheral_evt -> BLE_GAP_EVT_RSSI_CHANGED\r\n");
  313. break;
  314. case BLE_GAP_EVT_DATA_LENGTH_UPDATE_REQUEST:
  315. {
  316. BLE_PRINT("on_ble_peripheral_evt -> BLE_GAP_EVT_DATA_LENGTH_UPDATE_REQUEST\r\n");
  317. ble_gap_data_length_params_t const dlp =
  318. {
  319. .max_rx_octets = BLE_GAP_DATA_LENGTH_AUTO,
  320. .max_tx_octets = BLE_GAP_DATA_LENGTH_AUTO,
  321. };
  322. err_code = sd_ble_gap_data_length_update(p_ble_evt->evt.gap_evt.conn_handle, &dlp, NULL);
  323. APP_ERROR_CHECK(err_code);
  324. }
  325. break;
  326. case BLE_GAP_EVT_DATA_LENGTH_UPDATE:
  327. {
  328. BLE_PRINT("on_ble_peripheral_evt -> BLE_GAP_EVT_DATA_LENGTH_UPDATE\r\n");
  329. BLE_PRINT("max_rx_octets : %d \r\n", p_gap_evt->params.data_length_update.effective_params.max_rx_octets);
  330. BLE_PRINT("max_rx_time_us : %d \r\n", p_gap_evt->params.data_length_update.effective_params.max_rx_time_us);
  331. BLE_PRINT("max_tx_octets : %d \r\n", p_gap_evt->params.data_length_update.effective_params.max_tx_octets);
  332. BLE_PRINT("max_tx_time_us : %d \r\n", p_gap_evt->params.data_length_update.effective_params.max_tx_time_us);
  333. }
  334. break;
  335. case BLE_GAP_EVT_ADV_SET_TERMINATED:
  336. BLE_PRINT("on_ble_peripheral_evt -> BLE_GAP_EVT_ADV_SET_TERMINATED\r\n");
  337. break;
  338. case BLE_GATTS_EVT_HVN_TX_COMPLETE:
  339. // BLE_PRINT("on_ble_peripheral_evt -> BLE_GATTS_EVT_HVN_TX_COMPLETE\r\n");
  340. break;
  341. case BLE_GATTS_EVT_WRITE: //D′è?2ù×÷ò??-íê3é
  342. // BLE_PRINT("on_ble_peripheral_evt -> BLE_GATTS_EVT_WRITE\r\n");
  343. break;
  344. case BLE_GATTC_EVT_EXCHANGE_MTU_RSP:
  345. // err_code = sd_ble_gattc_exchange_mtu_request(p_ble_evt->evt.gattc_evt.conn_handle,247);
  346. // APP_ERROR_CHECK(err_code);
  347. BLE_PRINT("on_ble_peripheral_evt -> BLE_GATTC_EVT_EXCHANGE_MTU_RSP -> server_rx_mtu = %d\r\n",p_ble_evt->evt.gattc_evt.params.exchange_mtu_rsp.server_rx_mtu);
  348. break;
  349. case BLE_GATTS_EVT_EXCHANGE_MTU_REQUEST://?÷?ú?ò′ó?úéê??mtuê±μ?ê??t
  350. {
  351. sd_ble_gatts_exchange_mtu_reply(m_conn_handle, NRF_SDH_BLE_GATT_MAX_MTU_SIZE);
  352. BLE_PRINT("on_ble_peripheral_evt -> BLE_GATTS_EVT_EXCHANGE_MTU_REQUEST -> client_rx_mtu=%d\r\n",p_ble_evt->evt.gatts_evt.params.exchange_mtu_request.client_rx_mtu);
  353. }break;
  354. default:
  355. BLE_PRINT("on_ble_peripheral_evt -> default : 0x%2x\r\n", p_ble_evt->header.evt_id);
  356. // No implementation needed.
  357. break;
  358. }
  359. }
  360. #if USE_LADDR == 1
  361. ble_gap_addr_t m_my_addr;
  362. char set_adv_name = 0;
  363. #endif
  364. static void gap_params_init(void) //GAP3?ê??ˉ
  365. {
  366. uint32_t err_code;
  367. ble_gap_conn_params_t gap_conn_params;
  368. ble_gap_conn_sec_mode_t sec_mode;
  369. BLE_GAP_CONN_SEC_MODE_SET_OPEN(&sec_mode);
  370. #if USE_LADDR == 1
  371. err_code = sd_ble_gap_addr_get(&m_my_addr);
  372. APP_ERROR_CHECK(err_code);
  373. if (set_adv_name == 0)
  374. {
  375. BLE_PRINT("MAC [ %02X %02X %02X %02X %02X %02X ]\r\n", m_my_addr.addr[0], m_my_addr.addr[1], m_my_addr.addr[2], m_my_addr.addr[3], m_my_addr.addr[4], m_my_addr.addr[5]);
  376. sprintf(BleReallyName, "%s_%02X%02X", DEVICE_NAME, m_my_addr.addr[4], m_my_addr.addr[5]);
  377. err_code = sd_ble_gap_device_name_set(&sec_mode,
  378. (const uint8_t *)BleReallyName,
  379. strlen(DEVICE_NAME) + 5);
  380. }
  381. else
  382. {
  383. err_code = sd_ble_gap_device_name_set(&sec_mode,
  384. (const uint8_t *)BleReallyName,
  385. strlen(BleReallyName));
  386. }
  387. BLE_PRINT(">>>>>>>name:%d,%s",set_adv_name,BleReallyName);
  388. #else
  389. err_code = sd_ble_gap_device_name_set(&sec_mode,
  390. (const uint8_t *)DEVICE_NAME,
  391. strlen(DEVICE_NAME));
  392. #endif
  393. APP_ERROR_CHECK(err_code);
  394. memset(&gap_conn_params, 0, sizeof(gap_conn_params));
  395. gap_conn_params.min_conn_interval = MIN_CONN_INTERVAL;
  396. gap_conn_params.max_conn_interval = MAX_CONN_INTERVAL;
  397. gap_conn_params.slave_latency = SLAVE_LATENCY;
  398. gap_conn_params.conn_sup_timeout = CONN_SUP_TIMEOUT;
  399. err_code = sd_ble_gap_ppcp_set(&gap_conn_params);
  400. APP_ERROR_CHECK(err_code);
  401. // err_code = sd_ble_gap_tx_power_set(BLE_GAP_TX_POWER_ROLE_CONN,m_conn_handle,0);
  402. // APP_ERROR_CHECK(err_code);
  403. }
  404. #if USEFIFO
  405. RINGFRAME_DEF(sbc,ringframe_size_1024);
  406. static unsigned int TIME_GetTicks_ms;
  407. unsigned int send_bytes_client(unsigned char *bytes, uint16_t len)
  408. {
  409. unsigned short length = len;
  410. if (connect_to_client)
  411. {
  412. do
  413. {
  414. if(ringframe_in(&sbc,bytes,length)==0)return 0;
  415. }while(ringframe_throw(&sbc)==0);
  416. Process_SetHoldOn(send_bytes_client_pcs,1);
  417. TIME_GetTicks_ms=TIME_GetTicks();
  418. return 0;
  419. }
  420. else
  421. {
  422. BLE_PRINT("send_bytes_client error. connect_to_client=0\r\n");
  423. return 1;
  424. }
  425. } //作为从机时发送数据给主机
  426. void send_bytes_client_pcs(void)
  427. {
  428. unsigned char sbuff[256];
  429. unsigned char len=0;
  430. while(ringframe_peek(&sbc,sbuff,&len)==0)
  431. {
  432. unsigned short length = len;
  433. uint32_t flag = 0;
  434. flag = ble_nus_data_send(&m_nus, sbuff, &length, m_conn_handle);
  435. if(flag==0)ringframe_throw(&sbc);
  436. else
  437. {
  438. if((TIME_GetTicks()-TIME_GetTicks_ms>100)||(TIME_GetTicks_ms>TIME_GetTicks()))
  439. {
  440. Process_SetHoldOn(send_bytes_client_pcs,0);
  441. }
  442. return;
  443. }
  444. }
  445. Process_SetHoldOn(send_bytes_client_pcs,0);
  446. }
  447. #else
  448. unsigned int send_bytes_client(unsigned char *bytes, uint16_t len)
  449. {
  450. unsigned int rev=0;
  451. unsigned short length = len;
  452. if (connect_to_client){
  453. rev=ble_nus_data_send(&m_nus, bytes, &length, m_conn_handle);
  454. return rev;
  455. }
  456. else{
  457. BLE_PRINT("send_bytes_client error. connect_to_client=0\r\n");
  458. return 1;
  459. }
  460. } //作为从机时发送数据给主机
  461. void send_bytes_client_pcs(void)
  462. {
  463. }
  464. #endif
  465. extern void timer_init(void);
  466. extern void power_management_init(void);
  467. extern void ble_stack_init(void);
  468. extern void gatt_init(void);
  469. extern char ble_stack_init_sta;
  470. extern uint8_t Get_isHost(void);
  471. #if USEMACNAME && USE_LADDR != 1
  472. ble_gap_addr_t mAddr;
  473. #endif
  474. void slave_init(Ble_receive_handler_t receive_handler)
  475. {
  476. static unsigned char init = 1;
  477. if (init)
  478. {
  479. if (receive_handler == NULL)
  480. {
  481. BLE_PRINT("slave_init -> param err \r\n");
  482. return;
  483. }
  484. Rec_h = receive_handler;
  485. if (ble_stack_init_sta)
  486. {
  487. timer_init(); //
  488. power_management_init(); //
  489. ble_stack_init(); //
  490. gatt_init(); //
  491. ble_stack_init_sta = 0;
  492. }
  493. #if USEMACNAME && USE_LADDR != 1
  494. if (!Get_isHost())
  495. {
  496. sd_ble_gap_addr_get(&mAddr);
  497. memset(DEVICE_NAME, 0, TARFET_LEN_MAX);
  498. sprintf(DEVICE_NAME, "%02X%02X%02X%02X%02X%02X", mAddr.addr[5], mAddr.addr[4], mAddr.addr[3], mAddr.addr[2], mAddr.addr[1], mAddr.addr[0]);
  499. }
  500. #endif
  501. gap_params_init();
  502. services_init();
  503. advertising_init();
  504. conn_params_init();
  505. advertising_start();
  506. init = 0;
  507. #if USE_LADDR
  508. BLE_PRINT("slave_init -> name [ %s ] \r\n", BleReallyName);
  509. #else
  510. BLE_PRINT("slave_init -> name [ %s ] \r\n", DEVICE_NAME);
  511. #endif
  512. }
  513. else
  514. {
  515. BLE_PRINT("slave_init -> err slave has init done \r\n");
  516. }
  517. }
  518. unsigned char slave_isconnect(void)
  519. {
  520. return connect_to_client;
  521. }
  522. unsigned int slave_set_adv_name(char *name, int len)
  523. {
  524. #if USE_LADDR == 1
  525. if (len > TARFET_LEN_MAX)
  526. return APP_ERR_OVERLENGTH;
  527. set_adv_name = 1;
  528. memset(BleReallyName, 0, TARFET_LEN_MAX);
  529. memcpy(BleReallyName, name, len);
  530. #else
  531. if (len > TARFET_LEN_MAX)
  532. return APP_ERR_OVERLENGTH;
  533. memset(DEVICE_NAME, 0, TARFET_LEN_MAX);
  534. memcpy(DEVICE_NAME, name, len);
  535. #endif
  536. return APP_SUCCESS;
  537. }
  538. void slave_get_advname_len(int *len)
  539. {
  540. *len = strlen(BleReallyName);
  541. }
  542. void slave_get_advname(char *name, int len)
  543. {
  544. memcpy(name,BleReallyName,len);
  545. }
  546. void slave_disconnect(void)
  547. {
  548. if (connect_to_client)
  549. sd_ble_gap_disconnect(m_conn_handle, BLE_HCI_REMOTE_USER_TERMINATED_CONNECTION);
  550. }
  551. unsigned int slave_update_conn_interval_request(float min_conn_interval, float max_conn_interval)
  552. {
  553. ret_code_t err_code;
  554. ble_gap_conn_params_t bgcp;
  555. if (slave_update_conn_interval_request_sta)
  556. return APP_ERR_BUSY;
  557. if (connect_to_client)
  558. {
  559. slave_update_conn_interval_request_sta = 1;
  560. if ((max_conn_interval > 1.25 * 1599) || (max_conn_interval < min_conn_interval))
  561. return APP_ERR_PARAMERR;
  562. if (min_conn_interval < 7.5f)
  563. return APP_ERR_PARAMERR;
  564. bgcp.max_conn_interval = MSEC_TO_UNITS(max_conn_interval, UNIT_1_25_MS);
  565. bgcp.min_conn_interval = MSEC_TO_UNITS(min_conn_interval, UNIT_1_25_MS);
  566. bgcp.conn_sup_timeout = MSEC_TO_UNITS(4000, UNIT_10_MS);
  567. bgcp.slave_latency = 0;
  568. BLE_PRINT("slave_update_conn_interval_request -> %d \r\n", bgcp.max_conn_interval);
  569. err_code = sd_ble_gap_conn_param_update(m_conn_handle, &bgcp);
  570. APP_ERROR_CHECK(err_code);
  571. return err_code;
  572. }
  573. else
  574. {
  575. return APP_ERR_DISCONN;
  576. }
  577. }
  578. void slave_get_conn_params(ble_gap_conn_params_t *p)
  579. {
  580. p->conn_sup_timeout = slave_conn_params.conn_sup_timeout;
  581. p->max_conn_interval = slave_conn_params.max_conn_interval;
  582. p->min_conn_interval = slave_conn_params.min_conn_interval;
  583. p->slave_latency = slave_conn_params.slave_latency;
  584. }
  585. void slave_adv_init(void)
  586. {
  587. gap_params_init(); //ìí?óμ?GAP3?ê??ˉ
  588. conn_params_init(); //ìí?óμ?á??ó2?êy3?ê??ˉ
  589. advertising_init(); //ìí?ó1?2¥3?ê??ˉ
  590. }
  591. static signed char rssi = 0;
  592. signed char slave_get_rssi(void)
  593. {
  594. unsigned char channel;
  595. if (connect_to_client == 0)
  596. return 1;
  597. sd_ble_gap_rssi_get(m_conn_handle, &rssi, &channel);
  598. // BLE_PRINT("rssi= %d channel=%d\r\n", rssi, channel);
  599. return rssi;
  600. }
  601. #if DEBUGBLE
  602. #define led 13
  603. #define tx 11 //1.1
  604. #define rx 12
  605. //#define LS -1611916254 //?a·¢°?
  606. //#define RS -889050188
  607. //#define LS 97376119 //31
  608. //#define RS 627878688 //32
  609. #define LS -1087551583 //1.1
  610. #define RS -957332282 //1.1
  611. #define PS -1372482754 //usb
  612. unsigned char buff[255];
  613. char start = 0;
  614. void host_r(unsigned char *p, int len)
  615. {
  616. BLE_PRINT("hr : %d,0x%x\r\n", len, p[0]);
  617. if (p[0] == 0xbb)
  618. {
  619. BLE_PRINT("hr -------------: 0xbb\r\n");
  620. SEGGER_RTT_Write(0, &p[1], len);
  621. }
  622. if (p[0] == 0xcc)
  623. {
  624. BLE_PRINT("hr -------------: 0xcc\r\n");
  625. }
  626. }
  627. #define TIMER_TICK 25
  628. #define TCUN 1000
  629. unsigned short cun = 0;
  630. unsigned short ts = 0;
  631. unsigned short rec[5] = {0};
  632. unsigned short recrtc[5] = {0};
  633. unsigned int rtc_cun = 0;
  634. void slave_r(unsigned char *p, int len)
  635. {
  636. if (p[0] == 0xaa)
  637. {
  638. cun++;
  639. ts = p[1];
  640. ts = ts << 8;
  641. ts += p[2];
  642. if (ts >= 1)
  643. {
  644. start = 1;
  645. rtc_cun = NRF_RTC2->COUNTER;
  646. }
  647. if (ts == TCUN)
  648. start = 0;
  649. if (start)
  650. {
  651. if (NRF_RTC2->COUNTER - rtc_cun < 1 * TIMER_TICK)
  652. recrtc[0]++;
  653. if ((NRF_RTC2->COUNTER - rtc_cun >= 1 * TIMER_TICK) && (NRF_RTC2->COUNTER - rtc_cun < 2 * TIMER_TICK))
  654. recrtc[1]++;
  655. if ((NRF_RTC2->COUNTER - rtc_cun >= 2 * TIMER_TICK) && (NRF_RTC2->COUNTER - rtc_cun < 3 * TIMER_TICK))
  656. recrtc[2]++;
  657. if ((NRF_RTC2->COUNTER - rtc_cun >= 3 * TIMER_TICK) && (NRF_RTC2->COUNTER - rtc_cun < 4 * TIMER_TICK))
  658. recrtc[3]++;
  659. if (NRF_RTC2->COUNTER - rtc_cun > 4 * TIMER_TICK)
  660. recrtc[4]++;
  661. rtc_cun = NRF_RTC2->COUNTER;
  662. }
  663. BLE_PRINT("sr : %d\r\n", ts);
  664. }
  665. if (p[0] == 0xbb)
  666. {
  667. buff[0] = 0xbb;
  668. int leng = sprintf(((char *)&buff[1]), "0 :%d,%d\r\n1 :%d,%d\r\n2 :%d,%d\r\n3 :%d,%d\r\n4 :%d,%d\r\n", rec[0], recrtc[0], rec[1], recrtc[1], rec[2], recrtc[2], rec[3], recrtc[3], rec[4], recrtc[4]);
  669. send_bytes_server(buff, leng);
  670. }
  671. if (p[0] == 0xcc)
  672. {
  673. BLE_PRINT("sr -------------: 0xcc\r\n");
  674. memset(rec, 0, 10);
  675. memset(recrtc, 0, 10);
  676. send_bytes_server(p, 3);
  677. }
  678. }
  679. #include "cli.h"
  680. nrf_radio_request_t radio_request_p;
  681. APP_TIMER_DEF(s_Timer);
  682. #define TEST_PERIOD APP_TIMER_TICKS(TIMER_TICK)
  683. unsigned short tims = 0;
  684. unsigned short stp = 0;
  685. void s_TimerCallback(void *arg)
  686. {
  687. if ((tims > 0) && (tims <= TCUN))
  688. {
  689. buff[0] = 0xaa;
  690. buff[1] = tims >> 8;
  691. buff[2] = tims;
  692. send_bytes_client(buff, 100);
  693. BLE_PRINT("send : %d\r\n", tims);
  694. tims++;
  695. }
  696. if (start)
  697. {
  698. if (cun > 4)
  699. cun = 4;
  700. rec[cun]++;
  701. cun = 0;
  702. }
  703. //·¢êy?Y??ê??ú
  704. if (*NRF_FICR->DEVICEID == LS) //×ó±?D?
  705. {
  706. if (start)
  707. {
  708. buff[0] = 0xaa;
  709. buff[1] = stp >> 8;
  710. buff[2] = stp;
  711. send_bytes_client(buff, 100);
  712. }
  713. stp++;
  714. }
  715. // nrf_gpio_pin_toggle(rx);
  716. //nrf_gpio_pin_write(rx, 0);
  717. // BLE_PRINT("error= %d\r\n", sd_radio_request(&radio_request_p));
  718. }
  719. void Radio_State(void)
  720. {
  721. switch (NRF_RADIO->STATE)
  722. {
  723. case RADIO_STATE_STATE_Disabled:
  724. BLE_PRINT("RADIO_STATE_STATE_Disabled\r\n");
  725. break;
  726. case RADIO_STATE_STATE_RxRu:
  727. BLE_PRINT("RADIO_STATE_STATE_RxRu\r\n");
  728. break;
  729. case RADIO_STATE_STATE_RxIdle:
  730. BLE_PRINT("RADIO_STATE_STATE_RxIdle\r\n");
  731. break;
  732. case RADIO_STATE_STATE_Rx:
  733. BLE_PRINT("RADIO_STATE_STATE_Rx\r\n");
  734. break;
  735. case RADIO_STATE_STATE_RxDisable:
  736. BLE_PRINT("RADIO_STATE_STATE_RxDisable\r\n");
  737. break;
  738. case RADIO_STATE_STATE_TxRu:
  739. BLE_PRINT("RADIO_STATE_STATE_TxRu\r\n");
  740. break;
  741. case RADIO_STATE_STATE_TxIdle:
  742. BLE_PRINT("RADIO_STATE_STATE_TxIdle\r\n");
  743. break;
  744. case RADIO_STATE_STATE_Tx:
  745. BLE_PRINT("RADIO_STATE_STATE_Tx\r\n");
  746. break;
  747. case RADIO_STATE_STATE_TxDisable:
  748. BLE_PRINT("RADIO_STATE_STATE_TxDisable\r\n");
  749. break;
  750. }
  751. }
  752. void unoioo(void)
  753. {
  754. Ble_update_conn_interval(7.5,7.5);
  755. }
  756. void unoioo_s(void)
  757. {
  758. slave_update_conn_interval_request(30, 30);
  759. scan_start();
  760. }
  761. void unoioo_s_d(void)
  762. {
  763. host_disconnect();
  764. scan_start();
  765. }
  766. void rtc_config(void)
  767. {
  768. NRF_RTC2->PRESCALER = 0; //??ò?oá????êy?÷?ó1,1024us
  769. NRF_RTC2->TASKS_START = 1;
  770. }
  771. #include "nrf_drv_timer.h"
  772. void radio_evt_conf(void);
  773. const nrf_drv_timer_t TIMER_RADIO = NRF_DRV_TIMER_INSTANCE(2);
  774. void timer_led_event_handler(nrf_timer_event_t event_type, void *p_context)
  775. {
  776. if (*NRF_FICR->DEVICEID == LS) //×ó±?D?
  777. {
  778. switch (event_type)
  779. {
  780. case NRF_TIMER_EVENT_COMPARE0: //320
  781. sd_radio_request(&radio_request_p);
  782. NRF_PPI->CHEN &= (~(PPI_CHENCLR_CH0_Enabled << PPI_CHEN_CH0_Pos) | (PPI_CHENCLR_CH1_Enabled << PPI_CHEN_CH1_Pos));
  783. break;
  784. case NRF_TIMER_EVENT_COMPARE1: //324
  785. sd_radio_request(&radio_request_p);
  786. break;
  787. case NRF_TIMER_EVENT_COMPARE2: //328
  788. sd_radio_request(&radio_request_p);
  789. break;
  790. case NRF_TIMER_EVENT_COMPARE3: //332
  791. NRF_PPI->CHEN |= (PPI_CHENCLR_CH0_Enabled << PPI_CHEN_CH0_Pos) | (PPI_CHENCLR_CH1_Enabled << PPI_CHEN_CH1_Pos);
  792. break;
  793. default:
  794. //Do nothing.
  795. break;
  796. }
  797. }
  798. if (*NRF_FICR->DEVICEID == RS) //óò±?D?
  799. {
  800. switch (event_type)
  801. {
  802. case NRF_TIMER_EVENT_COMPARE0: //320
  803. nrf_gpio_pin_write(tx, 1);
  804. break;
  805. case NRF_TIMER_EVENT_COMPARE1: //324
  806. nrf_gpio_pin_write(tx, 0);
  807. break;
  808. case NRF_TIMER_EVENT_COMPARE2: //328
  809. break;
  810. case NRF_TIMER_EVENT_COMPARE3: //332
  811. break;
  812. default:
  813. //Do nothing.
  814. break;
  815. }
  816. }
  817. }
  818. void timer_config(void)
  819. {
  820. uint32_t time_us = 5000; //Time(in miliseconds) between consecutive compare events.
  821. uint32_t time_ticks;
  822. uint32_t err_code = NRF_SUCCESS;
  823. nrf_drv_timer_config_t timer_cfg = NRF_DRV_TIMER_DEFAULT_CONFIG;
  824. err_code = nrf_drv_timer_init(&TIMER_RADIO, &timer_cfg, timer_led_event_handler);
  825. APP_ERROR_CHECK(err_code);
  826. if (*NRF_FICR->DEVICEID == LS) //×ó±?D?
  827. {
  828. time_ticks = nrf_drv_timer_us_to_ticks(&TIMER_RADIO, time_us);
  829. nrf_drv_timer_extended_compare(&TIMER_RADIO, NRF_TIMER_CC_CHANNEL0, time_ticks, 0, true);
  830. time_ticks = nrf_drv_timer_us_to_ticks(&TIMER_RADIO, time_us + 10000);
  831. nrf_drv_timer_extended_compare(&TIMER_RADIO, NRF_TIMER_CC_CHANNEL1, time_ticks, 0, true);
  832. time_ticks = nrf_drv_timer_us_to_ticks(&TIMER_RADIO, time_us + 20000);
  833. nrf_drv_timer_extended_compare(&TIMER_RADIO, NRF_TIMER_CC_CHANNEL2, time_ticks, 0, true);
  834. time_ticks = nrf_drv_timer_us_to_ticks(&TIMER_RADIO, 29000);
  835. nrf_drv_timer_extended_compare(&TIMER_RADIO, NRF_TIMER_CC_CHANNEL3, time_ticks, NRF_TIMER_SHORT_COMPARE3_CLEAR_MASK, true);
  836. }
  837. if (*NRF_FICR->DEVICEID == RS) //óò±?D?
  838. {
  839. time_us = 1000;
  840. time_ticks = nrf_drv_timer_us_to_ticks(&TIMER_RADIO, time_us);
  841. nrf_drv_timer_extended_compare(&TIMER_RADIO, NRF_TIMER_CC_CHANNEL0, time_ticks, 0, true);
  842. time_ticks = nrf_drv_timer_us_to_ticks(&TIMER_RADIO, time_us + 9000 + 1);
  843. nrf_drv_timer_extended_compare(&TIMER_RADIO, NRF_TIMER_CC_CHANNEL1, time_ticks, NRF_TIMER_SHORT_COMPARE1_CLEAR_MASK, true);
  844. nrf_drv_timer_enable(&TIMER_RADIO);
  845. }
  846. // nrf_drv_timer_enable(&TIMER_RADIO);
  847. }
  848. void ppi_set(void)
  849. {
  850. NRF_PPI->CH[0].EEP = (unsigned int)(&NRF_TIMER0->EVENTS_COMPARE[0]);
  851. NRF_PPI->CH[0].TEP = (unsigned int)(&NRF_TIMER2->TASKS_START);
  852. NRF_PPI->CH[1].EEP = (unsigned int)(&NRF_TIMER2->EVENTS_COMPARE[3]);
  853. NRF_PPI->CH[1].TEP = (unsigned int)(&NRF_TIMER2->TASKS_SHUTDOWN);
  854. NRF_PPI->CHEN |= (PPI_CHENCLR_CH0_Enabled << PPI_CHEN_CH0_Pos) |
  855. (PPI_CHENCLR_CH1_Enabled << PPI_CHEN_CH1_Pos);
  856. }
  857. extern void USR_Init(void);
  858. extern void USR_Process(void);
  859. extern void TIME_Init(void);
  860. extern char Target_scan[];
  861. unsigned char txbuff[300] = {0x0a, 0x03, 0, 0, 2, 3, 4, 5, 6, 0, 8, 9};
  862. unsigned char rxbuff[300] = {0};
  863. void radio_init_R(void)
  864. {
  865. NRF_RADIO->POWER = (RADIO_POWER_POWER_Enabled << RADIO_POWER_POWER_Pos);
  866. /* Start 16 MHz crystal oscillator */
  867. NRF_CLOCK->EVENTS_HFCLKSTARTED = 0;
  868. NRF_CLOCK->TASKS_HFCLKSTART = 1;
  869. /* Wait for the external oscillator to start up */
  870. while (NRF_CLOCK->EVENTS_HFCLKSTARTED == 0)
  871. {
  872. // Do nothing.
  873. }
  874. // Radio config
  875. NRF_RADIO->TXPOWER = (RADIO_TXPOWER_TXPOWER_0dBm << RADIO_TXPOWER_TXPOWER_Pos);
  876. NRF_RADIO->FREQUENCY = 7UL; // Frequency bin 7, 2407MHz
  877. NRF_RADIO->MODE = (RADIO_MODE_MODE_Nrf_1Mbit << RADIO_MODE_MODE_Pos);
  878. NRF_RADIO->PREFIX0 = 0xC3438303;
  879. NRF_RADIO->PREFIX1 = 0xE3630023;
  880. NRF_RADIO->BASE0 = 0x80C4A2E6;
  881. NRF_RADIO->BASE1 = 0x91D5B3F7;
  882. NRF_RADIO->TXADDRESS = 0x00UL; // Set device address 0 to use when transmitting
  883. NRF_RADIO->RXADDRESSES = 0x01UL; // Enable device address 0 to use to select which addresses to receive
  884. NRF_RADIO->PCNF0 = 0X00030006;
  885. NRF_RADIO->PCNF1 = 0X01040020;
  886. NRF_RADIO->CRCCNF = (RADIO_CRCCNF_LEN_Two << RADIO_CRCCNF_LEN_Pos); // Number of checksum bits
  887. NRF_RADIO->CRCINIT = 0xFFFFUL; // Initial value
  888. NRF_RADIO->CRCPOLY = 0x11021UL; // CRC poly: x^16 + x^12^x^5 + 1
  889. NRF_RADIO->PACKETPTR = (uint32_t)&txbuff[0];
  890. }
  891. #include "nrf_drv_rtc.h"
  892. const nrf_drv_rtc_t rtc = NRF_DRV_RTC_INSTANCE(0); /**< Declaring an instance of nrf_drv_rtc for RTC2. */
  893. unsigned int countevt = 0;
  894. void radio_connect(void)
  895. {
  896. NRF_RTC0->CC[2] = NRF_RTC0->COUNTER;
  897. countevt = 1;
  898. nrf_drv_rtc_cc_set(&rtc, 0, NRF_RTC0->CC[2] + countevt * 0.009 * 32768, true);
  899. countevt++;
  900. }
  901. void RADIO_IRQHandler(void)
  902. {
  903. if (NRF_RADIO->EVENTS_READY && (NRF_RADIO->INTENSET & RADIO_INTENSET_READY_Msk))
  904. {
  905. NRF_RADIO->EVENTS_READY = 0U;
  906. BLE_PRINT("a");
  907. }
  908. if (NRF_RADIO->EVENTS_ADDRESS && (NRF_RADIO->INTENSET & RADIO_INTENSET_ADDRESS_Msk))
  909. {
  910. NRF_RADIO->EVENTS_ADDRESS = 0U;
  911. BLE_PRINT("b");
  912. }
  913. if (NRF_RADIO->EVENTS_PAYLOAD && (NRF_RADIO->INTENSET & RADIO_INTENSET_PAYLOAD_Msk))
  914. {
  915. NRF_RADIO->EVENTS_PAYLOAD = 0U;
  916. BLE_PRINT("c");
  917. }
  918. if (NRF_RADIO->EVENTS_END && (NRF_RADIO->INTENSET & RADIO_INTENSET_END_Msk))
  919. {
  920. NRF_RADIO->EVENTS_END = 0U;
  921. // NRF_LOG_INFO("d");
  922. if (NRF_RADIO->STATE >= 5UL)
  923. {
  924. NRF_RADIO->EVENTS_DISABLED = 0U;
  925. NRF_RADIO->TASKS_DISABLE = 1U;
  926. nrf_gpio_pin_write(tx, 0);
  927. // BLE_PRINT("Tx end\r\n");
  928. }
  929. else
  930. {
  931. //ê?μ?êy?Yoó?è?D???a·¢?í?£ê?
  932. NRF_RTC0->CC[2] = NRF_RTC0->COUNTER;
  933. NRF_RADIO->PACKETPTR = (unsigned int)txbuff;
  934. NRF_RADIO->SHORTS = RADIO_SHORTS_READY_START_Msk;
  935. nrf_gpio_pin_write(tx, 0);
  936. NRF_RADIO->EVENTS_DISABLED = 0U;
  937. NRF_RADIO->TASKS_DISABLE = 1U;
  938. while (NRF_RADIO->EVENTS_DISABLED == 0)
  939. ;
  940. NRF_RADIO->TASKS_TXEN = 1;
  941. nrf_gpio_pin_write(tx, 1);
  942. nrf_drv_rtc_cc_set(&rtc, 0, NRF_RTC0->CC[2] + 0.010 * 32768, true);
  943. nrf_drv_rtc_cc_set(&rtc, 1, NRF_RTC0->CC[2] + 0.018 * 32768, true);
  944. for (int i = 0; i < 50; i++)
  945. {
  946. BLE_PRINT("%x", rxbuff[i]);
  947. }
  948. BLE_PRINT("Rx\r\n", rxbuff[1]);
  949. }
  950. }
  951. if (NRF_RADIO->EVENTS_DISABLED && (NRF_RADIO->INTENSET & RADIO_INTENSET_DISABLED_Msk))
  952. {
  953. NRF_RADIO->EVENTS_DISABLED = 0U;
  954. BLE_PRINT("e");
  955. }
  956. if (NRF_RADIO->EVENTS_DEVMATCH && (NRF_RADIO->INTENSET & RADIO_INTENSET_DEVMATCH_Msk))
  957. {
  958. NRF_RADIO->EVENTS_DEVMATCH = 0U;
  959. BLE_PRINT("f");
  960. }
  961. if (NRF_RADIO->EVENTS_DEVMISS && (NRF_RADIO->INTENSET & RADIO_INTENSET_DEVMISS_Msk))
  962. {
  963. NRF_RADIO->EVENTS_DEVMISS = 0U;
  964. BLE_PRINT("g");
  965. }
  966. if (NRF_RADIO->EVENTS_RSSIEND && (NRF_RADIO->INTENSET & RADIO_INTENSET_RSSIEND_Msk))
  967. {
  968. NRF_RADIO->EVENTS_RSSIEND = 0U;
  969. BLE_PRINT("h");
  970. }
  971. if (NRF_RADIO->EVENTS_BCMATCH && (NRF_RADIO->INTENSET & RADIO_INTENSET_BCMATCH_Msk))
  972. {
  973. NRF_RADIO->EVENTS_BCMATCH = 0U;
  974. BLE_PRINT("i");
  975. }
  976. if (NRF_RADIO->EVENTS_CRCOK && (NRF_RADIO->INTENSET & RADIO_INTENSET_CRCOK_Msk))
  977. {
  978. NRF_RADIO->EVENTS_CRCOK = 0U;
  979. BLE_PRINT("k");
  980. }
  981. if (NRF_RADIO->EVENTS_CRCERROR && (NRF_RADIO->INTENSET & RADIO_INTENSET_CRCERROR_Msk))
  982. {
  983. NRF_RADIO->EVENTS_CRCERROR = 0U;
  984. BLE_PRINT("l");
  985. }
  986. NVIC_ClearPendingIRQ(RADIO_IRQn);
  987. }
  988. void radio_scan_start(void)
  989. {
  990. NRF_RADIO->SHORTS = 0;
  991. NRF_RADIO->SHORTS |= RADIO_SHORTS_DISABLED_RXEN_Msk;
  992. NRF_RADIO->SHORTS |= RADIO_SHORTS_READY_START_Msk;
  993. NRF_RADIO->SHORTS |= RADIO_SHORTS_END_START_Msk;
  994. NRF_RADIO->INTENSET |= RADIO_INTENSET_END_Msk;
  995. NRF_RADIO->TASKS_RXEN = 1;
  996. NRF_RADIO->EVENTS_READY = 0;
  997. while (NRF_RADIO->EVENTS_READY == 0)
  998. {
  999. }
  1000. NRF_RADIO->TASKS_START = 1;
  1001. NVIC_EnableIRQ(RADIO_IRQn);
  1002. Radio_State();
  1003. }
  1004. static void rtc_handler(nrf_drv_rtc_int_type_t int_type)
  1005. {
  1006. switch (int_type)
  1007. {
  1008. case NRFX_RTC_INT_COMPARE0:
  1009. nrf_gpio_pin_write(tx, 1);
  1010. NRF_RADIO->SHORTS = RADIO_SHORTS_READY_START_Msk;
  1011. NRF_RADIO->PACKETPTR = (unsigned int)rxbuff;
  1012. NRF_RADIO->TASKS_RXEN = 1U;
  1013. break;
  1014. case NRFX_RTC_INT_COMPARE1:
  1015. Radio_State();
  1016. BLE_PRINT("NRFX_RTC_INT_COMPARE1\r\n");
  1017. break;
  1018. case NRFX_RTC_INT_COMPARE2:
  1019. break;
  1020. case NRFX_RTC_INT_COMPARE3:
  1021. break;
  1022. case NRFX_RTC_INT_TICK:
  1023. break;
  1024. case NRFX_RTC_INT_OVERFLOW:
  1025. nrf_drv_rtc_counter_clear(&rtc);
  1026. break;
  1027. }
  1028. }
  1029. /**********************************************************
  1030. * oˉêy??×?£ortc_config
  1031. * oˉêy×÷ó?£ortc?y?ˉ3?ê??ˉoíéè??
  1032. * oˉêy2?êy£o?T
  1033. * oˉêy·μ???μ£o?T
  1034. ***********************************************************/
  1035. void radio_rtc_config(void)
  1036. {
  1037. uint32_t err_code;
  1038. NRF_CLOCK->LFCLKSRC = (CLOCK_LFCLKSRC_SRC_RC << CLOCK_LFCLKSRC_SRC_Pos);
  1039. NRF_CLOCK->EVENTS_LFCLKSTARTED = 0;
  1040. NRF_CLOCK->TASKS_LFCLKSTART = 1;
  1041. while (NRF_CLOCK->EVENTS_LFCLKSTARTED == 0)
  1042. {
  1043. // Do nothing.
  1044. }
  1045. //Initialize RTC instance
  1046. nrf_drv_rtc_config_t config = NRF_DRV_RTC_DEFAULT_CONFIG;
  1047. config.prescaler = 0; //4095;????????=32768/(config.prescaler+1)Hz;
  1048. err_code = nrf_drv_rtc_init(&rtc, &config, rtc_handler);
  1049. APP_ERROR_CHECK(err_code);
  1050. //Enable tick event & interrupt
  1051. // nrf_drv_rtc_tick_enable(&rtc, true);
  1052. //Set compare channel to trigger interrupt after COMPARE_COUNTERTIME seconds
  1053. // err_code = nrf_drv_rtc_cc_set(&rtc, 0, 8, true);
  1054. // APP_ERROR_CHECK(err_code);
  1055. //Power on RTC instance
  1056. nrf_drv_rtc_enable(&rtc);
  1057. }
  1058. int main(void)
  1059. {
  1060. unsigned int error = 0;
  1061. unsigned int rtctemp = 0;
  1062. unsigned int start = 0;
  1063. unsigned int radio_dis_cun = 0;
  1064. unsigned int radio_dis_cun_rtc = 0;
  1065. nrf_gpio_cfg_output(led);
  1066. nrf_gpio_pin_write(led, 1);
  1067. nrf_gpio_cfg_output(tx);
  1068. nrf_gpio_pin_write(tx, 0);
  1069. nrf_gpio_cfg_output(8);
  1070. nrf_gpio_pin_write(8, 0);
  1071. nrf_gpio_cfg_output(rx);
  1072. nrf_gpio_pin_write(rx, 0);
  1073. BLE_PRINT("NRF_FICR->DEVICEID : %d\r\n", *NRF_FICR->DEVICEID);
  1074. if (*NRF_FICR->DEVICEID == RS) //óò±?D?
  1075. {
  1076. #if 1
  1077. slave_init(host_r);
  1078. #else
  1079. radio_init_R();
  1080. radio_rtc_config();
  1081. radio_scan_start();
  1082. #endif
  1083. BLE_PRINT("you \r\n");
  1084. }
  1085. if (*NRF_FICR->DEVICEID == LS) //×ó±?D?
  1086. {
  1087. #if 0
  1088. Target_scan[0]=0xe3; //3132
  1089. Target_scan[1]=0x3f;
  1090. Target_scan[2]=0xd9;
  1091. Target_scan[3]=0x0d;
  1092. Target_scan[4]=0x0e;
  1093. Target_scan[5]=0xc6;
  1094. sscanf("A1 A3 9D 04 E9 F4","%hhx %hhx %hhx %hhx %hhx %hhx",&Target_scan[0],&Target_scan[1],&Target_scan[2],&Target_scan[3],&Target_scan[4],&Target_scan[5]);
  1095. // Target_scan[0]=0x3C; //?a·¢°?
  1096. // Target_scan[1]=0x83;
  1097. // Target_scan[2]=0xCF;
  1098. // Target_scan[3]=0x49;
  1099. // Target_scan[4]=0x50;
  1100. // Target_scan[5]=0xE1;
  1101. //
  1102. #endif
  1103. Ble_Host_Connectd_Evt_Regist(unoioo);
  1104. Ble_Slave_Connectd_Evt_Regist(unoioo_s);
  1105. Ble_Slave_Disconn_Evt_Regist(unoioo_s_d);
  1106. // extern void radio_request_earliest(void);
  1107. // Ble_Slave_Connectd_Evt_Regist(radio_request_earliest);
  1108. slave_init(host_r);
  1109. host_init(slave_r);
  1110. // timer_config();
  1111. BLE_PRINT("zuo \r\n");
  1112. }
  1113. if (*NRF_FICR->DEVICEID == PS) //ê??ú
  1114. {
  1115. #if 0
  1116. Target_scan[0] = 0x21;
  1117. Target_scan[1] = 0x8a;
  1118. Target_scan[2] = 0x4f;
  1119. Target_scan[3] = 0x61;
  1120. Target_scan[4] = 0xcb;
  1121. Target_scan[5] = 0xe8;
  1122. #endif
  1123. host_set_scan_name("SH_13EC", 7);
  1124. BLE_PRINT("shou \r\n");
  1125. host_init(slave_r);
  1126. scan_start();
  1127. }
  1128. rtc_config();
  1129. for (int i = 1; i < 200; i++)
  1130. {
  1131. buff[i] = i + 0x30;
  1132. // txbuff[i]=i;
  1133. }
  1134. app_timer_create(&s_Timer, APP_TIMER_MODE_REPEATED, s_TimerCallback);
  1135. app_timer_start(s_Timer, TEST_PERIOD, NULL);
  1136. // ppi_set();
  1137. while (1)
  1138. {
  1139. cli_process(&clirtt);
  1140. if (NRF_SUCCESS == sd_evt_get(&error))
  1141. {
  1142. BLE_PRINT("shou \r\n");
  1143. }
  1144. // if (*NRF_FICR->DEVICEID == LS) //×ó±?D?
  1145. {
  1146. if (NRF_RADIO->STATE == RADIO_STATE_STATE_Disabled)
  1147. {
  1148. nrf_gpio_pin_write(tx, 0);
  1149. }
  1150. else
  1151. {
  1152. nrf_gpio_pin_write(tx, 1);
  1153. }
  1154. }
  1155. }
  1156. }
  1157. void host_init_pcs(cli_t *p_cli, unsigned short argc, char **argv)
  1158. {
  1159. host_init(slave_r);
  1160. }
  1161. CLI_CMD_REGISTER(host_init, "clear sereen", host_init_pcs);
  1162. void hsb_pcs(cli_t *p_cli, unsigned short argc, char **argv)
  1163. {
  1164. send_bytes_server(buff, 200);
  1165. }
  1166. CLI_CMD_REGISTER(hsb, "clear sereen", hsb_pcs);
  1167. void send_pcs(cli_t *p_cli, unsigned short argc, char **argv)
  1168. {
  1169. tims = 1;
  1170. }
  1171. CLI_CMD_REGISTER(send, "clear sereen", send_pcs);
  1172. void scc_pcs(cli_t *p_cli, unsigned short argc, char **argv)
  1173. {
  1174. buff[0] = 0xcc;
  1175. send_bytes_client(buff, 6);
  1176. }
  1177. CLI_CMD_REGISTER(scc, "clear sereen", scc_pcs);
  1178. void sbb_pcs(cli_t *p_cli, unsigned short argc, char **argv)
  1179. {
  1180. buff[0] = 0xbb;
  1181. send_bytes_client(buff, 6);
  1182. }
  1183. CLI_CMD_REGISTER(sbb, "clear sereen", sbb_pcs);
  1184. void hcb_pcs(cli_t *p_cli, unsigned short argc, char **argv)
  1185. {
  1186. send_bytes_client(buff, 200);
  1187. }
  1188. CLI_CMD_REGISTER(hcb, "clear sereen", hcb_pcs);
  1189. void slave_init_pcs(cli_t *p_cli, unsigned short argc, char **argv)
  1190. {
  1191. slave_init(host_r);
  1192. }
  1193. CLI_CMD_REGISTER(slave_init, "clear sereen", slave_init_pcs);
  1194. void bleupdata_pcs(cli_t *p_cli, unsigned short argc, char **argv)
  1195. {
  1196. unsigned int error = 0;
  1197. error = Ble_update_conn_interval(10, 10);
  1198. cli_printf(p_cli, "err %d", error);
  1199. }
  1200. CLI_CMD_REGISTER(bleupdata10, "clear sereen", bleupdata_pcs);
  1201. void bleupdata_1000pcs(cli_t *p_cli, unsigned short argc, char **argv)
  1202. {
  1203. unsigned int error = 0;
  1204. error = Ble_update_conn_interval(1000, 1000);
  1205. cli_printf(p_cli, "err %d", error);
  1206. }
  1207. CLI_CMD_REGISTER(bleupdata1000, "clear sereen", bleupdata_1000pcs);
  1208. void slaveupdata_pcs(cli_t *p_cli, unsigned short argc, char **argv)
  1209. {
  1210. unsigned int error =
  1211. slave_update_conn_interval_request(40, 40);
  1212. cli_printf(p_cli, "err %d", error);
  1213. }
  1214. CLI_CMD_REGISTER(slaveupdata, "clear sereen", slaveupdata_pcs);
  1215. void conn_pcs(cli_t *p_cli, unsigned short argc, char **argv)
  1216. {
  1217. if (argc == 1)
  1218. {
  1219. host_set_scan_name(argv[0], strlen(argv[0]));
  1220. host_init(slave_r);
  1221. }
  1222. else
  1223. cli_printf(p_cli, "err ");
  1224. }
  1225. CLI_CMD_REGISTER(conn, "clear sereen", conn_pcs);
  1226. void scan_name_set_pcs(cli_t *p_cli, unsigned short argc, char **argv)
  1227. {
  1228. if (argc == 1)
  1229. {
  1230. host_set_scan_name(argv[0], strlen(argv[0]));
  1231. }
  1232. else
  1233. cli_printf(p_cli, "err ");
  1234. }
  1235. CLI_CMD_REGISTER(scan_name_set, "clear sereen", scan_name_set_pcs);
  1236. void systemreset_pcs(cli_t *p_cli, unsigned short argc, char **argv)
  1237. {
  1238. NVIC_SystemReset();
  1239. }
  1240. CLI_CMD_REGISTER(systemreset, "clear sereen", systemreset_pcs);
  1241. void scanstart_pcs(cli_t *p_cli, unsigned short argc, char **argv)
  1242. {
  1243. scan_start();
  1244. }
  1245. CLI_CMD_REGISTER(scanstart, "clear sereen", scanstart_pcs);
  1246. void slave_dec_pcs(cli_t *p_cli, unsigned short argc, char **argv)
  1247. {
  1248. slave_disconnect();
  1249. }
  1250. CLI_CMD_REGISTER(slave_dec, "clear sereen", slave_dec_pcs);
  1251. void host_dec_pcs(cli_t *p_cli, unsigned short argc, char **argv)
  1252. {
  1253. host_disconnect();
  1254. }
  1255. CLI_CMD_REGISTER(host_dec, "clear sereen", host_dec_pcs);
  1256. void getconn_pcs(cli_t *p_cli, unsigned short argc, char **argv)
  1257. {
  1258. BLE_PRINT("min_conn_interval : %d * 1.25 ms\r\n", slave_conn_params.min_conn_interval);
  1259. BLE_PRINT("max_conn_interval : %d * 1.25 ms\r\n", slave_conn_params.max_conn_interval);
  1260. BLE_PRINT("slave_latency : %d\r\n", slave_conn_params.slave_latency);
  1261. BLE_PRINT("conn_sup_timeout : %d * 10 ms\r\n", slave_conn_params.conn_sup_timeout);
  1262. extern ble_gap_conn_params_t host_conn_params;
  1263. BLE_PRINT("min_conn_interval : %d * 1.25 ms\r\n", host_conn_params.min_conn_interval);
  1264. BLE_PRINT("max_conn_interval : %d * 1.25 ms\r\n", host_conn_params.max_conn_interval);
  1265. BLE_PRINT("slave_latency : %d\r\n", host_conn_params.slave_latency);
  1266. BLE_PRINT("conn_sup_timeout : %d * 10 ms\r\n", host_conn_params.conn_sup_timeout);
  1267. slave_set_adv_name("123456", 6);
  1268. gap_params_init();
  1269. while (slave_isconnect() == 1)
  1270. {
  1271. }
  1272. BLE_PRINT("123456555");
  1273. advertising_start();
  1274. BLE_PRINT("4554564");
  1275. }
  1276. CLI_CMD_REGISTER(getconn, "clear sereen", getconn_pcs);
  1277. void slave_get_rssi_pcs(cli_t *p_cli, unsigned short argc, char **argv)
  1278. {
  1279. slave_get_rssi();
  1280. }
  1281. CLI_CMD_REGISTER(slave_get_rssi, "clear sereen", slave_get_rssi_pcs);
  1282. void host_get_rssi_pcs(cli_t *p_cli, unsigned short argc, char **argv)
  1283. {
  1284. host_get_rssi();
  1285. }
  1286. CLI_CMD_REGISTER(host_get_rssi, "clear sereen", host_get_rssi_pcs);
  1287. int teg = 0;
  1288. unsigned int rtccc = 0;
  1289. void radio_evt_conf(void)
  1290. {
  1291. NRF_RADIO->POWER = (RADIO_POWER_POWER_Enabled << RADIO_POWER_POWER_Pos);
  1292. /* Start 16 MHz crystal oscillator */
  1293. NRF_CLOCK->EVENTS_HFCLKSTARTED = 0;
  1294. NRF_CLOCK->TASKS_HFCLKSTART = 1;
  1295. txbuff[1] = NRF_RTC0->COUNTER;
  1296. txbuff[2] = teg;
  1297. /* Wait for the external oscillator to start up */
  1298. while (NRF_CLOCK->EVENTS_HFCLKSTARTED == 0)
  1299. {
  1300. // Do nothing.
  1301. }
  1302. // Radio config
  1303. NRF_RADIO->TXPOWER = (RADIO_TXPOWER_TXPOWER_0dBm << RADIO_TXPOWER_TXPOWER_Pos);
  1304. NRF_RADIO->FREQUENCY = 7UL; // Frequency bin 7, 2407MHz
  1305. NRF_RADIO->MODE = (RADIO_MODE_MODE_Nrf_1Mbit << RADIO_MODE_MODE_Pos);
  1306. NRF_RADIO->PREFIX0 = 0xC3438303;
  1307. NRF_RADIO->PREFIX1 = 0xE3630023;
  1308. NRF_RADIO->BASE0 = 0x80C4A2E6;
  1309. NRF_RADIO->BASE1 = 0x91D5B3F7;
  1310. NRF_RADIO->TXADDRESS = 0x00UL; // Set device address 0 to use when transmitting
  1311. NRF_RADIO->RXADDRESSES = 0x01UL; // Enable device address 0 to use to select which addresses to receive
  1312. NRF_RADIO->PCNF0 = 0X00030006;
  1313. NRF_RADIO->PCNF1 = 0X01040020;
  1314. NRF_RADIO->CRCCNF = (RADIO_CRCCNF_LEN_Two << RADIO_CRCCNF_LEN_Pos); // Number of checksum bits
  1315. NRF_RADIO->CRCINIT = 0xFFFFUL; // Initial value
  1316. NRF_RADIO->CRCPOLY = 0x11021UL; // CRC poly: x^16 + x^12^x^5 + 1
  1317. NRF_RADIO->SHORTS = RADIO_SHORTS_READY_START_Enabled << RADIO_SHORTS_READY_START_Pos //READYoó×??ˉ?aê??′DDSTART
  1318. | RADIO_SHORTS_END_DISABLE_Enabled << RADIO_SHORTS_END_DISABLE_Pos;
  1319. // Set payload pointer
  1320. NRF_RADIO->PACKETPTR = (uint32_t)&txbuff[0];
  1321. NRF_RADIO->EVENTS_DISABLED = 0; //??3y±ê????
  1322. NRF_RADIO->TASKS_TXEN = 1; //?aê?oó?á?ú2?×??o2ù×÷
  1323. while (NRF_RADIO->EVENTS_END == 0)
  1324. {
  1325. //μè′y·¢?ííê3é
  1326. }
  1327. nrf_gpio_pin_write(rx, 0);
  1328. NRF_RADIO->SHORTS = 0;
  1329. NRF_RADIO->EVENTS_DISABLED = 0U;
  1330. NRF_RADIO->TASKS_DISABLE = 1U;
  1331. while (NRF_RADIO->EVENTS_DISABLED == 0)
  1332. {
  1333. //μè′y1?μ?radio
  1334. }
  1335. NRF_RADIO->EVENTS_READY = 0U;
  1336. // Enable radio and wait for ready
  1337. NRF_RADIO->TASKS_RXEN = 1U;
  1338. NRF_RADIO->PACKETPTR = (uint32_t)&rxbuff[0];
  1339. while (NRF_RADIO->EVENTS_READY == 0U)
  1340. {
  1341. // wait
  1342. }
  1343. nrf_gpio_pin_write(rx, 1);
  1344. NRF_RADIO->EVENTS_END = 0U;
  1345. // Start listening and wait for address received event
  1346. NRF_RADIO->TASKS_START = 1U;
  1347. // Wait for end of packet or buttons state changed
  1348. for (int j = 0; j < 5000; j++)
  1349. {
  1350. if (NRF_RADIO->EVENTS_END == 1)
  1351. break;
  1352. }
  1353. if (NRF_RADIO->CRCSTATUS == 1U)
  1354. {
  1355. for (int i = 0; i < 50; i++)
  1356. {
  1357. BLE_PRINT("%x", rxbuff[i]);
  1358. }
  1359. BLE_PRINT("\r\n ");
  1360. memset(rxbuff, 0, 60);
  1361. }
  1362. else
  1363. {
  1364. BLE_PRINT("E\r\n ");
  1365. }
  1366. }
  1367. nrf_radio_signal_callback_return_param_t call_radio_return_val;
  1368. nrf_radio_signal_callback_return_param_t *call_radio(unsigned char sig)
  1369. {
  1370. nrf_gpio_pin_write(rx, 1);
  1371. radio_evt_conf();
  1372. nrf_gpio_pin_write(rx, 0);
  1373. call_radio_return_val.callback_action = NRF_RADIO_SIGNAL_CALLBACK_ACTION_REQUEST_AND_END;
  1374. return &call_radio_return_val;
  1375. }
  1376. void radio_session_open(void)
  1377. {
  1378. BLE_PRINT("error= %d\r\n", sd_radio_session_open(call_radio));
  1379. }
  1380. void radio_session_open_pcs(cli_t *p_cli, unsigned short argc, char **argv)
  1381. {
  1382. BLE_PRINT("error= %d\r\n", sd_radio_session_open(call_radio));
  1383. }
  1384. CLI_CMD_REGISTER(radio_s_open, "clear sereen", radio_session_open_pcs);
  1385. void radio_session_close_pcs(cli_t *p_cli, unsigned short argc, char **argv)
  1386. {
  1387. BLE_PRINT("error= %d\r\n", sd_radio_session_close());
  1388. }
  1389. CLI_CMD_REGISTER(radio_s_close, "clear sereen", radio_session_close_pcs);
  1390. void radio_request_earliest(void)
  1391. {
  1392. radio_session_open();
  1393. radio_request_p.request_type = NRF_RADIO_REQ_TYPE_EARLIEST;
  1394. radio_request_p.params.earliest.hfclk = NRF_RADIO_HFCLK_CFG_NO_GUARANTEE;
  1395. radio_request_p.params.earliest.length_us = 4000;
  1396. radio_request_p.params.earliest.priority = NRF_RADIO_PRIORITY_NORMAL;
  1397. radio_request_p.params.earliest.timeout_us = 2000;
  1398. BLE_PRINT("radio_request_earliest= %d\r\n", sd_radio_request(&radio_request_p));
  1399. //
  1400. // radio_request_p.request_type=NRF_RADIO_REQ_TYPE_NORMAL;
  1401. // radio_request_p.params.normal.hfclk=NRF_RADIO_HFCLK_CFG_XTAL_GUARANTEED;
  1402. // radio_request_p.params.normal.distance_us=10000;
  1403. // radio_request_p.params.normal.length_us=5000;
  1404. // radio_request_p.params.normal.priority=NRF_RADIO_PRIORITY_NORMAL;
  1405. }
  1406. void radio_request_e_pcs(cli_t *p_cli, unsigned short argc, char **argv)
  1407. {
  1408. radio_request_p.request_type = NRF_RADIO_REQ_TYPE_EARLIEST;
  1409. radio_request_p.params.earliest.hfclk = NRF_RADIO_HFCLK_CFG_XTAL_GUARANTEED;
  1410. radio_request_p.params.earliest.length_us = 5000;
  1411. radio_request_p.params.earliest.priority = NRF_RADIO_PRIORITY_NORMAL;
  1412. radio_request_p.params.earliest.timeout_us = 2000;
  1413. BLE_PRINT("error= %d", sd_radio_request(&radio_request_p));
  1414. }
  1415. CLI_CMD_REGISTER(radio_r_e, "clear sereen", radio_request_e_pcs);
  1416. void radio_request_n_pcs(cli_t *p_cli, unsigned short argc, char **argv)
  1417. {
  1418. radio_request_p.request_type = NRF_RADIO_REQ_TYPE_NORMAL;
  1419. BLE_PRINT("error= %d", sd_radio_request(&radio_request_p));
  1420. }
  1421. CLI_CMD_REGISTER(radio_r_n, "clear sereen", radio_request_n_pcs);
  1422. void Radio_State_pcs(cli_t *p_cli, unsigned short argc, char **argv)
  1423. {
  1424. Radio_State();
  1425. }
  1426. CLI_CMD_REGISTER(Radio_State, "clear sereen", Radio_State_pcs);
  1427. void s100_pcs(cli_t *p_cli, unsigned short argc, char **argv)
  1428. {
  1429. send_bytes_client(buff, 150);
  1430. }
  1431. CLI_CMD_REGISTER(s100, "clear sereen", s100_pcs);
  1432. #endif