From: Shengjiu Wang <shengjiu.w...@nxp.com>

Audio MCLK source option is selected with a 4:1 MUX
controller using MCLK Select bits in SAI xCR2 register.

On imx6/7 mclk0 and mclk1 always point to the same clock
source. Anyhow, this is no longer true for imx8.

For this reason, we need to add mclk0 and handle it
in a generic way in SAI driver.

Signed-off-by: Shengjiu Wang <shengjiu.w...@nxp.com>
Signed-off-by: Daniel Baluta <daniel.bal...@nxp.com>
---
 arch/arm/boot/dts/imx6sx.dtsi | 6 ++++--
 arch/arm/boot/dts/imx6ul.dtsi | 9 ++++++---
 arch/arm/boot/dts/imx7s.dtsi  | 9 ++++++---
 3 files changed, 16 insertions(+), 8 deletions(-)

diff --git a/arch/arm/boot/dts/imx6sx.dtsi b/arch/arm/boot/dts/imx6sx.dtsi
index b16a123990a2..682207b5d868 100644
--- a/arch/arm/boot/dts/imx6sx.dtsi
+++ b/arch/arm/boot/dts/imx6sx.dtsi
@@ -1071,9 +1071,10 @@
                                reg = <0x021d4000 0x4000>;
                                interrupts = <GIC_SPI 97 IRQ_TYPE_LEVEL_HIGH>;
                                clocks = <&clks IMX6SX_CLK_SAI1_IPG>,
+                                        <&clks IMX6SX_CLK_SAI1>,
                                         <&clks IMX6SX_CLK_SAI1>,
                                         <&clks 0>, <&clks 0>;
-                               clock-names = "bus", "mclk1", "mclk2", "mclk3";
+                               clock-names = "bus", "mclk0", "mclk1", "mclk2", 
"mclk3";
                                dma-names = "rx", "tx";
                                dmas = <&sdma 31 24 0>, <&sdma 32 24 0>;
                                status = "disabled";
@@ -1090,9 +1091,10 @@
                                reg = <0x021dc000 0x4000>;
                                interrupts = <GIC_SPI 98 IRQ_TYPE_LEVEL_HIGH>;
                                clocks = <&clks IMX6SX_CLK_SAI2_IPG>,
+                                        <&clks IMX6SX_CLK_SAI2>,
                                         <&clks IMX6SX_CLK_SAI2>,
                                         <&clks 0>, <&clks 0>;
-                               clock-names = "bus", "mclk1", "mclk2", "mclk3";
+                               clock-names = "bus", "mclk0", "mclk1", "mclk2", 
"mclk3";
                                dma-names = "rx", "tx";
                                dmas = <&sdma 33 24 0>, <&sdma 34 24 0>;
                                status = "disabled";
diff --git a/arch/arm/boot/dts/imx6ul.dtsi b/arch/arm/boot/dts/imx6ul.dtsi
index bbf010c73336..e9691306f557 100644
--- a/arch/arm/boot/dts/imx6ul.dtsi
+++ b/arch/arm/boot/dts/imx6ul.dtsi
@@ -304,9 +304,10 @@
                                        reg = <0x02028000 0x4000>;
                                        interrupts = <GIC_SPI 97 
IRQ_TYPE_LEVEL_HIGH>;
                                        clocks = <&clks IMX6UL_CLK_SAI1_IPG>,
+                                                <&clks IMX6UL_CLK_SAI1>,
                                                 <&clks IMX6UL_CLK_SAI1>,
                                                 <&clks IMX6UL_CLK_DUMMY>, 
<&clks IMX6UL_CLK_DUMMY>;
-                                       clock-names = "bus", "mclk1", "mclk2", 
"mclk3";
+                                       clock-names = "bus", "mclk0", "mclk1", 
"mclk2", "mclk3";
                                        dmas = <&sdma 35 24 0>,
                                               <&sdma 36 24 0>;
                                        dma-names = "rx", "tx";
@@ -319,9 +320,10 @@
                                        reg = <0x0202c000 0x4000>;
                                        interrupts = <GIC_SPI 98 
IRQ_TYPE_LEVEL_HIGH>;
                                        clocks = <&clks IMX6UL_CLK_SAI2_IPG>,
+                                                <&clks IMX6UL_CLK_SAI2>,
                                                 <&clks IMX6UL_CLK_SAI2>,
                                                 <&clks IMX6UL_CLK_DUMMY>, 
<&clks IMX6UL_CLK_DUMMY>;
-                                       clock-names = "bus", "mclk1", "mclk2", 
"mclk3";
+                                       clock-names = "bus", "mclk0", "mclk1", 
"mclk2", "mclk3";
                                        dmas = <&sdma 37 24 0>,
                                               <&sdma 38 24 0>;
                                        dma-names = "rx", "tx";
@@ -334,9 +336,10 @@
                                        reg = <0x02030000 0x4000>;
                                        interrupts = <GIC_SPI 24 
IRQ_TYPE_LEVEL_HIGH>;
                                        clocks = <&clks IMX6UL_CLK_SAI3_IPG>,
+                                                <&clks IMX6UL_CLK_SAI3>,
                                                 <&clks IMX6UL_CLK_SAI3>,
                                                 <&clks IMX6UL_CLK_DUMMY>, 
<&clks IMX6UL_CLK_DUMMY>;
-                                       clock-names = "bus", "mclk1", "mclk2", 
"mclk3";
+                                       clock-names = "bus", "mclk0", "mclk1", 
"mclk2", "mclk3";
                                        dmas = <&sdma 39 24 0>,
                                               <&sdma 40 24 0>;
                                        dma-names = "rx", "tx";
diff --git a/arch/arm/boot/dts/imx7s.dtsi b/arch/arm/boot/dts/imx7s.dtsi
index 106711d2c01b..c345a2e6d824 100644
--- a/arch/arm/boot/dts/imx7s.dtsi
+++ b/arch/arm/boot/dts/imx7s.dtsi
@@ -886,10 +886,11 @@
                                        reg = <0x308a0000 0x10000>;
                                        interrupts = <GIC_SPI 95 
IRQ_TYPE_LEVEL_HIGH>;
                                        clocks = <&clks IMX7D_SAI1_IPG_CLK>,
+                                                <&clks IMX7D_SAI1_ROOT_CLK>,
                                                 <&clks IMX7D_SAI1_ROOT_CLK>,
                                                 <&clks IMX7D_CLK_DUMMY>,
                                                 <&clks IMX7D_CLK_DUMMY>;
-                                       clock-names = "bus", "mclk1", "mclk2", 
"mclk3";
+                                       clock-names = "bus", "mclk0", "mclk1", 
"mclk2", "mclk3";
                                        dma-names = "rx", "tx";
                                        dmas = <&sdma 8 24 0>, <&sdma 9 24 0>;
                                        status = "disabled";
@@ -901,10 +902,11 @@
                                        reg = <0x308b0000 0x10000>;
                                        interrupts = <GIC_SPI 96 
IRQ_TYPE_LEVEL_HIGH>;
                                        clocks = <&clks IMX7D_SAI2_IPG_CLK>,
+                                                <&clks IMX7D_SAI2_ROOT_CLK>,
                                                 <&clks IMX7D_SAI2_ROOT_CLK>,
                                                 <&clks IMX7D_CLK_DUMMY>,
                                                 <&clks IMX7D_CLK_DUMMY>;
-                                       clock-names = "bus", "mclk1", "mclk2", 
"mclk3";
+                                       clock-names = "bus", "mclk0", "mclk1", 
"mclk2", "mclk3";
                                        dma-names = "rx", "tx";
                                        dmas = <&sdma 10 24 0>, <&sdma 11 24 0>;
                                        status = "disabled";
@@ -916,10 +918,11 @@
                                        reg = <0x308c0000 0x10000>;
                                        interrupts = <GIC_SPI 50 
IRQ_TYPE_LEVEL_HIGH>;
                                        clocks = <&clks IMX7D_SAI3_IPG_CLK>,
+                                                <&clks IMX7D_SAI3_ROOT_CLK>,
                                                 <&clks IMX7D_SAI3_ROOT_CLK>,
                                                 <&clks IMX7D_CLK_DUMMY>,
                                                 <&clks IMX7D_CLK_DUMMY>;
-                                       clock-names = "bus", "mclk1", "mclk2", 
"mclk3";
+                                       clock-names = "bus", "mclk0", "mclk1", 
"mclk2", "mclk3";
                                        dma-names = "rx", "tx";
                                        dmas = <&sdma 12 24 0>, <&sdma 13 24 0>;
                                        status = "disabled";
-- 
2.17.1

Reply via email to