Commit 30eb2080 authored by Jim Quinlan's avatar Jim Quinlan Committed by Krzysztof Wilczyński

PCI: brcmstb: PCI: brcmstb: Make HARD_DEBUG, INTR2_CPU_BASE offsets SoC-specific

Do preparatory work for the 7712 SoC, which is introduced in a
future commit.

Our HW design has changed two register offsets for the 7712, where
previously it was a common value for all Broadcom SoCs with PCIe
cores.

Specifically, the two offsets are to the registers HARD_DEBUG and
INTR2_CPU_BASE.

Link: https://lore.kernel.org/linux-pci/20240815225731.40276-8-james.quinlan@broadcom.comSigned-off-by: default avatarJim Quinlan <james.quinlan@broadcom.com>
[kwilczynski: commit log]
Signed-off-by: default avatarKrzysztof Wilczyński <kwilczynski@kernel.org>
Tested-by: default avatarFlorian Fainelli <florian.fainelli@broadcom.com>
Reviewed-by: default avatarFlorian Fainelli <florian.fainelli@broadcom.com>
Reviewed-by: default avatarKrzysztof Kozlowski <krzysztof.kozlowski@linaro.org>
Reviewed-by: default avatarManivannan Sadhasivam <manivannan.sadhasivam@linaro.org>
Reviewed-by: default avatarStanimir Varbanov <svarbanov@suse.de>
parent 82013602
...@@ -122,7 +122,6 @@ ...@@ -122,7 +122,6 @@
#define PCIE_MEM_WIN0_LIMIT_HI(win) \ #define PCIE_MEM_WIN0_LIMIT_HI(win) \
PCIE_MISC_CPU_2_PCIE_MEM_WIN0_LIMIT_HI + ((win) * 8) PCIE_MISC_CPU_2_PCIE_MEM_WIN0_LIMIT_HI + ((win) * 8)
#define PCIE_MISC_HARD_PCIE_HARD_DEBUG 0x4204
#define PCIE_MISC_HARD_PCIE_HARD_DEBUG_CLKREQ_DEBUG_ENABLE_MASK 0x2 #define PCIE_MISC_HARD_PCIE_HARD_DEBUG_CLKREQ_DEBUG_ENABLE_MASK 0x2
#define PCIE_MISC_HARD_PCIE_HARD_DEBUG_L1SS_ENABLE_MASK 0x200000 #define PCIE_MISC_HARD_PCIE_HARD_DEBUG_L1SS_ENABLE_MASK 0x200000
#define PCIE_MISC_HARD_PCIE_HARD_DEBUG_SERDES_IDDQ_MASK 0x08000000 #define PCIE_MISC_HARD_PCIE_HARD_DEBUG_SERDES_IDDQ_MASK 0x08000000
...@@ -131,9 +130,9 @@ ...@@ -131,9 +130,9 @@
(PCIE_MISC_HARD_PCIE_HARD_DEBUG_CLKREQ_DEBUG_ENABLE_MASK | \ (PCIE_MISC_HARD_PCIE_HARD_DEBUG_CLKREQ_DEBUG_ENABLE_MASK | \
PCIE_MISC_HARD_PCIE_HARD_DEBUG_L1SS_ENABLE_MASK) PCIE_MISC_HARD_PCIE_HARD_DEBUG_L1SS_ENABLE_MASK)
#define PCIE_INTR2_CPU_BASE 0x4300
#define PCIE_MSI_INTR2_BASE 0x4500 #define PCIE_MSI_INTR2_BASE 0x4500
/* Offsets from PCIE_INTR2_CPU_BASE and PCIE_MSI_INTR2_BASE */
/* Offsets from INTR2_CPU and MSI_INTR2 BASE offsets */
#define MSI_INT_STATUS 0x0 #define MSI_INT_STATUS 0x0
#define MSI_INT_CLR 0x8 #define MSI_INT_CLR 0x8
#define MSI_INT_MASK_SET 0x10 #define MSI_INT_MASK_SET 0x10
...@@ -184,9 +183,11 @@ ...@@ -184,9 +183,11 @@
#define SSC_STATUS_PLL_LOCK_MASK 0x800 #define SSC_STATUS_PLL_LOCK_MASK 0x800
#define PCIE_BRCM_MAX_MEMC 3 #define PCIE_BRCM_MAX_MEMC 3
#define IDX_ADDR(pcie) (pcie->reg_offsets[EXT_CFG_INDEX]) #define IDX_ADDR(pcie) ((pcie)->reg_offsets[EXT_CFG_INDEX])
#define DATA_ADDR(pcie) (pcie->reg_offsets[EXT_CFG_DATA]) #define DATA_ADDR(pcie) ((pcie)->reg_offsets[EXT_CFG_DATA])
#define PCIE_RGR1_SW_INIT_1(pcie) (pcie->reg_offsets[RGR1_SW_INIT_1]) #define PCIE_RGR1_SW_INIT_1(pcie) ((pcie)->reg_offsets[RGR1_SW_INIT_1])
#define HARD_DEBUG(pcie) ((pcie)->reg_offsets[PCIE_HARD_DEBUG])
#define INTR2_CPU_BASE(pcie) ((pcie)->reg_offsets[PCIE_INTR2_CPU_BASE])
/* Rescal registers */ /* Rescal registers */
#define PCIE_DVT_PMU_PCIE_PHY_CTRL 0xc700 #define PCIE_DVT_PMU_PCIE_PHY_CTRL 0xc700
...@@ -205,6 +206,8 @@ enum { ...@@ -205,6 +206,8 @@ enum {
RGR1_SW_INIT_1, RGR1_SW_INIT_1,
EXT_CFG_INDEX, EXT_CFG_INDEX,
EXT_CFG_DATA, EXT_CFG_DATA,
PCIE_HARD_DEBUG,
PCIE_INTR2_CPU_BASE,
}; };
enum { enum {
...@@ -651,7 +654,7 @@ static int brcm_pcie_enable_msi(struct brcm_pcie *pcie) ...@@ -651,7 +654,7 @@ static int brcm_pcie_enable_msi(struct brcm_pcie *pcie)
BUILD_BUG_ON(BRCM_INT_PCI_MSI_LEGACY_NR > BRCM_INT_PCI_MSI_NR); BUILD_BUG_ON(BRCM_INT_PCI_MSI_LEGACY_NR > BRCM_INT_PCI_MSI_NR);
if (msi->legacy) { if (msi->legacy) {
msi->intr_base = msi->base + PCIE_INTR2_CPU_BASE; msi->intr_base = msi->base + INTR2_CPU_BASE(pcie);
msi->nr = BRCM_INT_PCI_MSI_LEGACY_NR; msi->nr = BRCM_INT_PCI_MSI_LEGACY_NR;
msi->legacy_shift = 24; msi->legacy_shift = 24;
} else { } else {
...@@ -900,12 +903,12 @@ static int brcm_pcie_setup(struct brcm_pcie *pcie) ...@@ -900,12 +903,12 @@ static int brcm_pcie_setup(struct brcm_pcie *pcie)
/* Take the bridge out of reset */ /* Take the bridge out of reset */
pcie->bridge_sw_init_set(pcie, 0); pcie->bridge_sw_init_set(pcie, 0);
tmp = readl(base + PCIE_MISC_HARD_PCIE_HARD_DEBUG); tmp = readl(base + HARD_DEBUG(pcie));
if (is_bmips(pcie)) if (is_bmips(pcie))
tmp &= ~PCIE_BMIPS_MISC_HARD_PCIE_HARD_DEBUG_SERDES_IDDQ_MASK; tmp &= ~PCIE_BMIPS_MISC_HARD_PCIE_HARD_DEBUG_SERDES_IDDQ_MASK;
else else
tmp &= ~PCIE_MISC_HARD_PCIE_HARD_DEBUG_SERDES_IDDQ_MASK; tmp &= ~PCIE_MISC_HARD_PCIE_HARD_DEBUG_SERDES_IDDQ_MASK;
writel(tmp, base + PCIE_MISC_HARD_PCIE_HARD_DEBUG); writel(tmp, base + HARD_DEBUG(pcie));
/* Wait for SerDes to be stable */ /* Wait for SerDes to be stable */
usleep_range(100, 200); usleep_range(100, 200);
...@@ -1074,7 +1077,7 @@ static void brcm_config_clkreq(struct brcm_pcie *pcie) ...@@ -1074,7 +1077,7 @@ static void brcm_config_clkreq(struct brcm_pcie *pcie)
} }
/* Start out assuming safe mode (both mode bits cleared) */ /* Start out assuming safe mode (both mode bits cleared) */
clkreq_cntl = readl(pcie->base + PCIE_MISC_HARD_PCIE_HARD_DEBUG); clkreq_cntl = readl(pcie->base + HARD_DEBUG(pcie));
clkreq_cntl &= ~PCIE_CLKREQ_MASK; clkreq_cntl &= ~PCIE_CLKREQ_MASK;
if (strcmp(mode, "no-l1ss") == 0) { if (strcmp(mode, "no-l1ss") == 0) {
...@@ -1117,7 +1120,7 @@ static void brcm_config_clkreq(struct brcm_pcie *pcie) ...@@ -1117,7 +1120,7 @@ static void brcm_config_clkreq(struct brcm_pcie *pcie)
dev_err(pcie->dev, err_msg); dev_err(pcie->dev, err_msg);
mode = "safe"; mode = "safe";
} }
writel(clkreq_cntl, pcie->base + PCIE_MISC_HARD_PCIE_HARD_DEBUG); writel(clkreq_cntl, pcie->base + HARD_DEBUG(pcie));
dev_info(pcie->dev, "clkreq-mode set to %s\n", mode); dev_info(pcie->dev, "clkreq-mode set to %s\n", mode);
} }
...@@ -1339,9 +1342,9 @@ static void brcm_pcie_turn_off(struct brcm_pcie *pcie) ...@@ -1339,9 +1342,9 @@ static void brcm_pcie_turn_off(struct brcm_pcie *pcie)
writel(tmp, base + PCIE_MISC_PCIE_CTRL); writel(tmp, base + PCIE_MISC_PCIE_CTRL);
/* Turn off SerDes */ /* Turn off SerDes */
tmp = readl(base + PCIE_MISC_HARD_PCIE_HARD_DEBUG); tmp = readl(base + HARD_DEBUG(pcie));
u32p_replace_bits(&tmp, 1, PCIE_MISC_HARD_PCIE_HARD_DEBUG_SERDES_IDDQ_MASK); u32p_replace_bits(&tmp, 1, PCIE_MISC_HARD_PCIE_HARD_DEBUG_SERDES_IDDQ_MASK);
writel(tmp, base + PCIE_MISC_HARD_PCIE_HARD_DEBUG); writel(tmp, base + HARD_DEBUG(pcie));
/* Shutdown PCIe bridge */ /* Shutdown PCIe bridge */
pcie->bridge_sw_init_set(pcie, 1); pcie->bridge_sw_init_set(pcie, 1);
...@@ -1427,9 +1430,9 @@ static int brcm_pcie_resume_noirq(struct device *dev) ...@@ -1427,9 +1430,9 @@ static int brcm_pcie_resume_noirq(struct device *dev)
pcie->bridge_sw_init_set(pcie, 0); pcie->bridge_sw_init_set(pcie, 0);
/* SERDES_IDDQ = 0 */ /* SERDES_IDDQ = 0 */
tmp = readl(base + PCIE_MISC_HARD_PCIE_HARD_DEBUG); tmp = readl(base + HARD_DEBUG(pcie));
u32p_replace_bits(&tmp, 0, PCIE_MISC_HARD_PCIE_HARD_DEBUG_SERDES_IDDQ_MASK); u32p_replace_bits(&tmp, 0, PCIE_MISC_HARD_PCIE_HARD_DEBUG_SERDES_IDDQ_MASK);
writel(tmp, base + PCIE_MISC_HARD_PCIE_HARD_DEBUG); writel(tmp, base + HARD_DEBUG(pcie));
/* wait for serdes to be stable */ /* wait for serdes to be stable */
udelay(100); udelay(100);
...@@ -1501,12 +1504,16 @@ static const int pcie_offsets[] = { ...@@ -1501,12 +1504,16 @@ static const int pcie_offsets[] = {
[RGR1_SW_INIT_1] = 0x9210, [RGR1_SW_INIT_1] = 0x9210,
[EXT_CFG_INDEX] = 0x9000, [EXT_CFG_INDEX] = 0x9000,
[EXT_CFG_DATA] = 0x9004, [EXT_CFG_DATA] = 0x9004,
[PCIE_HARD_DEBUG] = 0x4204,
[PCIE_INTR2_CPU_BASE] = 0x4300,
}; };
static const int pcie_offsets_bmips_7425[] = { static const int pcie_offsets_bmips_7425[] = {
[RGR1_SW_INIT_1] = 0x8010, [RGR1_SW_INIT_1] = 0x8010,
[EXT_CFG_INDEX] = 0x8300, [EXT_CFG_INDEX] = 0x8300,
[EXT_CFG_DATA] = 0x8304, [EXT_CFG_DATA] = 0x8304,
[PCIE_HARD_DEBUG] = 0x4204,
[PCIE_INTR2_CPU_BASE] = 0x4300,
}; };
static const struct pcie_cfg_data generic_cfg = { static const struct pcie_cfg_data generic_cfg = {
...@@ -1541,6 +1548,8 @@ static const int pcie_offset_bcm7278[] = { ...@@ -1541,6 +1548,8 @@ static const int pcie_offset_bcm7278[] = {
[RGR1_SW_INIT_1] = 0xc010, [RGR1_SW_INIT_1] = 0xc010,
[EXT_CFG_INDEX] = 0x9000, [EXT_CFG_INDEX] = 0x9000,
[EXT_CFG_DATA] = 0x9004, [EXT_CFG_DATA] = 0x9004,
[PCIE_HARD_DEBUG] = 0x4204,
[PCIE_INTR2_CPU_BASE] = 0x4300,
}; };
static const struct pcie_cfg_data bcm7278_cfg = { static const struct pcie_cfg_data bcm7278_cfg = {
......
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