On 7/15/19 10:22 AM, Richard Zhu wrote:
<snip>
sg693v6UjM%2BFEk7TYHxgg6RDX611%2FKfjqA%3D&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.
- M core/RTOS wouldn't accept the start/stop/recover/reset operations issued from A core/Linux side.
in addition with the patch https://lkml.org/lkml/2018/11/30/159 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.
- 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.
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.
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.
Best Regards
Arnaud
Thanks in advanced.
Best Regards
Richard Zhu
<Snip>