Lines Matching full:rproc
93 static int imx_rproc_xtr_mbox_init(struct rproc *rproc);
94 static void imx_rproc_free_mbox(struct rproc *rproc);
95 static int imx_rproc_detach_pd(struct rproc *rproc);
101 struct rproc *rproc; member
373 static int imx_rproc_start(struct rproc *rproc) in imx_rproc_start() argument
375 struct imx_rproc *priv = rproc->priv; in imx_rproc_start()
381 ret = imx_rproc_xtr_mbox_init(rproc); in imx_rproc_start()
413 static int imx_rproc_stop(struct rproc *rproc) in imx_rproc_stop() argument
415 struct imx_rproc *priv = rproc->priv; in imx_rproc_stop()
452 imx_rproc_free_mbox(rproc); in imx_rproc_stop()
493 static void *imx_rproc_da_to_va(struct rproc *rproc, u64 da, size_t len, bool *is_iomem) in imx_rproc_da_to_va() argument
495 struct imx_rproc *priv = rproc->priv; in imx_rproc_da_to_va()
520 dev_dbg(&rproc->dev, "da = 0x%llx len = 0x%zx va = 0x%p\n", in imx_rproc_da_to_va()
526 static int imx_rproc_mem_alloc(struct rproc *rproc, in imx_rproc_mem_alloc() argument
529 struct device *dev = rproc->dev.parent; in imx_rproc_mem_alloc()
546 static int imx_rproc_mem_release(struct rproc *rproc, in imx_rproc_mem_release() argument
549 dev_dbg(rproc->dev.parent, "unmap memory: %pa\n", &mem->dma); in imx_rproc_mem_release()
555 static int imx_rproc_prepare(struct rproc *rproc) in imx_rproc_prepare() argument
557 struct imx_rproc *priv = rproc->priv; in imx_rproc_prepare()
593 rproc_coredump_add_segment(rproc, da, rmem->size); in imx_rproc_prepare()
599 rproc_add_carveout(rproc, mem); in imx_rproc_prepare()
605 static int imx_rproc_parse_fw(struct rproc *rproc, const struct firmware *fw) in imx_rproc_parse_fw() argument
609 ret = rproc_elf_load_rsc_table(rproc, fw); in imx_rproc_parse_fw()
611 dev_info(&rproc->dev, "No resource table in elf\n"); in imx_rproc_parse_fw()
616 static void imx_rproc_kick(struct rproc *rproc, int vqid) in imx_rproc_kick() argument
618 struct imx_rproc *priv = rproc->priv; in imx_rproc_kick()
639 static int imx_rproc_attach(struct rproc *rproc) in imx_rproc_attach() argument
641 return imx_rproc_xtr_mbox_init(rproc); in imx_rproc_attach()
644 static int imx_rproc_detach(struct rproc *rproc) in imx_rproc_detach() argument
646 struct imx_rproc *priv = rproc->priv; in imx_rproc_detach()
655 imx_rproc_free_mbox(rproc); in imx_rproc_detach()
660 static struct resource_table *imx_rproc_get_loaded_rsc_table(struct rproc *rproc, size_t *table_sz) in imx_rproc_get_loaded_rsc_table() argument
662 struct imx_rproc *priv = rproc->priv; in imx_rproc_get_loaded_rsc_table()
765 struct rproc *rproc = data; in imx_rproc_notified_idr_cb() local
767 rproc_vq_interrupt(rproc, id); in imx_rproc_notified_idr_cb()
776 struct rproc *rproc = priv->rproc; in imx_rproc_vq_work() local
778 idr_for_each(&rproc->notifyids, imx_rproc_notified_idr_cb, rproc); in imx_rproc_vq_work()
783 struct rproc *rproc = dev_get_drvdata(cl->dev); in imx_rproc_rx_callback() local
784 struct imx_rproc *priv = rproc->priv; in imx_rproc_rx_callback()
789 static int imx_rproc_xtr_mbox_init(struct rproc *rproc) in imx_rproc_xtr_mbox_init() argument
791 struct imx_rproc *priv = rproc->priv; in imx_rproc_xtr_mbox_init()
832 static void imx_rproc_free_mbox(struct rproc *rproc) in imx_rproc_free_mbox() argument
834 struct imx_rproc *priv = rproc->priv; in imx_rproc_free_mbox()
847 static void imx_rproc_put_scu(struct rproc *rproc) in imx_rproc_put_scu() argument
849 struct imx_rproc *priv = rproc->priv; in imx_rproc_put_scu()
856 imx_rproc_detach_pd(rproc); in imx_rproc_put_scu()
873 rproc_report_crash(priv->rproc, RPROC_WATCHDOG); in imx_rproc_partition_notify()
931 static int imx_rproc_detach_pd(struct rproc *rproc) in imx_rproc_detach_pd() argument
933 struct imx_rproc *priv = rproc->priv; in imx_rproc_detach_pd()
953 struct regmap_config config = { .name = "imx-rproc" }; in imx_rproc_detect_mode()
964 priv->rproc->state = RPROC_DETACHED; in imx_rproc_detect_mode()
969 priv->rproc->state = RPROC_DETACHED; in imx_rproc_detect_mode()
997 priv->rproc->state = RPROC_DETACHED; in imx_rproc_detect_mode()
998 priv->rproc->recovery_disabled = false; in imx_rproc_detect_mode()
999 rproc_set_feature(priv->rproc, RPROC_FEAT_ATTACH_ON_RECOVERY); in imx_rproc_detect_mode()
1051 imx_rproc_stop(priv->rproc); in imx_rproc_detect_mode()
1063 priv->rproc->state = RPROC_DETACHED; in imx_rproc_detect_mode()
1102 struct rproc *rproc; in imx_rproc_probe() local
1107 rproc = rproc_alloc(dev, "imx-rproc", &imx_rproc_ops, in imx_rproc_probe()
1109 if (!rproc) in imx_rproc_probe()
1118 priv = rproc->priv; in imx_rproc_probe()
1119 priv->rproc = rproc; in imx_rproc_probe()
1123 dev_set_drvdata(dev, rproc); in imx_rproc_probe()
1131 ret = imx_rproc_xtr_mbox_init(rproc); in imx_rproc_probe()
1151 if (rproc->state != RPROC_DETACHED) in imx_rproc_probe()
1152 rproc->auto_boot = of_property_read_bool(np, "fsl,auto-boot"); in imx_rproc_probe()
1154 ret = rproc_add(rproc); in imx_rproc_probe()
1165 imx_rproc_put_scu(rproc); in imx_rproc_probe()
1167 imx_rproc_free_mbox(rproc); in imx_rproc_probe()
1171 rproc_free(rproc); in imx_rproc_probe()
1178 struct rproc *rproc = platform_get_drvdata(pdev); in imx_rproc_remove() local
1179 struct imx_rproc *priv = rproc->priv; in imx_rproc_remove()
1182 rproc_del(rproc); in imx_rproc_remove()
1183 imx_rproc_put_scu(rproc); in imx_rproc_remove()
1184 imx_rproc_free_mbox(rproc); in imx_rproc_remove()
1186 rproc_free(rproc); in imx_rproc_remove()
1211 .name = "imx-rproc",