stm32_rproc.c 23 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960
  1. // SPDX-License-Identifier: GPL-2.0
  2. /*
  3. * Copyright (C) STMicroelectronics 2018 - All Rights Reserved
  4. * Authors: Ludovic Barre <ludovic.barre@st.com> for STMicroelectronics.
  5. * Fabien Dessenne <fabien.dessenne@st.com> for STMicroelectronics.
  6. */
  7. #include <linux/arm-smccc.h>
  8. #include <linux/dma-mapping.h>
  9. #include <linux/interrupt.h>
  10. #include <linux/io.h>
  11. #include <linux/mailbox_client.h>
  12. #include <linux/mfd/syscon.h>
  13. #include <linux/module.h>
  14. #include <linux/of.h>
  15. #include <linux/of_reserved_mem.h>
  16. #include <linux/platform_device.h>
  17. #include <linux/pm_wakeirq.h>
  18. #include <linux/regmap.h>
  19. #include <linux/remoteproc.h>
  20. #include <linux/reset.h>
  21. #include <linux/slab.h>
  22. #include <linux/workqueue.h>
  23. #include "remoteproc_internal.h"
  24. #define HOLD_BOOT 0
  25. #define RELEASE_BOOT 1
  26. #define MBOX_NB_VQ 2
  27. #define MBOX_NB_MBX 4
  28. #define STM32_SMC_RCC 0x82001000
  29. #define STM32_SMC_REG_WRITE 0x1
  30. #define STM32_MBX_VQ0 "vq0"
  31. #define STM32_MBX_VQ0_ID 0
  32. #define STM32_MBX_VQ1 "vq1"
  33. #define STM32_MBX_VQ1_ID 1
  34. #define STM32_MBX_SHUTDOWN "shutdown"
  35. #define STM32_MBX_DETACH "detach"
  36. #define RSC_TBL_SIZE 1024
  37. #define M4_STATE_OFF 0
  38. #define M4_STATE_INI 1
  39. #define M4_STATE_CRUN 2
  40. #define M4_STATE_CSTOP 3
  41. #define M4_STATE_STANDBY 4
  42. #define M4_STATE_CRASH 5
  43. struct stm32_syscon {
  44. struct regmap *map;
  45. u32 reg;
  46. u32 mask;
  47. };
  48. struct stm32_rproc_mem {
  49. char name[20];
  50. void __iomem *cpu_addr;
  51. phys_addr_t bus_addr;
  52. u32 dev_addr;
  53. size_t size;
  54. };
  55. struct stm32_rproc_mem_ranges {
  56. u32 dev_addr;
  57. u32 bus_addr;
  58. u32 size;
  59. };
  60. struct stm32_mbox {
  61. const unsigned char name[10];
  62. struct mbox_chan *chan;
  63. struct mbox_client client;
  64. struct work_struct vq_work;
  65. int vq_id;
  66. };
  67. struct stm32_rproc {
  68. struct reset_control *rst;
  69. struct reset_control *hold_boot_rst;
  70. struct stm32_syscon hold_boot;
  71. struct stm32_syscon pdds;
  72. struct stm32_syscon m4_state;
  73. struct stm32_syscon rsctbl;
  74. int wdg_irq;
  75. u32 nb_rmems;
  76. struct stm32_rproc_mem *rmems;
  77. struct stm32_mbox mb[MBOX_NB_MBX];
  78. struct workqueue_struct *workqueue;
  79. bool hold_boot_smc;
  80. void __iomem *rsc_va;
  81. };
  82. static int stm32_rproc_pa_to_da(struct rproc *rproc, phys_addr_t pa, u64 *da)
  83. {
  84. unsigned int i;
  85. struct stm32_rproc *ddata = rproc->priv;
  86. struct stm32_rproc_mem *p_mem;
  87. for (i = 0; i < ddata->nb_rmems; i++) {
  88. p_mem = &ddata->rmems[i];
  89. if (pa < p_mem->bus_addr ||
  90. pa >= p_mem->bus_addr + p_mem->size)
  91. continue;
  92. *da = pa - p_mem->bus_addr + p_mem->dev_addr;
  93. dev_dbg(rproc->dev.parent, "pa %pa to da %llx\n", &pa, *da);
  94. return 0;
  95. }
  96. return -EINVAL;
  97. }
  98. static int stm32_rproc_mem_alloc(struct rproc *rproc,
  99. struct rproc_mem_entry *mem)
  100. {
  101. struct device *dev = rproc->dev.parent;
  102. void *va;
  103. dev_dbg(dev, "map memory: %pad+%zx\n", &mem->dma, mem->len);
  104. va = (__force void *)ioremap_wc(mem->dma, mem->len);
  105. if (IS_ERR_OR_NULL(va)) {
  106. dev_err(dev, "Unable to map memory region: %pad+0x%zx\n",
  107. &mem->dma, mem->len);
  108. return -ENOMEM;
  109. }
  110. /* Update memory entry va */
  111. mem->va = va;
  112. return 0;
  113. }
  114. static int stm32_rproc_mem_release(struct rproc *rproc,
  115. struct rproc_mem_entry *mem)
  116. {
  117. dev_dbg(rproc->dev.parent, "unmap memory: %pa\n", &mem->dma);
  118. iounmap((__force __iomem void *)mem->va);
  119. return 0;
  120. }
  121. static int stm32_rproc_of_memory_translations(struct platform_device *pdev,
  122. struct stm32_rproc *ddata)
  123. {
  124. struct device *parent, *dev = &pdev->dev;
  125. struct device_node *np;
  126. struct stm32_rproc_mem *p_mems;
  127. struct stm32_rproc_mem_ranges *mem_range;
  128. int cnt, array_size, i, ret = 0;
  129. parent = dev->parent;
  130. np = parent->of_node;
  131. cnt = of_property_count_elems_of_size(np, "dma-ranges",
  132. sizeof(*mem_range));
  133. if (cnt <= 0) {
  134. dev_err(dev, "%s: dma-ranges property not defined\n", __func__);
  135. return -EINVAL;
  136. }
  137. p_mems = devm_kcalloc(dev, cnt, sizeof(*p_mems), GFP_KERNEL);
  138. if (!p_mems)
  139. return -ENOMEM;
  140. mem_range = kzalloc_objs(*mem_range, cnt);
  141. if (!mem_range)
  142. return -ENOMEM;
  143. array_size = cnt * sizeof(struct stm32_rproc_mem_ranges) / sizeof(u32);
  144. ret = of_property_read_u32_array(np, "dma-ranges",
  145. (u32 *)mem_range, array_size);
  146. if (ret) {
  147. dev_err(dev, "error while get dma-ranges property: %x\n", ret);
  148. goto free_mem;
  149. }
  150. for (i = 0; i < cnt; i++) {
  151. p_mems[i].bus_addr = mem_range[i].bus_addr;
  152. p_mems[i].dev_addr = mem_range[i].dev_addr;
  153. p_mems[i].size = mem_range[i].size;
  154. dev_dbg(dev, "memory range[%i]: da %#x, pa %pa, size %#zx:\n",
  155. i, p_mems[i].dev_addr, &p_mems[i].bus_addr,
  156. p_mems[i].size);
  157. }
  158. ddata->rmems = p_mems;
  159. ddata->nb_rmems = cnt;
  160. free_mem:
  161. kfree(mem_range);
  162. return ret;
  163. }
  164. static int stm32_rproc_mbox_idx(struct rproc *rproc, const unsigned char *name)
  165. {
  166. struct stm32_rproc *ddata = rproc->priv;
  167. int i;
  168. for (i = 0; i < ARRAY_SIZE(ddata->mb); i++) {
  169. if (!strncmp(ddata->mb[i].name, name, strlen(name)))
  170. return i;
  171. }
  172. dev_err(&rproc->dev, "mailbox %s not found\n", name);
  173. return -EINVAL;
  174. }
  175. static int stm32_rproc_prepare(struct rproc *rproc)
  176. {
  177. struct device *dev = rproc->dev.parent;
  178. struct device_node *np = dev->of_node;
  179. struct rproc_mem_entry *mem;
  180. u64 da;
  181. int index = 0, mr = 0;
  182. /* Register associated reserved memory regions */
  183. while (1) {
  184. struct resource res;
  185. int ret;
  186. ret = of_reserved_mem_region_to_resource(np, mr++, &res);
  187. if (ret)
  188. return 0;
  189. if (stm32_rproc_pa_to_da(rproc, res.start, &da) < 0) {
  190. dev_err(dev, "memory region not valid %pR\n", &res);
  191. return -EINVAL;
  192. }
  193. /* No need to map vdev buffer */
  194. if (!strstarts(res.name, "vdev0buffer")) {
  195. /* Register memory region */
  196. mem = rproc_mem_entry_init(dev, NULL,
  197. (dma_addr_t)res.start,
  198. resource_size(&res), da,
  199. stm32_rproc_mem_alloc,
  200. stm32_rproc_mem_release,
  201. "%.*s", strchrnul(res.name, '@') - res.name,
  202. res.name);
  203. if (mem)
  204. rproc_coredump_add_segment(rproc, da,
  205. resource_size(&res));
  206. } else {
  207. /* Register reserved memory for vdev buffer alloc */
  208. mem = rproc_of_resm_mem_entry_init(dev, index,
  209. resource_size(&res),
  210. res.start,
  211. "vdev0buffer");
  212. }
  213. if (!mem) {
  214. return -ENOMEM;
  215. }
  216. rproc_add_carveout(rproc, mem);
  217. index++;
  218. }
  219. }
  220. static int stm32_rproc_parse_fw(struct rproc *rproc, const struct firmware *fw)
  221. {
  222. if (rproc_elf_load_rsc_table(rproc, fw))
  223. dev_warn(&rproc->dev, "no resource table found for this firmware\n");
  224. return 0;
  225. }
  226. static irqreturn_t stm32_rproc_wdg(int irq, void *data)
  227. {
  228. struct platform_device *pdev = data;
  229. struct rproc *rproc = platform_get_drvdata(pdev);
  230. rproc_report_crash(rproc, RPROC_WATCHDOG);
  231. return IRQ_HANDLED;
  232. }
  233. static void stm32_rproc_mb_vq_work(struct work_struct *work)
  234. {
  235. struct stm32_mbox *mb = container_of(work, struct stm32_mbox, vq_work);
  236. struct rproc *rproc = dev_get_drvdata(mb->client.dev);
  237. mutex_lock(&rproc->lock);
  238. if (rproc->state != RPROC_RUNNING && rproc->state != RPROC_ATTACHED)
  239. goto unlock_mutex;
  240. if (rproc_vq_interrupt(rproc, mb->vq_id) == IRQ_NONE)
  241. dev_dbg(&rproc->dev, "no message found in vq%d\n", mb->vq_id);
  242. unlock_mutex:
  243. mutex_unlock(&rproc->lock);
  244. }
  245. static void stm32_rproc_mb_callback(struct mbox_client *cl, void *data)
  246. {
  247. struct rproc *rproc = dev_get_drvdata(cl->dev);
  248. struct stm32_mbox *mb = container_of(cl, struct stm32_mbox, client);
  249. struct stm32_rproc *ddata = rproc->priv;
  250. queue_work(ddata->workqueue, &mb->vq_work);
  251. }
  252. static void stm32_rproc_free_mbox(struct rproc *rproc)
  253. {
  254. struct stm32_rproc *ddata = rproc->priv;
  255. unsigned int i;
  256. for (i = 0; i < ARRAY_SIZE(ddata->mb); i++) {
  257. if (ddata->mb[i].chan)
  258. mbox_free_channel(ddata->mb[i].chan);
  259. ddata->mb[i].chan = NULL;
  260. }
  261. }
  262. static const struct stm32_mbox stm32_rproc_mbox[MBOX_NB_MBX] = {
  263. {
  264. .name = STM32_MBX_VQ0,
  265. .vq_id = STM32_MBX_VQ0_ID,
  266. .client = {
  267. .rx_callback = stm32_rproc_mb_callback,
  268. .tx_block = false,
  269. },
  270. },
  271. {
  272. .name = STM32_MBX_VQ1,
  273. .vq_id = STM32_MBX_VQ1_ID,
  274. .client = {
  275. .rx_callback = stm32_rproc_mb_callback,
  276. .tx_block = false,
  277. },
  278. },
  279. {
  280. .name = STM32_MBX_SHUTDOWN,
  281. .vq_id = -1,
  282. .client = {
  283. .tx_block = true,
  284. .tx_done = NULL,
  285. .tx_tout = 500, /* 500 ms time out */
  286. },
  287. },
  288. {
  289. .name = STM32_MBX_DETACH,
  290. .vq_id = -1,
  291. .client = {
  292. .tx_block = true,
  293. .tx_done = NULL,
  294. .tx_tout = 200, /* 200 ms time out to detach should be fair enough */
  295. },
  296. }
  297. };
  298. static int stm32_rproc_request_mbox(struct rproc *rproc)
  299. {
  300. struct stm32_rproc *ddata = rproc->priv;
  301. struct device *dev = &rproc->dev;
  302. unsigned int i;
  303. int j;
  304. const unsigned char *name;
  305. struct mbox_client *cl;
  306. /* Initialise mailbox structure table */
  307. memcpy(ddata->mb, stm32_rproc_mbox, sizeof(stm32_rproc_mbox));
  308. for (i = 0; i < MBOX_NB_MBX; i++) {
  309. name = ddata->mb[i].name;
  310. cl = &ddata->mb[i].client;
  311. cl->dev = dev->parent;
  312. ddata->mb[i].chan = mbox_request_channel_byname(cl, name);
  313. if (IS_ERR(ddata->mb[i].chan)) {
  314. if (PTR_ERR(ddata->mb[i].chan) == -EPROBE_DEFER) {
  315. dev_err_probe(dev->parent,
  316. PTR_ERR(ddata->mb[i].chan),
  317. "failed to request mailbox %s\n",
  318. name);
  319. goto err_probe;
  320. }
  321. dev_warn(dev, "cannot get %s mbox\n", name);
  322. ddata->mb[i].chan = NULL;
  323. }
  324. if (ddata->mb[i].vq_id >= 0) {
  325. INIT_WORK(&ddata->mb[i].vq_work,
  326. stm32_rproc_mb_vq_work);
  327. }
  328. }
  329. return 0;
  330. err_probe:
  331. for (j = i - 1; j >= 0; j--)
  332. if (ddata->mb[j].chan)
  333. mbox_free_channel(ddata->mb[j].chan);
  334. return -EPROBE_DEFER;
  335. }
  336. static int stm32_rproc_set_hold_boot(struct rproc *rproc, bool hold)
  337. {
  338. struct stm32_rproc *ddata = rproc->priv;
  339. struct stm32_syscon hold_boot = ddata->hold_boot;
  340. struct arm_smccc_res smc_res;
  341. int val, err;
  342. /*
  343. * Three ways to manage the hold boot
  344. * - using SCMI: the hold boot is managed as a reset,
  345. * - using Linux(no SCMI): the hold boot is managed as a syscon register
  346. * - using SMC call (deprecated): use SMC reset interface
  347. */
  348. val = hold ? HOLD_BOOT : RELEASE_BOOT;
  349. if (ddata->hold_boot_rst) {
  350. /* Use the SCMI reset controller */
  351. if (!hold)
  352. err = reset_control_deassert(ddata->hold_boot_rst);
  353. else
  354. err = reset_control_assert(ddata->hold_boot_rst);
  355. } else if (IS_ENABLED(CONFIG_HAVE_ARM_SMCCC) && ddata->hold_boot_smc) {
  356. /* Use the SMC call */
  357. arm_smccc_smc(STM32_SMC_RCC, STM32_SMC_REG_WRITE,
  358. hold_boot.reg, val, 0, 0, 0, 0, &smc_res);
  359. err = smc_res.a0;
  360. } else {
  361. /* Use syscon */
  362. err = regmap_update_bits(hold_boot.map, hold_boot.reg,
  363. hold_boot.mask, val);
  364. }
  365. if (err)
  366. dev_err(&rproc->dev, "failed to set hold boot\n");
  367. return err;
  368. }
  369. static void stm32_rproc_add_coredump_trace(struct rproc *rproc)
  370. {
  371. struct rproc_debug_trace *trace;
  372. struct rproc_dump_segment *segment;
  373. bool already_added;
  374. list_for_each_entry(trace, &rproc->traces, node) {
  375. already_added = false;
  376. list_for_each_entry(segment, &rproc->dump_segments, node) {
  377. if (segment->da == trace->trace_mem.da) {
  378. already_added = true;
  379. break;
  380. }
  381. }
  382. if (!already_added)
  383. rproc_coredump_add_segment(rproc, trace->trace_mem.da,
  384. trace->trace_mem.len);
  385. }
  386. }
  387. static int stm32_rproc_start(struct rproc *rproc)
  388. {
  389. struct stm32_rproc *ddata = rproc->priv;
  390. int err;
  391. stm32_rproc_add_coredump_trace(rproc);
  392. /* clear remote proc Deep Sleep */
  393. if (ddata->pdds.map) {
  394. err = regmap_update_bits(ddata->pdds.map, ddata->pdds.reg,
  395. ddata->pdds.mask, 0);
  396. if (err) {
  397. dev_err(&rproc->dev, "failed to clear pdds\n");
  398. return err;
  399. }
  400. }
  401. err = stm32_rproc_set_hold_boot(rproc, false);
  402. if (err)
  403. return err;
  404. return stm32_rproc_set_hold_boot(rproc, true);
  405. }
  406. static int stm32_rproc_attach(struct rproc *rproc)
  407. {
  408. stm32_rproc_add_coredump_trace(rproc);
  409. return stm32_rproc_set_hold_boot(rproc, true);
  410. }
  411. static int stm32_rproc_detach(struct rproc *rproc)
  412. {
  413. struct stm32_rproc *ddata = rproc->priv;
  414. int err, idx;
  415. /* Inform the remote processor of the detach */
  416. idx = stm32_rproc_mbox_idx(rproc, STM32_MBX_DETACH);
  417. if (idx >= 0 && ddata->mb[idx].chan) {
  418. err = mbox_send_message(ddata->mb[idx].chan, "stop");
  419. if (err < 0)
  420. dev_warn(&rproc->dev, "warning: remote FW detach without ack\n");
  421. }
  422. /* Allow remote processor to auto-reboot */
  423. return stm32_rproc_set_hold_boot(rproc, false);
  424. }
  425. static int stm32_rproc_stop(struct rproc *rproc)
  426. {
  427. struct stm32_rproc *ddata = rproc->priv;
  428. int err, idx;
  429. /* request shutdown of the remote processor */
  430. if (rproc->state != RPROC_OFFLINE && rproc->state != RPROC_CRASHED) {
  431. idx = stm32_rproc_mbox_idx(rproc, STM32_MBX_SHUTDOWN);
  432. if (idx >= 0 && ddata->mb[idx].chan) {
  433. err = mbox_send_message(ddata->mb[idx].chan, "detach");
  434. if (err < 0)
  435. dev_warn(&rproc->dev, "warning: remote FW shutdown without ack\n");
  436. }
  437. }
  438. err = stm32_rproc_set_hold_boot(rproc, true);
  439. if (err)
  440. return err;
  441. err = reset_control_assert(ddata->rst);
  442. if (err) {
  443. dev_err(&rproc->dev, "failed to assert the reset\n");
  444. return err;
  445. }
  446. /* to allow platform Standby power mode, set remote proc Deep Sleep */
  447. if (ddata->pdds.map) {
  448. err = regmap_update_bits(ddata->pdds.map, ddata->pdds.reg,
  449. ddata->pdds.mask, 1);
  450. if (err) {
  451. dev_err(&rproc->dev, "failed to set pdds\n");
  452. return err;
  453. }
  454. }
  455. /* update coprocessor state to OFF if available */
  456. if (ddata->m4_state.map) {
  457. err = regmap_update_bits(ddata->m4_state.map,
  458. ddata->m4_state.reg,
  459. ddata->m4_state.mask,
  460. M4_STATE_OFF);
  461. if (err) {
  462. dev_err(&rproc->dev, "failed to set copro state\n");
  463. return err;
  464. }
  465. }
  466. return 0;
  467. }
  468. static void stm32_rproc_kick(struct rproc *rproc, int vqid)
  469. {
  470. struct stm32_rproc *ddata = rproc->priv;
  471. unsigned int i;
  472. int err;
  473. if (WARN_ON(vqid >= MBOX_NB_VQ))
  474. return;
  475. for (i = 0; i < MBOX_NB_MBX; i++) {
  476. if (vqid != ddata->mb[i].vq_id)
  477. continue;
  478. if (!ddata->mb[i].chan)
  479. return;
  480. err = mbox_send_message(ddata->mb[i].chan, "kick");
  481. if (err < 0)
  482. dev_err(&rproc->dev, "%s: failed (%s, err:%d)\n",
  483. __func__, ddata->mb[i].name, err);
  484. return;
  485. }
  486. }
  487. static int stm32_rproc_da_to_pa(struct rproc *rproc,
  488. u64 da, phys_addr_t *pa)
  489. {
  490. struct stm32_rproc *ddata = rproc->priv;
  491. struct device *dev = rproc->dev.parent;
  492. struct stm32_rproc_mem *p_mem;
  493. unsigned int i;
  494. for (i = 0; i < ddata->nb_rmems; i++) {
  495. p_mem = &ddata->rmems[i];
  496. if (da < p_mem->dev_addr ||
  497. da >= p_mem->dev_addr + p_mem->size)
  498. continue;
  499. *pa = da - p_mem->dev_addr + p_mem->bus_addr;
  500. dev_dbg(dev, "da %llx to pa %pap\n", da, pa);
  501. return 0;
  502. }
  503. dev_err(dev, "can't translate da %llx\n", da);
  504. return -EINVAL;
  505. }
  506. static struct resource_table *
  507. stm32_rproc_get_loaded_rsc_table(struct rproc *rproc, size_t *table_sz)
  508. {
  509. struct stm32_rproc *ddata = rproc->priv;
  510. struct device *dev = rproc->dev.parent;
  511. phys_addr_t rsc_pa;
  512. u32 rsc_da;
  513. int err;
  514. /* The resource table has already been mapped, nothing to do */
  515. if (ddata->rsc_va)
  516. goto done;
  517. err = regmap_read(ddata->rsctbl.map, ddata->rsctbl.reg, &rsc_da);
  518. if (err) {
  519. dev_err(dev, "failed to read rsc tbl addr\n");
  520. return ERR_PTR(-EINVAL);
  521. }
  522. if (!rsc_da)
  523. /* no rsc table */
  524. return ERR_PTR(-ENOENT);
  525. err = stm32_rproc_da_to_pa(rproc, rsc_da, &rsc_pa);
  526. if (err)
  527. return ERR_PTR(err);
  528. ddata->rsc_va = devm_ioremap_wc(dev, rsc_pa, RSC_TBL_SIZE);
  529. if (IS_ERR_OR_NULL(ddata->rsc_va)) {
  530. dev_err(dev, "Unable to map memory region: %pa+%x\n",
  531. &rsc_pa, RSC_TBL_SIZE);
  532. ddata->rsc_va = NULL;
  533. return ERR_PTR(-ENOMEM);
  534. }
  535. done:
  536. /*
  537. * Assuming the resource table fits in 1kB is fair.
  538. * Notice for the detach, that this 1 kB memory area has to be reserved in the coprocessor
  539. * firmware for the resource table. On detach, the remoteproc core re-initializes this
  540. * entire area by overwriting it with the initial values stored in rproc->clean_table.
  541. */
  542. *table_sz = RSC_TBL_SIZE;
  543. return (__force struct resource_table *)ddata->rsc_va;
  544. }
  545. static const struct rproc_ops st_rproc_ops = {
  546. .prepare = stm32_rproc_prepare,
  547. .start = stm32_rproc_start,
  548. .stop = stm32_rproc_stop,
  549. .attach = stm32_rproc_attach,
  550. .detach = stm32_rproc_detach,
  551. .kick = stm32_rproc_kick,
  552. .load = rproc_elf_load_segments,
  553. .parse_fw = stm32_rproc_parse_fw,
  554. .find_loaded_rsc_table = rproc_elf_find_loaded_rsc_table,
  555. .get_loaded_rsc_table = stm32_rproc_get_loaded_rsc_table,
  556. .sanity_check = rproc_elf_sanity_check,
  557. .get_boot_addr = rproc_elf_get_boot_addr,
  558. };
  559. static const struct of_device_id stm32_rproc_match[] = {
  560. { .compatible = "st,stm32mp1-m4" },
  561. {},
  562. };
  563. MODULE_DEVICE_TABLE(of, stm32_rproc_match);
  564. static int stm32_rproc_get_syscon(struct device_node *np, const char *prop,
  565. struct stm32_syscon *syscon)
  566. {
  567. int err = 0;
  568. syscon->map = syscon_regmap_lookup_by_phandle(np, prop);
  569. if (IS_ERR(syscon->map)) {
  570. err = PTR_ERR(syscon->map);
  571. syscon->map = NULL;
  572. goto out;
  573. }
  574. err = of_property_read_u32_index(np, prop, 1, &syscon->reg);
  575. if (err)
  576. goto out;
  577. err = of_property_read_u32_index(np, prop, 2, &syscon->mask);
  578. out:
  579. return err;
  580. }
  581. static int stm32_rproc_parse_dt(struct platform_device *pdev,
  582. struct stm32_rproc *ddata, bool *auto_boot)
  583. {
  584. struct device *dev = &pdev->dev;
  585. struct device_node *np = dev->of_node;
  586. struct stm32_syscon tz;
  587. unsigned int tzen;
  588. int err, irq;
  589. irq = platform_get_irq_optional(pdev, 0);
  590. if (irq == -EPROBE_DEFER)
  591. return irq;
  592. if (irq > 0) {
  593. err = devm_request_irq(dev, irq, stm32_rproc_wdg, 0,
  594. dev_name(dev), pdev);
  595. if (err)
  596. return dev_err_probe(dev, err,
  597. "failed to request wdg irq\n");
  598. ddata->wdg_irq = irq;
  599. if (of_property_read_bool(np, "wakeup-source")) {
  600. device_init_wakeup(dev, true);
  601. dev_pm_set_wake_irq(dev, irq);
  602. }
  603. dev_info(dev, "wdg irq registered\n");
  604. }
  605. ddata->rst = devm_reset_control_get_optional(dev, "mcu_rst");
  606. if (!ddata->rst) {
  607. /* Try legacy fallback method: get it by index */
  608. ddata->rst = devm_reset_control_get_by_index(dev, 0);
  609. }
  610. if (IS_ERR(ddata->rst))
  611. return dev_err_probe(dev, PTR_ERR(ddata->rst),
  612. "failed to get mcu_reset\n");
  613. /*
  614. * Three ways to manage the hold boot
  615. * - using SCMI: the hold boot is managed as a reset
  616. * The DT "reset-mames" property should be defined with 2 items:
  617. * reset-names = "mcu_rst", "hold_boot";
  618. * - using SMC call (deprecated): use SMC reset interface
  619. * The DT "reset-mames" property is optional, "st,syscfg-tz" is required
  620. * - default(no SCMI, no SMC): the hold boot is managed as a syscon register
  621. * The DT "reset-mames" property is optional, "st,syscfg-holdboot" is required
  622. */
  623. ddata->hold_boot_rst = devm_reset_control_get_optional(dev, "hold_boot");
  624. if (IS_ERR(ddata->hold_boot_rst))
  625. return dev_err_probe(dev, PTR_ERR(ddata->hold_boot_rst),
  626. "failed to get hold_boot reset\n");
  627. if (!ddata->hold_boot_rst && IS_ENABLED(CONFIG_HAVE_ARM_SMCCC)) {
  628. /* Manage the MCU_BOOT using SMC call */
  629. err = stm32_rproc_get_syscon(np, "st,syscfg-tz", &tz);
  630. if (!err) {
  631. err = regmap_read(tz.map, tz.reg, &tzen);
  632. if (err) {
  633. dev_err(dev, "failed to read tzen\n");
  634. return err;
  635. }
  636. ddata->hold_boot_smc = tzen & tz.mask;
  637. }
  638. }
  639. if (!ddata->hold_boot_rst && !ddata->hold_boot_smc) {
  640. /* Default: hold boot manage it through the syscon controller */
  641. err = stm32_rproc_get_syscon(np, "st,syscfg-holdboot",
  642. &ddata->hold_boot);
  643. if (err) {
  644. dev_err(dev, "failed to get hold boot\n");
  645. return err;
  646. }
  647. }
  648. err = stm32_rproc_get_syscon(np, "st,syscfg-pdds", &ddata->pdds);
  649. if (err)
  650. dev_info(dev, "failed to get pdds\n");
  651. *auto_boot = of_property_read_bool(np, "st,auto-boot");
  652. /*
  653. * See if we can check the M4 status, i.e if it was started
  654. * from the boot loader or not.
  655. */
  656. err = stm32_rproc_get_syscon(np, "st,syscfg-m4-state",
  657. &ddata->m4_state);
  658. if (err) {
  659. /* remember this */
  660. ddata->m4_state.map = NULL;
  661. /* no coprocessor state syscon (optional) */
  662. dev_warn(dev, "m4 state not supported\n");
  663. /* no need to go further */
  664. return 0;
  665. }
  666. /* See if we can get the resource table */
  667. err = stm32_rproc_get_syscon(np, "st,syscfg-rsc-tbl",
  668. &ddata->rsctbl);
  669. if (err) {
  670. /* no rsc table syscon (optional) */
  671. dev_warn(dev, "rsc tbl syscon not supported\n");
  672. }
  673. return 0;
  674. }
  675. static int stm32_rproc_get_m4_status(struct stm32_rproc *ddata,
  676. unsigned int *state)
  677. {
  678. /* See stm32_rproc_parse_dt() */
  679. if (!ddata->m4_state.map) {
  680. /*
  681. * We couldn't get the coprocessor's state, assume
  682. * it is not running.
  683. */
  684. *state = M4_STATE_OFF;
  685. return 0;
  686. }
  687. return regmap_read(ddata->m4_state.map, ddata->m4_state.reg, state);
  688. }
  689. static int stm32_rproc_probe(struct platform_device *pdev)
  690. {
  691. struct device *dev = &pdev->dev;
  692. struct stm32_rproc *ddata;
  693. struct device_node *np = dev->of_node;
  694. const char *fw_name;
  695. struct rproc *rproc;
  696. unsigned int state;
  697. int ret;
  698. ret = dma_coerce_mask_and_coherent(dev, DMA_BIT_MASK(32));
  699. if (ret)
  700. return ret;
  701. /* Look for an optional firmware name */
  702. ret = rproc_of_parse_firmware(dev, 0, &fw_name);
  703. if (ret < 0 && ret != -EINVAL)
  704. return ret;
  705. rproc = devm_rproc_alloc(dev, np->name, &st_rproc_ops, fw_name, sizeof(*ddata));
  706. if (!rproc)
  707. return -ENOMEM;
  708. ddata = rproc->priv;
  709. rproc_coredump_set_elf_info(rproc, ELFCLASS32, EM_NONE);
  710. ret = stm32_rproc_parse_dt(pdev, ddata, &rproc->auto_boot);
  711. if (ret)
  712. goto free_rproc;
  713. ret = stm32_rproc_of_memory_translations(pdev, ddata);
  714. if (ret)
  715. goto free_rproc;
  716. ret = stm32_rproc_get_m4_status(ddata, &state);
  717. if (ret)
  718. goto free_rproc;
  719. if (state == M4_STATE_CRUN)
  720. rproc->state = RPROC_DETACHED;
  721. rproc->has_iommu = false;
  722. ddata->workqueue = create_workqueue(dev_name(dev));
  723. if (!ddata->workqueue) {
  724. dev_err(dev, "cannot create workqueue\n");
  725. ret = -ENOMEM;
  726. goto free_resources;
  727. }
  728. platform_set_drvdata(pdev, rproc);
  729. ret = stm32_rproc_request_mbox(rproc);
  730. if (ret)
  731. goto free_wkq;
  732. ret = rproc_add(rproc);
  733. if (ret)
  734. goto free_mb;
  735. return 0;
  736. free_mb:
  737. stm32_rproc_free_mbox(rproc);
  738. free_wkq:
  739. destroy_workqueue(ddata->workqueue);
  740. free_resources:
  741. rproc_resource_cleanup(rproc);
  742. free_rproc:
  743. if (device_may_wakeup(dev)) {
  744. dev_pm_clear_wake_irq(dev);
  745. device_init_wakeup(dev, false);
  746. }
  747. return ret;
  748. }
  749. static void stm32_rproc_remove(struct platform_device *pdev)
  750. {
  751. struct rproc *rproc = platform_get_drvdata(pdev);
  752. struct stm32_rproc *ddata = rproc->priv;
  753. struct device *dev = &pdev->dev;
  754. if (atomic_read(&rproc->power) > 0)
  755. rproc_shutdown(rproc);
  756. rproc_del(rproc);
  757. stm32_rproc_free_mbox(rproc);
  758. destroy_workqueue(ddata->workqueue);
  759. if (device_may_wakeup(dev)) {
  760. dev_pm_clear_wake_irq(dev);
  761. device_init_wakeup(dev, false);
  762. }
  763. }
  764. static int stm32_rproc_suspend(struct device *dev)
  765. {
  766. struct rproc *rproc = dev_get_drvdata(dev);
  767. struct stm32_rproc *ddata = rproc->priv;
  768. if (device_may_wakeup(dev))
  769. return enable_irq_wake(ddata->wdg_irq);
  770. return 0;
  771. }
  772. static int stm32_rproc_resume(struct device *dev)
  773. {
  774. struct rproc *rproc = dev_get_drvdata(dev);
  775. struct stm32_rproc *ddata = rproc->priv;
  776. if (device_may_wakeup(dev))
  777. return disable_irq_wake(ddata->wdg_irq);
  778. return 0;
  779. }
  780. static DEFINE_SIMPLE_DEV_PM_OPS(stm32_rproc_pm_ops,
  781. stm32_rproc_suspend, stm32_rproc_resume);
  782. static struct platform_driver stm32_rproc_driver = {
  783. .probe = stm32_rproc_probe,
  784. .remove = stm32_rproc_remove,
  785. .driver = {
  786. .name = "stm32-rproc",
  787. .pm = pm_ptr(&stm32_rproc_pm_ops),
  788. .of_match_table = stm32_rproc_match,
  789. },
  790. };
  791. module_platform_driver(stm32_rproc_driver);
  792. MODULE_DESCRIPTION("STM32 Remote Processor Control Driver");
  793. MODULE_AUTHOR("Ludovic Barre <ludovic.barre@st.com>");
  794. MODULE_AUTHOR("Fabien Dessenne <fabien.dessenne@st.com>");
  795. MODULE_LICENSE("GPL v2");