On 08/05/13 21:26, Marek Szyprowski wrote:
Hello,
Hi,
This patch series are an attempt to cleanup the reserved memory device
tree bindings for MFC device. MFC device has two memory ports (AXI
masters), which are used to do DMA. Usually separate memory regions are
being defined for each of those memory ports to improve performance.
Some versions of MFC block have also significant limitation on the
possible address range available for each of those memory ports/banks.
In the board file era, there have been two additional platform devices
defined for each of memory ports (named "s5p-mfc-l" and "s5p-mfc-r") to
let the driver distinguish memory allocations done for each of them.
Each of those platform devices might have special DMA ops assigned to
fulfil specific memory requirements for a given memory port.
Later, when device tree binding was added for MFC device, those memory
ports were designed as two additional properties: "samsung,mfc-l" and
"samsung,mfc-r" for codec node. This approach however has some
significant limitation, so I propose to redesign it before the binding
become considered as stable.
The first problem with the proposed bindings is the fact that
"samsung,mfc-r"/"samsung,mfc-l" properties are tied only to "base
address + size" attributes of reserved memory and do not allow to assign
any other attributes to those memory ports. This limits using those
memory ports only to simple reserved memory.
The second issue with those attributes is the fact that they are very
specific to the MFC device, while reserved memory region is something
more generic, which can be used for other devices as well. For example
even on Exynos4 platform, similar reserved memory handling will be
needed for the FIMC ISP device.
For handling reserved memory regions and having a method to assign them
to particular device I have posted the patches [1], which add device
tree support to Contiguous Memory Allocator and simple reserved memory
allocator based on dma_declare_coherent() function.
This patch series is my proposal for replacing those custom bindings
with generic approach, proposed in [1]. To get it working we need
separate device node for each memory port, what has been achieved by
adding "simple-bus" compatibility entry to the main MFC device node and
adding two child nodes, which represent each memory port. Those child
nodes have compatible property set to "samsung,memport".
With such a structure "dma-memory-region" property with a phandle to
respective reserved region can be easily added to the child nodes of MFC
device. The advantage of such approach is the fact that those child
nodes can be also used for adding properties for IOMMU (SYSMMU)
controllers. This way also bindings for SYSMMU and the code, which
handles it can be simplified, because respective device tree part better
matches physical hardware design.
Best regards
Marek Szyprowski
Samsung R&D Institute Poland
[1] http://thread.gmane.org/gmane.linux.ports.arm.kernel/257615/
Patch summary:
Marek Szyprowski (2):
ARM: Exynos: replace custom MFC reserved memory handling with generic
code
media: s5p-mfc: remove DT hacks and simplify initialization code
.../devicetree/bindings/media/s5p-mfc.txt | 63 +++++++++++++---
arch/arm/boot/dts/exynos4.dtsi | 10 ++-
arch/arm/boot/dts/exynos4210-origen.dts | 25 ++++++-
arch/arm/boot/dts/exynos4210-smdkv310.dts | 25 ++++++-
arch/arm/boot/dts/exynos4412-origen.dts | 25 ++++++-
arch/arm/boot/dts/exynos4412-smdk4412.dts | 25 ++++++-
arch/arm/boot/dts/exynos5250-arndale.dts | 26 ++++++-
arch/arm/boot/dts/exynos5250-smdk5250.dts | 26 ++++++-
arch/arm/boot/dts/exynos5250.dtsi | 10 ++-
arch/arm/mach-exynos/mach-exynos4-dt.c | 16 -----
arch/arm/mach-exynos/mach-exynos5-dt.c | 17 -----
arch/arm/plat-samsung/include/plat/mfc.h | 11 ---
arch/arm/plat-samsung/s5p-dev-mfc.c | 32 ---------
drivers/media/platform/s5p-mfc/s5p_mfc.c | 75 ++++----------------
14 files changed, 227 insertions(+), 159 deletions(-)
Nice cleanup MFC dt bindings, BTW, IMHO, how about keeping the reserved
memory in exynos4.dtsi instead of adding them in each board dts files,
it depends on board though...
Kamil, if you're OK on the 2nd patch, please let me know so that this
could be merged into samsung tree for v3.12..
Thanks,
Kukjin
--
To unsubscribe from this list: send the line "unsubscribe linux-media" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html