remoteproc: imx_rproc: iterate all notifiyids in rx callback
authorPeng Fan <peng.fan@nxp.com>
Thu, 29 Jun 2023 09:33:27 +0000 (17:33 +0800)
committerBjorn Andersson <andersson@kernel.org>
Sat, 15 Jul 2023 19:36:22 +0000 (12:36 -0700)
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@nxp.com>
Link: https://lore.kernel.org/r/20230629093327.3376308-1-peng.fan@oss.nxp.com
Signed-off-by: Bjorn Andersson <andersson@kernel.org>
drivers/remoteproc/imx_rproc.c

index b403a37ddb02e1be0b5e2b6610782cc549ff1713..4ee2646ce62ad2f8bebd6af25b5874cb3d278f54 100644 (file)
@@ -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,
                                              rproc_work);
+       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)