Re: [PATCH v5 0/5] Enable Remote GPIO over RPMSG on i.MX Platform

From: Arnaud POULIQUEN

Date: Fri Nov 07 2025 - 12:18:48 EST


hi Shenwei

On 11/6/25 17:26, Shenwei Wang wrote:
Hi Arnaud,

-----Original Message-----
From: Arnaud POULIQUEN <arnaud.pouliquen@xxxxxxxxxxx>
Sent: Thursday, November 6, 2025 4:17 AM
To: Shenwei Wang <shenwei.wang@xxxxxxx>; Peng Fan <peng.fan@xxxxxxx>;
Bjorn Andersson <andersson@xxxxxxxxxx>; Mathieu Poirier
<mathieu.poirier@xxxxxxxxxx>; Rob Herring <robh@xxxxxxxxxx>; Krzysztof
Kozlowski <krzk+dt@xxxxxxxxxx>; Conor Dooley <conor+dt@xxxxxxxxxx>; Shawn
Guo <shawnguo@xxxxxxxxxx>; Sascha Hauer <s.hauer@xxxxxxxxxxxxxx>;
Jonathan Corbet <corbet@xxxxxxx>; Linus Walleij <linus.walleij@xxxxxxxxxx>;
Bartosz Golaszewski <brgl@xxxxxxxx>
Cc: Pengutronix Kernel Team <kernel@xxxxxxxxxxxxxx>; Fabio Estevam
<festevam@xxxxxxxxx>; linux-remoteproc@xxxxxxxxxxxxxxx;
devicetree@xxxxxxxxxxxxxxx; imx@xxxxxxxxxxxxxxx; linux-arm-
kernel@xxxxxxxxxxxxxxxxxxx; linux-kernel@xxxxxxxxxxxxxxx; linux-
doc@xxxxxxxxxxxxxxx; dl-linux-imx <linux-imx@xxxxxxx>; Randy Dunlap
<rdunlap@xxxxxxxxxxxxx>; Andrew Lunn <andrew@xxxxxxx>; linux-
gpio@xxxxxxxxxxxxxxx
Subject: [EXT] Re: [PATCH v5 0/5] Enable Remote GPIO over RPMSG on i.MX
Platform

Hi Shenwei,

On 11/5/25 15:12, Shenwei Wang wrote:
Hi Arnaud,

-----Original Message-----

On 11/5/25 02:12, Peng Fan wrote:
Hi Shenwei

Subject: [PATCH v5 0/5] Enable Remote GPIO over RPMSG on i.MX
Platform

Support the remote devices on the remote processor via the RPMSG
bus on i.MX platform.


I have not look into the details of new version, but before that,
just want to check, have we agreed on what Arnaud suggested?
or continue to proceed to be this as i.MX specific?

Thanks, Peng, for pointing this out. Regarding the V3 discussions, it
seems that I am not the only one suggesting a generic driver.


As I mentioned before, the only i.MX-specific part is the transport protocol over
the RPMSG bus.
In this v5 patches, we’ve included detailed documentation for the
protocol in a separate file. Any platform that follows the same protocol should
work right out of the box.

If you spot anything that could be improved, please let me know!

My concerns remain the same as those shared previously:

1) The simpler one: gpio-imx-rpmsg.c should be renamed to gpio-rpmsg.c.


Agree. Will fix it in the next version.

2) The more complex one: the driver should be independent of the remoteproc
driver. The rpmsg protocol relies on virtio and can be used in contexts other than
remoteproc. In other words, the struct rpmsg_driver and its associated
operations should be defined within the rpmsg-gpio driver, not in the remoteproc
driver.


The GPIO driver operates independently of the remoteproc driver.

The channel_device_map table in imx_rproc.c would give me the opposite feeling

It functions based
on the defined GPIO-RPMSG transport protocol. Any remoteproc that supports
this protocol can exchange data with the GPIO driver via the underlying rpmsg bus.
Placing the rpmsg_driver (which manages the rpmsg channel) within the remoteproc
driver is more logical, as rpmsg channels run on the rpmsg bus. This bus is defined inside
the remoteproc device tree node and is populated by the corresponding remoteproc driver.


Regarding imx_of_rpmsg_node_init(), It seems you rely on device tree in the rproc platform to register rpmsg drivers. This implies you are creating drivers based on a device description. To me, this does not appear to be a valid implementation, but perhaps such an approach already exists in the Linux kernel?


For your information, I'm facing a similar issue with my remoteproc_tee series [1]. The advice I received was to look at the PCIe DT implementation (I haven't had time to explore it yet). This advice also seems relevant to your series.

Do you also have a look to rpmsg_virtio_bus ? it seems a good candidate to match the device tree properties with the rpmsg device?

In the end, this is my point of view. Perhaps it is better to wait for others before deciding on the direction...

Thanks,
Arnaud

[1]https://lists.infradead.org/pipermail/linux-arm-kernel/2025-October/1069154.html


Thanks,
Shenwei


Thanks,
Arnaud


Thanks,
Shenwei

Thanks,
Arnaud


Thanks
Peng.