wm_i2s.c 25 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059
  1. #include <string.h>
  2. #include "wm_include.h"
  3. #include "wm_i2s.h"
  4. #include "wm_irq.h"
  5. #define FPGA_800_I2S 0
  6. #define I2S_CLK 160000000
  7. #define TEST_WITH_F401 0
  8. #define APPEND_NUM 4
  9. wm_i2s_buf_t wm_i2s_buf[1] = { 0 };
  10. static uint8_t tx_channel = 0, rx_channel = 0;
  11. static wm_dma_desc g_dma_desc_tx[2];
  12. static wm_dma_desc g_dma_desc_rx[2];
  13. //master or slave
  14. static void wm_i2s_set_mode(bool bl)
  15. {
  16. tls_bitband_write(HR_I2S_CTRL, 28, bl);
  17. }
  18. //master or slave
  19. #if 0
  20. static uint32_t wm_i2s_get_mode(void)
  21. {
  22. uint32_t reg;
  23. reg = tls_reg_read32(HR_I2S_CTRL);
  24. reg = reg>>28;
  25. return (reg & 0x1);
  26. }
  27. #endif
  28. //i2s_stardard
  29. void wm_i2s_set_format(uint32_t format)
  30. {
  31. uint32_t reg;
  32. reg = tls_reg_read32(HR_I2S_CTRL);
  33. reg &= ~(0x3<<24);
  34. reg |= format;
  35. tls_reg_write32(HR_I2S_CTRL, reg);
  36. }
  37. void wm_i2s_left_channel_sel(bool bl)
  38. {
  39. tls_bitband_write(HR_I2S_CTRL, 23, bl);
  40. }
  41. void wm_i2s_mono_select(bool bl)
  42. {
  43. tls_bitband_write(HR_I2S_CTRL, 22, bl);
  44. }
  45. static void wm_i2s_rx_dma_enable(bool bl)
  46. {
  47. tls_bitband_write(HR_I2S_CTRL, 21, bl);
  48. }
  49. void wm_i2s_tx_dma_enable(bool bl)
  50. {
  51. tls_bitband_write(HR_I2S_CTRL, 20, bl);
  52. }
  53. static void wm_i2s_rx_fifo_clear()
  54. {
  55. tls_bitband_write(HR_I2S_CTRL, 19, 1);
  56. }
  57. static void wm_i2s_tx_fifo_clear()
  58. {
  59. tls_bitband_write(HR_I2S_CTRL, 18, 1);
  60. }
  61. #if 0
  62. static void wm_i2s_left_zerocross_enable(bool bl)
  63. {
  64. tls_bitband_write(HR_I2S_CTRL, 17, bl);
  65. }
  66. static void wm_i2s_right_zerocross_enable(bool bl)
  67. {
  68. tls_bitband_write(HR_I2S_CTRL, 16, bl);
  69. }
  70. #endif
  71. static void wm_i2s_set_rxth(uint8_t th)
  72. {
  73. uint32_t reg;
  74. if(th > 7)
  75. {
  76. th = 7;
  77. }
  78. reg = tls_reg_read32(HR_I2S_CTRL);
  79. reg &= ~(0x7<<12);
  80. reg |= (th << 12);
  81. tls_reg_write32(HR_I2S_CTRL, reg);
  82. }
  83. static void wm_i2s_set_txth(uint8_t th)
  84. {
  85. uint32_t reg;
  86. if(th > 7)
  87. {
  88. th = 7;
  89. }
  90. reg = tls_reg_read32(HR_I2S_CTRL);
  91. reg &= ~(0x7<<9);
  92. reg |= (th << 9);
  93. tls_reg_write32(HR_I2S_CTRL, reg);
  94. }
  95. #if 0
  96. static void wm_i2s_clk_inverse(bool bl)
  97. {
  98. tls_bitband_write(HR_I2S_CTRL, 8, bl);
  99. tls_bitband_write(HR_I2S_CTRL, 15, bl);
  100. }
  101. #endif
  102. void wm_i2s_set_word_len(uint8_t len)
  103. {
  104. uint32_t reg;
  105. reg = tls_reg_read32(HR_I2S_CTRL);
  106. reg &= ~(0x3<<4);
  107. len = (len>>3) - 1;
  108. reg |= (len<<4);
  109. tls_reg_write32(HR_I2S_CTRL, reg);
  110. }
  111. #if 0
  112. static void wm_i2s_set_mute(bool bl)
  113. {
  114. tls_bitband_write(HR_I2S_CTRL, 3, bl);
  115. }
  116. #endif
  117. void wm_i2s_rx_enable(bool bl)
  118. {
  119. tls_bitband_write(HR_I2S_CTRL, 2, bl);
  120. }
  121. void wm_i2s_tx_enable(bool bl)
  122. {
  123. tls_bitband_write(HR_I2S_CTRL, 1, bl);
  124. }
  125. void wm_i2s_enable(bool bl)
  126. {
  127. tls_bitband_write(HR_I2S_CTRL, 0, bl);
  128. }
  129. #if 0
  130. static void wm_i2s_lzc_int_mask(bool bl)
  131. {
  132. tls_bitband_write(HR_I2S_INT_MASK, 9, bl);
  133. }
  134. static void wm_i2s_rzc_int_mask(bool bl)
  135. {
  136. tls_bitband_write(HR_I2S_INT_MASK, 8, bl);
  137. }
  138. static void wm_i2s_txdone_int_mask(bool bl)
  139. {
  140. tls_bitband_write(HR_I2S_INT_MASK, 7, bl);
  141. }
  142. #endif
  143. static void wm_i2s_txth_int_mask(bool bl)
  144. {
  145. tls_bitband_write(HR_I2S_INT_MASK, 6, bl);
  146. }
  147. #if 0
  148. static void wm_i2s_txover_int_mask(bool bl)
  149. {
  150. tls_bitband_write(HR_I2S_INT_MASK, 5, bl);
  151. }
  152. static void wm_i2s_txuderflow_int_mask(bool bl)
  153. {
  154. tls_bitband_write(HR_I2S_INT_MASK, 4, bl);
  155. }
  156. static void wm_i2s_rxdone_int_mask(bool bl)
  157. {
  158. tls_bitband_write(HR_I2S_INT_MASK, 3, bl);
  159. }
  160. #endif
  161. static void wm_i2s_rxth_int_mask(bool bl)
  162. {
  163. tls_bitband_write(HR_I2S_INT_MASK, 2, bl);
  164. }
  165. #if 0
  166. static void wm_i2s_rx_overflow_int_mask(bool bl)
  167. {
  168. tls_bitband_write(HR_I2S_INT_MASK, 1, bl);
  169. }
  170. static void wm_i2s_rx_uderflow_int_mask(bool bl)
  171. {
  172. tls_bitband_write(HR_I2S_INT_MASK, 0, bl);
  173. }
  174. #endif
  175. void wm_i2s_set_freq(uint32_t lr_freq, uint32_t mclk)
  176. {
  177. uint32_t div, mclk_div;
  178. uint32_t temp;
  179. uint8_t wdwidth, stereo;
  180. temp = I2S->CTRL;
  181. wdwidth = (((temp>>4)&0x03)+1)<<3;
  182. stereo = tls_bitband_read(HR_I2S_CTRL, 22) ? 1:2;
  183. stereo = 2;
  184. div = (I2S_CLK + lr_freq * wdwidth * stereo)/(lr_freq * wdwidth * stereo) - 1;
  185. #if FPGA_800_I2S
  186. div = div/2;
  187. #else
  188. div = div;
  189. #endif
  190. //Mclk should be set bigger than sample_rate * 256.
  191. //mclk_div = I2S_CLK / ( freq*256 ) + 1;
  192. mclk_div = I2S_CLK / mclk;
  193. (mclk_div > 0x3F)?(mclk_div = 0x3F):(mclk_div = mclk_div);
  194. *(volatile uint32_t *)HR_CLK_I2S_CTL &= ~0x3FFFF;
  195. //set bclk div ,mclk div, inter clk be used, mclk enabled.
  196. *(volatile uint32_t *)HR_CLK_I2S_CTL |= (uint32_t)(div<<8 | mclk_div<<2 | 2);
  197. }
  198. #if 0
  199. static void wm_i2s_set_freq_exclk(uint32_t freq, uint32_t exclk)
  200. {
  201. uint32_t div;
  202. uint32_t temp;
  203. uint8_t wdwidth, stereo;
  204. temp = I2S->CTRL;
  205. wdwidth = (((temp>>4)&0x03)+1)<<3;
  206. stereo = tls_bitband_read(HR_I2S_CTRL, 22) ? 1:2;
  207. div = (exclk * 2 + freq * wdwidth * stereo)/(2* freq * wdwidth * stereo) - 1;
  208. *(volatile uint32_t *)HR_CLK_I2S_CTL &= ~0x3FF00;
  209. *(volatile uint32_t *)HR_CLK_I2S_CTL |= (uint32_t)div<<8;
  210. *(volatile uint32_t *)HR_CLK_I2S_CTL |= 0x01;
  211. }
  212. #endif
  213. static void wm_i2s_int_clear_all(void)
  214. {
  215. tls_reg_write32(HR_I2S_INT_SRC, 0x3FF);
  216. }
  217. static void wm_i2s_int_mask_all(void)
  218. {
  219. tls_reg_write32(HR_I2S_INT_MASK, 0x3FF);
  220. }
  221. static void wm_i2s_dma_start(uint8_t ch)
  222. {
  223. DMA_CHNLCTRL_REG(ch) = DMA_CHNL_CTRL_CHNL_ON;
  224. }
  225. #if 0
  226. static void wm_i2s_dma_stop(uint8_t ch)
  227. {
  228. if(DMA_CHNLCTRL_REG(ch) & DMA_CHNL_CTRL_CHNL_ON)
  229. {
  230. DMA_CHNLCTRL_REG(ch) |= DMA_CHNL_CTRL_CHNL_OFF;
  231. while(DMA_CHNLCTRL_REG(ch) & DMA_CHNL_CTRL_CHNL_ON);
  232. }
  233. }
  234. #endif
  235. static void wm_i2s_module_reset(void)
  236. {
  237. tls_bitband_write(HR_CLK_RST_CTL, 24, 0);
  238. tls_bitband_write(HR_CLK_RST_CTL, 24, 1);
  239. }
  240. static void wm_i2s_dma_tx_init(uint8_t ch, uint32_t count, int16_t *buf)
  241. {
  242. DMA_INTMASK_REG &= ~(0x02<<(ch*2));
  243. DMA_SRCADDR_REG(ch) = (uint32_t )buf;
  244. DMA_DESTADDR_REG(ch) = HR_I2S_TX;
  245. DMA_CTRL_REG(ch) = DMA_CTRL_SRC_ADDR_INC | DMA_CTRL_DATA_SIZE_WORD | DMA_CTRL_BURST_SIZE1;
  246. DMA_MODE_REG(ch) = DMA_MODE_SEL_I2S_TX | DMA_MODE_HARD_MODE;
  247. DMA_CTRL_REG(ch) &= ~0xFFFF00;
  248. DMA_CTRL_REG(ch) |= (count<<8);
  249. }
  250. static void wm_i2s_dma_rx_init(uint8_t ch, uint32_t count, int16_t * buf)
  251. {
  252. DMA_INTMASK_REG &=~(0x02<<(ch*2));
  253. DMA_SRCADDR_REG(ch) = HR_I2S_RX;
  254. DMA_DESTADDR_REG(ch) = (uint32_t )buf;
  255. DMA_CTRL_REG(ch) = DMA_CTRL_DEST_ADDR_INC | DMA_CTRL_DATA_SIZE_WORD | DMA_CTRL_BURST_SIZE1;
  256. DMA_MODE_REG(ch) = DMA_MODE_SEL_I2S_RX | DMA_MODE_HARD_MODE;
  257. DMA_CTRL_REG(ch) &= ~0xFFFF00;
  258. DMA_CTRL_REG(ch) |= (count<<8);
  259. }
  260. ATTRIBUTE_ISR void i2s_I2S_IRQHandler(void)
  261. {
  262. volatile uint32_t temp;
  263. volatile uint8_t fifo_level, cnt;
  264. csi_kernel_intrpt_enter();
  265. /* TxTH*/
  266. if ((M32(HR_I2S_INT_SRC) >> 6) & 0x1)
  267. {
  268. if (wm_i2s_buf->txtail < wm_i2s_buf->txlen)
  269. {
  270. for(fifo_level = ((I2S->INT_STATUS >> 4)& 0x0F),temp = 0; temp < 8-fifo_level; temp++)
  271. {
  272. tls_reg_write32(HR_I2S_TX, wm_i2s_buf->txbuf[wm_i2s_buf->txtail++]);
  273. if (wm_i2s_buf->txtail >= wm_i2s_buf->txlen)
  274. {
  275. wm_i2s_buf->txtail = 0;
  276. wm_i2s_buf->txdata_done = 1;
  277. tls_bitband_write(HR_I2S_INT_MASK, 6, 1);
  278. break;
  279. }
  280. }
  281. }
  282. //printf("s\n");
  283. tls_reg_write32(HR_I2S_INT_SRC, 0x40);
  284. }
  285. /*LZC */
  286. if (tls_bitband_read(HR_I2S_INT_SRC, 9))
  287. {
  288. tls_reg_write32(HR_I2S_INT_SRC, 0x200);
  289. }
  290. /*RZC */
  291. if (tls_bitband_read(HR_I2S_INT_SRC, 8) )
  292. {
  293. tls_reg_write32(HR_I2S_INT_SRC, 0x100);
  294. }
  295. /* Tx Done*/
  296. if (tls_bitband_read(HR_I2S_INT_SRC, 7) )
  297. {
  298. tls_reg_write32(HR_I2S_INT_SRC, 0x80);
  299. }
  300. /*TXOV*/
  301. if (tls_bitband_read(HR_I2S_INT_SRC, 5) )
  302. {
  303. tls_reg_write32(HR_I2S_INT_SRC, 0x20);
  304. }
  305. /*TXUD*/
  306. if (tls_bitband_read(HR_I2S_INT_SRC, 4) )
  307. {
  308. tls_reg_write32(HR_I2S_INT_SRC, 0x10);
  309. }
  310. /* Rx Done*/
  311. if (tls_bitband_read(HR_I2S_INT_SRC, 3) )
  312. {
  313. tls_reg_write32(HR_I2S_INT_SRC, 0x08);
  314. }
  315. /* RxTH */
  316. if (tls_bitband_read(HR_I2S_INT_SRC, 2) )
  317. {
  318. for(cnt = (I2S->INT_STATUS & 0x0F),temp = 0; temp < cnt; temp++)
  319. {
  320. if (wm_i2s_buf->rxhead < wm_i2s_buf->rxlen)
  321. {
  322. wm_i2s_buf->rxbuf[wm_i2s_buf->rxhead++] = I2S->RX;
  323. if (wm_i2s_buf->rxhead >= wm_i2s_buf->rxlen)
  324. {
  325. wm_i2s_buf->rxhead = 0;
  326. wm_i2s_buf->rxdata_ready = 1;
  327. tls_bitband_write(HR_I2S_INT_MASK, 2, 1);
  328. break;
  329. }
  330. }
  331. }
  332. tls_reg_write32(HR_I2S_INT_SRC, 0x04);
  333. }
  334. /*RXOV*/
  335. if (tls_bitband_read(HR_I2S_INT_SRC, 1) )
  336. {
  337. tls_reg_write32(HR_I2S_INT_SRC, 0x02);
  338. }
  339. /*RXUD*/
  340. if (tls_bitband_read(HR_I2S_INT_SRC, 0) )
  341. {
  342. tls_reg_write32(HR_I2S_INT_SRC, 0x01);
  343. }
  344. csi_kernel_intrpt_exit();
  345. }
  346. void i2s_DMA_TX_Channel_IRQHandler(void *p)
  347. {
  348. wm_dma_handler_type *hdma = (wm_dma_handler_type *)p;
  349. wm_dma_desc *dma_desc = &g_dma_desc_tx[0];
  350. if(p)
  351. {
  352. if(wm_i2s_buf->txdata_done)
  353. {
  354. wm_i2s_buf->txdata_done = 0;
  355. dma_desc[1].valid |= (1 << 31);
  356. if(hdma->XferCpltCallback)
  357. {
  358. hdma->XferCpltCallback(hdma);
  359. }
  360. }
  361. else
  362. {
  363. wm_i2s_buf->txdata_done = 1;
  364. dma_desc[0].valid |= (1 << 31);
  365. if(hdma->XferHalfCpltCallback)
  366. {
  367. hdma->XferHalfCpltCallback(hdma);
  368. }
  369. }
  370. }
  371. else
  372. {
  373. wm_i2s_buf->txdata_done = 1;
  374. }
  375. }
  376. void i2s_DMA_RX_Channel_IRQHandler(void *p)
  377. {
  378. wm_dma_handler_type *hdma = (wm_dma_handler_type *)p;
  379. wm_dma_desc *dma_desc = &g_dma_desc_rx[0];
  380. if(p)
  381. {
  382. if(wm_i2s_buf->rxdata_ready)
  383. {
  384. wm_i2s_buf->rxdata_ready = 0;
  385. dma_desc[1].valid |= (1 << 31);
  386. if(hdma->XferCpltCallback)
  387. {
  388. hdma->XferCpltCallback(hdma);
  389. }
  390. }
  391. else
  392. {
  393. wm_i2s_buf->rxdata_ready = 1;
  394. dma_desc[0].valid |= (1 << 31);
  395. if(hdma->XferHalfCpltCallback)
  396. {
  397. hdma->XferHalfCpltCallback(hdma);
  398. }
  399. }
  400. }
  401. else
  402. {
  403. wm_i2s_buf->rxdata_ready = 1;
  404. }
  405. }
  406. void wm_i2s_register_callback(tls_i2s_callback callback)
  407. {
  408. wm_i2s_buf->tx_callback = callback;
  409. }
  410. int wm_i2s_port_init(I2S_InitDef *opts)
  411. {
  412. I2S_InitDef opt = { I2S_MODE_MASTER, I2S_CTRL_STEREO, I2S_RIGHT_CHANNEL, I2S_Standard, I2S_DataFormat_16, 8000, 5000000 };
  413. if(NULL != opts)
  414. {
  415. memcpy(&opt, opts, sizeof(I2S_InitDef));
  416. }
  417. wm_i2s_module_reset();
  418. tls_reg_write32(HR_I2S_CTRL, 0);
  419. wm_i2s_set_mode(opt.I2S_Mode_MS);
  420. wm_i2s_int_clear_all();
  421. wm_i2s_int_mask_all();
  422. wm_i2s_mono_select(opt.I2S_Mode_SS);
  423. wm_i2s_left_channel_sel(opt.I2S_Mode_LR);
  424. wm_i2s_set_format(opt.I2S_Trans_STD);
  425. wm_i2s_set_word_len(opt.I2S_DataFormat);
  426. wm_i2s_set_freq(opt.I2S_AudioFreq, opt.I2S_MclkFreq);
  427. wm_i2s_set_txth(4);
  428. wm_i2s_set_rxth(4);
  429. // tx_channel = tls_dma_request(WM_I2S_TX_DMA_CHANNEL, TLS_DMA_FLAGS_CHANNEL_SEL(TLS_DMA_SEL_I2S_TX) | TLS_DMA_FLAGS_HARD_MODE);
  430. // rx_channel = tls_dma_request(WM_I2S_RX_DMA_CHANNEL, TLS_DMA_FLAGS_CHANNEL_SEL(TLS_DMA_SEL_I2S_RX) | TLS_DMA_FLAGS_HARD_MODE);
  431. //
  432. // if (tx_channel == 0 || rx_channel == 0)
  433. // {
  434. // return WM_FAILED;
  435. // }
  436. // if (tls_dma_stop(tx_channel) || tls_dma_stop(rx_channel))
  437. // {
  438. // return WM_FAILED;
  439. // }
  440. //
  441. // tls_dma_irq_register(tx_channel, i2s_DMA_TX_Channel_IRQHandler, NULL, TLS_DMA_IRQ_TRANSFER_DONE);
  442. // tls_dma_irq_register(rx_channel, i2s_DMA_RX_Channel_IRQHandler, NULL, TLS_DMA_IRQ_TRANSFER_DONE);
  443. return WM_SUCCESS;
  444. }
  445. void wm_i2s_tx_rx_stop(void)
  446. {
  447. // if( I2S_MODE_MASTER==wm_i2s_get_mode() )
  448. // {
  449. // int i;
  450. //
  451. // for(i = 0; i < APPEND_NUM; i++)
  452. // {
  453. // tls_reg_write32(HR_I2S_TX, 0x00);
  454. // }
  455. // wm_i2s_tx_enable(1);
  456. // while( tls_reg_read32(HR_I2S_STATUS)&0xF0 );
  457. // }
  458. wm_i2s_tx_enable(0);
  459. wm_i2s_rx_enable(0);
  460. tls_dma_free(tx_channel);
  461. tls_dma_free(rx_channel);
  462. wm_i2s_enable(0);
  463. }
  464. int wm_i2s_tx_int(int16_t *data, uint16_t len, int16_t *next_data)
  465. {
  466. volatile uint32_t temp;
  467. volatile uint8_t fifo_level;
  468. if((data == NULL) || (len == 0)) {
  469. return WM_FAILED;
  470. }
  471. wm_i2s_buf->txlen = (uint32_t)len;
  472. wm_i2s_buf->txtail = 0;
  473. wm_i2s_buf->txbuf = (uint32_t *)data;
  474. wm_i2s_buf->txdata_done = 0;
  475. wm_i2s_set_mode(I2S_MODE_MASTER);
  476. wm_i2s_txth_int_mask(0);
  477. wm_i2s_tx_fifo_clear();
  478. tls_irq_enable(I2S_IRQn);
  479. wm_i2s_tx_enable(1);
  480. for(fifo_level = ((I2S->INT_STATUS >> 4)& 0x0F),temp = 0; temp < 8-fifo_level; temp++)
  481. {
  482. tls_reg_write32(HR_I2S_TX, wm_i2s_buf->txbuf[wm_i2s_buf->txtail++]);
  483. }
  484. wm_i2s_enable(1);
  485. if((wm_i2s_buf->tx_callback != NULL) && (next_data != NULL))
  486. {
  487. wm_i2s_buf->tx_callback((uint32_t *)next_data, &len);
  488. }
  489. while( wm_i2s_buf->txdata_done == 0 );
  490. while( tls_reg_read32(HR_I2S_STATUS)&0xF0 );
  491. return WM_SUCCESS;
  492. }
  493. int wm_i2s_tx_dma(int16_t *data, uint16_t len, int16_t *next_data)
  494. {
  495. if((data == NULL) || (len == 0)) {
  496. return WM_FAILED;
  497. }
  498. wm_i2s_buf->txdata_done = 0;
  499. wm_i2s_set_mode(I2S_MODE_MASTER);
  500. wm_i2s_dma_tx_init(tx_channel, len*4, data);
  501. wm_i2s_dma_start(tx_channel);
  502. wm_i2s_tx_dma_enable(1);
  503. wm_i2s_tx_enable(1);
  504. wm_i2s_enable(1);
  505. if((wm_i2s_buf->tx_callback != NULL) && (next_data != NULL))
  506. {
  507. wm_i2s_buf->tx_callback((uint32_t *)next_data, &len);
  508. }
  509. while( wm_i2s_buf->txdata_done == 0 );
  510. while( tls_reg_read32(HR_I2S_STATUS)&0xF0 );
  511. return WM_SUCCESS;
  512. }
  513. int wm_i2s_tx_dma_link(int16_t *data, uint16_t len, int16_t *next_data)
  514. {
  515. if((data == NULL) || (next_data == NULL) || (len == 0)) {
  516. return WM_FAILED;
  517. }
  518. uint32_t dma_ctrl;
  519. wm_dma_desc dma_desc[2];
  520. wm_i2s_buf->txdata_done = 0;
  521. wm_i2s_set_mode(I2S_MODE_MASTER);
  522. dma_ctrl = DMA_CTRL_SRC_ADDR_INC | DMA_CTRL_DATA_SIZE_WORD | DMA_CTRL_BURST_SIZE1;
  523. dma_ctrl &= ~ 0xFFFF00;
  524. dma_ctrl |= ((len*2)<<8);
  525. dma_desc[0].next = &dma_desc[1];
  526. dma_desc[0].dest_addr = HR_I2S_TX;
  527. dma_desc[0].src_addr = (unsigned int)data;
  528. dma_desc[0].dma_ctrl = dma_ctrl>>1;
  529. dma_desc[0].valid = 0x80000000;
  530. dma_desc[1].next = &dma_desc[0];
  531. dma_desc[1].dest_addr = HR_I2S_TX;
  532. dma_desc[1].src_addr = (unsigned int)next_data;
  533. dma_desc[1].dma_ctrl = dma_ctrl>>1;
  534. dma_desc[1].valid = 0x80000000;
  535. DMA_INTMASK_REG &= ~(0x02<<(tx_channel*2));
  536. DMA_MODE_REG(tx_channel) = DMA_MODE_SEL_I2S_TX | DMA_MODE_CHAIN_MODE | DMA_MODE_HARD_MODE | (1<<6);
  537. tls_reg_write32(HR_DMA_CHNL0_LINK_DEST_ADDR + 0x30*tx_channel, (uint32_t)dma_desc);
  538. wm_i2s_dma_start(tx_channel);
  539. wm_i2s_tx_dma_enable(1);
  540. wm_i2s_tx_enable(1);
  541. wm_i2s_enable(1);
  542. while(1)
  543. {
  544. if( dma_desc[0].valid == 0 )
  545. {
  546. dma_desc[0].valid = 0x80000000;
  547. if(wm_i2s_buf->tx_callback != NULL)
  548. {
  549. wm_i2s_buf->tx_callback((uint32_t *)data, &len);
  550. }
  551. }
  552. if( dma_desc[1].valid == 0 )
  553. {
  554. dma_desc[1].valid = 0x80000000;
  555. if(wm_i2s_buf->tx_callback != NULL)
  556. {
  557. wm_i2s_buf->tx_callback((uint32_t *)next_data, &len);
  558. }
  559. }
  560. /* todo: a way to break this rountine */
  561. if( len == 0xFFFF )
  562. {
  563. break;
  564. }
  565. }
  566. return WM_SUCCESS;
  567. }
  568. int wm_i2s_rx_int(int16_t *data, uint16_t len)
  569. {
  570. if((data == NULL) || (len == 0)) {
  571. return WM_FAILED;
  572. }
  573. wm_i2s_buf->rxbuf = (uint32_t *)data;
  574. wm_i2s_buf->rxlen = (uint32_t)len;
  575. wm_i2s_buf->rxhead = 0;
  576. wm_i2s_buf->rxdata_ready = 0;
  577. wm_i2s_set_mode(I2S_MODE_SLAVE);
  578. wm_i2s_rxth_int_mask(0);
  579. wm_i2s_rx_fifo_clear();
  580. tls_irq_enable(I2S_IRQn);
  581. wm_i2s_rx_enable(1);
  582. wm_i2s_enable(1);
  583. while( wm_i2s_buf->rxdata_ready == 0 );
  584. return WM_SUCCESS;
  585. }
  586. int wm_i2s_rx_dma(int16_t *data, uint16_t len)
  587. {
  588. if((data == NULL) || (len == 0)) {
  589. return WM_FAILED;
  590. }
  591. wm_i2s_buf->rxdata_ready = 0;
  592. wm_i2s_set_mode(I2S_MODE_SLAVE);
  593. wm_i2s_dma_rx_init(rx_channel, len*4, data);
  594. wm_i2s_dma_start(rx_channel);
  595. wm_i2s_rx_dma_enable(1);
  596. wm_i2s_rx_enable(1);
  597. wm_i2s_enable(1);
  598. while( wm_i2s_buf->rxdata_ready == 0 );
  599. return WM_SUCCESS;
  600. }
  601. int wm_i2s_tx_rx_int(I2S_InitDef *opts, int16_t *data_tx, int16_t *data_rx, uint16_t len)
  602. {
  603. if((data_tx == NULL) || (data_rx == NULL) || (len == 0)) {
  604. return WM_FAILED;
  605. }
  606. wm_i2s_buf->txbuf = (uint32_t *)data_tx;
  607. wm_i2s_buf->txlen = (uint32_t)len;
  608. wm_i2s_buf->txtail = 0;
  609. wm_i2s_buf->txdata_done = 0;
  610. wm_i2s_buf->rxbuf = (uint32_t *)data_rx;
  611. wm_i2s_buf->rxlen = (uint32_t)len;
  612. wm_i2s_buf->rxhead = 0;
  613. wm_i2s_buf->rxdata_ready = 0;
  614. wm_i2s_set_mode(opts->I2S_Mode_MS);
  615. #if TEST_WITH_F401
  616. ( opts->I2S_Trans_STD==I2S_Standard || opts->I2S_Trans_STD==I2S_Standard_MSB )?(wm_i2s_clk_inverse(0)):(wm_i2s_clk_inverse(1));
  617. #endif
  618. wm_i2s_txth_int_mask(0);
  619. wm_i2s_rxth_int_mask(0);
  620. tls_irq_enable(I2S_IRQn);
  621. wm_i2s_tx_enable(1);
  622. wm_i2s_rx_enable(1);
  623. wm_i2s_enable(1);
  624. while( wm_i2s_buf->txdata_done == 0 || wm_i2s_buf->rxdata_ready == 0);
  625. while( tls_reg_read32(HR_I2S_STATUS)&0xF0 );
  626. return WM_SUCCESS;
  627. }
  628. int wm_i2s_tx_rx_dma(I2S_InitDef *opts, int16_t *data_tx, int16_t *data_rx, uint16_t len)
  629. {
  630. if((data_tx == NULL) || (data_rx == NULL) || (len == 0)) {
  631. return WM_FAILED;
  632. }
  633. wm_i2s_buf->txdata_done = 0;
  634. wm_i2s_buf->rxdata_ready = 0;
  635. wm_i2s_set_mode(opts->I2S_Mode_MS);
  636. #if TEST_WITH_F401
  637. ( opts->I2S_Trans_STD==I2S_Standard || opts->I2S_Trans_STD==I2S_Standard_MSB )?(wm_i2s_clk_inverse(0)):(wm_i2s_clk_inverse(1));
  638. #endif
  639. wm_i2s_tx_dma_enable(1);
  640. wm_i2s_rx_dma_enable(1);
  641. wm_i2s_tx_enable(1);
  642. wm_i2s_rx_enable(1);
  643. wm_i2s_dma_tx_init(tx_channel, len*4, data_tx);
  644. wm_i2s_dma_rx_init(rx_channel, len*4, data_rx);
  645. wm_i2s_dma_start(tx_channel);
  646. wm_i2s_dma_start(rx_channel);
  647. wm_i2s_enable(1);
  648. while( wm_i2s_buf->txdata_done == 0 || wm_i2s_buf->rxdata_ready == 0);
  649. while( tls_reg_read32(HR_I2S_STATUS)&0xF0 );
  650. return WM_SUCCESS;
  651. }
  652. int wm_i2s_receive_dma(wm_dma_handler_type *hdma, uint16_t *data, uint16_t len)
  653. {
  654. uint32_t dma_ctrl;
  655. wm_dma_desc *dma_desc = &g_dma_desc_rx[0];
  656. uint16_t *next_data = &data[(len/2)];
  657. if((data == NULL) || (len == 0)) {
  658. return WM_FAILED;
  659. }
  660. wm_i2s_buf->rxdata_ready = 0;
  661. //wm_i2s_set_mode(I2S_MODE_SLAVE);
  662. if(rx_channel)
  663. {
  664. tls_dma_free(rx_channel);
  665. }
  666. rx_channel = tls_dma_request(WM_I2S_RX_DMA_CHANNEL, TLS_DMA_FLAGS_CHANNEL_SEL(TLS_DMA_SEL_I2S_RX) | TLS_DMA_FLAGS_HARD_MODE);
  667. if (rx_channel == 0xFF)
  668. {
  669. return WM_FAILED;
  670. }
  671. hdma->channel = rx_channel;
  672. if (tls_dma_stop(rx_channel))
  673. {
  674. return WM_FAILED;
  675. }
  676. tls_dma_irq_register(rx_channel, i2s_DMA_RX_Channel_IRQHandler, hdma, TLS_DMA_IRQ_TRANSFER_DONE);
  677. dma_ctrl = DMA_CTRL_DEST_ADDR_INC | DMA_CTRL_DATA_SIZE_WORD | DMA_CTRL_BURST_SIZE1;
  678. dma_ctrl &= ~ 0xFFFF00;
  679. dma_ctrl |= ((len)<<8); //half length of data
  680. dma_desc[0].next = &dma_desc[1];
  681. dma_desc[0].dest_addr = (unsigned int)data;
  682. dma_desc[0].src_addr = HR_I2S_RX;
  683. dma_desc[0].dma_ctrl = dma_ctrl>>1;
  684. dma_desc[0].valid = 0x80000000;
  685. dma_desc[1].next = &dma_desc[0];
  686. dma_desc[1].dest_addr = (unsigned int)next_data;
  687. dma_desc[1].src_addr = HR_I2S_RX;
  688. dma_desc[1].dma_ctrl = dma_ctrl>>1;
  689. dma_desc[1].valid = 0x80000000;
  690. DMA_INTMASK_REG &= ~(0x02<<(rx_channel*2));
  691. DMA_MODE_REG(rx_channel) = DMA_MODE_SEL_I2S_RX | DMA_MODE_CHAIN_MODE | DMA_MODE_HARD_MODE | DMA_MODE_CHAIN_LINK_EN;
  692. tls_reg_write32(HR_DMA_CHNL0_LINK_DEST_ADDR + 0x30*rx_channel, (uint32_t)dma_desc);
  693. wm_i2s_dma_start(rx_channel);
  694. wm_i2s_rx_dma_enable(1);
  695. wm_i2s_rx_enable(1);
  696. wm_i2s_enable(1);
  697. return WM_SUCCESS;
  698. }
  699. int wm_i2s_transmit_dma(wm_dma_handler_type *hdma, uint16_t *data, uint16_t len)
  700. {
  701. uint32_t dma_ctrl;
  702. wm_dma_desc *dma_desc = &g_dma_desc_tx[0];
  703. uint16_t *next_data = &data[(len/2)];
  704. if((data == NULL) || (len == 0)) {
  705. return WM_FAILED;
  706. }
  707. wm_i2s_buf->txdata_done = 0;
  708. //wm_i2s_set_mode(I2S_MODE_MASTER);
  709. if(tx_channel)
  710. {
  711. tls_dma_free(tx_channel);
  712. }
  713. tx_channel = tls_dma_request(WM_I2S_TX_DMA_CHANNEL, TLS_DMA_FLAGS_CHANNEL_SEL(TLS_DMA_SEL_I2S_TX) | TLS_DMA_FLAGS_HARD_MODE);
  714. if (tx_channel == 0xFF)
  715. {
  716. return WM_FAILED;
  717. }
  718. hdma->channel = tx_channel;
  719. if (tls_dma_stop(tx_channel))
  720. {
  721. return WM_FAILED;
  722. }
  723. tls_dma_irq_register(tx_channel, i2s_DMA_TX_Channel_IRQHandler, hdma, TLS_DMA_IRQ_TRANSFER_DONE);
  724. dma_ctrl = DMA_CTRL_SRC_ADDR_INC | DMA_CTRL_DATA_SIZE_WORD | DMA_CTRL_BURST_SIZE1;
  725. dma_ctrl &= ~ 0xFFFF00;
  726. dma_ctrl |= ((len)<<8); //half length of data
  727. dma_desc[0].next = &dma_desc[1];
  728. dma_desc[0].dest_addr = HR_I2S_TX;
  729. dma_desc[0].src_addr = (unsigned int)data;
  730. dma_desc[0].dma_ctrl = dma_ctrl>>1;
  731. dma_desc[0].valid = 0x80000000;
  732. dma_desc[1].next = &dma_desc[0];
  733. dma_desc[1].dest_addr = HR_I2S_TX;
  734. dma_desc[1].src_addr = (unsigned int)next_data;
  735. dma_desc[1].dma_ctrl = dma_ctrl>>1;
  736. dma_desc[1].valid = 0x80000000;
  737. DMA_INTMASK_REG &= ~(0x02<<(tx_channel*2));
  738. DMA_MODE_REG(tx_channel) = DMA_MODE_SEL_I2S_TX | DMA_MODE_CHAIN_MODE | DMA_MODE_HARD_MODE | DMA_MODE_CHAIN_LINK_EN;
  739. tls_reg_write32(HR_DMA_CHNL0_LINK_DEST_ADDR + 0x30*tx_channel, (uint32_t)dma_desc);
  740. wm_i2s_dma_start(tx_channel);
  741. wm_i2s_tx_dma_enable(1);
  742. wm_i2s_tx_enable(1);
  743. wm_i2s_enable(1);
  744. return WM_SUCCESS;
  745. }
  746. int wm_i2s_tranceive_dma(uint32_t i2s_mode, wm_dma_handler_type *hdma_tx, wm_dma_handler_type *hdma_rx, uint16_t *data_tx, uint16_t *data_rx, uint16_t len)
  747. {
  748. uint32_t dma_ctrl;
  749. wm_dma_desc *dma_desc_tx = &g_dma_desc_tx[0];
  750. wm_dma_desc *dma_desc_rx = &g_dma_desc_rx[0];
  751. uint16_t *next_data_tx = &data_tx[(len/2)];
  752. uint16_t *next_data_rx = &data_rx[(len/2)];
  753. if((data_tx == NULL) || (data_rx == NULL) || (len == 0)) {
  754. return WM_FAILED;
  755. }
  756. wm_i2s_buf->txdata_done = 0;
  757. wm_i2s_buf->rxdata_ready = 0;
  758. wm_i2s_set_mode(i2s_mode);
  759. if(tx_channel)
  760. {
  761. tls_dma_free(tx_channel);
  762. }
  763. tx_channel = tls_dma_request(WM_I2S_TX_DMA_CHANNEL, TLS_DMA_FLAGS_CHANNEL_SEL(TLS_DMA_SEL_I2S_TX) | TLS_DMA_FLAGS_HARD_MODE);
  764. if (tx_channel == 0xFF)
  765. {
  766. return WM_FAILED;
  767. }
  768. hdma_tx->channel = tx_channel;
  769. if (tls_dma_stop(tx_channel))
  770. {
  771. return WM_FAILED;
  772. }
  773. tls_dma_irq_register(tx_channel, i2s_DMA_TX_Channel_IRQHandler, hdma_tx, TLS_DMA_IRQ_TRANSFER_DONE);
  774. dma_ctrl = DMA_CTRL_SRC_ADDR_INC | DMA_CTRL_DATA_SIZE_WORD | DMA_CTRL_BURST_SIZE1;
  775. dma_ctrl &= ~ 0xFFFF00;
  776. dma_ctrl |= ((len)<<8); //half length of data
  777. dma_desc_tx[0].next = &dma_desc_tx[1];
  778. dma_desc_tx[0].dest_addr = HR_I2S_TX;
  779. dma_desc_tx[0].src_addr = (unsigned int)data_tx;
  780. dma_desc_tx[0].dma_ctrl = dma_ctrl>>1;
  781. dma_desc_tx[0].valid = 0x80000000;
  782. dma_desc_tx[1].next = &dma_desc_tx[0];
  783. dma_desc_tx[1].dest_addr = HR_I2S_TX;
  784. dma_desc_tx[1].src_addr = (unsigned int)next_data_tx;
  785. dma_desc_tx[1].dma_ctrl = dma_ctrl>>1;
  786. dma_desc_tx[1].valid = 0x80000000;
  787. // DMA_INTMASK_REG |= (0x03<<(tx_channel*2));
  788. DMA_MODE_REG(tx_channel) = DMA_MODE_SEL_I2S_TX | DMA_MODE_CHAIN_MODE | DMA_MODE_HARD_MODE | DMA_MODE_CHAIN_LINK_EN;
  789. tls_reg_write32(HR_DMA_CHNL0_LINK_DEST_ADDR + 0x30*tx_channel, (uint32_t)dma_desc_tx);
  790. if(rx_channel)
  791. {
  792. tls_dma_free(rx_channel);
  793. }
  794. rx_channel = tls_dma_request(WM_I2S_RX_DMA_CHANNEL, TLS_DMA_FLAGS_CHANNEL_SEL(TLS_DMA_SEL_I2S_RX) | TLS_DMA_FLAGS_HARD_MODE);
  795. if (rx_channel == 0xFF)
  796. {
  797. return WM_FAILED;
  798. }
  799. hdma_rx->channel = rx_channel;
  800. if (tls_dma_stop(rx_channel))
  801. {
  802. return WM_FAILED;
  803. }
  804. tls_dma_irq_register(rx_channel, i2s_DMA_RX_Channel_IRQHandler, hdma_rx, TLS_DMA_IRQ_TRANSFER_DONE);
  805. dma_ctrl = DMA_CTRL_DEST_ADDR_INC | DMA_CTRL_DATA_SIZE_WORD | DMA_CTRL_BURST_SIZE1;
  806. dma_ctrl &= ~ 0xFFFF00;
  807. dma_ctrl |= ((len)<<8); //half length of data
  808. dma_desc_rx[0].next = &dma_desc_rx[1];
  809. dma_desc_rx[0].dest_addr = (unsigned int)data_rx;
  810. dma_desc_rx[0].src_addr = HR_I2S_RX;
  811. dma_desc_rx[0].dma_ctrl = dma_ctrl>>1;
  812. dma_desc_rx[0].valid = 0x80000000;
  813. dma_desc_rx[1].next = &dma_desc_rx[0];
  814. dma_desc_rx[1].dest_addr = (unsigned int)next_data_rx;
  815. dma_desc_rx[1].src_addr = HR_I2S_RX;
  816. dma_desc_rx[1].dma_ctrl = dma_ctrl>>1;
  817. dma_desc_rx[1].valid = 0x80000000;
  818. // DMA_INTMASK_REG &= ~(0x02<<(rx_channel*2));
  819. DMA_MODE_REG(rx_channel) = DMA_MODE_SEL_I2S_RX | DMA_MODE_CHAIN_MODE | DMA_MODE_HARD_MODE | DMA_MODE_CHAIN_LINK_EN;
  820. tls_reg_write32(HR_DMA_CHNL0_LINK_DEST_ADDR + 0x30*rx_channel, (uint32_t)dma_desc_rx);
  821. wm_i2s_dma_start(rx_channel);
  822. wm_i2s_rx_dma_enable(1);
  823. wm_i2s_rx_enable(1);
  824. wm_i2s_dma_start(tx_channel);
  825. wm_i2s_tx_dma_enable(1);
  826. wm_i2s_tx_enable(1);
  827. wm_i2s_enable(1);
  828. return WM_SUCCESS;
  829. }
  830. /**
  831. *******************************************************
  832. * TEST CODE IS BELOW
  833. *******************************************************
  834. */
  835. #if 0
  836. #define UNIT_SIZE 2*1024
  837. #define PCM_ADDRDSS 0x100000
  838. #define FIRM_SIZE 940
  839. int16_t data_1[2][UNIT_SIZE];
  840. void i2s_demo_callback_play(int16_t *data, uint32_t *len)
  841. {
  842. static int number = 0;
  843. tls_fls_read(PCM_ADDRDSS+number*UNIT_SIZE*2, data, UNIT_SIZE*2);
  844. number ++;
  845. if( number > FIRM_SIZE/UNIT_SIZE/1024/2 )
  846. {
  847. number = 0;
  848. *len = 0xFFFF;
  849. }
  850. printf("%d, %x\n", number, data[0]);
  851. }
  852. void wm_i2s_play_demo(void)
  853. {
  854. wm_i2s_ck_config(WM_IO_PB_08);
  855. wm_i2s_ws_config(WM_IO_PB_09);
  856. wm_i2s_di_config(WM_IO_PB_10);
  857. wm_i2s_do_config(WM_IO_PB_11);
  858. wm_i2s_mclk_config(WM_IO_PA_00);
  859. //wm_i2c_scl_config(WM_IO_PA_01);
  860. //wm_i2c_sda_config(WM_IO_PA_04);
  861. //CodecInit();
  862. //CodecSetSampleRate(cur_sample_rate);
  863. //CodecMute(1);
  864. //CodecMute(0);
  865. I2S_InitDef i2s_config = { I2S_MODE_MASTER, I2S_CTRL_MONO, I2S_RIGHT_CHANNEL, I2S_Standard, I2S_DataFormat_16, 8000, 5000000 };
  866. int i;
  867. wm_i2s_port_init(&i2s_config);
  868. wm_i2s_register_callback(i2s_demo_callback_play);
  869. memset(data_1[0], 1, sizeof(data_1[0]));
  870. memset(data_1[1], 2, sizeof(data_1[1]));
  871. printf("1\n");
  872. //wm_i2s_tx_int(data_1[0], UNIT_SIZE, data_1[1]);
  873. //wm_i2s_tx_dma(data_1[0], UNIT_SIZE, data_1[1]);
  874. //wm_i2s_tx_dma_link(data_1[0], UNIT_SIZE, data_1[1]);
  875. //wm_i2s_rx_int(data_1[0], UNIT_SIZE);
  876. //for( i=0; i<UNIT_SIZE; i++ ) { printf("%x\n", data_1[0][i]); }
  877. //wm_i2s_rx_dma(data_1[0], UNIT_SIZE);
  878. //for( i=0; i<UNIT_SIZE; i++ ) { printf("%x\n", data_1[0][i]); }
  879. //wm_i2s_tx_rx_int(&i2s_config, data_1[0], data_1[1], UNIT_SIZE);
  880. //for( i=0; i<UNIT_SIZE; i++ ) { printf("%x\n", data_1[1][i]); }
  881. wm_i2s_tx_rx_dma(&i2s_config, data_1[0], data_1[1], UNIT_SIZE);
  882. for( i=0; i<UNIT_SIZE; i++ ) { printf("%x\n", data_1[1][i]); }
  883. printf("2\n");
  884. wm_i2s_tx_rx_stop();
  885. printf("stop\n");
  886. }
  887. #endif