ux500_msp_i2s.c 19 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729
  1. // SPDX-License-Identifier: GPL-2.0-only
  2. /*
  3. * Copyright (C) ST-Ericsson SA 2012
  4. *
  5. * Author: Ola Lilja <[email protected]>,
  6. * Roger Nilsson <[email protected]>,
  7. * Sandeep Kaushik <[email protected]>
  8. * for ST-Ericsson.
  9. */
  10. #include <linux/module.h>
  11. #include <linux/platform_device.h>
  12. #include <linux/delay.h>
  13. #include <linux/slab.h>
  14. #include <linux/io.h>
  15. #include <linux/of.h>
  16. #include <linux/platform_data/asoc-ux500-msp.h>
  17. #include <sound/soc.h>
  18. #include "ux500_msp_i2s.h"
  19. /* Protocol desciptors */
  20. static const struct msp_protdesc prot_descs[] = {
  21. { /* I2S */
  22. MSP_SINGLE_PHASE,
  23. MSP_SINGLE_PHASE,
  24. MSP_PHASE2_START_MODE_IMEDIATE,
  25. MSP_PHASE2_START_MODE_IMEDIATE,
  26. MSP_BTF_MS_BIT_FIRST,
  27. MSP_BTF_MS_BIT_FIRST,
  28. MSP_FRAME_LEN_1,
  29. MSP_FRAME_LEN_1,
  30. MSP_FRAME_LEN_1,
  31. MSP_FRAME_LEN_1,
  32. MSP_ELEM_LEN_32,
  33. MSP_ELEM_LEN_32,
  34. MSP_ELEM_LEN_32,
  35. MSP_ELEM_LEN_32,
  36. MSP_DELAY_1,
  37. MSP_DELAY_1,
  38. MSP_RISING_EDGE,
  39. MSP_FALLING_EDGE,
  40. MSP_FSYNC_POL_ACT_LO,
  41. MSP_FSYNC_POL_ACT_LO,
  42. MSP_SWAP_NONE,
  43. MSP_SWAP_NONE,
  44. MSP_COMPRESS_MODE_LINEAR,
  45. MSP_EXPAND_MODE_LINEAR,
  46. MSP_FSYNC_IGNORE,
  47. 31,
  48. 15,
  49. 32,
  50. }, { /* PCM */
  51. MSP_DUAL_PHASE,
  52. MSP_DUAL_PHASE,
  53. MSP_PHASE2_START_MODE_FSYNC,
  54. MSP_PHASE2_START_MODE_FSYNC,
  55. MSP_BTF_MS_BIT_FIRST,
  56. MSP_BTF_MS_BIT_FIRST,
  57. MSP_FRAME_LEN_1,
  58. MSP_FRAME_LEN_1,
  59. MSP_FRAME_LEN_1,
  60. MSP_FRAME_LEN_1,
  61. MSP_ELEM_LEN_16,
  62. MSP_ELEM_LEN_16,
  63. MSP_ELEM_LEN_16,
  64. MSP_ELEM_LEN_16,
  65. MSP_DELAY_0,
  66. MSP_DELAY_0,
  67. MSP_RISING_EDGE,
  68. MSP_FALLING_EDGE,
  69. MSP_FSYNC_POL_ACT_HI,
  70. MSP_FSYNC_POL_ACT_HI,
  71. MSP_SWAP_NONE,
  72. MSP_SWAP_NONE,
  73. MSP_COMPRESS_MODE_LINEAR,
  74. MSP_EXPAND_MODE_LINEAR,
  75. MSP_FSYNC_IGNORE,
  76. 255,
  77. 0,
  78. 256,
  79. }, { /* Companded PCM */
  80. MSP_SINGLE_PHASE,
  81. MSP_SINGLE_PHASE,
  82. MSP_PHASE2_START_MODE_FSYNC,
  83. MSP_PHASE2_START_MODE_FSYNC,
  84. MSP_BTF_MS_BIT_FIRST,
  85. MSP_BTF_MS_BIT_FIRST,
  86. MSP_FRAME_LEN_1,
  87. MSP_FRAME_LEN_1,
  88. MSP_FRAME_LEN_1,
  89. MSP_FRAME_LEN_1,
  90. MSP_ELEM_LEN_8,
  91. MSP_ELEM_LEN_8,
  92. MSP_ELEM_LEN_8,
  93. MSP_ELEM_LEN_8,
  94. MSP_DELAY_0,
  95. MSP_DELAY_0,
  96. MSP_RISING_EDGE,
  97. MSP_RISING_EDGE,
  98. MSP_FSYNC_POL_ACT_HI,
  99. MSP_FSYNC_POL_ACT_HI,
  100. MSP_SWAP_NONE,
  101. MSP_SWAP_NONE,
  102. MSP_COMPRESS_MODE_LINEAR,
  103. MSP_EXPAND_MODE_LINEAR,
  104. MSP_FSYNC_IGNORE,
  105. 255,
  106. 0,
  107. 256,
  108. },
  109. };
  110. static void set_prot_desc_tx(struct ux500_msp *msp,
  111. struct msp_protdesc *protdesc,
  112. enum msp_data_size data_size)
  113. {
  114. u32 temp_reg = 0;
  115. temp_reg |= MSP_P2_ENABLE_BIT(protdesc->tx_phase_mode);
  116. temp_reg |= MSP_P2_START_MODE_BIT(protdesc->tx_phase2_start_mode);
  117. temp_reg |= MSP_P1_FRAME_LEN_BITS(protdesc->tx_frame_len_1);
  118. temp_reg |= MSP_P2_FRAME_LEN_BITS(protdesc->tx_frame_len_2);
  119. if (msp->def_elem_len) {
  120. temp_reg |= MSP_P1_ELEM_LEN_BITS(protdesc->tx_elem_len_1);
  121. temp_reg |= MSP_P2_ELEM_LEN_BITS(protdesc->tx_elem_len_2);
  122. } else {
  123. temp_reg |= MSP_P1_ELEM_LEN_BITS(data_size);
  124. temp_reg |= MSP_P2_ELEM_LEN_BITS(data_size);
  125. }
  126. temp_reg |= MSP_DATA_DELAY_BITS(protdesc->tx_data_delay);
  127. temp_reg |= MSP_SET_ENDIANNES_BIT(protdesc->tx_byte_order);
  128. temp_reg |= MSP_FSYNC_POL(protdesc->tx_fsync_pol);
  129. temp_reg |= MSP_DATA_WORD_SWAP(protdesc->tx_half_word_swap);
  130. temp_reg |= MSP_SET_COMPANDING_MODE(protdesc->compression_mode);
  131. temp_reg |= MSP_SET_FSYNC_IGNORE(protdesc->frame_sync_ignore);
  132. writel(temp_reg, msp->registers + MSP_TCF);
  133. }
  134. static void set_prot_desc_rx(struct ux500_msp *msp,
  135. struct msp_protdesc *protdesc,
  136. enum msp_data_size data_size)
  137. {
  138. u32 temp_reg = 0;
  139. temp_reg |= MSP_P2_ENABLE_BIT(protdesc->rx_phase_mode);
  140. temp_reg |= MSP_P2_START_MODE_BIT(protdesc->rx_phase2_start_mode);
  141. temp_reg |= MSP_P1_FRAME_LEN_BITS(protdesc->rx_frame_len_1);
  142. temp_reg |= MSP_P2_FRAME_LEN_BITS(protdesc->rx_frame_len_2);
  143. if (msp->def_elem_len) {
  144. temp_reg |= MSP_P1_ELEM_LEN_BITS(protdesc->rx_elem_len_1);
  145. temp_reg |= MSP_P2_ELEM_LEN_BITS(protdesc->rx_elem_len_2);
  146. } else {
  147. temp_reg |= MSP_P1_ELEM_LEN_BITS(data_size);
  148. temp_reg |= MSP_P2_ELEM_LEN_BITS(data_size);
  149. }
  150. temp_reg |= MSP_DATA_DELAY_BITS(protdesc->rx_data_delay);
  151. temp_reg |= MSP_SET_ENDIANNES_BIT(protdesc->rx_byte_order);
  152. temp_reg |= MSP_FSYNC_POL(protdesc->rx_fsync_pol);
  153. temp_reg |= MSP_DATA_WORD_SWAP(protdesc->rx_half_word_swap);
  154. temp_reg |= MSP_SET_COMPANDING_MODE(protdesc->expansion_mode);
  155. temp_reg |= MSP_SET_FSYNC_IGNORE(protdesc->frame_sync_ignore);
  156. writel(temp_reg, msp->registers + MSP_RCF);
  157. }
  158. static int configure_protocol(struct ux500_msp *msp,
  159. struct ux500_msp_config *config)
  160. {
  161. struct msp_protdesc *protdesc;
  162. enum msp_data_size data_size;
  163. u32 temp_reg = 0;
  164. data_size = config->data_size;
  165. msp->def_elem_len = config->def_elem_len;
  166. if (config->default_protdesc == 1) {
  167. if (config->protocol >= MSP_INVALID_PROTOCOL) {
  168. dev_err(msp->dev, "%s: ERROR: Invalid protocol!\n",
  169. __func__);
  170. return -EINVAL;
  171. }
  172. protdesc =
  173. (struct msp_protdesc *)&prot_descs[config->protocol];
  174. } else {
  175. protdesc = (struct msp_protdesc *)&config->protdesc;
  176. }
  177. if (data_size < MSP_DATA_BITS_DEFAULT || data_size > MSP_DATA_BITS_32) {
  178. dev_err(msp->dev,
  179. "%s: ERROR: Invalid data-size requested (data_size = %d)!\n",
  180. __func__, data_size);
  181. return -EINVAL;
  182. }
  183. if (config->direction & MSP_DIR_TX)
  184. set_prot_desc_tx(msp, protdesc, data_size);
  185. if (config->direction & MSP_DIR_RX)
  186. set_prot_desc_rx(msp, protdesc, data_size);
  187. /* The code below should not be separated. */
  188. temp_reg = readl(msp->registers + MSP_GCR) & ~TX_CLK_POL_RISING;
  189. temp_reg |= MSP_TX_CLKPOL_BIT(~protdesc->tx_clk_pol);
  190. writel(temp_reg, msp->registers + MSP_GCR);
  191. temp_reg = readl(msp->registers + MSP_GCR) & ~RX_CLK_POL_RISING;
  192. temp_reg |= MSP_RX_CLKPOL_BIT(protdesc->rx_clk_pol);
  193. writel(temp_reg, msp->registers + MSP_GCR);
  194. return 0;
  195. }
  196. static int setup_bitclk(struct ux500_msp *msp, struct ux500_msp_config *config)
  197. {
  198. u32 reg_val_GCR;
  199. u32 frame_per = 0;
  200. u32 sck_div = 0;
  201. u32 frame_width = 0;
  202. u32 temp_reg = 0;
  203. struct msp_protdesc *protdesc = NULL;
  204. reg_val_GCR = readl(msp->registers + MSP_GCR);
  205. writel(reg_val_GCR & ~SRG_ENABLE, msp->registers + MSP_GCR);
  206. if (config->default_protdesc)
  207. protdesc =
  208. (struct msp_protdesc *)&prot_descs[config->protocol];
  209. else
  210. protdesc = (struct msp_protdesc *)&config->protdesc;
  211. switch (config->protocol) {
  212. case MSP_PCM_PROTOCOL:
  213. case MSP_PCM_COMPAND_PROTOCOL:
  214. frame_width = protdesc->frame_width;
  215. sck_div = config->f_inputclk / (config->frame_freq *
  216. (protdesc->clocks_per_frame));
  217. frame_per = protdesc->frame_period;
  218. break;
  219. case MSP_I2S_PROTOCOL:
  220. frame_width = protdesc->frame_width;
  221. sck_div = config->f_inputclk / (config->frame_freq *
  222. (protdesc->clocks_per_frame));
  223. frame_per = protdesc->frame_period;
  224. break;
  225. default:
  226. dev_err(msp->dev, "%s: ERROR: Unknown protocol (%d)!\n",
  227. __func__,
  228. config->protocol);
  229. return -EINVAL;
  230. }
  231. temp_reg = (sck_div - 1) & SCK_DIV_MASK;
  232. temp_reg |= FRAME_WIDTH_BITS(frame_width);
  233. temp_reg |= FRAME_PERIOD_BITS(frame_per);
  234. writel(temp_reg, msp->registers + MSP_SRG);
  235. msp->f_bitclk = (config->f_inputclk)/(sck_div + 1);
  236. /* Enable bit-clock */
  237. udelay(100);
  238. reg_val_GCR = readl(msp->registers + MSP_GCR);
  239. writel(reg_val_GCR | SRG_ENABLE, msp->registers + MSP_GCR);
  240. udelay(100);
  241. return 0;
  242. }
  243. static int configure_multichannel(struct ux500_msp *msp,
  244. struct ux500_msp_config *config)
  245. {
  246. struct msp_protdesc *protdesc;
  247. struct msp_multichannel_config *mcfg;
  248. u32 reg_val_MCR;
  249. if (config->default_protdesc == 1) {
  250. if (config->protocol >= MSP_INVALID_PROTOCOL) {
  251. dev_err(msp->dev,
  252. "%s: ERROR: Invalid protocol (%d)!\n",
  253. __func__, config->protocol);
  254. return -EINVAL;
  255. }
  256. protdesc = (struct msp_protdesc *)
  257. &prot_descs[config->protocol];
  258. } else {
  259. protdesc = (struct msp_protdesc *)&config->protdesc;
  260. }
  261. mcfg = &config->multichannel_config;
  262. if (mcfg->tx_multichannel_enable) {
  263. if (protdesc->tx_phase_mode == MSP_SINGLE_PHASE) {
  264. reg_val_MCR = readl(msp->registers + MSP_MCR);
  265. writel(reg_val_MCR | (mcfg->tx_multichannel_enable ?
  266. 1 << TMCEN_BIT : 0),
  267. msp->registers + MSP_MCR);
  268. writel(mcfg->tx_channel_0_enable,
  269. msp->registers + MSP_TCE0);
  270. writel(mcfg->tx_channel_1_enable,
  271. msp->registers + MSP_TCE1);
  272. writel(mcfg->tx_channel_2_enable,
  273. msp->registers + MSP_TCE2);
  274. writel(mcfg->tx_channel_3_enable,
  275. msp->registers + MSP_TCE3);
  276. } else {
  277. dev_err(msp->dev,
  278. "%s: ERROR: Only single-phase supported (TX-mode: %d)!\n",
  279. __func__, protdesc->tx_phase_mode);
  280. return -EINVAL;
  281. }
  282. }
  283. if (mcfg->rx_multichannel_enable) {
  284. if (protdesc->rx_phase_mode == MSP_SINGLE_PHASE) {
  285. reg_val_MCR = readl(msp->registers + MSP_MCR);
  286. writel(reg_val_MCR | (mcfg->rx_multichannel_enable ?
  287. 1 << RMCEN_BIT : 0),
  288. msp->registers + MSP_MCR);
  289. writel(mcfg->rx_channel_0_enable,
  290. msp->registers + MSP_RCE0);
  291. writel(mcfg->rx_channel_1_enable,
  292. msp->registers + MSP_RCE1);
  293. writel(mcfg->rx_channel_2_enable,
  294. msp->registers + MSP_RCE2);
  295. writel(mcfg->rx_channel_3_enable,
  296. msp->registers + MSP_RCE3);
  297. } else {
  298. dev_err(msp->dev,
  299. "%s: ERROR: Only single-phase supported (RX-mode: %d)!\n",
  300. __func__, protdesc->rx_phase_mode);
  301. return -EINVAL;
  302. }
  303. if (mcfg->rx_comparison_enable_mode) {
  304. reg_val_MCR = readl(msp->registers + MSP_MCR);
  305. writel(reg_val_MCR |
  306. (mcfg->rx_comparison_enable_mode << RCMPM_BIT),
  307. msp->registers + MSP_MCR);
  308. writel(mcfg->comparison_mask,
  309. msp->registers + MSP_RCM);
  310. writel(mcfg->comparison_value,
  311. msp->registers + MSP_RCV);
  312. }
  313. }
  314. return 0;
  315. }
  316. static int enable_msp(struct ux500_msp *msp, struct ux500_msp_config *config)
  317. {
  318. int status = 0;
  319. u32 reg_val_DMACR, reg_val_GCR;
  320. /* Configure msp with protocol dependent settings */
  321. configure_protocol(msp, config);
  322. setup_bitclk(msp, config);
  323. if (config->multichannel_configured == 1) {
  324. status = configure_multichannel(msp, config);
  325. if (status)
  326. dev_warn(msp->dev,
  327. "%s: WARN: configure_multichannel failed (%d)!\n",
  328. __func__, status);
  329. }
  330. /* Make sure the correct DMA-directions are configured */
  331. if ((config->direction & MSP_DIR_RX) &&
  332. !msp->capture_dma_data.dma_cfg) {
  333. dev_err(msp->dev, "%s: ERROR: MSP RX-mode is not configured!",
  334. __func__);
  335. return -EINVAL;
  336. }
  337. if ((config->direction == MSP_DIR_TX) &&
  338. !msp->playback_dma_data.dma_cfg) {
  339. dev_err(msp->dev, "%s: ERROR: MSP TX-mode is not configured!",
  340. __func__);
  341. return -EINVAL;
  342. }
  343. reg_val_DMACR = readl(msp->registers + MSP_DMACR);
  344. if (config->direction & MSP_DIR_RX)
  345. reg_val_DMACR |= RX_DMA_ENABLE;
  346. if (config->direction & MSP_DIR_TX)
  347. reg_val_DMACR |= TX_DMA_ENABLE;
  348. writel(reg_val_DMACR, msp->registers + MSP_DMACR);
  349. writel(config->iodelay, msp->registers + MSP_IODLY);
  350. /* Enable frame generation logic */
  351. reg_val_GCR = readl(msp->registers + MSP_GCR);
  352. writel(reg_val_GCR | FRAME_GEN_ENABLE, msp->registers + MSP_GCR);
  353. return status;
  354. }
  355. static void flush_fifo_rx(struct ux500_msp *msp)
  356. {
  357. u32 reg_val_GCR, reg_val_FLR;
  358. u32 limit = 32;
  359. reg_val_GCR = readl(msp->registers + MSP_GCR);
  360. writel(reg_val_GCR | RX_ENABLE, msp->registers + MSP_GCR);
  361. reg_val_FLR = readl(msp->registers + MSP_FLR);
  362. while (!(reg_val_FLR & RX_FIFO_EMPTY) && limit--) {
  363. readl(msp->registers + MSP_DR);
  364. reg_val_FLR = readl(msp->registers + MSP_FLR);
  365. }
  366. writel(reg_val_GCR, msp->registers + MSP_GCR);
  367. }
  368. static void flush_fifo_tx(struct ux500_msp *msp)
  369. {
  370. u32 reg_val_GCR, reg_val_FLR;
  371. u32 limit = 32;
  372. reg_val_GCR = readl(msp->registers + MSP_GCR);
  373. writel(reg_val_GCR | TX_ENABLE, msp->registers + MSP_GCR);
  374. writel(MSP_ITCR_ITEN | MSP_ITCR_TESTFIFO, msp->registers + MSP_ITCR);
  375. reg_val_FLR = readl(msp->registers + MSP_FLR);
  376. while (!(reg_val_FLR & TX_FIFO_EMPTY) && limit--) {
  377. readl(msp->registers + MSP_TSTDR);
  378. reg_val_FLR = readl(msp->registers + MSP_FLR);
  379. }
  380. writel(0x0, msp->registers + MSP_ITCR);
  381. writel(reg_val_GCR, msp->registers + MSP_GCR);
  382. }
  383. int ux500_msp_i2s_open(struct ux500_msp *msp,
  384. struct ux500_msp_config *config)
  385. {
  386. u32 old_reg, new_reg, mask;
  387. int res;
  388. unsigned int tx_sel, rx_sel, tx_busy, rx_busy;
  389. if (in_interrupt()) {
  390. dev_err(msp->dev,
  391. "%s: ERROR: Open called in interrupt context!\n",
  392. __func__);
  393. return -1;
  394. }
  395. tx_sel = (config->direction & MSP_DIR_TX) > 0;
  396. rx_sel = (config->direction & MSP_DIR_RX) > 0;
  397. if (!tx_sel && !rx_sel) {
  398. dev_err(msp->dev, "%s: Error: No direction selected!\n",
  399. __func__);
  400. return -EINVAL;
  401. }
  402. tx_busy = (msp->dir_busy & MSP_DIR_TX) > 0;
  403. rx_busy = (msp->dir_busy & MSP_DIR_RX) > 0;
  404. if (tx_busy && tx_sel) {
  405. dev_err(msp->dev, "%s: Error: TX is in use!\n", __func__);
  406. return -EBUSY;
  407. }
  408. if (rx_busy && rx_sel) {
  409. dev_err(msp->dev, "%s: Error: RX is in use!\n", __func__);
  410. return -EBUSY;
  411. }
  412. msp->dir_busy |= (tx_sel ? MSP_DIR_TX : 0) | (rx_sel ? MSP_DIR_RX : 0);
  413. /* First do the global config register */
  414. mask = RX_CLK_SEL_MASK | TX_CLK_SEL_MASK | RX_FSYNC_MASK |
  415. TX_FSYNC_MASK | RX_SYNC_SEL_MASK | TX_SYNC_SEL_MASK |
  416. RX_FIFO_ENABLE_MASK | TX_FIFO_ENABLE_MASK | SRG_CLK_SEL_MASK |
  417. LOOPBACK_MASK | TX_EXTRA_DELAY_MASK;
  418. new_reg = (config->tx_clk_sel | config->rx_clk_sel |
  419. config->rx_fsync_pol | config->tx_fsync_pol |
  420. config->rx_fsync_sel | config->tx_fsync_sel |
  421. config->rx_fifo_config | config->tx_fifo_config |
  422. config->srg_clk_sel | config->loopback_enable |
  423. config->tx_data_enable);
  424. old_reg = readl(msp->registers + MSP_GCR);
  425. old_reg &= ~mask;
  426. new_reg |= old_reg;
  427. writel(new_reg, msp->registers + MSP_GCR);
  428. res = enable_msp(msp, config);
  429. if (res < 0) {
  430. dev_err(msp->dev, "%s: ERROR: enable_msp failed (%d)!\n",
  431. __func__, res);
  432. return -EBUSY;
  433. }
  434. if (config->loopback_enable & 0x80)
  435. msp->loopback_enable = 1;
  436. /* Flush FIFOs */
  437. flush_fifo_tx(msp);
  438. flush_fifo_rx(msp);
  439. msp->msp_state = MSP_STATE_CONFIGURED;
  440. return 0;
  441. }
  442. static void disable_msp_rx(struct ux500_msp *msp)
  443. {
  444. u32 reg_val_GCR, reg_val_DMACR, reg_val_IMSC;
  445. reg_val_GCR = readl(msp->registers + MSP_GCR);
  446. writel(reg_val_GCR & ~RX_ENABLE, msp->registers + MSP_GCR);
  447. reg_val_DMACR = readl(msp->registers + MSP_DMACR);
  448. writel(reg_val_DMACR & ~RX_DMA_ENABLE, msp->registers + MSP_DMACR);
  449. reg_val_IMSC = readl(msp->registers + MSP_IMSC);
  450. writel(reg_val_IMSC &
  451. ~(RX_SERVICE_INT | RX_OVERRUN_ERROR_INT),
  452. msp->registers + MSP_IMSC);
  453. msp->dir_busy &= ~MSP_DIR_RX;
  454. }
  455. static void disable_msp_tx(struct ux500_msp *msp)
  456. {
  457. u32 reg_val_GCR, reg_val_DMACR, reg_val_IMSC;
  458. reg_val_GCR = readl(msp->registers + MSP_GCR);
  459. writel(reg_val_GCR & ~TX_ENABLE, msp->registers + MSP_GCR);
  460. reg_val_DMACR = readl(msp->registers + MSP_DMACR);
  461. writel(reg_val_DMACR & ~TX_DMA_ENABLE, msp->registers + MSP_DMACR);
  462. reg_val_IMSC = readl(msp->registers + MSP_IMSC);
  463. writel(reg_val_IMSC &
  464. ~(TX_SERVICE_INT | TX_UNDERRUN_ERR_INT),
  465. msp->registers + MSP_IMSC);
  466. msp->dir_busy &= ~MSP_DIR_TX;
  467. }
  468. static int disable_msp(struct ux500_msp *msp, unsigned int dir)
  469. {
  470. u32 reg_val_GCR;
  471. unsigned int disable_tx, disable_rx;
  472. reg_val_GCR = readl(msp->registers + MSP_GCR);
  473. disable_tx = dir & MSP_DIR_TX;
  474. disable_rx = dir & MSP_DIR_TX;
  475. if (disable_tx && disable_rx) {
  476. reg_val_GCR = readl(msp->registers + MSP_GCR);
  477. writel(reg_val_GCR | LOOPBACK_MASK,
  478. msp->registers + MSP_GCR);
  479. /* Flush TX-FIFO */
  480. flush_fifo_tx(msp);
  481. /* Disable TX-channel */
  482. writel((readl(msp->registers + MSP_GCR) &
  483. (~TX_ENABLE)), msp->registers + MSP_GCR);
  484. /* Flush RX-FIFO */
  485. flush_fifo_rx(msp);
  486. /* Disable Loopback and Receive channel */
  487. writel((readl(msp->registers + MSP_GCR) &
  488. (~(RX_ENABLE | LOOPBACK_MASK))),
  489. msp->registers + MSP_GCR);
  490. disable_msp_tx(msp);
  491. disable_msp_rx(msp);
  492. } else if (disable_tx)
  493. disable_msp_tx(msp);
  494. else if (disable_rx)
  495. disable_msp_rx(msp);
  496. return 0;
  497. }
  498. int ux500_msp_i2s_trigger(struct ux500_msp *msp, int cmd, int direction)
  499. {
  500. u32 reg_val_GCR, enable_bit;
  501. if (msp->msp_state == MSP_STATE_IDLE) {
  502. dev_err(msp->dev, "%s: ERROR: MSP is not configured!\n",
  503. __func__);
  504. return -EINVAL;
  505. }
  506. switch (cmd) {
  507. case SNDRV_PCM_TRIGGER_START:
  508. case SNDRV_PCM_TRIGGER_RESUME:
  509. case SNDRV_PCM_TRIGGER_PAUSE_RELEASE:
  510. if (direction == SNDRV_PCM_STREAM_PLAYBACK)
  511. enable_bit = TX_ENABLE;
  512. else
  513. enable_bit = RX_ENABLE;
  514. reg_val_GCR = readl(msp->registers + MSP_GCR);
  515. writel(reg_val_GCR | enable_bit, msp->registers + MSP_GCR);
  516. break;
  517. case SNDRV_PCM_TRIGGER_STOP:
  518. case SNDRV_PCM_TRIGGER_SUSPEND:
  519. case SNDRV_PCM_TRIGGER_PAUSE_PUSH:
  520. if (direction == SNDRV_PCM_STREAM_PLAYBACK)
  521. disable_msp_tx(msp);
  522. else
  523. disable_msp_rx(msp);
  524. break;
  525. default:
  526. return -EINVAL;
  527. }
  528. return 0;
  529. }
  530. int ux500_msp_i2s_close(struct ux500_msp *msp, unsigned int dir)
  531. {
  532. int status = 0;
  533. dev_dbg(msp->dev, "%s: Enter (dir = 0x%01x).\n", __func__, dir);
  534. status = disable_msp(msp, dir);
  535. if (msp->dir_busy == 0) {
  536. /* disable sample rate and frame generators */
  537. msp->msp_state = MSP_STATE_IDLE;
  538. writel((readl(msp->registers + MSP_GCR) &
  539. (~(FRAME_GEN_ENABLE | SRG_ENABLE))),
  540. msp->registers + MSP_GCR);
  541. writel(0, msp->registers + MSP_GCR);
  542. writel(0, msp->registers + MSP_TCF);
  543. writel(0, msp->registers + MSP_RCF);
  544. writel(0, msp->registers + MSP_DMACR);
  545. writel(0, msp->registers + MSP_SRG);
  546. writel(0, msp->registers + MSP_MCR);
  547. writel(0, msp->registers + MSP_RCM);
  548. writel(0, msp->registers + MSP_RCV);
  549. writel(0, msp->registers + MSP_TCE0);
  550. writel(0, msp->registers + MSP_TCE1);
  551. writel(0, msp->registers + MSP_TCE2);
  552. writel(0, msp->registers + MSP_TCE3);
  553. writel(0, msp->registers + MSP_RCE0);
  554. writel(0, msp->registers + MSP_RCE1);
  555. writel(0, msp->registers + MSP_RCE2);
  556. writel(0, msp->registers + MSP_RCE3);
  557. }
  558. return status;
  559. }
  560. static int ux500_msp_i2s_of_init_msp(struct platform_device *pdev,
  561. struct ux500_msp *msp,
  562. struct msp_i2s_platform_data **platform_data)
  563. {
  564. struct msp_i2s_platform_data *pdata;
  565. *platform_data = devm_kzalloc(&pdev->dev,
  566. sizeof(struct msp_i2s_platform_data),
  567. GFP_KERNEL);
  568. pdata = *platform_data;
  569. if (!pdata)
  570. return -ENOMEM;
  571. msp->playback_dma_data.dma_cfg = devm_kzalloc(&pdev->dev,
  572. sizeof(struct stedma40_chan_cfg),
  573. GFP_KERNEL);
  574. if (!msp->playback_dma_data.dma_cfg)
  575. return -ENOMEM;
  576. msp->capture_dma_data.dma_cfg = devm_kzalloc(&pdev->dev,
  577. sizeof(struct stedma40_chan_cfg),
  578. GFP_KERNEL);
  579. if (!msp->capture_dma_data.dma_cfg)
  580. return -ENOMEM;
  581. return 0;
  582. }
  583. int ux500_msp_i2s_init_msp(struct platform_device *pdev,
  584. struct ux500_msp **msp_p,
  585. struct msp_i2s_platform_data *platform_data)
  586. {
  587. struct resource *res = NULL;
  588. struct device_node *np = pdev->dev.of_node;
  589. struct ux500_msp *msp;
  590. int ret;
  591. *msp_p = devm_kzalloc(&pdev->dev, sizeof(struct ux500_msp), GFP_KERNEL);
  592. msp = *msp_p;
  593. if (!msp)
  594. return -ENOMEM;
  595. if (!platform_data) {
  596. if (np) {
  597. ret = ux500_msp_i2s_of_init_msp(pdev, msp,
  598. &platform_data);
  599. if (ret)
  600. return ret;
  601. } else
  602. return -EINVAL;
  603. } else {
  604. msp->playback_dma_data.dma_cfg = platform_data->msp_i2s_dma_tx;
  605. msp->capture_dma_data.dma_cfg = platform_data->msp_i2s_dma_rx;
  606. msp->id = platform_data->id;
  607. }
  608. msp->dev = &pdev->dev;
  609. res = platform_get_resource(pdev, IORESOURCE_MEM, 0);
  610. if (res == NULL) {
  611. dev_err(&pdev->dev, "%s: ERROR: Unable to get resource!\n",
  612. __func__);
  613. return -ENOMEM;
  614. }
  615. msp->playback_dma_data.tx_rx_addr = res->start + MSP_DR;
  616. msp->capture_dma_data.tx_rx_addr = res->start + MSP_DR;
  617. msp->registers = devm_ioremap(&pdev->dev, res->start,
  618. resource_size(res));
  619. if (msp->registers == NULL) {
  620. dev_err(&pdev->dev, "%s: ERROR: ioremap failed!\n", __func__);
  621. return -ENOMEM;
  622. }
  623. msp->msp_state = MSP_STATE_IDLE;
  624. msp->loopback_enable = 0;
  625. return 0;
  626. }
  627. void ux500_msp_i2s_cleanup_msp(struct platform_device *pdev,
  628. struct ux500_msp *msp)
  629. {
  630. dev_dbg(msp->dev, "%s: Enter (id = %d).\n", __func__, msp->id);
  631. }
  632. MODULE_LICENSE("GPL v2");