ux500_msp_i2s.c 21 KB

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