RE: [EXT] Re: [RFC 2/2] rpmsg: imx: add the initial imx rpmsg support

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

 



> -----Original Message-----
> From: Arnaud Pouliquen <arnaud.pouliquen@xxxxxx>
> Sent: 2019年7月15日 20:16
> To: Richard Zhu <hongxing.zhu@xxxxxxx>; Oleksij Rempel
> <o.rempel@xxxxxxxxxxxxxx>; ohad@xxxxxxxxxx; bjorn.andersson@xxxxxxxxxx;
> linux-remoteproc@xxxxxxxxxxxxxxx
> Cc: loic.pallardy@xxxxxx; Fabien DESSENNE <fabien.dessenne@xxxxxx>;
> elder@xxxxxxxxxx; linux-arm-kernel@xxxxxxxxxxxxxxxxxxx
> Subject: [EXT] Re: [RFC 2/2] rpmsg: imx: add the initial imx rpmsg support
> 
> On 7/15/19 10:22 AM, Richard Zhu wrote:
> 
> <snip>
> 
> >>>> sg693v6UjM%2BFEk7TYHxgg6RDX611%2FKfjqA%3D&amp;reserved=0
> >>>>>
> >>>>> M core/RTOS insists to run and manage its resources assigned by
> >>>>> XRDC
> >>>> standalone.
> >>>>> All the interactions between A core and M core are transferred on
> >>>>> RPMSG
> >>>> channels.
> >>>>> For example, the audio codec configuration and so on.
> >>>>> So, what I do here is just setup the communication RPMSG channels
> >>>>> between A core/Linux and M core/RTOS.
> >>>>>
> >>>>> One more concern, I'm afraid that I may mess up the current solid
> >>>>> reproc flow and framework if  I force this implementation into the
> >>>>> current
> >>>> reproc drivers.
> >>>>> So, I summit this patch-set in the end. Pre-reserved vring buffer,
> >>>>> register virtio_device, establish the RPMSG channels lets A
> >>>>> core/Linux and
> >>>> M Core/RTOS can communicate with each other.
> >>>>> That's all.
> >>>> Your concern is valid, and as we have the same requirement, it
> >>>> would be nice to find a common solution. That's why i propose this
> >>>> alternative, which would have the advantage of reusing existing
> >>>> rpmsg
> >> implementation.
> >>>>
> >>>    [Richard Zhu] I looked through the codes briefly. Correct me if
> >>> my
> >> understand
> >>>    is wrong.
> >>> It seems that the A core side does a lot of manipulations to the
> >>> remote M4
> >> core
> >>>    on ST32M.
> >>> During the start/stop/recovery operations, M4 acted as slave and
> >>> waiting
> >> for the
> >>>    control constructions sent from the master A core/Linux side
> >>> although
> >> the
> >>>    early_boot is set.
> >>>
> >>> There are some differences in the relationship between A core and M
> core.
> >>> On ST32M: M4/RTOS would started/stopped/recovered by A core/Linux
> >> side.
> >>>
> >>> In my purposed implementation, both A core/Linux and M core/RTOS
> >> working in the real
> >>>    independent mode.
> >>> - M4/RTOS complete the start/stop/recovery and son on operations by
> >>> itself,
> >> it wouldn't
> >>>    accept any start/stop/reset interactions from A core/Linux side.
> >>> Same to
> >> A core/Linux side.
> >>> - SCFW monitors the running status of each side, would notify the
> >>> other side,
> >> if there is a
> >>>    system stall at one side.
> >>>    when the lived side receives the notification and know the other
> >>> side is
> >> reset,
> >>>    It would only recover its own rpmsg stack, wait the rpmsg "ready"
> >>> signal
> >> of the opposite side,
> >>>    then re-establish the rpmsg channels again.
> >>>    A core/Linux or M core/RTOS wouldn't do the start/stop/recovery
> >> operations on the opposite side.
> >> On STM32MP1 we have not exactly the same strategy but it only a ST
> >> design choice, implemented in our stm32 remoteproc driver. You should
> >> be able to implement your expected behavior in your the imx remoteproc
> driver.
> >>
> >> On STM32MP1 we manage the M4 preloaded firmware in this way:
> >> -  On Linux stm32 remoteproc probe:
> >>          We detect that the firmware is preloaded (early-booted filed
> >> in DT) and set the earl_boot variable.
> >>          we provide the resource table address to the remoteproc core
> >> that parses it an call the stm32_rproc_start. here we do nothing as
> >> M4 already started we just set the hold boot to freeze the M4 in case
> >> of crash
> >>
> >> - On M4 crash we have not the same strategy as your one. We consider
> >> that the M4 firmware can be corrupted and either we try to reload a
> >> firmware which as been provided by application, or we don't let it
> >> restarting (hold boot set on start).
> >>
> >> -We allow userland to stop the preloaded firmware to load and to run
> >> a new one.
> >>
> >>>
> >>> Anyway, let me do some more homework, and figure out that whether I
> >>> can fit these into the existing remoteproc framework or not.
> >> Sorry to give you homework... but seems (IMHO) possible to integrate
> >> your constraint in rpmsg/remoteproc current design.
> >>
> > [Richard Zhu] Hi Arnaud, I still can't find a way to combine this patch-set
> with the master/slave mode.
> > Regarding to my understand, almost all the defined items of the struct rproc
> is used by the master(A core/Linux) to control/manipulate the slave remote
> slave processor.
> > It's fine when the master(A core)/Slave(remote processor) mode is used.
> >
> > But it's too hard to apply the slave/master mode into this scenario.
> > - M core/RTOS insists to run and manage its resources assigned by XRDC
> standalone.
> Please could you explain the dependency between XRDC management and
> the RPMsg protocol, i don't figure out the blocking point here. So maybe i
> missed something important.
[Richard Zhu] There are access control managements in this use case.
Regarding to the security reasons or something else, the XRDC arranges the HW access control managements.
It would assign the access capabilities of the HW resources to different domains.
Thus, the HW resource required by M4 can be reserved for M4 by XRDC.
Same to A core/Linux side.
Both of them, manipulate their HW resources independently, and wouldn't have the HW conflictions.
SCFW wouldn't allow the cross-the border access.
All of this is preconfigured in SCFW, one system control firmware on top of bootloader/Linux/and RTOS.

RPMSG protocol is used to setup the communication between A core/Linux and M core/RTOS,
when the A core/Linux wants to use some HW resources under controlled by M core/RTOS.
- A core/Linux would send the RPMSG to M core/RTOS.
- Receive the results after M core/RTOS finish the execution.

> > - M core/RTOS wouldn't accept the start/stop/recover/reset operations
> issued from A core/Linux side.
> in addition with the patch
> https://eur01.safelinks.protection.outlook.com/?url=https%3A%2F%2Flkml.or
> g%2Flkml%2F2018%2F11%2F30%2F159&amp;data=02%7C01%7Chongxing.z
> hu%40nxp.com%7C532e75444add4475036208d7091e426d%7C686ea1d3bc2
> b4c6fa92cd99c5c301635%7C0%7C0%7C636987897883960797&amp;sdata=
> Ht3%2BKbdqLn%2BIFUO8Qj23ev8uFAtd9FffOGkssm1QmlQ%3D&amp;reserv
> ed=0 you can control this in your platform driver using the rproc->preloaded
> variable
> >
> > So the parallel mode is used in my proposal, both A core/Linux and M
> core/RTOS works in real independent mode. There is no slave/master in this
> implementation.
> They are independent in terms of live cycle but not in terms of communication.
> So you still need synchronization.
> For instance your implementation uses a mailbox to synchronize both
> (mailbox rdb). In existing rpmsg/virtio driver similar synchronization is done
> through a status register in the resource table plus an optional mailbox kick
> from Linux to remote processor.
> 
> In case the Cortex-M4 starts first:
> - The M4 firmware starts first (managing CAN)
> - The Linux OS starts: it just parses the resource table, creates/allocates virtio
> rings and buffers, update the vdev status flag in the resource table and kick
> the M4 via mailbox.
[Richard Zhu] The vring and buffer address are defined in the DTS files.
So, the resource table contains the clks/pwr or some other HW resources required by M4.
It seems that the resource table is not mandatory required in this scenario, because that all the HW resources are pre-assigned and managed by XRDC already.

The vdev status flag is an interesting synchronization mechanism in the resource table.

> - The M4 receive the mailbox kick, checks the vdev status and start the rpmsg
> communication.
> This is what we have implemented on STM32MP1. And we are able to re-use
> the same M4 firmware booted first (independent mode) or loaded by Linux.
> 
[Richard Zhu] Thanks a lot for your kindly clarification.

> > All the items defined in the struct rproc can't be used in this scenario.
> I would say can be ignored, but the idea is that same rproc manages both
> scenarios.
> > IMHO, this patch-set is just to setup one communication channel between A
> core and M core.
> > There are no salve remote processor instances at A core/Linux side, that can
> be controlled and manipulated by A core/Linux.
> Yes i agree with you, no need to manage the remote processor in your case.
> But the goal of remoteproc is not only the management of the remote
> processor but also the management of the shared resources (rpmsg, carveout,
> remote processor traces...). My proposal is to bypass the management of the
> remote processor live cycle using Loic's patches, but to keep the remoteproc
> part handling the associated resources to be able to probe RPMsg bus driver.
> 
[Richard Zhu] Got that, would try to follow that direction.
Thanks.

> >
> > Is it possible to add another folder(e.x parallel_proc) under
> drivers/remoteproc/ to extend the current remoteproc work mode?
> > Then, the parallel work mode can be setup in it. And the original
> master/slave mode wouldn't messed up by the parallel mode extension.
> > Please to feel free to give the comments.
> > Any comments and suggestions are appreciated.
> IMHO, That's seems to be useless, if existing solution could be adapted.
> But I'm not the maintainer... just a contributor.
> 
[Richard Zhu] Understand. Thanks. 😊

Best Regards
Richard
> 
> Best Regards
> Arnaud
> 
> >
> > Thanks in advanced.
> >
> > Best Regards
> > Richard Zhu
> >
> 
> <Snip>




[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