* [PATCH 0/2] Rockchip RK3588 fixes
@ 2023-12-05 7:27 Sascha Hauer
2023-12-05 7:27 ` [PATCH 1/2] ARM: rockchip: rk3588: Use upstream dts files Sascha Hauer
2023-12-05 7:27 ` [PATCH 2/2] ARM: rockchip: rock-5a: Disable non working devices Sascha Hauer
0 siblings, 2 replies; 3+ messages in thread
From: Sascha Hauer @ 2023-12-05 7:27 UTC (permalink / raw)
To: Barebox List
The RK3588 upstream dtsi files have evolved a lot. This series fixes the
worst regressions caused by this. We switch to use upstream dtsi files
and drop the downstream variants containing the PCI and SDMMC nodes. We
still have to overwrite the ranges property for the pcie2x1l2 node, I do
not yet understand what the Linux PCI driver makes different to work
with the Linux ranges properties. With this at least the PCI ethernet
controller works again. We disable some other PCI and USB nodes which
otherwise throw annoying warning messages due to missing phys.
Sascha Hauer (2):
ARM: rockchip: rk3588: Use upstream dts files
ARM: rockchip: rock-5a: Disable non working devices
arch/arm/dts/rk3588-rock-5b.dts | 39 +++++
arch/arm/dts/rk3588.dtsi | 145 ------------------
arch/arm/dts/rk3588s.dtsi | 126 +--------------
.../rockchip/phy-rockchip-naneng-combphy.c | 8 +-
4 files changed, 44 insertions(+), 274 deletions(-)
--
2.39.2
^ permalink raw reply [flat|nested] 3+ messages in thread
* [PATCH 1/2] ARM: rockchip: rk3588: Use upstream dts files
2023-12-05 7:27 [PATCH 0/2] Rockchip RK3588 fixes Sascha Hauer
@ 2023-12-05 7:27 ` Sascha Hauer
2023-12-05 7:27 ` [PATCH 2/2] ARM: rockchip: rock-5a: Disable non working devices Sascha Hauer
1 sibling, 0 replies; 3+ messages in thread
From: Sascha Hauer @ 2023-12-05 7:27 UTC (permalink / raw)
To: Barebox List
We have downstream rk3588 dtsi files containing the PCI controllers
and also the SDMMC controller. Use the now existing upstream nodes
instead.
Signed-off-by: Sascha Hauer <s.hauer@pengutronix.de>
---
arch/arm/dts/rk3588.dtsi | 145 ------------------
arch/arm/dts/rk3588s.dtsi | 126 +--------------
.../rockchip/phy-rockchip-naneng-combphy.c | 8 +-
3 files changed, 5 insertions(+), 274 deletions(-)
diff --git a/arch/arm/dts/rk3588.dtsi b/arch/arm/dts/rk3588.dtsi
index 28bcb2f643..0aef30eaff 100644
--- a/arch/arm/dts/rk3588.dtsi
+++ b/arch/arm/dts/rk3588.dtsi
@@ -4,149 +4,4 @@
#include "rk3588s.dtsi"
/ {
- pcie30_phy_grf: syscon@fd5b8000 {
- compatible = "rockchip,pcie30-phy-grf", "syscon";
- reg = <0x0 0xfd5b8000 0x0 0x10000>;
- };
-
- pipe_phy0_grf: syscon@fd5bc000 {
- compatible = "rockchip,pipe-phy-grf", "syscon";
- reg = <0x0 0xfd5bc000 0x0 0x100>;
- };
-
- pipe_phy1_grf: syscon@fd5c0000 {
- compatible = "rockchip,pipe-phy-grf", "syscon";
- reg = <0x0 0xfd5c0000 0x0 0x100>;
- };
-
- pcie3x4: pcie@fe150000 {
- compatible = "rockchip,rk3588-pcie", "snps,dw-pcie";
- #address-cells = <3>;
- #size-cells = <2>;
- bus-range = <0x00 0x0f>;
- clocks = <&cru ACLK_PCIE_4L_MSTR>, <&cru ACLK_PCIE_4L_SLV>,
- <&cru ACLK_PCIE_4L_DBI>, <&cru PCLK_PCIE_4L>,
- <&cru CLK_PCIE_AUX0>, <&cru CLK_PCIE4L_PIPE>;
- clock-names = "aclk_mst", "aclk_slv",
- "aclk_dbi", "pclk",
- "aux", "pipe";
- device_type = "pci";
- linux,pci-domain = <0>;
- num-ib-windows = <16>;
- num-ob-windows = <16>;
- num-viewport = <8>;
- max-link-speed = <3>;
- num-lanes = <4>;
- phys = <&pcie30phy>;
- phy-names = "pcie-phy";
- power-domains = <&power RK3588_PD_PCIE>;
- ranges = <0x81000000 0x0 0xf0100000 0x0 0xf0100000 0x0 0x100000
- 0x82000000 0x0 0xf0200000 0x0 0xf0200000 0x0 0xe00000
- 0xc3000000 0x9 0x00000000 0x9 0x00000000 0x0 0x40000000>;
- reg = <0x0 0xfe150000 0x0 0x10000>,
- <0xa 0x40000000 0x0 0x400000>,
- <0x0 0xf0000000 0x0 0x100000>;
- reg-names = "apb", "dbi", "config";
- resets = <&cru SRST_PCIE0_POWER_UP>, <&cru SRST_P_PCIE0>;
- reset-names = "pcie", "periph";
- rockchip,pipe-grf = <&php_grf>;
- status = "disabled";
- };
-
- pcie3x2: pcie@fe160000 {
- compatible = "rockchip,rk3588-pcie", "snps,dw-pcie";
- #address-cells = <3>;
- #size-cells = <2>;
- bus-range = <0x10 0x1f>;
- clocks = <&cru ACLK_PCIE_2L_MSTR>, <&cru ACLK_PCIE_2L_SLV>,
- <&cru ACLK_PCIE_2L_DBI>, <&cru PCLK_PCIE_2L>,
- <&cru CLK_PCIE_AUX1>, <&cru CLK_PCIE2L_PIPE>;
- clock-names = "aclk_mst", "aclk_slv",
- "aclk_dbi", "pclk",
- "aux", "pipe";
- device_type = "pci";
- linux,pci-domain = <1>;
- num-ib-windows = <16>;
- num-ob-windows = <16>;
- num-viewport = <8>;
- max-link-speed = <3>;
- num-lanes = <2>;
- phys = <&pcie30phy>;
- phy-names = "pcie-phy";
- power-domains = <&power RK3588_PD_PCIE>;
- ranges = <0x81000000 0x0 0xf1100000 0x0 0xf1100000 0x0 0x100000
- 0x82000000 0x0 0xf1200000 0x0 0xf1200000 0x0 0xe00000
- 0xc3000000 0x9 0x40000000 0x9 0x40000000 0x0 0x40000000>;
- reg = <0x0 0xfe160000 0x0 0x10000>,
- <0xa 0x40400000 0x0 0x400000>,
- <0x0 0xf1000000 0x0 0x100000>;
- reg-names = "apb", "dbi", "config";
- resets = <&cru SRST_PCIE1_POWER_UP>, <&cru SRST_P_PCIE1>;
- reset-names = "pcie", "periph";
- rockchip,pipe-grf = <&php_grf>;
- status = "disabled";
- };
-
- pcie2x1l0: pcie@fe170000 {
- compatible = "rockchip,rk3588-pcie", "snps,dw-pcie";
- #address-cells = <3>;
- #size-cells = <2>;
- bus-range = <0x20 0x2f>;
- clocks = <&cru ACLK_PCIE_1L0_MSTR>, <&cru ACLK_PCIE_1L0_SLV>,
- <&cru ACLK_PCIE_1L0_DBI>, <&cru PCLK_PCIE_1L0>,
- <&cru CLK_PCIE_AUX2>, <&cru CLK_PCIE1L0_PIPE>;
- clock-names = "aclk_mst", "aclk_slv",
- "aclk_dbi", "pclk",
- "aux", "pipe";
- device_type = "pci";
- linux,pci-domain = <2>;
- num-ib-windows = <8>;
- num-ob-windows = <8>;
- num-viewport = <4>;
- max-link-speed = <2>;
- num-lanes = <1>;
- phys = <&combphy1_ps PHY_TYPE_PCIE>;
- phy-names = "pcie-phy";
- ranges = <0x81000000 0x0 0xf2100000 0x0 0xf2100000 0x0 0x100000
- 0x82000000 0x0 0xf2200000 0x0 0xf2200000 0x0 0xe00000
- 0xc3000000 0x9 0x80000000 0x9 0x80000000 0x0 0x40000000>;
- reg = <0x0 0xfe170000 0x0 0x10000>,
- <0xa 0x40800000 0x0 0x400000>,
- <0x0 0xf2000000 0x0 0x100000>;
- reg-names = "apb", "dbi", "config";
- resets = <&cru SRST_PCIE2_POWER_UP>, <&cru SRST_P_PCIE2>;
- reset-names = "pcie", "periph";
- rockchip,pipe-grf = <&php_grf>;
- status = "disabled";
- };
-
- combphy1_ps: phy@fee10000 {
- compatible = "rockchip,rk3588-naneng-combphy";
- reg = <0x0 0xfee10000 0x0 0x100>;
- #phy-cells = <1>;
- clocks = <&cru CLK_REF_PIPE_PHY1>, <&cru PCLK_PCIE_COMBO_PIPE_PHY1>,
- <&cru PCLK_PHP_ROOT>;
- clock-names = "refclk", "apbclk", "phpclk";
- assigned-clocks = <&cru CLK_REF_PIPE_PHY1>;
- assigned-clock-rates = <100000000>;
- resets = <&cru SRST_P_PCIE2_PHY1>, <&cru SRST_REF_PIPE_PHY1>;
- reset-names = "combphy-apb", "combphy";
- rockchip,pipe-grf = <&php_grf>;
- rockchip,pipe-phy-grf = <&pipe_phy1_grf>;
- rockchip,pcie1ln-sel-bits = <0x100 0 0 0>;
- status = "disabled";
- };
-
- pcie30phy: phy@fee80000 {
- compatible = "rockchip,rk3588-pcie3-phy";
- reg = <0x0 0xfee80000 0x0 0x20000>;
- #phy-cells = <0>;
- clocks = <&cru PCLK_PCIE_COMBO_PIPE_PHY>;
- clock-names = "pclk";
- resets = <&cru SRST_PCIE30_PHY>;
- reset-names = "phy";
- rockchip,pipe-grf = <&php_grf>;
- rockchip,phy-grf = <&pcie30_phy_grf>;
- status = "disabled";
- };
};
diff --git a/arch/arm/dts/rk3588s.dtsi b/arch/arm/dts/rk3588s.dtsi
index 6f055d826e..6572588ad6 100644
--- a/arch/arm/dts/rk3588s.dtsi
+++ b/arch/arm/dts/rk3588s.dtsi
@@ -1,131 +1,7 @@
/ {
dmc: memory-controller {
compatible = "rockchip,rk3588-dmc";
- rockchip,pmu = <&pmugrf>;
- };
-
- pmugrf: syscon@fd58a000 {
- compatible = "rockchip,rk3588-pmugrf", "syscon", "simple-mfd";
- reg = <0x0 0xfd58a000 0x0 0x10000>;
- };
-
- pipe_phy2_grf: syscon@fd5c4000 {
- compatible = "rockchip,pipe-phy-grf", "syscon";
- reg = <0x0 0xfd5c4000 0x0 0x100>;
- };
-
- pcie2x1l1: pcie@fe180000 {
- compatible = "rockchip,rk3588-pcie", "snps,dw-pcie";
- #address-cells = <3>;
- #size-cells = <2>;
- bus-range = <0x30 0x3f>;
- clocks = <&cru ACLK_PCIE_1L1_MSTR>, <&cru ACLK_PCIE_1L1_SLV>,
- <&cru ACLK_PCIE_1L1_DBI>, <&cru PCLK_PCIE_1L1>,
- <&cru CLK_PCIE_AUX3>, <&cru CLK_PCIE1L1_PIPE>;
- clock-names = "aclk_mst", "aclk_slv",
- "aclk_dbi", "pclk",
- "aux", "pipe";
- device_type = "pci";
- linux,pci-domain = <3>;
- num-ib-windows = <8>;
- num-ob-windows = <8>;
- num-viewport = <4>;
- max-link-speed = <2>;
- num-lanes = <1>;
- phys = <&combphy2_psu PHY_TYPE_PCIE>;
- phy-names = "pcie-phy";
- ranges = <0x81000000 0x0 0xf3100000 0x0 0xf3100000 0x0 0x100000
- 0x82000000 0x0 0xf3200000 0x0 0xf3200000 0x0 0xe00000
- 0xc3000000 0x9 0xc0000000 0x9 0xc0000000 0x0 0x40000000>;
- reg = <0x0 0xfe180000 0x0 0x10000>,
- <0xa 0x40c00000 0x0 0x400000>,
- <0x0 0xf3000000 0x0 0x100000>;
- reg-names = "apb", "dbi", "config";
- resets = <&cru SRST_PCIE3_POWER_UP>, <&cru SRST_P_PCIE3>;
- reset-names = "pcie", "periph";
- rockchip,pipe-grf = <&php_grf>;
- status = "disabled";
- };
-
- pcie2x1l2: pcie@fe190000 {
- compatible = "rockchip,rk3588-pcie", "snps,dw-pcie";
- #address-cells = <3>;
- #size-cells = <2>;
- bus-range = <0x40 0x4f>;
- clocks = <&cru ACLK_PCIE_1L2_MSTR>, <&cru ACLK_PCIE_1L2_SLV>,
- <&cru ACLK_PCIE_1L2_DBI>, <&cru PCLK_PCIE_1L2>,
- <&cru CLK_PCIE_AUX4>, <&cru CLK_PCIE1L2_PIPE>;
- clock-names = "aclk_mst", "aclk_slv",
- "aclk_dbi", "pclk",
- "aux", "pipe";
- device_type = "pci";
- linux,pci-domain = <4>;
- num-ib-windows = <8>;
- num-ob-windows = <8>;
- num-viewport = <4>;
- max-link-speed = <2>;
- num-lanes = <1>;
- phys = <&combphy0_ps PHY_TYPE_PCIE>;
- phy-names = "pcie-phy";
- ranges = <0x81000000 0x0 0xf4100000 0x0 0xf4100000 0x0 0x100000
- 0x82000000 0x0 0xf4200000 0x0 0xf4200000 0x0 0xe00000
- 0xc3000000 0xa 0x00000000 0xa 0x00000000 0x0 0x40000000>;
- reg = <0x0 0xfe190000 0x0 0x10000>,
- <0xa 0x41000000 0x0 0x400000>,
- <0x0 0xf4000000 0x0 0x100000>;
- reg-names = "apb", "dbi", "config";
- resets = <&cru SRST_PCIE4_POWER_UP>, <&cru SRST_P_PCIE4>;
- reset-names = "pcie", "periph";
- rockchip,pipe-grf = <&php_grf>;
- status = "disabled";
- };
-
- sdmmc: mmc@fe2c0000 {
- compatible = "rockchip,rk3588-dw-mshc", "rockchip,rk3288-dw-mshc";
- reg = <0x0 0xfe2c0000 0x0 0x4000>;
- interrupts = <GIC_SPI 203 IRQ_TYPE_LEVEL_HIGH 0>;
- clocks = <&scmi_clk SCMI_HCLK_SD>, <&scmi_clk SCMI_CCLK_SD>,
- <&cru SCLK_SDMMC_DRV>, <&cru SCLK_SDMMC_SAMPLE>;
- clock-names = "biu", "ciu", "ciu-drive", "ciu-sample";
- fifo-depth = <0x100>;
- max-frequency = <200000000>;
- pinctrl-names = "default";
- pinctrl-0 = <&sdmmc_clk &sdmmc_cmd &sdmmc_det &sdmmc_bus4>;
- power-domains = <&power RK3588_PD_SDMMC>;
- status = "disabled";
- };
-
- combphy0_ps: phy@fee00000 {
- compatible = "rockchip,rk3588-naneng-combphy";
- reg = <0x0 0xfee00000 0x0 0x100>;
- #phy-cells = <1>;
- clocks = <&cru CLK_REF_PIPE_PHY0>, <&cru PCLK_PCIE_COMBO_PIPE_PHY0>,
- <&cru PCLK_PHP_ROOT>;
- clock-names = "refclk", "apbclk", "phpclk";
- assigned-clocks = <&cru CLK_REF_PIPE_PHY0>;
- assigned-clock-rates = <100000000>;
- resets = <&cru SRST_P_PCIE2_PHY0>, <&cru SRST_REF_PIPE_PHY0>;
- reset-names = "combphy-apb", "combphy";
- rockchip,pipe-grf = <&php_grf>;
- rockchip,pipe-phy-grf = <&pipe_phy0_grf>;
- status = "disabled";
- };
-
- combphy2_psu: phy@fee20000 {
- compatible = "rockchip,rk3588-naneng-combphy";
- reg = <0x0 0xfee20000 0x0 0x100>;
- #phy-cells = <1>;
- clocks = <&cru CLK_REF_PIPE_PHY2>, <&cru PCLK_PCIE_COMBO_PIPE_PHY2>,
- <&cru PCLK_PHP_ROOT>;
- clock-names = "refclk", "apbclk", "phpclk";
- assigned-clocks = <&cru CLK_REF_PIPE_PHY2>;
- assigned-clock-rates = <100000000>;
- resets = <&cru SRST_P_PCIE2_PHY2>, <&cru SRST_REF_PIPE_PHY2>;
- reset-names = "combphy-apb", "combphy";
- rockchip,pipe-grf = <&php_grf>;
- rockchip,pipe-phy-grf = <&pipe_phy2_grf>;
- rockchip,pcie1ln-sel-bits = <0x100 1 1 0>;
- status = "disabled";
+ rockchip,pmu = <&pmu1grf>;
};
};
diff --git a/drivers/phy/rockchip/phy-rockchip-naneng-combphy.c b/drivers/phy/rockchip/phy-rockchip-naneng-combphy.c
index 9676d8fe99..9e52beed1b 100644
--- a/drivers/phy/rockchip/phy-rockchip-naneng-combphy.c
+++ b/drivers/phy/rockchip/phy-rockchip-naneng-combphy.c
@@ -594,7 +594,7 @@ static int rk3588_combphy_cfg(struct rockchip_combphy_priv *priv)
/* Configure PHY reference clock frequency */
for (i = 0; i < priv->num_clks; i++) {
- if (!strncmp(priv->clks[i].id, "refclk", 6)) {
+ if (!strncmp(priv->clks[i].id, "ref", 6)) {
refclk = priv->clks[i].clk;
break;
}
@@ -843,9 +843,9 @@ static const struct rockchip_combphy_grfcfg rk3588_combphy_grfcfgs = {
static const struct clk_bulk_data rk3588_clks[] = {
- { .id = "refclk" },
- { .id = "apbclk" },
- { .id = "phpclk" },
+ { .id = "ref" },
+ { .id = "apb" },
+ { .id = "pipe" },
};
static const struct rockchip_combphy_cfg rk3588_combphy_cfgs = {
--
2.39.2
^ permalink raw reply [flat|nested] 3+ messages in thread
* [PATCH 2/2] ARM: rockchip: rock-5a: Disable non working devices
2023-12-05 7:27 [PATCH 0/2] Rockchip RK3588 fixes Sascha Hauer
2023-12-05 7:27 ` [PATCH 1/2] ARM: rockchip: rk3588: Use upstream dts files Sascha Hauer
@ 2023-12-05 7:27 ` Sascha Hauer
1 sibling, 0 replies; 3+ messages in thread
From: Sascha Hauer @ 2023-12-05 7:27 UTC (permalink / raw)
To: Barebox List
Some devices do not work in barebox because we lack phy drivers for
them. Also we need to overwrite the ranges property in pcie2x1l2.
The original upstream values do not work, likely because of some
deficiency in the PCI driver.
Signed-off-by: Sascha Hauer <s.hauer@pengutronix.de>
---
arch/arm/dts/rk3588-rock-5b.dts | 39 +++++++++++++++++++++++++++++++++
1 file changed, 39 insertions(+)
diff --git a/arch/arm/dts/rk3588-rock-5b.dts b/arch/arm/dts/rk3588-rock-5b.dts
index 6c3159bdb7..ddff76028e 100644
--- a/arch/arm/dts/rk3588-rock-5b.dts
+++ b/arch/arm/dts/rk3588-rock-5b.dts
@@ -52,3 +52,42 @@ environment_sd: partition@408000 {
};
};
};
+
+&pcie3x4 {
+ /* Does not work in barebox (missing phy driver) */
+ status = "disabled";
+};
+
+&pcie30phy {
+ status = "disabled";
+};
+
+&pcie2x1l2 {
+ /*
+ * Originally in upstream dts this is:
+ * ranges = <0x01000000 0x0 0xf4100000 0x0 0xf4100000 0x0 0x00100000>,
+ * <0x02000000 0x0 0xf4200000 0x0 0xf4200000 0x0 0x00e00000>,
+ * <0x03000000 0x0 0x40000000 0xa 0x00000000 0x0 0x40000000>;
+ *
+ * Overwriting this shouldn't be necessary, but without it PCI doesn't
+ * work. We have some deficiency in the PCI driver that causes this.
+ */
+ ranges = <0x01000000 0x0 0xf4100000 0x0 0xf4100000 0x0 0x00100000>,
+ <0x02000000 0x0 0xf4200000 0x0 0xf4200000 0x0 0x00e00000>,
+ <0x03000000 0xa 0x00000000 0xa 0x00000000 0x0 0x40000000>;
+};
+
+&pcie2x1l0 {
+ /* Does not work in barebox */
+ status = "disabled";
+};
+
+&usb_host0_ehci {
+ /* Does not work in barebox (missing phy driver) */
+ status = "disabled";
+};
+
+&usb_host1_ehci {
+ /* Does not work in barebox (missing phy driver) */
+ status = "disabled";
+};
--
2.39.2
^ permalink raw reply [flat|nested] 3+ messages in thread
end of thread, other threads:[~2023-12-05 7:28 UTC | newest]
Thread overview: 3+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2023-12-05 7:27 [PATCH 0/2] Rockchip RK3588 fixes Sascha Hauer
2023-12-05 7:27 ` [PATCH 1/2] ARM: rockchip: rk3588: Use upstream dts files Sascha Hauer
2023-12-05 7:27 ` [PATCH 2/2] ARM: rockchip: rock-5a: Disable non working devices Sascha Hauer
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox