Lines Matching full:rproc
82 struct rproc *rproc; member
296 static int imx_rproc_start(struct rproc *rproc) in imx_rproc_start() argument
298 struct imx_rproc *priv = rproc->priv; in imx_rproc_start()
323 static int imx_rproc_stop(struct rproc *rproc) in imx_rproc_stop() argument
325 struct imx_rproc *priv = rproc->priv; in imx_rproc_stop()
377 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
379 struct imx_rproc *priv = rproc->priv; in imx_rproc_da_to_va()
404 dev_dbg(&rproc->dev, "da = 0x%llx len = 0x%zx va = 0x%p\n", in imx_rproc_da_to_va()
410 static int imx_rproc_mem_alloc(struct rproc *rproc, in imx_rproc_mem_alloc() argument
413 struct device *dev = rproc->dev.parent; in imx_rproc_mem_alloc()
430 static int imx_rproc_mem_release(struct rproc *rproc, in imx_rproc_mem_release() argument
433 dev_dbg(rproc->dev.parent, "unmap memory: %pa\n", &mem->dma); in imx_rproc_mem_release()
439 static int imx_rproc_prepare(struct rproc *rproc) in imx_rproc_prepare() argument
441 struct imx_rproc *priv = rproc->priv; in imx_rproc_prepare()
476 rproc_coredump_add_segment(rproc, da, rmem->size); in imx_rproc_prepare()
480 rproc_add_carveout(rproc, mem); in imx_rproc_prepare()
486 static int imx_rproc_parse_fw(struct rproc *rproc, const struct firmware *fw) in imx_rproc_parse_fw() argument
490 ret = rproc_elf_load_rsc_table(rproc, fw); in imx_rproc_parse_fw()
492 dev_info(&rproc->dev, "No resource table in elf\n"); in imx_rproc_parse_fw()
497 static void imx_rproc_kick(struct rproc *rproc, int vqid) in imx_rproc_kick() argument
499 struct imx_rproc *priv = rproc->priv; in imx_rproc_kick()
520 static int imx_rproc_attach(struct rproc *rproc) in imx_rproc_attach() argument
525 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
527 struct imx_rproc *priv = rproc->priv; in imx_rproc_get_loaded_rsc_table()
632 rproc_vq_interrupt(priv->rproc, 0); in imx_rproc_vq_work()
633 rproc_vq_interrupt(priv->rproc, 1); in imx_rproc_vq_work()
638 struct rproc *rproc = dev_get_drvdata(cl->dev); in imx_rproc_rx_callback() local
639 struct imx_rproc *priv = rproc->priv; in imx_rproc_rx_callback()
644 static int imx_rproc_xtr_mbox_init(struct rproc *rproc) in imx_rproc_xtr_mbox_init() argument
646 struct imx_rproc *priv = rproc->priv; in imx_rproc_xtr_mbox_init()
675 static void imx_rproc_free_mbox(struct rproc *rproc) in imx_rproc_free_mbox() argument
677 struct imx_rproc *priv = rproc->priv; in imx_rproc_free_mbox()
685 struct regmap_config config = { .name = "imx-rproc" }; in imx_rproc_detect_mode()
695 priv->rproc->state = RPROC_DETACHED; in imx_rproc_detect_mode()
700 priv->rproc->state = RPROC_DETACHED; in imx_rproc_detect_mode()
722 priv->rproc->state = RPROC_DETACHED; in imx_rproc_detect_mode()
761 struct rproc *rproc; in imx_rproc_probe() local
766 rproc = rproc_alloc(dev, "imx-rproc", &imx_rproc_ops, in imx_rproc_probe()
768 if (!rproc) in imx_rproc_probe()
777 priv = rproc->priv; in imx_rproc_probe()
778 priv->rproc = rproc; in imx_rproc_probe()
782 dev_set_drvdata(dev, rproc); in imx_rproc_probe()
790 ret = imx_rproc_xtr_mbox_init(rproc); in imx_rproc_probe()
810 if (rproc->state != RPROC_DETACHED) in imx_rproc_probe()
811 rproc->auto_boot = of_property_read_bool(np, "fsl,auto-boot"); in imx_rproc_probe()
813 ret = rproc_add(rproc); in imx_rproc_probe()
824 imx_rproc_free_mbox(rproc); in imx_rproc_probe()
828 rproc_free(rproc); in imx_rproc_probe()
835 struct rproc *rproc = platform_get_drvdata(pdev); in imx_rproc_remove() local
836 struct imx_rproc *priv = rproc->priv; in imx_rproc_remove()
839 rproc_del(rproc); in imx_rproc_remove()
840 imx_rproc_free_mbox(rproc); in imx_rproc_remove()
842 rproc_free(rproc); in imx_rproc_remove()
865 .name = "imx-rproc",