Re: [STLinux Kernel] [PATCH 4/5] remoteproc: core: Supply framework to request, declare and fetch shared memory

From: loic pallardy
Date: Tue Jun 21 2016 - 03:34:21 EST




On 06/16/2016 12:06 AM, Bjorn Andersson wrote:
On Thu 05 May 06:29 PDT 2016, Lee Jones wrote:

Normally used for management of; carveout, devmem and trace memory.

Signed-off-by: Lee Jones <lee.jones@xxxxxxxxxx>
---
drivers/remoteproc/remoteproc_core.c | 174 +++++++++++++++++++++++++++++++++--
1 file changed, 167 insertions(+), 7 deletions(-)

[..]
+}
+EXPORT_SYMBOL(rproc_subdev_add);

Hi Bjorn,

I worked up a prototype that allows remoteproc drivers to
programmatically specify carveout resources, which then are matched and
merged with entires from the resource table. I've given these
programmatically allocated carveouts a device so that the associated
allocation comes out of the specified region - or the rproc region if no
match is found.

No sure to catch your exact use case, but let me try to explain what we have today.
There are different rproc in ST. Some request a large chunk of memory for code and data, some have several dedicated memories like IRAM and DRAM.
In that case carevout memories are defined as subdev (like vrings).
Association is done thanks to carevout name in firmware resource table (in rproc_handle_carveout).

Moreover, as our coprocessors have no iommu, we add some check on allocated buffer to verify it fit with resource table declaration (pa).
This allows to guarantee complete alignment between resources needed by firmware and ones allocated by Linux kernel.

This solves my use case of carving out memory from two disjoint memory
regions for one of my remoteprocs, but differs from your approach in
that you specify one large carveout (and vrings) region and any
carveouts (or vrings) will chip away from this.

Would this approach work for you, or do you depend on having 1:N
relationship between your memory region and your resources?


Is this approach covering your needs?

Regards,
Loic

Regards,
Bjorn

_______________________________________________
Kernel mailing list
Kernel@xxxxxxxxxxx
http://www.stlinux.com/mailman/listinfo/kernel