mirror of
https://github.com/openwrt/openwrt.git
synced 2025-01-12 16:03:13 +00:00
9131cb44ff
Introduce EN7581 SoC support with currently rfb board supported. This is a new 64bit SoC from Airoha that is currently almost fully supported upstream with only the DTS missing. Setting source-only waiting for the full upstream support to be completed. Link: https://github.com/openwrt/openwrt/pull/16730 Signed-off-by: Christian Marangi <ansuelsmth@gmail.com>
61 lines
2.1 KiB
Diff
61 lines
2.1 KiB
Diff
From 64e497f372dfca3e6be9fe05a0f9b874ea8604d2 Mon Sep 17 00:00:00 2001
|
|
From: Lorenzo Bianconi <lorenzo@kernel.org>
|
|
Date: Tue, 3 Sep 2024 23:39:46 +0200
|
|
Subject: [PATCH 1/6] clk: en7523: remove REG_PCIE*_{MEM,MEM_MASK}
|
|
configuration
|
|
|
|
REG_PCIE*_MEM and REG_PCIE*_MEM_MASK regs (PBUS_CSR memory region) are not
|
|
part of the scu block on the EN7581 SoC and they are used to select the
|
|
PCIE ports on the PBUS, so remove this configuration from the clock driver
|
|
and set these registers in the PCIE host driver instead.
|
|
This patch does not introduce any backward incompatibility since the dts
|
|
for EN7581 SoC is not upstream yet.
|
|
|
|
Signed-off-by: Lorenzo Bianconi <lorenzo@kernel.org>
|
|
---
|
|
drivers/clk/clk-en7523.c | 18 ------------------
|
|
1 file changed, 18 deletions(-)
|
|
|
|
--- a/drivers/clk/clk-en7523.c
|
|
+++ b/drivers/clk/clk-en7523.c
|
|
@@ -31,12 +31,6 @@
|
|
#define REG_RESET_CONTROL_PCIE1 BIT(27)
|
|
#define REG_RESET_CONTROL_PCIE2 BIT(26)
|
|
/* EN7581 */
|
|
-#define REG_PCIE0_MEM 0x00
|
|
-#define REG_PCIE0_MEM_MASK 0x04
|
|
-#define REG_PCIE1_MEM 0x08
|
|
-#define REG_PCIE1_MEM_MASK 0x0c
|
|
-#define REG_PCIE2_MEM 0x10
|
|
-#define REG_PCIE2_MEM_MASK 0x14
|
|
#define REG_NP_SCU_PCIC 0x88
|
|
#define REG_NP_SCU_SSTR 0x9c
|
|
#define REG_PCIE_XSI0_SEL_MASK GENMASK(14, 13)
|
|
@@ -415,26 +409,14 @@ static void en7581_pci_disable(struct cl
|
|
static int en7581_clk_hw_init(struct platform_device *pdev,
|
|
void __iomem *np_base)
|
|
{
|
|
- void __iomem *pb_base;
|
|
u32 val;
|
|
|
|
- pb_base = devm_platform_ioremap_resource(pdev, 3);
|
|
- if (IS_ERR(pb_base))
|
|
- return PTR_ERR(pb_base);
|
|
-
|
|
val = readl(np_base + REG_NP_SCU_SSTR);
|
|
val &= ~(REG_PCIE_XSI0_SEL_MASK | REG_PCIE_XSI1_SEL_MASK);
|
|
writel(val, np_base + REG_NP_SCU_SSTR);
|
|
val = readl(np_base + REG_NP_SCU_PCIC);
|
|
writel(val | 3, np_base + REG_NP_SCU_PCIC);
|
|
|
|
- writel(0x20000000, pb_base + REG_PCIE0_MEM);
|
|
- writel(0xfc000000, pb_base + REG_PCIE0_MEM_MASK);
|
|
- writel(0x24000000, pb_base + REG_PCIE1_MEM);
|
|
- writel(0xfc000000, pb_base + REG_PCIE1_MEM_MASK);
|
|
- writel(0x28000000, pb_base + REG_PCIE2_MEM);
|
|
- writel(0xfc000000, pb_base + REG_PCIE2_MEM_MASK);
|
|
-
|
|
return 0;
|
|
}
|
|
|