omap_ssi_port.c 40 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383
  1. // SPDX-License-Identifier: GPL-2.0-only
  2. /* OMAP SSI port driver.
  3. *
  4. * Copyright (C) 2010 Nokia Corporation. All rights reserved.
  5. * Copyright (C) 2014 Sebastian Reichel <sre@kernel.org>
  6. *
  7. * Contact: Carlos Chinea <carlos.chinea@nokia.com>
  8. */
  9. #include <linux/mod_devicetable.h>
  10. #include <linux/platform_device.h>
  11. #include <linux/dma-mapping.h>
  12. #include <linux/pm_runtime.h>
  13. #include <linux/delay.h>
  14. #include <linux/gpio/consumer.h>
  15. #include <linux/pinctrl/consumer.h>
  16. #include <linux/debugfs.h>
  17. #include "omap_ssi_regs.h"
  18. #include "omap_ssi.h"
  19. static inline int hsi_dummy_msg(struct hsi_msg *msg __maybe_unused)
  20. {
  21. return 0;
  22. }
  23. static inline int hsi_dummy_cl(struct hsi_client *cl __maybe_unused)
  24. {
  25. return 0;
  26. }
  27. static inline unsigned int ssi_wakein(struct hsi_port *port)
  28. {
  29. struct omap_ssi_port *omap_port = hsi_port_drvdata(port);
  30. return gpiod_get_value(omap_port->wake_gpio);
  31. }
  32. #ifdef CONFIG_DEBUG_FS
  33. static void ssi_debug_remove_port(struct hsi_port *port)
  34. {
  35. struct omap_ssi_port *omap_port = hsi_port_drvdata(port);
  36. debugfs_remove_recursive(omap_port->dir);
  37. }
  38. static int ssi_port_regs_show(struct seq_file *m, void *p __maybe_unused)
  39. {
  40. struct hsi_port *port = m->private;
  41. struct omap_ssi_port *omap_port = hsi_port_drvdata(port);
  42. struct hsi_controller *ssi = to_hsi_controller(port->device.parent);
  43. struct omap_ssi_controller *omap_ssi = hsi_controller_drvdata(ssi);
  44. void __iomem *base = omap_ssi->sys;
  45. unsigned int ch;
  46. pm_runtime_get_sync(omap_port->pdev);
  47. if (omap_port->wake_irq > 0)
  48. seq_printf(m, "CAWAKE\t\t: %d\n", ssi_wakein(port));
  49. seq_printf(m, "WAKE\t\t: 0x%08x\n",
  50. readl(base + SSI_WAKE_REG(port->num)));
  51. seq_printf(m, "MPU_ENABLE_IRQ%d\t: 0x%08x\n", 0,
  52. readl(base + SSI_MPU_ENABLE_REG(port->num, 0)));
  53. seq_printf(m, "MPU_STATUS_IRQ%d\t: 0x%08x\n", 0,
  54. readl(base + SSI_MPU_STATUS_REG(port->num, 0)));
  55. /* SST */
  56. base = omap_port->sst_base;
  57. seq_puts(m, "\nSST\n===\n");
  58. seq_printf(m, "ID SST\t\t: 0x%08x\n",
  59. readl(base + SSI_SST_ID_REG));
  60. seq_printf(m, "MODE\t\t: 0x%08x\n",
  61. readl(base + SSI_SST_MODE_REG));
  62. seq_printf(m, "FRAMESIZE\t: 0x%08x\n",
  63. readl(base + SSI_SST_FRAMESIZE_REG));
  64. seq_printf(m, "DIVISOR\t\t: 0x%08x\n",
  65. readl(base + SSI_SST_DIVISOR_REG));
  66. seq_printf(m, "CHANNELS\t: 0x%08x\n",
  67. readl(base + SSI_SST_CHANNELS_REG));
  68. seq_printf(m, "ARBMODE\t\t: 0x%08x\n",
  69. readl(base + SSI_SST_ARBMODE_REG));
  70. seq_printf(m, "TXSTATE\t\t: 0x%08x\n",
  71. readl(base + SSI_SST_TXSTATE_REG));
  72. seq_printf(m, "BUFSTATE\t: 0x%08x\n",
  73. readl(base + SSI_SST_BUFSTATE_REG));
  74. seq_printf(m, "BREAK\t\t: 0x%08x\n",
  75. readl(base + SSI_SST_BREAK_REG));
  76. for (ch = 0; ch < omap_port->channels; ch++) {
  77. seq_printf(m, "BUFFER_CH%d\t: 0x%08x\n", ch,
  78. readl(base + SSI_SST_BUFFER_CH_REG(ch)));
  79. }
  80. /* SSR */
  81. base = omap_port->ssr_base;
  82. seq_puts(m, "\nSSR\n===\n");
  83. seq_printf(m, "ID SSR\t\t: 0x%08x\n",
  84. readl(base + SSI_SSR_ID_REG));
  85. seq_printf(m, "MODE\t\t: 0x%08x\n",
  86. readl(base + SSI_SSR_MODE_REG));
  87. seq_printf(m, "FRAMESIZE\t: 0x%08x\n",
  88. readl(base + SSI_SSR_FRAMESIZE_REG));
  89. seq_printf(m, "CHANNELS\t: 0x%08x\n",
  90. readl(base + SSI_SSR_CHANNELS_REG));
  91. seq_printf(m, "TIMEOUT\t\t: 0x%08x\n",
  92. readl(base + SSI_SSR_TIMEOUT_REG));
  93. seq_printf(m, "RXSTATE\t\t: 0x%08x\n",
  94. readl(base + SSI_SSR_RXSTATE_REG));
  95. seq_printf(m, "BUFSTATE\t: 0x%08x\n",
  96. readl(base + SSI_SSR_BUFSTATE_REG));
  97. seq_printf(m, "BREAK\t\t: 0x%08x\n",
  98. readl(base + SSI_SSR_BREAK_REG));
  99. seq_printf(m, "ERROR\t\t: 0x%08x\n",
  100. readl(base + SSI_SSR_ERROR_REG));
  101. seq_printf(m, "ERRORACK\t: 0x%08x\n",
  102. readl(base + SSI_SSR_ERRORACK_REG));
  103. for (ch = 0; ch < omap_port->channels; ch++) {
  104. seq_printf(m, "BUFFER_CH%d\t: 0x%08x\n", ch,
  105. readl(base + SSI_SSR_BUFFER_CH_REG(ch)));
  106. }
  107. pm_runtime_put_autosuspend(omap_port->pdev);
  108. return 0;
  109. }
  110. DEFINE_SHOW_ATTRIBUTE(ssi_port_regs);
  111. static int ssi_div_get(void *data, u64 *val)
  112. {
  113. struct hsi_port *port = data;
  114. struct omap_ssi_port *omap_port = hsi_port_drvdata(port);
  115. pm_runtime_get_sync(omap_port->pdev);
  116. *val = readl(omap_port->sst_base + SSI_SST_DIVISOR_REG);
  117. pm_runtime_put_autosuspend(omap_port->pdev);
  118. return 0;
  119. }
  120. static int ssi_div_set(void *data, u64 val)
  121. {
  122. struct hsi_port *port = data;
  123. struct omap_ssi_port *omap_port = hsi_port_drvdata(port);
  124. if (val > 127)
  125. return -EINVAL;
  126. pm_runtime_get_sync(omap_port->pdev);
  127. writel(val, omap_port->sst_base + SSI_SST_DIVISOR_REG);
  128. omap_port->sst.divisor = val;
  129. pm_runtime_put_autosuspend(omap_port->pdev);
  130. return 0;
  131. }
  132. DEFINE_DEBUGFS_ATTRIBUTE(ssi_sst_div_fops, ssi_div_get, ssi_div_set, "%llu\n");
  133. static void ssi_debug_add_port(struct omap_ssi_port *omap_port,
  134. struct dentry *dir)
  135. {
  136. struct hsi_port *port = to_hsi_port(omap_port->dev);
  137. dir = debugfs_create_dir(dev_name(omap_port->dev), dir);
  138. omap_port->dir = dir;
  139. debugfs_create_file("regs", S_IRUGO, dir, port, &ssi_port_regs_fops);
  140. dir = debugfs_create_dir("sst", dir);
  141. debugfs_create_file_unsafe("divisor", 0644, dir, port,
  142. &ssi_sst_div_fops);
  143. }
  144. #endif
  145. static void ssi_process_errqueue(struct work_struct *work)
  146. {
  147. struct omap_ssi_port *omap_port;
  148. struct list_head *head, *tmp;
  149. struct hsi_msg *msg;
  150. omap_port = container_of(work, struct omap_ssi_port, errqueue_work.work);
  151. list_for_each_safe(head, tmp, &omap_port->errqueue) {
  152. msg = list_entry(head, struct hsi_msg, link);
  153. msg->complete(msg);
  154. list_del(head);
  155. }
  156. }
  157. static int ssi_claim_lch(struct hsi_msg *msg)
  158. {
  159. struct hsi_port *port = hsi_get_port(msg->cl);
  160. struct hsi_controller *ssi = to_hsi_controller(port->device.parent);
  161. struct omap_ssi_controller *omap_ssi = hsi_controller_drvdata(ssi);
  162. int lch;
  163. for (lch = 0; lch < SSI_MAX_GDD_LCH; lch++)
  164. if (!omap_ssi->gdd_trn[lch].msg) {
  165. omap_ssi->gdd_trn[lch].msg = msg;
  166. omap_ssi->gdd_trn[lch].sg = msg->sgt.sgl;
  167. return lch;
  168. }
  169. return -EBUSY;
  170. }
  171. static int ssi_start_dma(struct hsi_msg *msg, int lch)
  172. {
  173. struct hsi_port *port = hsi_get_port(msg->cl);
  174. struct omap_ssi_port *omap_port = hsi_port_drvdata(port);
  175. struct hsi_controller *ssi = to_hsi_controller(port->device.parent);
  176. struct omap_ssi_controller *omap_ssi = hsi_controller_drvdata(ssi);
  177. void __iomem *gdd = omap_ssi->gdd;
  178. int err;
  179. u16 csdp;
  180. u16 ccr;
  181. u32 s_addr;
  182. u32 d_addr;
  183. u32 tmp;
  184. /* Hold clocks during the transfer */
  185. pm_runtime_get(omap_port->pdev);
  186. if (!pm_runtime_active(omap_port->pdev)) {
  187. dev_warn(&port->device, "ssi_start_dma called without runtime PM!\n");
  188. pm_runtime_put_autosuspend(omap_port->pdev);
  189. return -EREMOTEIO;
  190. }
  191. if (msg->ttype == HSI_MSG_READ) {
  192. err = dma_map_sg(&ssi->device, msg->sgt.sgl, msg->sgt.nents,
  193. DMA_FROM_DEVICE);
  194. if (!err) {
  195. dev_dbg(&ssi->device, "DMA map SG failed !\n");
  196. pm_runtime_put_autosuspend(omap_port->pdev);
  197. return -EIO;
  198. }
  199. csdp = SSI_DST_BURST_4x32_BIT | SSI_DST_MEMORY_PORT |
  200. SSI_SRC_SINGLE_ACCESS0 | SSI_SRC_PERIPHERAL_PORT |
  201. SSI_DATA_TYPE_S32;
  202. ccr = msg->channel + 0x10 + (port->num * 8); /* Sync */
  203. ccr |= SSI_DST_AMODE_POSTINC | SSI_SRC_AMODE_CONST |
  204. SSI_CCR_ENABLE;
  205. s_addr = omap_port->ssr_dma +
  206. SSI_SSR_BUFFER_CH_REG(msg->channel);
  207. d_addr = sg_dma_address(msg->sgt.sgl);
  208. } else {
  209. err = dma_map_sg(&ssi->device, msg->sgt.sgl, msg->sgt.nents,
  210. DMA_TO_DEVICE);
  211. if (!err) {
  212. dev_dbg(&ssi->device, "DMA map SG failed !\n");
  213. pm_runtime_put_autosuspend(omap_port->pdev);
  214. return -EIO;
  215. }
  216. csdp = SSI_SRC_BURST_4x32_BIT | SSI_SRC_MEMORY_PORT |
  217. SSI_DST_SINGLE_ACCESS0 | SSI_DST_PERIPHERAL_PORT |
  218. SSI_DATA_TYPE_S32;
  219. ccr = (msg->channel + 1 + (port->num * 8)) & 0xf; /* Sync */
  220. ccr |= SSI_SRC_AMODE_POSTINC | SSI_DST_AMODE_CONST |
  221. SSI_CCR_ENABLE;
  222. s_addr = sg_dma_address(msg->sgt.sgl);
  223. d_addr = omap_port->sst_dma +
  224. SSI_SST_BUFFER_CH_REG(msg->channel);
  225. }
  226. dev_dbg(&ssi->device, "lch %d cdsp %08x ccr %04x s_addr %08x d_addr %08x\n",
  227. lch, csdp, ccr, s_addr, d_addr);
  228. writew_relaxed(csdp, gdd + SSI_GDD_CSDP_REG(lch));
  229. writew_relaxed(SSI_BLOCK_IE | SSI_TOUT_IE, gdd + SSI_GDD_CICR_REG(lch));
  230. writel_relaxed(d_addr, gdd + SSI_GDD_CDSA_REG(lch));
  231. writel_relaxed(s_addr, gdd + SSI_GDD_CSSA_REG(lch));
  232. writew_relaxed(SSI_BYTES_TO_FRAMES(msg->sgt.sgl->length),
  233. gdd + SSI_GDD_CEN_REG(lch));
  234. spin_lock_bh(&omap_ssi->lock);
  235. tmp = readl(omap_ssi->sys + SSI_GDD_MPU_IRQ_ENABLE_REG);
  236. tmp |= SSI_GDD_LCH(lch);
  237. writel_relaxed(tmp, omap_ssi->sys + SSI_GDD_MPU_IRQ_ENABLE_REG);
  238. spin_unlock_bh(&omap_ssi->lock);
  239. writew(ccr, gdd + SSI_GDD_CCR_REG(lch));
  240. msg->status = HSI_STATUS_PROCEEDING;
  241. return 0;
  242. }
  243. static int ssi_start_pio(struct hsi_msg *msg)
  244. {
  245. struct hsi_port *port = hsi_get_port(msg->cl);
  246. struct omap_ssi_port *omap_port = hsi_port_drvdata(port);
  247. struct hsi_controller *ssi = to_hsi_controller(port->device.parent);
  248. struct omap_ssi_controller *omap_ssi = hsi_controller_drvdata(ssi);
  249. u32 val;
  250. pm_runtime_get(omap_port->pdev);
  251. if (!pm_runtime_active(omap_port->pdev)) {
  252. dev_warn(&port->device, "ssi_start_pio called without runtime PM!\n");
  253. pm_runtime_put_autosuspend(omap_port->pdev);
  254. return -EREMOTEIO;
  255. }
  256. if (msg->ttype == HSI_MSG_WRITE) {
  257. val = SSI_DATAACCEPT(msg->channel);
  258. /* Hold clocks for pio writes */
  259. pm_runtime_get(omap_port->pdev);
  260. } else {
  261. val = SSI_DATAAVAILABLE(msg->channel) | SSI_ERROROCCURED;
  262. }
  263. dev_dbg(&port->device, "Single %s transfer\n",
  264. msg->ttype ? "write" : "read");
  265. val |= readl(omap_ssi->sys + SSI_MPU_ENABLE_REG(port->num, 0));
  266. writel(val, omap_ssi->sys + SSI_MPU_ENABLE_REG(port->num, 0));
  267. pm_runtime_put_autosuspend(omap_port->pdev);
  268. msg->actual_len = 0;
  269. msg->status = HSI_STATUS_PROCEEDING;
  270. return 0;
  271. }
  272. static int ssi_start_transfer(struct list_head *queue)
  273. {
  274. struct hsi_msg *msg;
  275. int lch = -1;
  276. if (list_empty(queue))
  277. return 0;
  278. msg = list_first_entry(queue, struct hsi_msg, link);
  279. if (msg->status != HSI_STATUS_QUEUED)
  280. return 0;
  281. if ((msg->sgt.nents) && (msg->sgt.sgl->length > sizeof(u32)))
  282. lch = ssi_claim_lch(msg);
  283. if (lch >= 0)
  284. return ssi_start_dma(msg, lch);
  285. else
  286. return ssi_start_pio(msg);
  287. }
  288. static int ssi_async_break(struct hsi_msg *msg)
  289. {
  290. struct hsi_port *port = hsi_get_port(msg->cl);
  291. struct omap_ssi_port *omap_port = hsi_port_drvdata(port);
  292. struct hsi_controller *ssi = to_hsi_controller(port->device.parent);
  293. struct omap_ssi_controller *omap_ssi = hsi_controller_drvdata(ssi);
  294. int err = 0;
  295. u32 tmp;
  296. pm_runtime_get_sync(omap_port->pdev);
  297. if (msg->ttype == HSI_MSG_WRITE) {
  298. if (omap_port->sst.mode != SSI_MODE_FRAME) {
  299. err = -EINVAL;
  300. goto out;
  301. }
  302. writel(1, omap_port->sst_base + SSI_SST_BREAK_REG);
  303. msg->status = HSI_STATUS_COMPLETED;
  304. msg->complete(msg);
  305. } else {
  306. if (omap_port->ssr.mode != SSI_MODE_FRAME) {
  307. err = -EINVAL;
  308. goto out;
  309. }
  310. spin_lock_bh(&omap_port->lock);
  311. tmp = readl(omap_ssi->sys +
  312. SSI_MPU_ENABLE_REG(port->num, 0));
  313. writel(tmp | SSI_BREAKDETECTED,
  314. omap_ssi->sys + SSI_MPU_ENABLE_REG(port->num, 0));
  315. msg->status = HSI_STATUS_PROCEEDING;
  316. list_add_tail(&msg->link, &omap_port->brkqueue);
  317. spin_unlock_bh(&omap_port->lock);
  318. }
  319. out:
  320. pm_runtime_put_autosuspend(omap_port->pdev);
  321. return err;
  322. }
  323. static int ssi_async(struct hsi_msg *msg)
  324. {
  325. struct hsi_port *port = hsi_get_port(msg->cl);
  326. struct omap_ssi_port *omap_port = hsi_port_drvdata(port);
  327. struct list_head *queue;
  328. int err = 0;
  329. BUG_ON(!msg);
  330. if (msg->sgt.nents > 1)
  331. return -ENOSYS; /* TODO: Add sg support */
  332. if (msg->break_frame)
  333. return ssi_async_break(msg);
  334. if (msg->ttype) {
  335. BUG_ON(msg->channel >= omap_port->sst.channels);
  336. queue = &omap_port->txqueue[msg->channel];
  337. } else {
  338. BUG_ON(msg->channel >= omap_port->ssr.channels);
  339. queue = &omap_port->rxqueue[msg->channel];
  340. }
  341. msg->status = HSI_STATUS_QUEUED;
  342. pm_runtime_get_sync(omap_port->pdev);
  343. spin_lock_bh(&omap_port->lock);
  344. list_add_tail(&msg->link, queue);
  345. err = ssi_start_transfer(queue);
  346. if (err < 0) {
  347. list_del(&msg->link);
  348. msg->status = HSI_STATUS_ERROR;
  349. }
  350. spin_unlock_bh(&omap_port->lock);
  351. pm_runtime_put_autosuspend(omap_port->pdev);
  352. dev_dbg(&port->device, "msg status %d ttype %d ch %d\n",
  353. msg->status, msg->ttype, msg->channel);
  354. return err;
  355. }
  356. static u32 ssi_calculate_div(struct hsi_controller *ssi)
  357. {
  358. struct omap_ssi_controller *omap_ssi = hsi_controller_drvdata(ssi);
  359. u32 tx_fckrate = (u32) omap_ssi->fck_rate;
  360. /* / 2 : SSI TX clock is always half of the SSI functional clock */
  361. tx_fckrate >>= 1;
  362. /* Round down when tx_fckrate % omap_ssi->max_speed == 0 */
  363. tx_fckrate--;
  364. dev_dbg(&ssi->device, "TX div %d for fck_rate %lu Khz speed %d Kb/s\n",
  365. tx_fckrate / omap_ssi->max_speed, omap_ssi->fck_rate,
  366. omap_ssi->max_speed);
  367. return tx_fckrate / omap_ssi->max_speed;
  368. }
  369. static void ssi_flush_queue(struct list_head *queue, struct hsi_client *cl)
  370. {
  371. struct list_head *node, *tmp;
  372. struct hsi_msg *msg;
  373. list_for_each_safe(node, tmp, queue) {
  374. msg = list_entry(node, struct hsi_msg, link);
  375. if ((cl) && (cl != msg->cl))
  376. continue;
  377. list_del(node);
  378. pr_debug("flush queue: ch %d, msg %p len %d type %d ctxt %p\n",
  379. msg->channel, msg, msg->sgt.sgl->length,
  380. msg->ttype, msg->context);
  381. if (msg->destructor)
  382. msg->destructor(msg);
  383. else
  384. hsi_free_msg(msg);
  385. }
  386. }
  387. static int ssi_setup(struct hsi_client *cl)
  388. {
  389. struct hsi_port *port = to_hsi_port(cl->device.parent);
  390. struct omap_ssi_port *omap_port = hsi_port_drvdata(port);
  391. struct hsi_controller *ssi = to_hsi_controller(port->device.parent);
  392. struct omap_ssi_controller *omap_ssi = hsi_controller_drvdata(ssi);
  393. void __iomem *sst = omap_port->sst_base;
  394. void __iomem *ssr = omap_port->ssr_base;
  395. u32 div;
  396. u32 val;
  397. int err = 0;
  398. pm_runtime_get_sync(omap_port->pdev);
  399. spin_lock_bh(&omap_port->lock);
  400. if (cl->tx_cfg.speed)
  401. omap_ssi->max_speed = cl->tx_cfg.speed;
  402. div = ssi_calculate_div(ssi);
  403. if (div > SSI_MAX_DIVISOR) {
  404. dev_err(&cl->device, "Invalid TX speed %d Mb/s (div %d)\n",
  405. cl->tx_cfg.speed, div);
  406. err = -EINVAL;
  407. goto out;
  408. }
  409. /* Set TX/RX module to sleep to stop TX/RX during cfg update */
  410. writel_relaxed(SSI_MODE_SLEEP, sst + SSI_SST_MODE_REG);
  411. writel_relaxed(SSI_MODE_SLEEP, ssr + SSI_SSR_MODE_REG);
  412. /* Flush posted write */
  413. val = readl(ssr + SSI_SSR_MODE_REG);
  414. /* TX */
  415. writel_relaxed(31, sst + SSI_SST_FRAMESIZE_REG);
  416. writel_relaxed(div, sst + SSI_SST_DIVISOR_REG);
  417. writel_relaxed(cl->tx_cfg.num_hw_channels, sst + SSI_SST_CHANNELS_REG);
  418. writel_relaxed(cl->tx_cfg.arb_mode, sst + SSI_SST_ARBMODE_REG);
  419. writel_relaxed(cl->tx_cfg.mode, sst + SSI_SST_MODE_REG);
  420. /* RX */
  421. writel_relaxed(31, ssr + SSI_SSR_FRAMESIZE_REG);
  422. writel_relaxed(cl->rx_cfg.num_hw_channels, ssr + SSI_SSR_CHANNELS_REG);
  423. writel_relaxed(0, ssr + SSI_SSR_TIMEOUT_REG);
  424. /* Cleanup the break queue if we leave FRAME mode */
  425. if ((omap_port->ssr.mode == SSI_MODE_FRAME) &&
  426. (cl->rx_cfg.mode != SSI_MODE_FRAME))
  427. ssi_flush_queue(&omap_port->brkqueue, cl);
  428. writel_relaxed(cl->rx_cfg.mode, ssr + SSI_SSR_MODE_REG);
  429. omap_port->channels = max(cl->rx_cfg.num_hw_channels,
  430. cl->tx_cfg.num_hw_channels);
  431. /* Shadow registering for OFF mode */
  432. /* SST */
  433. omap_port->sst.divisor = div;
  434. omap_port->sst.frame_size = 31;
  435. omap_port->sst.channels = cl->tx_cfg.num_hw_channels;
  436. omap_port->sst.arb_mode = cl->tx_cfg.arb_mode;
  437. omap_port->sst.mode = cl->tx_cfg.mode;
  438. /* SSR */
  439. omap_port->ssr.frame_size = 31;
  440. omap_port->ssr.timeout = 0;
  441. omap_port->ssr.channels = cl->rx_cfg.num_hw_channels;
  442. omap_port->ssr.mode = cl->rx_cfg.mode;
  443. out:
  444. spin_unlock_bh(&omap_port->lock);
  445. pm_runtime_put_autosuspend(omap_port->pdev);
  446. return err;
  447. }
  448. static int ssi_flush(struct hsi_client *cl)
  449. {
  450. struct hsi_port *port = hsi_get_port(cl);
  451. struct omap_ssi_port *omap_port = hsi_port_drvdata(port);
  452. struct hsi_controller *ssi = to_hsi_controller(port->device.parent);
  453. struct omap_ssi_controller *omap_ssi = hsi_controller_drvdata(ssi);
  454. struct hsi_msg *msg;
  455. void __iomem *sst = omap_port->sst_base;
  456. void __iomem *ssr = omap_port->ssr_base;
  457. unsigned int i;
  458. u32 err;
  459. pm_runtime_get_sync(omap_port->pdev);
  460. spin_lock_bh(&omap_port->lock);
  461. /* stop all ssi communication */
  462. pinctrl_pm_select_idle_state(omap_port->pdev);
  463. udelay(1); /* wait for racing frames */
  464. /* Stop all DMA transfers */
  465. for (i = 0; i < SSI_MAX_GDD_LCH; i++) {
  466. msg = omap_ssi->gdd_trn[i].msg;
  467. if (!msg || (port != hsi_get_port(msg->cl)))
  468. continue;
  469. writew_relaxed(0, omap_ssi->gdd + SSI_GDD_CCR_REG(i));
  470. if (msg->ttype == HSI_MSG_READ)
  471. pm_runtime_put_autosuspend(omap_port->pdev);
  472. omap_ssi->gdd_trn[i].msg = NULL;
  473. }
  474. /* Flush all SST buffers */
  475. writel_relaxed(0, sst + SSI_SST_BUFSTATE_REG);
  476. writel_relaxed(0, sst + SSI_SST_TXSTATE_REG);
  477. /* Flush all SSR buffers */
  478. writel_relaxed(0, ssr + SSI_SSR_RXSTATE_REG);
  479. writel_relaxed(0, ssr + SSI_SSR_BUFSTATE_REG);
  480. /* Flush all errors */
  481. err = readl(ssr + SSI_SSR_ERROR_REG);
  482. writel_relaxed(err, ssr + SSI_SSR_ERRORACK_REG);
  483. /* Flush break */
  484. writel_relaxed(0, ssr + SSI_SSR_BREAK_REG);
  485. /* Clear interrupts */
  486. writel_relaxed(0, omap_ssi->sys + SSI_MPU_ENABLE_REG(port->num, 0));
  487. writel_relaxed(0xffffff00,
  488. omap_ssi->sys + SSI_MPU_STATUS_REG(port->num, 0));
  489. writel_relaxed(0, omap_ssi->sys + SSI_GDD_MPU_IRQ_ENABLE_REG);
  490. writel(0xff, omap_ssi->sys + SSI_GDD_MPU_IRQ_STATUS_REG);
  491. /* Dequeue all pending requests */
  492. for (i = 0; i < omap_port->channels; i++) {
  493. /* Release write clocks */
  494. if (!list_empty(&omap_port->txqueue[i]))
  495. pm_runtime_put_autosuspend(omap_port->pdev);
  496. ssi_flush_queue(&omap_port->txqueue[i], NULL);
  497. ssi_flush_queue(&omap_port->rxqueue[i], NULL);
  498. }
  499. ssi_flush_queue(&omap_port->brkqueue, NULL);
  500. /* Resume SSI communication */
  501. pinctrl_pm_select_default_state(omap_port->pdev);
  502. spin_unlock_bh(&omap_port->lock);
  503. pm_runtime_put_autosuspend(omap_port->pdev);
  504. return 0;
  505. }
  506. static void start_tx_work(struct work_struct *work)
  507. {
  508. struct omap_ssi_port *omap_port =
  509. container_of(work, struct omap_ssi_port, work);
  510. struct hsi_port *port = to_hsi_port(omap_port->dev);
  511. struct hsi_controller *ssi = to_hsi_controller(port->device.parent);
  512. struct omap_ssi_controller *omap_ssi = hsi_controller_drvdata(ssi);
  513. pm_runtime_get_sync(omap_port->pdev); /* Grab clocks */
  514. writel(SSI_WAKE(0), omap_ssi->sys + SSI_SET_WAKE_REG(port->num));
  515. }
  516. static int ssi_start_tx(struct hsi_client *cl)
  517. {
  518. struct hsi_port *port = hsi_get_port(cl);
  519. struct omap_ssi_port *omap_port = hsi_port_drvdata(port);
  520. dev_dbg(&port->device, "Wake out high %d\n", omap_port->wk_refcount);
  521. spin_lock_bh(&omap_port->wk_lock);
  522. if (omap_port->wk_refcount++) {
  523. spin_unlock_bh(&omap_port->wk_lock);
  524. return 0;
  525. }
  526. spin_unlock_bh(&omap_port->wk_lock);
  527. schedule_work(&omap_port->work);
  528. return 0;
  529. }
  530. static int ssi_stop_tx(struct hsi_client *cl)
  531. {
  532. struct hsi_port *port = hsi_get_port(cl);
  533. struct omap_ssi_port *omap_port = hsi_port_drvdata(port);
  534. struct hsi_controller *ssi = to_hsi_controller(port->device.parent);
  535. struct omap_ssi_controller *omap_ssi = hsi_controller_drvdata(ssi);
  536. dev_dbg(&port->device, "Wake out low %d\n", omap_port->wk_refcount);
  537. spin_lock_bh(&omap_port->wk_lock);
  538. BUG_ON(!omap_port->wk_refcount);
  539. if (--omap_port->wk_refcount) {
  540. spin_unlock_bh(&omap_port->wk_lock);
  541. return 0;
  542. }
  543. writel(SSI_WAKE(0), omap_ssi->sys + SSI_CLEAR_WAKE_REG(port->num));
  544. spin_unlock_bh(&omap_port->wk_lock);
  545. pm_runtime_put_autosuspend(omap_port->pdev); /* Release clocks */
  546. return 0;
  547. }
  548. static void ssi_transfer(struct omap_ssi_port *omap_port,
  549. struct list_head *queue)
  550. {
  551. struct hsi_msg *msg;
  552. int err = -1;
  553. pm_runtime_get(omap_port->pdev);
  554. spin_lock_bh(&omap_port->lock);
  555. while (err < 0) {
  556. err = ssi_start_transfer(queue);
  557. if (err < 0) {
  558. msg = list_first_entry(queue, struct hsi_msg, link);
  559. msg->status = HSI_STATUS_ERROR;
  560. msg->actual_len = 0;
  561. list_del(&msg->link);
  562. spin_unlock_bh(&omap_port->lock);
  563. msg->complete(msg);
  564. spin_lock_bh(&omap_port->lock);
  565. }
  566. }
  567. spin_unlock_bh(&omap_port->lock);
  568. pm_runtime_put_autosuspend(omap_port->pdev);
  569. }
  570. static void ssi_cleanup_queues(struct hsi_client *cl)
  571. {
  572. struct hsi_port *port = hsi_get_port(cl);
  573. struct omap_ssi_port *omap_port = hsi_port_drvdata(port);
  574. struct hsi_controller *ssi = to_hsi_controller(port->device.parent);
  575. struct omap_ssi_controller *omap_ssi = hsi_controller_drvdata(ssi);
  576. struct hsi_msg *msg;
  577. unsigned int i;
  578. u32 rxbufstate = 0;
  579. u32 txbufstate = 0;
  580. u32 status = SSI_ERROROCCURED;
  581. u32 tmp;
  582. ssi_flush_queue(&omap_port->brkqueue, cl);
  583. if (list_empty(&omap_port->brkqueue))
  584. status |= SSI_BREAKDETECTED;
  585. for (i = 0; i < omap_port->channels; i++) {
  586. if (list_empty(&omap_port->txqueue[i]))
  587. continue;
  588. msg = list_first_entry(&omap_port->txqueue[i], struct hsi_msg,
  589. link);
  590. if ((msg->cl == cl) && (msg->status == HSI_STATUS_PROCEEDING)) {
  591. txbufstate |= (1 << i);
  592. status |= SSI_DATAACCEPT(i);
  593. /* Release the clocks writes, also GDD ones */
  594. pm_runtime_put_autosuspend(omap_port->pdev);
  595. }
  596. ssi_flush_queue(&omap_port->txqueue[i], cl);
  597. }
  598. for (i = 0; i < omap_port->channels; i++) {
  599. if (list_empty(&omap_port->rxqueue[i]))
  600. continue;
  601. msg = list_first_entry(&omap_port->rxqueue[i], struct hsi_msg,
  602. link);
  603. if ((msg->cl == cl) && (msg->status == HSI_STATUS_PROCEEDING)) {
  604. rxbufstate |= (1 << i);
  605. status |= SSI_DATAAVAILABLE(i);
  606. }
  607. ssi_flush_queue(&omap_port->rxqueue[i], cl);
  608. /* Check if we keep the error detection interrupt armed */
  609. if (!list_empty(&omap_port->rxqueue[i]))
  610. status &= ~SSI_ERROROCCURED;
  611. }
  612. /* Cleanup write buffers */
  613. tmp = readl(omap_port->sst_base + SSI_SST_BUFSTATE_REG);
  614. tmp &= ~txbufstate;
  615. writel_relaxed(tmp, omap_port->sst_base + SSI_SST_BUFSTATE_REG);
  616. /* Cleanup read buffers */
  617. tmp = readl(omap_port->ssr_base + SSI_SSR_BUFSTATE_REG);
  618. tmp &= ~rxbufstate;
  619. writel_relaxed(tmp, omap_port->ssr_base + SSI_SSR_BUFSTATE_REG);
  620. /* Disarm and ack pending interrupts */
  621. tmp = readl(omap_ssi->sys + SSI_MPU_ENABLE_REG(port->num, 0));
  622. tmp &= ~status;
  623. writel_relaxed(tmp, omap_ssi->sys + SSI_MPU_ENABLE_REG(port->num, 0));
  624. writel_relaxed(status, omap_ssi->sys +
  625. SSI_MPU_STATUS_REG(port->num, 0));
  626. }
  627. static void ssi_cleanup_gdd(struct hsi_controller *ssi, struct hsi_client *cl)
  628. {
  629. struct omap_ssi_controller *omap_ssi = hsi_controller_drvdata(ssi);
  630. struct hsi_port *port = hsi_get_port(cl);
  631. struct omap_ssi_port *omap_port = hsi_port_drvdata(port);
  632. struct hsi_msg *msg;
  633. unsigned int i;
  634. u32 val = 0;
  635. u32 tmp;
  636. for (i = 0; i < SSI_MAX_GDD_LCH; i++) {
  637. msg = omap_ssi->gdd_trn[i].msg;
  638. if ((!msg) || (msg->cl != cl))
  639. continue;
  640. writew_relaxed(0, omap_ssi->gdd + SSI_GDD_CCR_REG(i));
  641. val |= (1 << i);
  642. /*
  643. * Clock references for write will be handled in
  644. * ssi_cleanup_queues
  645. */
  646. if (msg->ttype == HSI_MSG_READ) {
  647. pm_runtime_put_autosuspend(omap_port->pdev);
  648. }
  649. omap_ssi->gdd_trn[i].msg = NULL;
  650. }
  651. tmp = readl_relaxed(omap_ssi->sys + SSI_GDD_MPU_IRQ_ENABLE_REG);
  652. tmp &= ~val;
  653. writel_relaxed(tmp, omap_ssi->sys + SSI_GDD_MPU_IRQ_ENABLE_REG);
  654. writel(val, omap_ssi->sys + SSI_GDD_MPU_IRQ_STATUS_REG);
  655. }
  656. static int ssi_set_port_mode(struct omap_ssi_port *omap_port, u32 mode)
  657. {
  658. writel(mode, omap_port->sst_base + SSI_SST_MODE_REG);
  659. writel(mode, omap_port->ssr_base + SSI_SSR_MODE_REG);
  660. /* OCP barrier */
  661. mode = readl(omap_port->ssr_base + SSI_SSR_MODE_REG);
  662. return 0;
  663. }
  664. static int ssi_release(struct hsi_client *cl)
  665. {
  666. struct hsi_port *port = hsi_get_port(cl);
  667. struct omap_ssi_port *omap_port = hsi_port_drvdata(port);
  668. struct hsi_controller *ssi = to_hsi_controller(port->device.parent);
  669. pm_runtime_get_sync(omap_port->pdev);
  670. spin_lock_bh(&omap_port->lock);
  671. /* Stop all the pending DMA requests for that client */
  672. ssi_cleanup_gdd(ssi, cl);
  673. /* Now cleanup all the queues */
  674. ssi_cleanup_queues(cl);
  675. /* If it is the last client of the port, do extra checks and cleanup */
  676. if (port->claimed <= 1) {
  677. /*
  678. * Drop the clock reference for the incoming wake line
  679. * if it is still kept high by the other side.
  680. */
  681. if (test_and_clear_bit(SSI_WAKE_EN, &omap_port->flags))
  682. pm_runtime_put_sync(omap_port->pdev);
  683. pm_runtime_get(omap_port->pdev);
  684. /* Stop any SSI TX/RX without a client */
  685. ssi_set_port_mode(omap_port, SSI_MODE_SLEEP);
  686. omap_port->sst.mode = SSI_MODE_SLEEP;
  687. omap_port->ssr.mode = SSI_MODE_SLEEP;
  688. pm_runtime_put(omap_port->pdev);
  689. WARN_ON(omap_port->wk_refcount != 0);
  690. }
  691. spin_unlock_bh(&omap_port->lock);
  692. pm_runtime_put_sync(omap_port->pdev);
  693. return 0;
  694. }
  695. static void ssi_error(struct hsi_port *port)
  696. {
  697. struct omap_ssi_port *omap_port = hsi_port_drvdata(port);
  698. struct hsi_controller *ssi = to_hsi_controller(port->device.parent);
  699. struct omap_ssi_controller *omap_ssi = hsi_controller_drvdata(ssi);
  700. struct hsi_msg *msg;
  701. unsigned int i;
  702. u32 err;
  703. u32 val;
  704. u32 tmp;
  705. /* ACK error */
  706. err = readl(omap_port->ssr_base + SSI_SSR_ERROR_REG);
  707. dev_err(&port->device, "SSI error: 0x%02x\n", err);
  708. if (!err) {
  709. dev_dbg(&port->device, "spurious SSI error ignored!\n");
  710. return;
  711. }
  712. spin_lock(&omap_ssi->lock);
  713. /* Cancel all GDD read transfers */
  714. for (i = 0, val = 0; i < SSI_MAX_GDD_LCH; i++) {
  715. msg = omap_ssi->gdd_trn[i].msg;
  716. if ((msg) && (msg->ttype == HSI_MSG_READ)) {
  717. writew_relaxed(0, omap_ssi->gdd + SSI_GDD_CCR_REG(i));
  718. val |= (1 << i);
  719. omap_ssi->gdd_trn[i].msg = NULL;
  720. }
  721. }
  722. tmp = readl(omap_ssi->sys + SSI_GDD_MPU_IRQ_ENABLE_REG);
  723. tmp &= ~val;
  724. writel_relaxed(tmp, omap_ssi->sys + SSI_GDD_MPU_IRQ_ENABLE_REG);
  725. spin_unlock(&omap_ssi->lock);
  726. /* Cancel all PIO read transfers */
  727. spin_lock(&omap_port->lock);
  728. tmp = readl(omap_ssi->sys + SSI_MPU_ENABLE_REG(port->num, 0));
  729. tmp &= 0xfeff00ff; /* Disable error & all dataavailable interrupts */
  730. writel_relaxed(tmp, omap_ssi->sys + SSI_MPU_ENABLE_REG(port->num, 0));
  731. /* ACK error */
  732. writel_relaxed(err, omap_port->ssr_base + SSI_SSR_ERRORACK_REG);
  733. writel_relaxed(SSI_ERROROCCURED,
  734. omap_ssi->sys + SSI_MPU_STATUS_REG(port->num, 0));
  735. /* Signal the error all current pending read requests */
  736. for (i = 0; i < omap_port->channels; i++) {
  737. if (list_empty(&omap_port->rxqueue[i]))
  738. continue;
  739. msg = list_first_entry(&omap_port->rxqueue[i], struct hsi_msg,
  740. link);
  741. list_del(&msg->link);
  742. msg->status = HSI_STATUS_ERROR;
  743. spin_unlock(&omap_port->lock);
  744. msg->complete(msg);
  745. /* Now restart queued reads if any */
  746. ssi_transfer(omap_port, &omap_port->rxqueue[i]);
  747. spin_lock(&omap_port->lock);
  748. }
  749. spin_unlock(&omap_port->lock);
  750. }
  751. static void ssi_break_complete(struct hsi_port *port)
  752. {
  753. struct omap_ssi_port *omap_port = hsi_port_drvdata(port);
  754. struct hsi_controller *ssi = to_hsi_controller(port->device.parent);
  755. struct omap_ssi_controller *omap_ssi = hsi_controller_drvdata(ssi);
  756. struct hsi_msg *msg;
  757. struct hsi_msg *tmp;
  758. u32 val;
  759. dev_dbg(&port->device, "HWBREAK received\n");
  760. spin_lock(&omap_port->lock);
  761. val = readl(omap_ssi->sys + SSI_MPU_ENABLE_REG(port->num, 0));
  762. val &= ~SSI_BREAKDETECTED;
  763. writel_relaxed(val, omap_ssi->sys + SSI_MPU_ENABLE_REG(port->num, 0));
  764. writel_relaxed(0, omap_port->ssr_base + SSI_SSR_BREAK_REG);
  765. writel(SSI_BREAKDETECTED,
  766. omap_ssi->sys + SSI_MPU_STATUS_REG(port->num, 0));
  767. spin_unlock(&omap_port->lock);
  768. list_for_each_entry_safe(msg, tmp, &omap_port->brkqueue, link) {
  769. msg->status = HSI_STATUS_COMPLETED;
  770. spin_lock(&omap_port->lock);
  771. list_del(&msg->link);
  772. spin_unlock(&omap_port->lock);
  773. msg->complete(msg);
  774. }
  775. }
  776. static void ssi_pio_complete(struct hsi_port *port, struct list_head *queue)
  777. {
  778. struct hsi_controller *ssi = to_hsi_controller(port->device.parent);
  779. struct omap_ssi_controller *omap_ssi = hsi_controller_drvdata(ssi);
  780. struct omap_ssi_port *omap_port = hsi_port_drvdata(port);
  781. struct hsi_msg *msg;
  782. u32 *buf;
  783. u32 reg;
  784. u32 val;
  785. spin_lock_bh(&omap_port->lock);
  786. msg = list_first_entry(queue, struct hsi_msg, link);
  787. if ((!msg->sgt.nents) || (!msg->sgt.sgl->length)) {
  788. msg->actual_len = 0;
  789. msg->status = HSI_STATUS_PENDING;
  790. }
  791. if (msg->ttype == HSI_MSG_WRITE)
  792. val = SSI_DATAACCEPT(msg->channel);
  793. else
  794. val = SSI_DATAAVAILABLE(msg->channel);
  795. if (msg->status == HSI_STATUS_PROCEEDING) {
  796. buf = sg_virt(msg->sgt.sgl) + msg->actual_len;
  797. if (msg->ttype == HSI_MSG_WRITE)
  798. writel(*buf, omap_port->sst_base +
  799. SSI_SST_BUFFER_CH_REG(msg->channel));
  800. else
  801. *buf = readl(omap_port->ssr_base +
  802. SSI_SSR_BUFFER_CH_REG(msg->channel));
  803. dev_dbg(&port->device, "ch %d ttype %d 0x%08x\n", msg->channel,
  804. msg->ttype, *buf);
  805. msg->actual_len += sizeof(*buf);
  806. if (msg->actual_len >= msg->sgt.sgl->length)
  807. msg->status = HSI_STATUS_COMPLETED;
  808. /*
  809. * Wait for the last written frame to be really sent before
  810. * we call the complete callback
  811. */
  812. if ((msg->status == HSI_STATUS_PROCEEDING) ||
  813. ((msg->status == HSI_STATUS_COMPLETED) &&
  814. (msg->ttype == HSI_MSG_WRITE))) {
  815. writel(val, omap_ssi->sys +
  816. SSI_MPU_STATUS_REG(port->num, 0));
  817. spin_unlock_bh(&omap_port->lock);
  818. return;
  819. }
  820. }
  821. /* Transfer completed at this point */
  822. reg = readl(omap_ssi->sys + SSI_MPU_ENABLE_REG(port->num, 0));
  823. if (msg->ttype == HSI_MSG_WRITE) {
  824. /* Release clocks for write transfer */
  825. pm_runtime_put_autosuspend(omap_port->pdev);
  826. }
  827. reg &= ~val;
  828. writel_relaxed(reg, omap_ssi->sys + SSI_MPU_ENABLE_REG(port->num, 0));
  829. writel_relaxed(val, omap_ssi->sys + SSI_MPU_STATUS_REG(port->num, 0));
  830. list_del(&msg->link);
  831. spin_unlock_bh(&omap_port->lock);
  832. msg->complete(msg);
  833. ssi_transfer(omap_port, queue);
  834. }
  835. static irqreturn_t ssi_pio_thread(int irq, void *ssi_port)
  836. {
  837. struct hsi_port *port = (struct hsi_port *)ssi_port;
  838. struct hsi_controller *ssi = to_hsi_controller(port->device.parent);
  839. struct omap_ssi_port *omap_port = hsi_port_drvdata(port);
  840. struct omap_ssi_controller *omap_ssi = hsi_controller_drvdata(ssi);
  841. void __iomem *sys = omap_ssi->sys;
  842. unsigned int ch;
  843. u32 status_reg;
  844. pm_runtime_get_sync(omap_port->pdev);
  845. do {
  846. status_reg = readl(sys + SSI_MPU_STATUS_REG(port->num, 0));
  847. status_reg &= readl(sys + SSI_MPU_ENABLE_REG(port->num, 0));
  848. for (ch = 0; ch < omap_port->channels; ch++) {
  849. if (status_reg & SSI_DATAACCEPT(ch))
  850. ssi_pio_complete(port, &omap_port->txqueue[ch]);
  851. if (status_reg & SSI_DATAAVAILABLE(ch))
  852. ssi_pio_complete(port, &omap_port->rxqueue[ch]);
  853. }
  854. if (status_reg & SSI_BREAKDETECTED)
  855. ssi_break_complete(port);
  856. if (status_reg & SSI_ERROROCCURED)
  857. ssi_error(port);
  858. status_reg = readl(sys + SSI_MPU_STATUS_REG(port->num, 0));
  859. status_reg &= readl(sys + SSI_MPU_ENABLE_REG(port->num, 0));
  860. /* TODO: sleep if we retry? */
  861. } while (status_reg);
  862. pm_runtime_put_autosuspend(omap_port->pdev);
  863. return IRQ_HANDLED;
  864. }
  865. static irqreturn_t ssi_wake_thread(int irq __maybe_unused, void *ssi_port)
  866. {
  867. struct hsi_port *port = (struct hsi_port *)ssi_port;
  868. struct hsi_controller *ssi = to_hsi_controller(port->device.parent);
  869. struct omap_ssi_port *omap_port = hsi_port_drvdata(port);
  870. struct omap_ssi_controller *omap_ssi = hsi_controller_drvdata(ssi);
  871. if (ssi_wakein(port)) {
  872. /**
  873. * We can have a quick High-Low-High transition in the line.
  874. * In such a case if we have long interrupt latencies,
  875. * we can miss the low event or get twice a high event.
  876. * This workaround will avoid breaking the clock reference
  877. * count when such a situation ocurrs.
  878. */
  879. if (!test_and_set_bit(SSI_WAKE_EN, &omap_port->flags))
  880. pm_runtime_get_sync(omap_port->pdev);
  881. dev_dbg(&ssi->device, "Wake in high\n");
  882. if (omap_port->wktest) { /* FIXME: HACK ! To be removed */
  883. writel(SSI_WAKE(0),
  884. omap_ssi->sys + SSI_SET_WAKE_REG(port->num));
  885. }
  886. hsi_event(port, HSI_EVENT_START_RX);
  887. } else {
  888. dev_dbg(&ssi->device, "Wake in low\n");
  889. if (omap_port->wktest) { /* FIXME: HACK ! To be removed */
  890. writel(SSI_WAKE(0),
  891. omap_ssi->sys + SSI_CLEAR_WAKE_REG(port->num));
  892. }
  893. hsi_event(port, HSI_EVENT_STOP_RX);
  894. if (test_and_clear_bit(SSI_WAKE_EN, &omap_port->flags)) {
  895. pm_runtime_put_autosuspend(omap_port->pdev);
  896. }
  897. }
  898. return IRQ_HANDLED;
  899. }
  900. static int ssi_port_irq(struct hsi_port *port, struct platform_device *pd)
  901. {
  902. struct omap_ssi_port *omap_port = hsi_port_drvdata(port);
  903. int err;
  904. err = platform_get_irq(pd, 0);
  905. if (err < 0)
  906. return err;
  907. omap_port->irq = err;
  908. err = devm_request_threaded_irq(&port->device, omap_port->irq, NULL,
  909. ssi_pio_thread, IRQF_ONESHOT, "SSI PORT", port);
  910. if (err < 0)
  911. dev_err(&port->device, "Request IRQ %d failed (%d)\n",
  912. omap_port->irq, err);
  913. return err;
  914. }
  915. static int ssi_wake_irq(struct hsi_port *port, struct platform_device *pd)
  916. {
  917. struct omap_ssi_port *omap_port = hsi_port_drvdata(port);
  918. int cawake_irq;
  919. int err;
  920. if (!omap_port->wake_gpio) {
  921. omap_port->wake_irq = -1;
  922. return 0;
  923. }
  924. cawake_irq = gpiod_to_irq(omap_port->wake_gpio);
  925. omap_port->wake_irq = cawake_irq;
  926. err = devm_request_threaded_irq(&port->device, cawake_irq, NULL,
  927. ssi_wake_thread,
  928. IRQF_TRIGGER_RISING | IRQF_TRIGGER_FALLING | IRQF_ONESHOT,
  929. "SSI cawake", port);
  930. if (err < 0)
  931. dev_err(&port->device, "Request Wake in IRQ %d failed %d\n",
  932. cawake_irq, err);
  933. err = enable_irq_wake(cawake_irq);
  934. if (err < 0)
  935. dev_err(&port->device, "Enable wake on the wakeline in irq %d failed %d\n",
  936. cawake_irq, err);
  937. return err;
  938. }
  939. static void ssi_queues_init(struct omap_ssi_port *omap_port)
  940. {
  941. unsigned int ch;
  942. for (ch = 0; ch < SSI_MAX_CHANNELS; ch++) {
  943. INIT_LIST_HEAD(&omap_port->txqueue[ch]);
  944. INIT_LIST_HEAD(&omap_port->rxqueue[ch]);
  945. }
  946. INIT_LIST_HEAD(&omap_port->brkqueue);
  947. }
  948. static int ssi_port_get_iomem(struct platform_device *pd,
  949. const char *name, void __iomem **pbase, dma_addr_t *phy)
  950. {
  951. struct hsi_port *port = platform_get_drvdata(pd);
  952. struct resource *mem;
  953. struct resource *ioarea;
  954. void __iomem *base;
  955. mem = platform_get_resource_byname(pd, IORESOURCE_MEM, name);
  956. if (!mem) {
  957. dev_err(&pd->dev, "IO memory region missing (%s)\n", name);
  958. return -ENXIO;
  959. }
  960. ioarea = devm_request_mem_region(&port->device, mem->start,
  961. resource_size(mem), dev_name(&pd->dev));
  962. if (!ioarea) {
  963. dev_err(&pd->dev, "%s IO memory region request failed\n",
  964. mem->name);
  965. return -ENXIO;
  966. }
  967. base = devm_ioremap(&port->device, mem->start, resource_size(mem));
  968. if (!base) {
  969. dev_err(&pd->dev, "%s IO remap failed\n", mem->name);
  970. return -ENXIO;
  971. }
  972. *pbase = base;
  973. if (phy)
  974. *phy = mem->start;
  975. return 0;
  976. }
  977. static int ssi_port_probe(struct platform_device *pd)
  978. {
  979. struct device_node *np = pd->dev.of_node;
  980. struct hsi_port *port;
  981. struct omap_ssi_port *omap_port;
  982. struct hsi_controller *ssi = dev_get_drvdata(pd->dev.parent);
  983. struct omap_ssi_controller *omap_ssi = hsi_controller_drvdata(ssi);
  984. struct gpio_desc *cawake_gpio = NULL;
  985. u32 port_id;
  986. int err;
  987. dev_dbg(&pd->dev, "init ssi port...\n");
  988. if (!ssi->port || !omap_ssi->port) {
  989. dev_err(&pd->dev, "ssi controller not initialized!\n");
  990. err = -ENODEV;
  991. goto error;
  992. }
  993. /* get id of first uninitialized port in controller */
  994. for (port_id = 0; port_id < ssi->num_ports && omap_ssi->port[port_id];
  995. port_id++)
  996. ;
  997. if (port_id >= ssi->num_ports) {
  998. dev_err(&pd->dev, "port id out of range!\n");
  999. err = -ENODEV;
  1000. goto error;
  1001. }
  1002. port = ssi->port[port_id];
  1003. if (!np) {
  1004. dev_err(&pd->dev, "missing device tree data\n");
  1005. err = -EINVAL;
  1006. goto error;
  1007. }
  1008. cawake_gpio = devm_gpiod_get(&pd->dev, "ti,ssi-cawake", GPIOD_IN);
  1009. if (IS_ERR(cawake_gpio)) {
  1010. err = PTR_ERR(cawake_gpio);
  1011. dev_err(&pd->dev, "couldn't get cawake gpio (err=%d)!\n", err);
  1012. goto error;
  1013. }
  1014. omap_port = devm_kzalloc(&port->device, sizeof(*omap_port), GFP_KERNEL);
  1015. if (!omap_port) {
  1016. err = -ENOMEM;
  1017. goto error;
  1018. }
  1019. omap_port->wake_gpio = cawake_gpio;
  1020. omap_port->pdev = &pd->dev;
  1021. omap_port->port_id = port_id;
  1022. INIT_DEFERRABLE_WORK(&omap_port->errqueue_work, ssi_process_errqueue);
  1023. INIT_WORK(&omap_port->work, start_tx_work);
  1024. /* initialize HSI port */
  1025. port->async = ssi_async;
  1026. port->setup = ssi_setup;
  1027. port->flush = ssi_flush;
  1028. port->start_tx = ssi_start_tx;
  1029. port->stop_tx = ssi_stop_tx;
  1030. port->release = ssi_release;
  1031. hsi_port_set_drvdata(port, omap_port);
  1032. omap_ssi->port[port_id] = omap_port;
  1033. platform_set_drvdata(pd, port);
  1034. err = ssi_port_get_iomem(pd, "tx", &omap_port->sst_base,
  1035. &omap_port->sst_dma);
  1036. if (err < 0)
  1037. goto error;
  1038. err = ssi_port_get_iomem(pd, "rx", &omap_port->ssr_base,
  1039. &omap_port->ssr_dma);
  1040. if (err < 0)
  1041. goto error;
  1042. err = ssi_port_irq(port, pd);
  1043. if (err < 0)
  1044. goto error;
  1045. err = ssi_wake_irq(port, pd);
  1046. if (err < 0)
  1047. goto error;
  1048. ssi_queues_init(omap_port);
  1049. spin_lock_init(&omap_port->lock);
  1050. spin_lock_init(&omap_port->wk_lock);
  1051. omap_port->dev = &port->device;
  1052. pm_runtime_use_autosuspend(omap_port->pdev);
  1053. pm_runtime_set_autosuspend_delay(omap_port->pdev, 250);
  1054. pm_runtime_enable(omap_port->pdev);
  1055. #ifdef CONFIG_DEBUG_FS
  1056. ssi_debug_add_port(omap_port, omap_ssi->dir);
  1057. #endif
  1058. hsi_add_clients_from_dt(port, np);
  1059. dev_info(&pd->dev, "ssi port %u successfully initialized\n", port_id);
  1060. return 0;
  1061. error:
  1062. return err;
  1063. }
  1064. static void ssi_port_remove(struct platform_device *pd)
  1065. {
  1066. struct hsi_port *port = platform_get_drvdata(pd);
  1067. struct omap_ssi_port *omap_port = hsi_port_drvdata(port);
  1068. struct hsi_controller *ssi = to_hsi_controller(port->device.parent);
  1069. struct omap_ssi_controller *omap_ssi = hsi_controller_drvdata(ssi);
  1070. #ifdef CONFIG_DEBUG_FS
  1071. ssi_debug_remove_port(port);
  1072. #endif
  1073. cancel_delayed_work_sync(&omap_port->errqueue_work);
  1074. hsi_port_unregister_clients(port);
  1075. port->async = hsi_dummy_msg;
  1076. port->setup = hsi_dummy_cl;
  1077. port->flush = hsi_dummy_cl;
  1078. port->start_tx = hsi_dummy_cl;
  1079. port->stop_tx = hsi_dummy_cl;
  1080. port->release = hsi_dummy_cl;
  1081. omap_ssi->port[omap_port->port_id] = NULL;
  1082. platform_set_drvdata(pd, NULL);
  1083. pm_runtime_dont_use_autosuspend(&pd->dev);
  1084. pm_runtime_disable(&pd->dev);
  1085. }
  1086. static int ssi_restore_divisor(struct omap_ssi_port *omap_port)
  1087. {
  1088. writel_relaxed(omap_port->sst.divisor,
  1089. omap_port->sst_base + SSI_SST_DIVISOR_REG);
  1090. return 0;
  1091. }
  1092. void omap_ssi_port_update_fclk(struct hsi_controller *ssi,
  1093. struct omap_ssi_port *omap_port)
  1094. {
  1095. /* update divisor */
  1096. u32 div = ssi_calculate_div(ssi);
  1097. omap_port->sst.divisor = div;
  1098. ssi_restore_divisor(omap_port);
  1099. }
  1100. #ifdef CONFIG_PM
  1101. static int ssi_save_port_ctx(struct omap_ssi_port *omap_port)
  1102. {
  1103. struct hsi_port *port = to_hsi_port(omap_port->dev);
  1104. struct hsi_controller *ssi = to_hsi_controller(port->device.parent);
  1105. struct omap_ssi_controller *omap_ssi = hsi_controller_drvdata(ssi);
  1106. omap_port->sys_mpu_enable = readl(omap_ssi->sys +
  1107. SSI_MPU_ENABLE_REG(port->num, 0));
  1108. return 0;
  1109. }
  1110. static int ssi_restore_port_ctx(struct omap_ssi_port *omap_port)
  1111. {
  1112. struct hsi_port *port = to_hsi_port(omap_port->dev);
  1113. struct hsi_controller *ssi = to_hsi_controller(port->device.parent);
  1114. struct omap_ssi_controller *omap_ssi = hsi_controller_drvdata(ssi);
  1115. void __iomem *base;
  1116. writel_relaxed(omap_port->sys_mpu_enable,
  1117. omap_ssi->sys + SSI_MPU_ENABLE_REG(port->num, 0));
  1118. /* SST context */
  1119. base = omap_port->sst_base;
  1120. writel_relaxed(omap_port->sst.frame_size, base + SSI_SST_FRAMESIZE_REG);
  1121. writel_relaxed(omap_port->sst.channels, base + SSI_SST_CHANNELS_REG);
  1122. writel_relaxed(omap_port->sst.arb_mode, base + SSI_SST_ARBMODE_REG);
  1123. /* SSR context */
  1124. base = omap_port->ssr_base;
  1125. writel_relaxed(omap_port->ssr.frame_size, base + SSI_SSR_FRAMESIZE_REG);
  1126. writel_relaxed(omap_port->ssr.channels, base + SSI_SSR_CHANNELS_REG);
  1127. writel_relaxed(omap_port->ssr.timeout, base + SSI_SSR_TIMEOUT_REG);
  1128. return 0;
  1129. }
  1130. static int ssi_restore_port_mode(struct omap_ssi_port *omap_port)
  1131. {
  1132. u32 mode;
  1133. writel_relaxed(omap_port->sst.mode,
  1134. omap_port->sst_base + SSI_SST_MODE_REG);
  1135. writel_relaxed(omap_port->ssr.mode,
  1136. omap_port->ssr_base + SSI_SSR_MODE_REG);
  1137. /* OCP barrier */
  1138. mode = readl(omap_port->ssr_base + SSI_SSR_MODE_REG);
  1139. return 0;
  1140. }
  1141. static int omap_ssi_port_runtime_suspend(struct device *dev)
  1142. {
  1143. struct hsi_port *port = dev_get_drvdata(dev);
  1144. struct omap_ssi_port *omap_port = hsi_port_drvdata(port);
  1145. struct hsi_controller *ssi = to_hsi_controller(port->device.parent);
  1146. struct omap_ssi_controller *omap_ssi = hsi_controller_drvdata(ssi);
  1147. dev_dbg(dev, "port runtime suspend!\n");
  1148. ssi_set_port_mode(omap_port, SSI_MODE_SLEEP);
  1149. if (omap_ssi->get_loss)
  1150. omap_port->loss_count =
  1151. omap_ssi->get_loss(ssi->device.parent);
  1152. ssi_save_port_ctx(omap_port);
  1153. return 0;
  1154. }
  1155. static int omap_ssi_port_runtime_resume(struct device *dev)
  1156. {
  1157. struct hsi_port *port = dev_get_drvdata(dev);
  1158. struct omap_ssi_port *omap_port = hsi_port_drvdata(port);
  1159. struct hsi_controller *ssi = to_hsi_controller(port->device.parent);
  1160. struct omap_ssi_controller *omap_ssi = hsi_controller_drvdata(ssi);
  1161. dev_dbg(dev, "port runtime resume!\n");
  1162. if ((omap_ssi->get_loss) && (omap_port->loss_count ==
  1163. omap_ssi->get_loss(ssi->device.parent)))
  1164. goto mode; /* We always need to restore the mode & TX divisor */
  1165. ssi_restore_port_ctx(omap_port);
  1166. mode:
  1167. ssi_restore_divisor(omap_port);
  1168. ssi_restore_port_mode(omap_port);
  1169. return 0;
  1170. }
  1171. static const struct dev_pm_ops omap_ssi_port_pm_ops = {
  1172. SET_RUNTIME_PM_OPS(omap_ssi_port_runtime_suspend,
  1173. omap_ssi_port_runtime_resume, NULL)
  1174. };
  1175. #define DEV_PM_OPS (&omap_ssi_port_pm_ops)
  1176. #else
  1177. #define DEV_PM_OPS NULL
  1178. #endif
  1179. #ifdef CONFIG_OF
  1180. static const struct of_device_id omap_ssi_port_of_match[] = {
  1181. { .compatible = "ti,omap3-ssi-port", },
  1182. {},
  1183. };
  1184. MODULE_DEVICE_TABLE(of, omap_ssi_port_of_match);
  1185. #else
  1186. #define omap_ssi_port_of_match NULL
  1187. #endif
  1188. struct platform_driver ssi_port_pdriver = {
  1189. .probe = ssi_port_probe,
  1190. .remove = ssi_port_remove,
  1191. .driver = {
  1192. .name = "omap_ssi_port",
  1193. .of_match_table = omap_ssi_port_of_match,
  1194. .pm = DEV_PM_OPS,
  1195. },
  1196. };