[PATCH V3] remoteproc: imx_rproc: iterate all notifiyids in rx callback

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]


From: Peng Fan <peng.fan@xxxxxxx>

The current code only supports one vdev and a single callback,
but there are cases need more vdevs. So iterate all notifyids to
support more vdevs with the single callback.

Signed-off-by: Peng Fan <peng.fan@xxxxxxx>

 Drop debug message in callback

 Update commit log

 drivers/remoteproc/imx_rproc.c | 13 +++++++++++--
 1 file changed, 11 insertions(+), 2 deletions(-)

diff --git a/drivers/remoteproc/imx_rproc.c b/drivers/remoteproc/imx_rproc.c
index f9874fc5a80f..986d3db81596 100644
--- a/drivers/remoteproc/imx_rproc.c
+++ b/drivers/remoteproc/imx_rproc.c
@@ -725,13 +725,22 @@ static int imx_rproc_addr_init(struct imx_rproc *priv,
 	return 0;
+static int imx_rproc_notified_idr_cb(int id, void *ptr, void *data)
+	struct rproc *rproc = data;
+	rproc_vq_interrupt(rproc, id);
+	return 0;
 static void imx_rproc_vq_work(struct work_struct *work)
 	struct imx_rproc *priv = container_of(work, struct imx_rproc,
+	struct rproc *rproc = priv->rproc;
-	rproc_vq_interrupt(priv->rproc, 0);
-	rproc_vq_interrupt(priv->rproc, 1);
+	idr_for_each(&rproc->notifyids, imx_rproc_notified_idr_cb, rproc);
 static void imx_rproc_rx_callback(struct mbox_client *cl, void *msg)

[Index of Archives]     [Linux Sound]     [ALSA Users]     [ALSA Devel]     [Linux Audio Users]     [Linux Media]     [Kernel]     [Photo Sharing]     [Gimp]     [Yosemite News]     [Linux Media]

  Powered by Linux