func.c 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625
  1. #include "include.h"
  2. func_cb_t func_cb AT(.buf.func_cb);
  3. #if UART_S_UPDATE
  4. bool deal_update_uart_msg(void);
  5. #endif // UART_S_UPDATE
  6. extern void sys_mic_set_eq(void);
  7. #if VBAT_DETECT_EN
  8. AT(.text.func.msg)
  9. void lowpower_vbat_process(void)
  10. {
  11. int lpwr_vbat_sta = is_lowpower_vbat_warning();
  12. if (lpwr_vbat_sta == 1) {
  13. #if WARNING_LOW_BATTERY
  14. func_mp3_res_play(RES_BUF_LOW_BATTERY_MP3, RES_LEN_LOW_BATTERY_MP3);
  15. #endif
  16. sys_cb.pwrdwn_tone_en = 1;
  17. func_cb.sta = FUNC_PWROFF; //低电,进入关机或省电模式
  18. return;
  19. }
  20. if ((func_cb.mp3_res_play == NULL) || (lpwr_vbat_sta != 2)) {
  21. if ((sys_cb.lowbat_flag) && (sys_cb.vbat > 3800)) {
  22. sys_cb.vbat_nor_cnt++;
  23. if (sys_cb.vbat_nor_cnt > 40) {
  24. sys_cb.lowbat_flag = 0;
  25. sys_cb.lpwr_warning_times = LPWR_WARING_TIMES;
  26. plugin_lowbat_vol_recover(); //离开低电, 恢复音乐音量
  27. }
  28. }
  29. return;
  30. }
  31. //低电提示音播放
  32. sys_cb.vbat_nor_cnt = 0;
  33. if (sys_cb.lpwr_warning_cnt > xcfg_cb.lpwr_warning_period) {
  34. sys_cb.lpwr_warning_cnt = 0;
  35. if (sys_cb.lpwr_warning_times) { //低电语音提示次数
  36. if (RLED_LOWBAT_FOLLOW_EN) {
  37. led_lowbat_follow_warning();
  38. }
  39. sys_cb.lowbat_flag = 1;
  40. #if WARNING_LOW_BATTERY
  41. func_mp3_res_play(RES_BUF_LOW_BATTERY_MP3, RES_LEN_LOW_BATTERY_MP3);
  42. #endif
  43. plugin_lowbat_vol_reduce(); //低电降低音乐音量
  44. if (RLED_LOWBAT_FOLLOW_EN) {
  45. while (get_led_sta(1)) { //等待红灯闪完
  46. delay_5ms(2);
  47. }
  48. led_lowbat_recover();
  49. }
  50. if (sys_cb.lpwr_warning_times != 0xff) {
  51. sys_cb.lpwr_warning_times--;
  52. }
  53. }
  54. }
  55. }
  56. #endif // VBAT_DETECT_EN
  57. AT(.text.func.bt)
  58. void printf_vol(void)
  59. {
  60. static u32 ticks = 0;
  61. if (tick_check_expire(ticks,1000)) {
  62. ticks = tick_get();
  63. #if EXLIB_BT_MONO_XDRC_EN
  64. //printf("--------------->, sys_clk = %d\n",get_cur_sysclk());
  65. //printf("AUBUFSIZE = 0x%X, FIFOCNT = %d\n",AUBUFSIZE, (u16)AUBUFFIFOCNT);
  66. print_xdrc_audio_cfg();
  67. xdrc_softvol_print();
  68. printf("xdrc_prevol = %d\n",xdrc_prevol_get());
  69. #endif
  70. printf("DACVOLCON = 0x%X , AUANGCON3 = 0x%X,\n", DACVOLCON&0x7FFF,AUANGCON3&0x7F); //DACVOLCON 总的数字音量 //AUANGCON3低7BIT为模拟音量
  71. // printf("SRC0VOLCON = 0x%X, SRC1VOLCON = 0x%X\n",SRC0VOLCON&0x7FFF,SRC1VOLCON&0x7FFF); //SRC0VOLCON是音乐音量 //SRC1VOLCON是MIC音量
  72. // printf("AU0LMIXCOEF = 0x%X, AU0RMIXCOEF = 0x%X\n",AU0LMIXCOEF,AU0RMIXCOEF); //DACDIGCON0的BIT(7)设置为1时该寄存器有效
  73. // printf("AU1LMIXCOEF = 0x%X, AU1RMIXCOEF = 0x%X\n",AU1LMIXCOEF,AU1RMIXCOEF); //DACDIGCON0的BIT(8)设置为1时该寄存器有效
  74. // printf("DACDIGCON0 & (BIT(7)|BIT(8)) = 0x%X\n\n",DACDIGCON0 & (BIT(7)|BIT(8)));
  75. }
  76. }
  77. void print_cache_lock_map(void);
  78. AT(.text.func.process)
  79. void print_info(void)
  80. {
  81. static u32 ticks = 0;
  82. if (tick_check_expire(ticks,1000)) {
  83. ticks = tick_get();
  84. //printf("[%d]",get_karaok_mic_maxpow(0));
  85. //printf("DACVOLCON = 0x%X , AUANGCON3 = 0x%X,\n", DACVOLCON&0x7FFF,AUANGCON3&0x7F); //print DVOL,AVOL
  86. //my_printf("dac_dnr_get_sta = %d\n",dac_dnr_get_sta());
  87. //printf("--------------->PWRCON2 = 0x%X, %d\n",PWRCON2,PWRCON2&0x1F);
  88. //printf("CLKCON0~4: 0_0x%X,1_0x%X,2_0x%X,3_0x%X,4_0x%X\n",CLKCON0,CLKCON1,CLKCON2,CLKCON3,CLKCON4);
  89. }
  90. }
  91. AT(.text.func.process)
  92. void func_process(void)
  93. {
  94. WDT_CLR();
  95. //printf_vol();
  96. //print_info();
  97. #if BT_2ACL_EN
  98. /*一拖二 点击手机播放可切换对应的手机播放 还需注释 avdtp_acl2_sbc_compare_buf 函数*/
  99. // static u8 play_change_flag = 0;
  100. // if(bt_play_data_check(750)){
  101. // if(!play_change_flag){
  102. // play_change_flag = 1;
  103. // bt_2acl_switch_music_play();
  104. // }
  105. // }else{
  106. // play_change_flag = 0;
  107. // }
  108. #endif // BT_2ACL_EN
  109. #if VBAT_DETECT_EN
  110. lowpower_vbat_process();
  111. #endif // VBAT_DETECT_EN
  112. #if BT_BACKSTAGE_EN
  113. if (func_cb.sta != FUNC_BT) {
  114. func_bt_warning();
  115. uint status = bt_get_status();
  116. #if BT_BACKSTAGE_PLAY_DETECT_EN
  117. if (status >= BT_STA_PLAYING) {
  118. #else
  119. if (status > BT_STA_PLAYING) {
  120. #endif
  121. if(!bt_is_silence()) {
  122. func_cb.sta_break = func_cb.sta;
  123. func_cb.sta = FUNC_BT;
  124. }
  125. }
  126. }
  127. #endif
  128. //PWRKEY模拟硬开关关机处理
  129. if ((PWRKEY_2_HW_PWRON) && (sys_cb.pwrdwn_hw_flag)) {
  130. sys_cb.pwrdwn_tone_en = 1;
  131. func_cb.sta = FUNC_PWROFF;
  132. sys_cb.pwrdwn_hw_flag = 0;
  133. }
  134. #if CHARGE_EN
  135. if (xcfg_cb.charge_en) {
  136. charge_detect(1);
  137. }
  138. #endif // CHARGE_EN
  139. #if SYS_KARAOK_EN
  140. karaok_process();
  141. #endif
  142. #if FOT_EN
  143. bsp_fot_process();
  144. #endif
  145. #if LE_EN
  146. bsp_ble_process();
  147. #endif
  148. }
  149. //func common message process
  150. AT(.text.func.msg)
  151. void func_message(u16 msg)
  152. {
  153. switch (msg) {
  154. case KL_NEXT_VOL_UP:
  155. case KH_NEXT_VOL_UP:
  156. case KL_VOL_UP:
  157. case KH_VOL_UP:
  158. sys_cb.maxvol_fade = 1;
  159. case KU_VOL_UP_NEXT:
  160. case KU_VOL_UP:
  161. case KU_VOL_NEXT_PREV:
  162. if(bsp_bt_hid_vol_change(HID_KEY_VOL_UP)){
  163. printf("HID vol up\n");
  164. }else{
  165. if (msg == KU_VOL_NEXT_PREV) {
  166. //循环音量加, 最大音量后提示下, 然后从0开始。
  167. if (sys_cb.vol == VOL_MAX) {
  168. bsp_set_volume(0);
  169. } else {
  170. bsp_set_volume(bsp_volume_inc(sys_cb.vol));
  171. }
  172. } else {
  173. bsp_set_volume(bsp_volume_inc(sys_cb.vol));
  174. }
  175. func_set_vol_callback(1);
  176. bsp_bt_vol_change();
  177. }
  178. printf("current volume: %d (DVOL=0x%X,AVOL=0x%X)\n", sys_cb.vol, DACVOLCON&0x7FFF,AUANGCON3&0x7F);
  179. #if WARNING_MAX_VOLUME
  180. if (sys_cb.vol == VOL_MAX) {
  181. maxvol_tone_play();
  182. }
  183. #endif // WARNING_MAX_VOLUME
  184. break;
  185. case KLU_VOL_UP:
  186. case KLU_NEXT_VOL_UP:
  187. if (sys_cb.maxvol_fade == 2) {
  188. dac_fade_in();
  189. }
  190. sys_cb.maxvol_fade = 0;
  191. break;
  192. case KL_PREV_VOL_DOWN:
  193. case KH_PREV_VOL_DOWN:
  194. case KU_VOL_DOWN_PREV:
  195. case KU_VOL_DOWN:
  196. case KL_VOL_DOWN:
  197. case KH_VOL_DOWN:
  198. if(bsp_bt_hid_vol_change(HID_KEY_VOL_DOWN)){
  199. printf("HID vol down\n");
  200. }else{
  201. bsp_set_volume(bsp_volume_dec(sys_cb.vol));
  202. func_set_vol_callback(0);
  203. bsp_bt_vol_change();
  204. printf("current volume: %d (DVOL=0x%X,AVOL=0x%X)\n", sys_cb.vol, DACVOLCON&0x7FFF,AUANGCON3&0x7F);
  205. }
  206. #if WARNING_MIN_VOLUME
  207. if (sys_cb.vol == 0) {
  208. func_mp3_res_play(RES_BUF_MAX_VOL_MP3, RES_LEN_MAX_VOL_MP3);
  209. }
  210. #endif // WARNING_MIN_VOLUME
  211. break;
  212. #if SOFT_POWER_ON_OFF
  213. //长按PP/POWER软关机(通过PWROFF_PRESS_TIME控制长按时间)
  214. case KLH_PLAY_POWER:
  215. case KLH_MODE_POWER:
  216. case KLH_HSF_POWER:
  217. case KLH_POWER:
  218. sys_cb.pwrdwn_tone_en = 1;
  219. func_cb.sta = FUNC_PWROFF;
  220. break;
  221. #endif // SOFT_POWER_ON_OFF
  222. #if IRRX_HW_EN
  223. case KU_IR_POWER:
  224. func_cb.sta = FUNC_SLEEPMODE;
  225. break;
  226. #endif
  227. case KU_MODE:
  228. case KU_MODE_POWER:
  229. case KL_PLAY_MODE:
  230. func_cb.sta = FUNC_NULL;
  231. break;
  232. #if EQ_MODE_EN
  233. case KU_EQ:
  234. sys_set_eq();
  235. // sys_mic_set_eq();
  236. break;
  237. #endif // EQ_MODE_EN
  238. case KU_MUTE:
  239. if (sys_cb.mute) {
  240. bsp_sys_unmute();
  241. } else {
  242. bsp_sys_mute();
  243. }
  244. break;
  245. #if SYS_KARAOK_EN
  246. #if KARAOK_RM_VOICE
  247. case KU_VOICE_RM:
  248. karaok_voice_rm_switch();
  249. printf("KU_VOICE_RM: %d\n",karaok_get_voice_rm_sta());
  250. break;
  251. #endif
  252. #if SYS_MAGIC_VOICE_EN
  253. case KL_VOICE_RM:
  254. magic_voice_switch();
  255. break;
  256. #endif
  257. #endif
  258. case MSG_SYS_500MS:
  259. break;
  260. #if MUSIC_UDISK_EN
  261. case EVT_UDISK_INSERT:
  262. if (dev_is_online(DEV_UDISK)) {
  263. #if SD_USB_MUX_IO_EN
  264. sys_cb.cur_dev = DEV_UDISK;
  265. #endif // SD_USB_MUX_IO_EN
  266. if (dev_udisk_activation_try(0)) {
  267. sys_cb.cur_dev = DEV_UDISK;
  268. func_cb.sta = FUNC_MUSIC;
  269. }
  270. }
  271. break;
  272. #endif // MUSIC_UDISK_EN
  273. #if MUSIC_SDCARD_EN
  274. case EVT_SD_INSERT:
  275. if (dev_is_online(DEV_SDCARD)) {
  276. sys_cb.cur_dev = DEV_SDCARD;
  277. func_cb.sta = FUNC_MUSIC;
  278. }
  279. break;
  280. #endif // MUSIC_SDCARD_EN
  281. #if MUSIC_SDCARD1_EN
  282. case EVT_SD1_INSERT:
  283. if (dev_is_online(DEV_SDCARD1)) {
  284. sys_cb.cur_dev = DEV_SDCARD1;
  285. func_cb.sta = FUNC_MUSIC;
  286. }
  287. break;
  288. #endif // MUSIC_SDCARD1_EN
  289. #if FUNC_USBDEV_EN
  290. case EVT_PC_INSERT:
  291. if (dev_is_online(DEV_USBPC)) {
  292. func_cb.sta = FUNC_USBDEV;
  293. }
  294. break;
  295. #endif // FUNC_USBDEV_EN
  296. #if LINEIN_DETECT_EN
  297. case EVT_LINEIN_INSERT:
  298. if (dev_is_online(DEV_LINEIN)) {
  299. #if LINEIN_2_PWRDOWN_EN
  300. sys_cb.pwrdwn_tone_en = LINEIN_2_PWRDOWN_TONE_EN;
  301. func_cb.sta = FUNC_PWROFF;
  302. #else
  303. func_cb.sta = FUNC_AUX;
  304. #endif // LINEIN_2_PWRDOWN_EN
  305. }
  306. break;
  307. #endif // LINEIN_DETECT_EN
  308. #if FUNC_HDMI_EN
  309. case EVT_HDMI_INSERT:
  310. if (dev_is_online(DEV_HDMI)) {
  311. func_cb.sta = FUNC_HDMI;
  312. bsp_hdmi_cec_init();
  313. cec_rx_start(); //提前开始接收,及时回电视ack信息
  314. }
  315. break;
  316. case EVT_HDMI_REMOVE:
  317. break;
  318. #endif
  319. case EVT_TWS_SET_VOL:
  320. case EVT_A2DP_SET_VOL:
  321. if(bt_get_status() != BT_STA_INCALL) {
  322. printf("A2DP SET VOL: %d\n", sys_cb.vol);
  323. #if SYS_KARAOK_EN
  324. a2dp_set_vol(sys_cb.vol);
  325. #else
  326. bsp_change_volume(sys_cb.vol);
  327. #endif
  328. gui_box_show_vol();
  329. param_sys_vol_write();
  330. sys_cb.cm_times = 0;
  331. sys_cb.cm_vol_change = 1;
  332. }
  333. break;
  334. case EVT_UDE_SET_VOL:
  335. bsp_change_volume(sys_cb.vol);
  336. gui_box_show_vol();
  337. param_sys_vol_write();
  338. sys_cb.cm_times = 0;
  339. sys_cb.cm_vol_change = 1;
  340. break;
  341. case EVT_BT_SCAN_START:
  342. if (bt_get_status() < BT_STA_SCANNING) {
  343. bt_scan_enable();
  344. }
  345. break;
  346. #if EQ_DBG_IN_UART || EQ_DBG_IN_SPP
  347. case EVT_ONLINE_SET_EQ:
  348. #if EXLIB_SOFT_EQ_DRC_EN
  349. sed_adj_parse_cmd_equalizer();
  350. #elif EXLIB_BT_MONO_XDRC_EN
  351. mono_xdrc_onlie_adjust_process();
  352. #else
  353. eq_parse_cmd();
  354. #endif
  355. break;
  356. #endif
  357. #if SYS_KARAOK_EN
  358. case EVT_ECHO_LEVEL:
  359. // printf("echo level:%x\n", sys_cb.echo_level);
  360. bsp_echo_set_level();
  361. break;
  362. case EVT_MIC_VOL:
  363. // printf("mic vol:%x\n", sys_cb.mic_vol);
  364. bsp_karaok_set_mic_volume();
  365. break;
  366. case EVT_MUSIC_VOL:
  367. // printf("music vol:%x\n", sys_cb.music_vol);
  368. bsp_karaok_set_music_volume();
  369. break;
  370. #endif
  371. #if LANG_SELECT == LANG_EN_ZH
  372. case EVT_BT_SET_LANG_ID:
  373. param_lang_id_write();
  374. param_sync();
  375. break;
  376. #endif
  377. #if EQ_MODE_EN
  378. case EVT_BT_SET_EQ:
  379. music_set_eq_by_num(sys_cb.eq_mode);
  380. break;
  381. #endif
  382. #if MIC_DETECT_EN
  383. case EVT_MIC_INSERT:
  384. karaok_mic_unmute();
  385. break;
  386. case EVT_MIC_REMOVE:
  387. karaok_mic_mute();
  388. break;
  389. #endif
  390. #if UART_S_UPDATE
  391. case EVT_UART_UPDATE:
  392. if(deal_update_uart_msg()) {
  393. func_cb.sta = FUNC_NULL;
  394. }
  395. break;
  396. #endif
  397. }
  398. //调节音量,3秒后写入flash
  399. if ((sys_cb.cm_vol_change) && (sys_cb.cm_times >= 6)) {
  400. sys_cb.cm_vol_change = 0;
  401. cm_sync();
  402. }
  403. #if SD_SOFT_DETECT_EN
  404. sd_soft_cmd_detect(120);
  405. #endif
  406. }
  407. ///进入一个功能的总入口
  408. AT(.text.func)
  409. void func_enter(void)
  410. {
  411. gui_box_clear();
  412. param_sync();
  413. reset_sleep_delay();
  414. reset_pwroff_delay();
  415. func_cb.mp3_res_play = NULL;
  416. func_cb.set_vol_callback = NULL;
  417. bsp_clr_mute_sta();
  418. sys_cb.voice_evt_brk_en = 1; //播放提示音时,快速响应事件。
  419. AMPLIFIER_SEL_D();
  420. #if SYS_KARAOK_EN
  421. karaok_voice_rm_disable();
  422. bsp_karaok_echo_reset_buf(func_cb.sta);
  423. #endif
  424. #if VUSB_ADCCH
  425. ADCCH_VUSB_EN();
  426. #endif
  427. }
  428. AT(.text.func)
  429. void func_exit(void)
  430. {
  431. #if UART_S_UPDATE
  432. void uart_s_update(void);
  433. uart_s_update();
  434. #endif // UART_S_UPDATE
  435. u8 func_num;
  436. u8 funcs_total = get_funcs_total();
  437. for (func_num = 0; func_num != funcs_total; func_num++) {
  438. if (func_cb.last == func_sort_table[func_num]) {
  439. break;
  440. }
  441. }
  442. func_num++; //切换到下一个任务
  443. if (func_num >= funcs_total) {
  444. func_num = 0;
  445. }
  446. func_cb.sta = func_sort_table[func_num]; //新的任务
  447. #if SYS_MODE_BREAKPOINT_EN
  448. param_sys_mode_write(func_cb.sta);
  449. #endif // SYS_MODE_BREAKPOINT_EN
  450. }
  451. AT(.text.func)
  452. void func_run(void)
  453. {
  454. printf("%s\n", __func__);
  455. // func_cb.sta = FUNC_SPEAKER;
  456. #if !BT_BACKSTAGE_EN && FUNC_BT_EN
  457. func_bt_chk_off();
  458. #endif
  459. while (1) {
  460. func_enter();
  461. switch (func_cb.sta) {
  462. #if FUNC_MUSIC_EN
  463. case FUNC_MUSIC:
  464. func_music();
  465. break;
  466. #endif // FUNC_MUSIC_EN
  467. #if FUNC_FMRX_EN
  468. case FUNC_FMRX:
  469. func_fmrx();
  470. break;
  471. #endif // FUNC_FMRX_EN
  472. #if EX_SPIFLASH_SUPPORT && !FUNC_TOM_CAT_EN
  473. case FUNC_EXSPIFLASH_MUSIC:
  474. func_exspifalsh_music();
  475. break;
  476. #endif
  477. #if FUNC_TOM_CAT_EN
  478. case FUNC_TOM_CAT:
  479. func_tom_cat();
  480. break;
  481. #endif
  482. #if FUNC_CLOCK_EN
  483. case FUNC_CLOCK:
  484. func_clock();
  485. break;
  486. #endif // FUNC_CLOCK_EN
  487. #if FUNC_BT_EN
  488. case FUNC_BT:
  489. func_bt();
  490. break;
  491. #endif
  492. #if FUNC_BTHID_EN
  493. case FUNC_BTHID:
  494. func_bthid();
  495. break;
  496. #endif // FUNC_BTHID_EN
  497. #if FUNC_BT_DUT_EN
  498. case FUNC_BT_DUT:
  499. func_bt_dut();
  500. break;
  501. #endif
  502. #if FUNC_BT_FCC_EN
  503. case FUNC_BT_FCC:
  504. func_bt_fcc();
  505. break;
  506. #endif
  507. #if FUNC_AUX_EN
  508. case FUNC_AUX:
  509. func_aux();
  510. break;
  511. #endif // FUNC_AUX_EN
  512. #if FUNC_USBDEV_EN
  513. case FUNC_USBDEV:
  514. func_usbdev();
  515. break;
  516. #endif
  517. #if FUNC_SPDIF_EN
  518. case FUNC_SPDIF:
  519. func_spdif();
  520. break;
  521. #endif
  522. #if FUNC_HDMI_EN
  523. case FUNC_HDMI:
  524. func_hdmi();
  525. break;
  526. #endif
  527. #if FUNC_SPEAKER_EN
  528. case FUNC_SPEAKER:
  529. func_speaker();
  530. break;
  531. #endif // FUNC_SPEAKER_EN
  532. #if FUNC_I2S_EN
  533. case FUNC_I2S:
  534. func_i2s();
  535. break;
  536. #endif
  537. #if FUNC_HUART_EN
  538. case FUNC_HUART:
  539. func_huart();
  540. break;
  541. #endif
  542. #if FUNC_IDLE_EN
  543. case FUNC_IDLE:
  544. func_idle();
  545. break;
  546. #endif // FUNC_IDLE_EN
  547. case FUNC_PWROFF:
  548. func_pwroff(sys_cb.pwrdwn_tone_en);
  549. break;
  550. case FUNC_SLEEPMODE:
  551. func_sleepmode();
  552. break;
  553. default:
  554. func_exit();
  555. break;
  556. }
  557. }
  558. }