stm32_rproc.c 22 KB

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