]> git.karo-electronics.de Git - karo-tx-linux.git/commitdiff
arm64: dts: mt8173: Fix mdp device tree
authorDaniel Kurtz <djkurtz@chromium.org>
Tue, 23 May 2017 03:24:10 +0000 (11:24 +0800)
committerMatthias Brugger <matthias.bgg@gmail.com>
Thu, 8 Jun 2017 13:19:04 +0000 (15:19 +0200)
If the mdp_* nodes are under an mdp sub-node, their corresponding
platform device does not automatically get its iommu assigned properly.

Fix this by moving the mdp component nodes up a level such that they are
siblings of mdp and all other SoC subsystems.  This also simplifies the
device tree.

Although it fixes iommu assignment issue, it also break compatibility
with old device tree. So, the patch in driver is needed to iterate over
sibling mdp device nodes, not child ones, to keep driver work properly.

Signed-off-by: Daniel Kurtz <djkurtz@chromium.org>
Signed-off-by: Minghsiu Tsai <minghsiu.tsai@mediatek.com>
Acked-by: Hans Verkuil <hans.verkuil@cisco.com>
Signed-off-by: Matthias Brugger <matthias.bgg@gmail.com>
arch/arm64/boot/dts/mediatek/mt8173.dtsi

index 1c9e0d54b89fc42131f5d2b5a1aefda9b97173e5..b99a27372965ec82473112094d302a5a3e596092 100644 (file)
                        #clock-cells = <1>;
                };
 
-               mdp {
-                       compatible = "mediatek,mt8173-mdp";
-                       #address-cells = <2>;
-                       #size-cells = <2>;
-                       ranges;
+               mdp_rdma0: rdma@14001000 {
+                       compatible = "mediatek,mt8173-mdp-rdma",
+                                    "mediatek,mt8173-mdp";
+                       reg = <0 0x14001000 0 0x1000>;
+                       clocks = <&mmsys CLK_MM_MDP_RDMA0>,
+                                <&mmsys CLK_MM_MUTEX_32K>;
+                       power-domains = <&scpsys MT8173_POWER_DOMAIN_MM>;
+                       iommus = <&iommu M4U_PORT_MDP_RDMA0>;
+                       mediatek,larb = <&larb0>;
                        mediatek,vpu = <&vpu>;
+               };
 
-                       mdp_rdma0: rdma@14001000 {
-                               compatible = "mediatek,mt8173-mdp-rdma";
-                               reg = <0 0x14001000 0 0x1000>;
-                               clocks = <&mmsys CLK_MM_MDP_RDMA0>,
-                                        <&mmsys CLK_MM_MUTEX_32K>;
-                               power-domains = <&scpsys MT8173_POWER_DOMAIN_MM>;
-                               iommus = <&iommu M4U_PORT_MDP_RDMA0>;
-                               mediatek,larb = <&larb0>;
-                       };
-
-                       mdp_rdma1: rdma@14002000 {
-                               compatible = "mediatek,mt8173-mdp-rdma";
-                               reg = <0 0x14002000 0 0x1000>;
-                               clocks = <&mmsys CLK_MM_MDP_RDMA1>,
-                                        <&mmsys CLK_MM_MUTEX_32K>;
-                               power-domains = <&scpsys MT8173_POWER_DOMAIN_MM>;
-                               iommus = <&iommu M4U_PORT_MDP_RDMA1>;
-                               mediatek,larb = <&larb4>;
-                       };
+               mdp_rdma1: rdma@14002000 {
+                       compatible = "mediatek,mt8173-mdp-rdma";
+                       reg = <0 0x14002000 0 0x1000>;
+                       clocks = <&mmsys CLK_MM_MDP_RDMA1>,
+                                <&mmsys CLK_MM_MUTEX_32K>;
+                       power-domains = <&scpsys MT8173_POWER_DOMAIN_MM>;
+                       iommus = <&iommu M4U_PORT_MDP_RDMA1>;
+                       mediatek,larb = <&larb4>;
+               };
 
-                       mdp_rsz0: rsz@14003000 {
-                               compatible = "mediatek,mt8173-mdp-rsz";
-                               reg = <0 0x14003000 0 0x1000>;
-                               clocks = <&mmsys CLK_MM_MDP_RSZ0>;
-                               power-domains = <&scpsys MT8173_POWER_DOMAIN_MM>;
-                       };
+               mdp_rsz0: rsz@14003000 {
+                       compatible = "mediatek,mt8173-mdp-rsz";
+                       reg = <0 0x14003000 0 0x1000>;
+                       clocks = <&mmsys CLK_MM_MDP_RSZ0>;
+                       power-domains = <&scpsys MT8173_POWER_DOMAIN_MM>;
+               };
 
-                       mdp_rsz1: rsz@14004000 {
-                               compatible = "mediatek,mt8173-mdp-rsz";
-                               reg = <0 0x14004000 0 0x1000>;
-                               clocks = <&mmsys CLK_MM_MDP_RSZ1>;
-                               power-domains = <&scpsys MT8173_POWER_DOMAIN_MM>;
-                       };
+               mdp_rsz1: rsz@14004000 {
+                       compatible = "mediatek,mt8173-mdp-rsz";
+                       reg = <0 0x14004000 0 0x1000>;
+                       clocks = <&mmsys CLK_MM_MDP_RSZ1>;
+                       power-domains = <&scpsys MT8173_POWER_DOMAIN_MM>;
+               };
 
-                       mdp_rsz2: rsz@14005000 {
-                               compatible = "mediatek,mt8173-mdp-rsz";
-                               reg = <0 0x14005000 0 0x1000>;
-                               clocks = <&mmsys CLK_MM_MDP_RSZ2>;
-                               power-domains = <&scpsys MT8173_POWER_DOMAIN_MM>;
-                       };
+               mdp_rsz2: rsz@14005000 {
+                       compatible = "mediatek,mt8173-mdp-rsz";
+                       reg = <0 0x14005000 0 0x1000>;
+                       clocks = <&mmsys CLK_MM_MDP_RSZ2>;
+                       power-domains = <&scpsys MT8173_POWER_DOMAIN_MM>;
+               };
 
-                       mdp_wdma0: wdma@14006000 {
-                               compatible = "mediatek,mt8173-mdp-wdma";
-                               reg = <0 0x14006000 0 0x1000>;
-                               clocks = <&mmsys CLK_MM_MDP_WDMA>;
-                               power-domains = <&scpsys MT8173_POWER_DOMAIN_MM>;
-                               iommus = <&iommu M4U_PORT_MDP_WDMA>;
-                               mediatek,larb = <&larb0>;
-                       };
+               mdp_wdma0: wdma@14006000 {
+                       compatible = "mediatek,mt8173-mdp-wdma";
+                       reg = <0 0x14006000 0 0x1000>;
+                       clocks = <&mmsys CLK_MM_MDP_WDMA>;
+                       power-domains = <&scpsys MT8173_POWER_DOMAIN_MM>;
+                       iommus = <&iommu M4U_PORT_MDP_WDMA>;
+                       mediatek,larb = <&larb0>;
+               };
 
-                       mdp_wrot0: wrot@14007000 {
-                               compatible = "mediatek,mt8173-mdp-wrot";
-                               reg = <0 0x14007000 0 0x1000>;
-                               clocks = <&mmsys CLK_MM_MDP_WROT0>;
-                               power-domains = <&scpsys MT8173_POWER_DOMAIN_MM>;
-                               iommus = <&iommu M4U_PORT_MDP_WROT0>;
-                               mediatek,larb = <&larb0>;
-                       };
+               mdp_wrot0: wrot@14007000 {
+                       compatible = "mediatek,mt8173-mdp-wrot";
+                       reg = <0 0x14007000 0 0x1000>;
+                       clocks = <&mmsys CLK_MM_MDP_WROT0>;
+                       power-domains = <&scpsys MT8173_POWER_DOMAIN_MM>;
+                       iommus = <&iommu M4U_PORT_MDP_WROT0>;
+                       mediatek,larb = <&larb0>;
+               };
 
-                       mdp_wrot1: wrot@14008000 {
-                               compatible = "mediatek,mt8173-mdp-wrot";
-                               reg = <0 0x14008000 0 0x1000>;
-                               clocks = <&mmsys CLK_MM_MDP_WROT1>;
-                               power-domains = <&scpsys MT8173_POWER_DOMAIN_MM>;
-                               iommus = <&iommu M4U_PORT_MDP_WROT1>;
-                               mediatek,larb = <&larb4>;
-                       };
+               mdp_wrot1: wrot@14008000 {
+                       compatible = "mediatek,mt8173-mdp-wrot";
+                       reg = <0 0x14008000 0 0x1000>;
+                       clocks = <&mmsys CLK_MM_MDP_WROT1>;
+                       power-domains = <&scpsys MT8173_POWER_DOMAIN_MM>;
+                       iommus = <&iommu M4U_PORT_MDP_WROT1>;
+                       mediatek,larb = <&larb4>;
                };
 
                ovl0: ovl@1400c000 {