From 404cd71e7c4cb3b69a53db4876c0b2cbf27c3036 Mon Sep 17 00:00:00 2001 From: jogo Date: Mon, 4 Feb 2013 10:19:50 +0000 Subject: bcm63xx: add support for linux 3.7 Based on 3.7.6. Signed-off-by: Jonas Gorski git-svn-id: svn://svn.openwrt.org/openwrt/trunk@35481 3c298f89-4303-0410-b956-a3cf2f4a3e73 --- ...003-MIPS-BCM63XX-use-the-new-reset-helper.patch | 98 ++++++++++++++++++++++ 1 file changed, 98 insertions(+) create mode 100644 target/linux/brcm63xx/patches-3.7/003-MIPS-BCM63XX-use-the-new-reset-helper.patch (limited to 'target/linux/brcm63xx/patches-3.7/003-MIPS-BCM63XX-use-the-new-reset-helper.patch') diff --git a/target/linux/brcm63xx/patches-3.7/003-MIPS-BCM63XX-use-the-new-reset-helper.patch b/target/linux/brcm63xx/patches-3.7/003-MIPS-BCM63XX-use-the-new-reset-helper.patch new file mode 100644 index 000000000..bd2bd66e7 --- /dev/null +++ b/target/linux/brcm63xx/patches-3.7/003-MIPS-BCM63XX-use-the-new-reset-helper.patch @@ -0,0 +1,98 @@ +From 5b837e6c8499aa9bdf9f76889247feac553870d0 Mon Sep 17 00:00:00 2001 +From: Jonas Gorski +Date: Sun, 28 Oct 2012 13:09:38 +0100 +Subject: [PATCH 3/3] MIPS: BCM63XX: use the new reset helper + +Use the new reset helper where appropriate. + +Signed-off-by: Jonas Gorski +--- + arch/mips/bcm63xx/clk.c | 19 +++++-------------- + arch/mips/pci/pci-bcm63xx.c | 19 ++++++------------- + 2 files changed, 11 insertions(+), 27 deletions(-) + +--- a/arch/mips/bcm63xx/clk.c ++++ b/arch/mips/bcm63xx/clk.c +@@ -14,6 +14,7 @@ + #include + #include + #include ++#include + #include + + static DEFINE_MUTEX(clocks_mutex); +@@ -124,15 +125,10 @@ static void enetsw_set(struct clk *clk, + CKCTL_6368_SWPKT_USB_EN | + CKCTL_6368_SWPKT_SAR_EN, enable); + if (enable) { +- u32 val; +- + /* reset switch core afer clock change */ +- val = bcm_perf_readl(PERF_SOFTRESET_6368_REG); +- val &= ~SOFTRESET_6368_ENETSW_MASK; +- bcm_perf_writel(val, PERF_SOFTRESET_6368_REG); ++ bcm63xx_core_set_reset(BCM63XX_RESET_ENETSW, 1); + msleep(10); +- val |= SOFTRESET_6368_ENETSW_MASK; +- bcm_perf_writel(val, PERF_SOFTRESET_6368_REG); ++ bcm63xx_core_set_reset(BCM63XX_RESET_ENETSW, 0); + msleep(10); + } + } +@@ -222,15 +218,10 @@ static void xtm_set(struct clk *clk, int + CKCTL_6368_SWPKT_SAR_EN, enable); + + if (enable) { +- u32 val; +- + /* reset sar core afer clock change */ +- val = bcm_perf_readl(PERF_SOFTRESET_6368_REG); +- val &= ~SOFTRESET_6368_SAR_MASK; +- bcm_perf_writel(val, PERF_SOFTRESET_6368_REG); ++ bcm63xx_core_set_reset(BCM63XX_RESET_SAR, 1); + mdelay(1); +- val |= SOFTRESET_6368_SAR_MASK; +- bcm_perf_writel(val, PERF_SOFTRESET_6368_REG); ++ bcm63xx_core_set_reset(BCM63XX_RESET_SAR, 0); + mdelay(1); + } + } +--- a/arch/mips/pci/pci-bcm63xx.c ++++ b/arch/mips/pci/pci-bcm63xx.c +@@ -13,6 +13,8 @@ + #include + #include + ++#include ++ + #include "pci-bcm63xx.h" + + /* +@@ -130,23 +132,14 @@ static void __init bcm63xx_reset_pcie(vo + bcm_misc_writel(val, MISC_SERDES_CTRL_REG); + + /* reset the PCIe core */ +- val = bcm_perf_readl(PERF_SOFTRESET_6328_REG); +- +- val &= ~SOFTRESET_6328_PCIE_MASK; +- val &= ~SOFTRESET_6328_PCIE_CORE_MASK; +- val &= ~SOFTRESET_6328_PCIE_HARD_MASK; +- val &= ~SOFTRESET_6328_PCIE_EXT_MASK; +- bcm_perf_writel(val, PERF_SOFTRESET_6328_REG); ++ bcm63xx_core_set_reset(BCM63XX_RESET_PCIE, 1); ++ bcm63xx_core_set_reset(BCM63XX_RESET_PCIE_EXT, 1); + mdelay(10); + +- val |= SOFTRESET_6328_PCIE_MASK; +- val |= SOFTRESET_6328_PCIE_CORE_MASK; +- val |= SOFTRESET_6328_PCIE_HARD_MASK; +- bcm_perf_writel(val, PERF_SOFTRESET_6328_REG); ++ bcm63xx_core_set_reset(BCM63XX_RESET_PCIE, 0); + mdelay(10); + +- val |= SOFTRESET_6328_PCIE_EXT_MASK; +- bcm_perf_writel(val, PERF_SOFTRESET_6328_REG); ++ bcm63xx_core_set_reset(BCM63XX_RESET_PCIE_EXT, 0); + mdelay(200); + } + -- cgit v1.2.3