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 1c9e0d5..b99a273 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 {