Commit f72b544a authored by Frank Li's avatar Frank Li Committed by Shawn Guo

arm64: dts: imx8-ss-dma: fix spi lpcg indices

spi0_lpcg: clock-controller@5a400000 {
	...                                                  Col0   Col1
	clocks = <&clk IMX_SC_R_SPI_0 IMX_SC_PM_CLK_PER>,//   0      1
		 <&dma_ipg_clk>;                         //   1      4
	clock-indices = <IMX_LPCG_CLK_0>, <IMX_LPCG_CLK_4>;
};

Col1: index, which existing dts try to get.
Col2: actual index in lpcg driver.

lpspi0: spi@5a000000 {
	...
	clocks = <&spi0_lpcg 0>, <&spi0_lpcg 1>;
			     ^		     ^
Should be:
	clocks = <&spi0_lpcg IMX_LPCG_CLK_0>, <&spi0_lpcg IMX_LPCG_CLK_4>;
};

Arg0 is divided by 4 in lpcg driver. <&spi0_lpcg 0> and <&spi0_lpcg 1> are
IMX_SC_PM_CLK_PER. Although code can work, code logic is wrong. It should
use IMX_LPCG_CLK_0 and IMX_LPCG_CLK_4 for lpcg arg0.

Cc: stable@vger.kernel.org
Fixes: c4098885 ("arm64: dts: imx8dxl: add lpspi support")
Signed-off-by: default avatarFrank Li <Frank.Li@nxp.com>
Signed-off-by: default avatarShawn Guo <shawnguo@kernel.org>
parent 808e7716
...@@ -28,8 +28,8 @@ lpspi0: spi@5a000000 { ...@@ -28,8 +28,8 @@ lpspi0: spi@5a000000 {
#size-cells = <0>; #size-cells = <0>;
interrupts = <GIC_SPI 336 IRQ_TYPE_LEVEL_HIGH>; interrupts = <GIC_SPI 336 IRQ_TYPE_LEVEL_HIGH>;
interrupt-parent = <&gic>; interrupt-parent = <&gic>;
clocks = <&spi0_lpcg 0>, clocks = <&spi0_lpcg IMX_LPCG_CLK_0>,
<&spi0_lpcg 1>; <&spi0_lpcg IMX_LPCG_CLK_4>;
clock-names = "per", "ipg"; clock-names = "per", "ipg";
assigned-clocks = <&clk IMX_SC_R_SPI_0 IMX_SC_PM_CLK_PER>; assigned-clocks = <&clk IMX_SC_R_SPI_0 IMX_SC_PM_CLK_PER>;
assigned-clock-rates = <60000000>; assigned-clock-rates = <60000000>;
...@@ -44,8 +44,8 @@ lpspi1: spi@5a010000 { ...@@ -44,8 +44,8 @@ lpspi1: spi@5a010000 {
#size-cells = <0>; #size-cells = <0>;
interrupts = <GIC_SPI 337 IRQ_TYPE_LEVEL_HIGH>; interrupts = <GIC_SPI 337 IRQ_TYPE_LEVEL_HIGH>;
interrupt-parent = <&gic>; interrupt-parent = <&gic>;
clocks = <&spi1_lpcg 0>, clocks = <&spi1_lpcg IMX_LPCG_CLK_0>,
<&spi1_lpcg 1>; <&spi1_lpcg IMX_LPCG_CLK_4>;
clock-names = "per", "ipg"; clock-names = "per", "ipg";
assigned-clocks = <&clk IMX_SC_R_SPI_1 IMX_SC_PM_CLK_PER>; assigned-clocks = <&clk IMX_SC_R_SPI_1 IMX_SC_PM_CLK_PER>;
assigned-clock-rates = <60000000>; assigned-clock-rates = <60000000>;
...@@ -60,8 +60,8 @@ lpspi2: spi@5a020000 { ...@@ -60,8 +60,8 @@ lpspi2: spi@5a020000 {
#size-cells = <0>; #size-cells = <0>;
interrupts = <GIC_SPI 338 IRQ_TYPE_LEVEL_HIGH>; interrupts = <GIC_SPI 338 IRQ_TYPE_LEVEL_HIGH>;
interrupt-parent = <&gic>; interrupt-parent = <&gic>;
clocks = <&spi2_lpcg 0>, clocks = <&spi2_lpcg IMX_LPCG_CLK_0>,
<&spi2_lpcg 1>; <&spi2_lpcg IMX_LPCG_CLK_4>;
clock-names = "per", "ipg"; clock-names = "per", "ipg";
assigned-clocks = <&clk IMX_SC_R_SPI_2 IMX_SC_PM_CLK_PER>; assigned-clocks = <&clk IMX_SC_R_SPI_2 IMX_SC_PM_CLK_PER>;
assigned-clock-rates = <60000000>; assigned-clock-rates = <60000000>;
...@@ -76,8 +76,8 @@ lpspi3: spi@5a030000 { ...@@ -76,8 +76,8 @@ lpspi3: spi@5a030000 {
#size-cells = <0>; #size-cells = <0>;
interrupts = <GIC_SPI 339 IRQ_TYPE_LEVEL_HIGH>; interrupts = <GIC_SPI 339 IRQ_TYPE_LEVEL_HIGH>;
interrupt-parent = <&gic>; interrupt-parent = <&gic>;
clocks = <&spi3_lpcg 0>, clocks = <&spi3_lpcg IMX_LPCG_CLK_0>,
<&spi3_lpcg 1>; <&spi3_lpcg IMX_LPCG_CLK_4>;
clock-names = "per", "ipg"; clock-names = "per", "ipg";
assigned-clocks = <&clk IMX_SC_R_SPI_3 IMX_SC_PM_CLK_PER>; assigned-clocks = <&clk IMX_SC_R_SPI_3 IMX_SC_PM_CLK_PER>;
assigned-clock-rates = <60000000>; assigned-clock-rates = <60000000>;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment