aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJulien Dusser <julien.dusser@free.fr>2017-12-20 15:29:42 +0100
committerJohn Crispin <john@phrozen.org>2018-02-13 11:20:58 +0100
commit8dd455e3c4dc567c90950230ef848c3a64af3ade (patch)
tree2b7adc75fc1d208f6094c3ab12dbad373dc1db73
parent13f9e40602707479aaffac0d68a952070f305b7d (diff)
downloadupstream-8dd455e3c4dc567c90950230ef848c3a64af3ade.tar.gz
upstream-8dd455e3c4dc567c90950230ef848c3a64af3ade.tar.bz2
upstream-8dd455e3c4dc567c90950230ef848c3a64af3ade.zip
ar71xx: add more registers to ar71x_regs.h
Add more registers and flags to ar71x_regs.h for QCA955x and QCA956x SoCs. Values come from Qualcomm Atheros u-boot code. Patches can be merged into 622-MIPS-ath79-add-more-register-defines-for-QCA956x-SoC.patch Signed-off-by: Julien Dusser <julien.dusser@free.fr>
-rw-r--r--target/linux/ar71xx/files/arch/mips/ath79/mach-mr18.c11
-rw-r--r--target/linux/ar71xx/patches-4.4/921-MIPS-ath79-add-even-more-register-defines-for-QCA956x-SoC.patch194
-rw-r--r--target/linux/ar71xx/patches-4.9/921-MIPS-ath79-add-even-more-register-defines-for-QCA956x-SoC.patch194
3 files changed, 388 insertions, 11 deletions
diff --git a/target/linux/ar71xx/files/arch/mips/ath79/mach-mr18.c b/target/linux/ar71xx/files/arch/mips/ath79/mach-mr18.c
index a24cb3fce6..2d2fb6e84c 100644
--- a/target/linux/ar71xx/files/arch/mips/ath79/mach-mr18.c
+++ b/target/linux/ar71xx/files/arch/mips/ath79/mach-mr18.c
@@ -168,17 +168,6 @@ static int mr18_extract_sgmii_res_cal(void)
return reversed_sgmii_value;
}
-#define QCA955X_PLL_ETH_SGMII_SERDES_REG 0x004c
-#define QCA955X_PLL_ETH_SGMII_SERDES_LOCK_DETECT BIT(2)
-#define QCA955X_PLL_ETH_SGMII_SERDES_PLL_REFCLK BIT(1)
-#define QCA955X_PLL_ETH_SGMII_SERDES_EN_PLL BIT(0)
-
-#define QCA955X_GMAC_REG_SGMII_SERDES 0x0018
-#define QCA955X_SGMII_SERDES_RES_CALIBRATION BIT(23)
-#define QCA955X_SGMII_SERDES_RES_CALIBRATION_MASK 0xf
-#define QCA955X_SGMII_SERDES_RES_CALIBRATION_SHIFT 23
-#define QCA955X_SGMII_SERDES_LOCK_DETECT_STATUS BIT(15)
-
static void mr18_setup_qca955x_eth_serdes_cal(unsigned int sgmii_value)
{
void __iomem *ethbase, *pllbase;
diff --git a/target/linux/ar71xx/patches-4.4/921-MIPS-ath79-add-even-more-register-defines-for-QCA956x-SoC.patch b/target/linux/ar71xx/patches-4.4/921-MIPS-ath79-add-even-more-register-defines-for-QCA956x-SoC.patch
new file mode 100644
index 0000000000..a4608ea48d
--- /dev/null
+++ b/target/linux/ar71xx/patches-4.4/921-MIPS-ath79-add-even-more-register-defines-for-QCA956x-SoC.patch
@@ -0,0 +1,194 @@
+Add more registers for QCA955x and QCA956x.
+
+--- a/arch/mips/include/asm/mach-ath79/ar71xx_regs.h
++++ b/arch/mips/include/asm/mach-ath79/ar71xx_regs.h
+@@ -175,6 +175,35 @@
+ /*
+ * Hidden Registers
+ */
++#define QCA956X_MAC_CFG_BASE 0xb9000000
++#define QCA956X_MAC_CFG_SIZE 0x64
++
++#define QCA956X_MAC_CFG1_REG 0x00
++#define QCA956X_MAC_CFG1_SOFT_RST BIT(31)
++#define QCA956X_MAC_CFG1_RX_RST BIT(19)
++#define QCA956X_MAC_CFG1_TX_RST BIT(18)
++#define QCA956X_MAC_CFG1_LOOPBACK BIT(8)
++#define QCA956X_MAC_CFG1_RX_EN BIT(2)
++#define QCA956X_MAC_CFG1_TX_EN BIT(0)
++
++#define QCA956X_MAC_CFG2_REG 0x04
++#define QCA956X_MAC_CFG2_IF_1000 BIT(9)
++#define QCA956X_MAC_CFG2_IF_10_100 BIT(8)
++#define QCA956X_MAC_CFG2_HUGE_FRAME_EN BIT(5)
++#define QCA956X_MAC_CFG2_LEN_CHECK BIT(4)
++#define QCA956X_MAC_CFG2_PAD_CRC_EN BIT(2)
++#define QCA956X_MAC_CFG2_FDX BIT(0)
++
++#define QCA956X_MAC_MII_MGMT_CFG_REG 0x20
++#define QCA956X_MGMT_CFG_CLK_DIV_20 0x07
++
++#define QCA956X_MAC_FIFO_CFG0_REG 0x48
++#define QCA956X_MAC_FIFO_CFG1_REG 0x4c
++#define QCA956X_MAC_FIFO_CFG2_REG 0x50
++#define QCA956X_MAC_FIFO_CFG3_REG 0x54
++#define QCA956X_MAC_FIFO_CFG4_REG 0x58
++#define QCA956X_MAC_FIFO_CFG5_REG 0x5c
++
+ #define QCA956X_DAM_RESET_OFFSET 0xb90001bc
+ #define QCA956X_DAM_RESET_SIZE 0x4
+ #define QCA956X_INLINE_CHKSUM_ENG BIT(27)
+@@ -384,6 +413,7 @@
+ #define QCA955X_PLL_CLK_CTRL_REG 0x08
+ #define QCA955X_PLL_ETH_XMII_CONTROL_REG 0x28
+ #define QCA955X_PLL_ETH_SGMII_CONTROL_REG 0x48
++#define QCA955X_PLL_ETH_SGMII_SERDES_REG 0x4c
+
+ #define QCA955X_PLL_CPU_CONFIG_NFRAC_SHIFT 0
+ #define QCA955X_PLL_CPU_CONFIG_NFRAC_MASK 0x3f
+@@ -416,12 +446,18 @@
+ #define QCA955X_PLL_CLK_CTRL_DDRCLK_FROM_DDRPLL BIT(21)
+ #define QCA955X_PLL_CLK_CTRL_AHBCLK_FROM_DDRPLL BIT(24)
+
++#define QCA955X_PLL_ETH_SGMII_SERDES_LOCK_DETECT BIT(2)
++#define QCA955X_PLL_ETH_SGMII_SERDES_PLL_REFCLK BIT(1)
++#define QCA955X_PLL_ETH_SGMII_SERDES_EN_PLL BIT(0)
++
+ #define QCA956X_PLL_CPU_CONFIG_REG 0x00
+ #define QCA956X_PLL_CPU_CONFIG1_REG 0x04
+ #define QCA956X_PLL_DDR_CONFIG_REG 0x08
+ #define QCA956X_PLL_DDR_CONFIG1_REG 0x0c
+ #define QCA956X_PLL_CLK_CTRL_REG 0x10
++#define QCA956X_PLL_SWITCH_CLOCK_CONTROL_REG 0x28
+ #define QCA956X_PLL_ETH_XMII_CONTROL_REG 0x30
++#define QCA956X_PLL_ETH_SGMII_SERDES_REG 0x4c
+
+ #define QCA956X_PLL_CPU_CONFIG_REFDIV_SHIFT 12
+ #define QCA956X_PLL_CPU_CONFIG_REFDIV_MASK 0x1f
+@@ -460,6 +496,31 @@
+ #define QCA956X_PLL_CLK_CTRL_CPU_DDRCLK_FROM_CPUPLL BIT(21)
+ #define QCA956X_PLL_CLK_CTRL_AHBCLK_FROM_DDRPLL BIT(24)
+
++#define QCA956X_PLL_SWITCH_CLOCK_SPARE_I2C_CLK_SELB BIT(5)
++#define QCA956X_PLL_SWITCH_CLOCK_SPARE_MDIO_CLK_SEL0_1 BIT(6)
++#define QCA956X_PLL_SWITCH_CLOCK_SPARE_UART1_CLK_SEL BIT(7)
++#define QCA956X_PLL_SWITCH_CLOCK_SPARE_USB_REFCLK_FREQ_SEL_SHIFT 8
++#define QCA956X_PLL_SWITCH_CLOCK_SPARE_USB_REFCLK_FREQ_SEL_MASK 0xf
++#define QCA956X_PLL_SWITCH_CLOCK_SPARE_EN_PLL_TOP BIT(12)
++#define QCA956X_PLL_SWITCH_CLOCK_SPARE_MDIO_CLK_SEL0_2 BIT(13)
++#define QCA956X_PLL_SWITCH_CLOCK_SPARE_MDIO_CLK_SEL1_1 BIT(14)
++#define QCA956X_PLL_SWITCH_CLOCK_SPARE_MDIO_CLK_SEL1_2 BIT(15)
++#define QCA956X_PLL_SWITCH_CLOCK_SPARE_SWITCH_FUNC_TST_MODE BIT(16)
++#define QCA956X_PLL_SWITCH_CLOCK_SPARE_EEE_ENABLE BIT(17)
++#define QCA956X_PLL_SWITCH_CLOCK_SPARE_OEN_CLK125M_PLL BIT(18)
++#define QCA956X_PLL_SWITCH_CLOCK_SPARE_SWITCHCLK_SEL BIT(19)
++
++#define QCA956X_PLL_ETH_XMII_TX_INVERT BIT(1)
++#define QCA956X_PLL_ETH_XMII_GIGE BIT(25)
++#define QCA956X_PLL_ETH_XMII_RX_DELAY_SHIFT 28
++#define QCA956X_PLL_ETH_XMII_RX_DELAY_MASK 0x3
++#define QCA956X_PLL_ETH_XMII_TX_DELAY_SHIFT 26
++#define QCA956X_PLL_ETH_XMII_TX_DELAY_MASK 3
++
++#define QCA956X_PLL_ETH_SGMII_SERDES_LOCK_DETECT BIT(2)
++#define QCA956X_PLL_ETH_SGMII_SERDES_PLL_REFCLK BIT(1)
++#define QCA956X_PLL_ETH_SGMII_SERDES_EN_PLL BIT(0)
++
+ /*
+ * USB_CONFIG block
+ */
+@@ -657,6 +718,25 @@
+ #define QCA955X_RESET_MBOX BIT(1)
+ #define QCA955X_RESET_I2S BIT(0)
+
++#define QCA956X_RESET_EXTERNAL BIT(28)
++#define QCA956X_RESET_FULL_CHIP BIT(24)
++#define QCA956X_RESET_GE1_MDIO BIT(23)
++#define QCA956X_RESET_GE0_MDIO BIT(22)
++#define QCA956X_RESET_CPU_NMI BIT(21)
++#define QCA956X_RESET_CPU_COLD BIT(20)
++#define QCA956X_RESET_DMA BIT(19)
++#define QCA956X_RESET_DDR BIT(16)
++#define QCA956X_RESET_GE1_MAC BIT(13)
++#define QCA956X_RESET_SGMII_ANALOG BIT(12)
++#define QCA956X_RESET_USB_PHY_ANALOG BIT(11)
++#define QCA956X_RESET_GE0_MAC BIT(9)
++#define QCA956X_RESET_SGMII BIT(8)
++#define QCA956X_RESET_USB_HOST BIT(5)
++#define QCA956X_RESET_USB_PHY BIT(4)
++#define QCA956X_RESET_USBSUS_OVERRIDE BIT(3)
++#define QCA956X_RESET_SWITCH_ANALOG BIT(2)
++#define QCA956X_RESET_SWITCH BIT(0)
++
+ #define AR933X_BOOTSTRAP_MDIO_GPIO_EN BIT(18)
+ #define AR933X_BOOTSTRAP_EEPBUSY BIT(4)
+ #define AR933X_BOOTSTRAP_USB_MODE_HOST BIT(3)
+@@ -1189,6 +1269,7 @@
+ */
+
+ #define QCA955X_GMAC_REG_ETH_CFG 0x00
++#define QCA955X_GMAC_REG_SGMII_SERDES 0x18
+
+ #define QCA955X_ETH_CFG_RGMII_EN BIT(0)
+ #define QCA955X_ETH_CFG_MII_GE0 BIT(1)
+@@ -1210,16 +1291,58 @@
+ #define QCA955X_ETH_CFG_TXE_DELAY_MASK 0x3
+ #define QCA955X_ETH_CFG_TXE_DELAY_SHIFT 20
+
++#define QCA955X_SGMII_SERDES_LOCK_DETECT_STATUS BIT(15)
++#define QCA955X_SGMII_SERDES_RES_CALIBRATION_SHIFT 23
++#define QCA955X_SGMII_SERDES_RES_CALIBRATION_MASK 0xf
+ /*
+ * QCA956X GMAC Interface
+ */
+
+-#define QCA956X_GMAC_REG_ETH_CFG 0x00
++#define QCA956X_GMAC_REG_ETH_CFG 0x00
++#define QCA956X_GMAC_REG_SGMII_RESET 0x14
++#define QCA956X_GMAC_REG_SGMII_SERDES 0x18
++#define QCA956X_GMAC_REG_MR_AN_CONTROL 0x1c
++#define QCA956X_GMAC_REG_SGMII_CONFIG 0x34
++#define QCA956X_GMAC_REG_SGMII_DEBUG 0x58
+
++#define QCA956X_ETH_CFG_RGMII_EN BIT(0)
++#define QCA956X_ETH_CFG_GE0_SGMII BIT(6)
+ #define QCA956X_ETH_CFG_SW_ONLY_MODE BIT(7)
+-#define QCA956X_ETH_CFG_SW_PHY_SWAP BIT(8)
++#define QCA956X_ETH_CFG_SW_PHY_SWAP BIT(8)
+ #define QCA956X_ETH_CFG_SW_PHY_ADDR_SWAP BIT(9)
+ #define QCA956X_ETH_CFG_SW_APB_ACCESS BIT(10)
+ #define QCA956X_ETH_CFG_SW_ACC_MSB_FIRST BIT(13)
++#define QCA956X_ETH_CFG_RXD_DELAY_MASK 0x3
++#define QCA956X_ETH_CFG_RXD_DELAY_SHIFT 14
++#define QCA956X_ETH_CFG_RDV_DELAY_MASK 0x3
++#define QCA956X_ETH_CFG_RDV_DELAY_SHIFT 16
++
++#define QCA956X_SGMII_RESET_RX_CLK_N_RESET 0x0
++#define QCA956X_SGMII_RESET_RX_CLK_N BIT(0)
++#define QCA956X_SGMII_RESET_TX_CLK_N BIT(1)
++#define QCA956X_SGMII_RESET_RX_125M_N BIT(2)
++#define QCA956X_SGMII_RESET_TX_125M_N BIT(3)
++#define QCA956X_SGMII_RESET_HW_RX_125M_N BIT(4)
++
++#define QCA956X_SGMII_SERDES_CDR_BW_MASK 0x3
++#define QCA956X_SGMII_SERDES_CDR_BW_SHIFT 1
++#define QCA956X_SGMII_SERDES_TX_DR_CTRL_MASK 0x7
++#define QCA956X_SGMII_SERDES_TX_DR_CTRL_SHIFT 4
++#define QCA956X_SGMII_SERDES_PLL_BW BIT(8)
++#define QCA956X_SGMII_SERDES_VCO_FAST BIT(9)
++#define QCA956X_SGMII_SERDES_VCO_SLOW BIT(10)
++#define QCA956X_SGMII_SERDES_LOCK_DETECT_STATUS BIT(15)
++#define QCA956X_SGMII_SERDES_EN_SIGNAL_DETECT BIT(16)
++#define QCA956X_SGMII_SERDES_FIBER_SDO BIT(17)
++#define QCA956X_SGMII_SERDES_RES_CALIBRATION_SHIFT 23
++#define QCA956X_SGMII_SERDES_RES_CALIBRATION_MASK 0xf
++#define QCA956X_SGMII_SERDES_VCO_REG_SHIFT 27
++#define QCA956X_SGMII_SERDES_VCO_REG_MASK 0xf
++
++#define QCA956X_MR_AN_CONTROL_AN_ENABLE BIT(12)
++#define QCA956X_MR_AN_CONTROL_PHY_RESET BIT(15)
++
++#define QCA956X_SGMII_CONFIG_MODE_CTRL_SHIFT 0
++#define QCA956X_SGMII_CONFIG_MODE_CTRL_MASK 0x7
+
+ #endif /* __ASM_MACH_AR71XX_REGS_H */
diff --git a/target/linux/ar71xx/patches-4.9/921-MIPS-ath79-add-even-more-register-defines-for-QCA956x-SoC.patch b/target/linux/ar71xx/patches-4.9/921-MIPS-ath79-add-even-more-register-defines-for-QCA956x-SoC.patch
new file mode 100644
index 0000000000..a4608ea48d
--- /dev/null
+++ b/target/linux/ar71xx/patches-4.9/921-MIPS-ath79-add-even-more-register-defines-for-QCA956x-SoC.patch
@@ -0,0 +1,194 @@
+Add more registers for QCA955x and QCA956x.
+
+--- a/arch/mips/include/asm/mach-ath79/ar71xx_regs.h
++++ b/arch/mips/include/asm/mach-ath79/ar71xx_regs.h
+@@ -175,6 +175,35 @@
+ /*
+ * Hidden Registers
+ */
++#define QCA956X_MAC_CFG_BASE 0xb9000000
++#define QCA956X_MAC_CFG_SIZE 0x64
++
++#define QCA956X_MAC_CFG1_REG 0x00
++#define QCA956X_MAC_CFG1_SOFT_RST BIT(31)
++#define QCA956X_MAC_CFG1_RX_RST BIT(19)
++#define QCA956X_MAC_CFG1_TX_RST BIT(18)
++#define QCA956X_MAC_CFG1_LOOPBACK BIT(8)
++#define QCA956X_MAC_CFG1_RX_EN BIT(2)
++#define QCA956X_MAC_CFG1_TX_EN BIT(0)
++
++#define QCA956X_MAC_CFG2_REG 0x04
++#define QCA956X_MAC_CFG2_IF_1000 BIT(9)
++#define QCA956X_MAC_CFG2_IF_10_100 BIT(8)
++#define QCA956X_MAC_CFG2_HUGE_FRAME_EN BIT(5)
++#define QCA956X_MAC_CFG2_LEN_CHECK BIT(4)
++#define QCA956X_MAC_CFG2_PAD_CRC_EN BIT(2)
++#define QCA956X_MAC_CFG2_FDX BIT(0)
++
++#define QCA956X_MAC_MII_MGMT_CFG_REG 0x20
++#define QCA956X_MGMT_CFG_CLK_DIV_20 0x07
++
++#define QCA956X_MAC_FIFO_CFG0_REG 0x48
++#define QCA956X_MAC_FIFO_CFG1_REG 0x4c
++#define QCA956X_MAC_FIFO_CFG2_REG 0x50
++#define QCA956X_MAC_FIFO_CFG3_REG 0x54
++#define QCA956X_MAC_FIFO_CFG4_REG 0x58
++#define QCA956X_MAC_FIFO_CFG5_REG 0x5c
++
+ #define QCA956X_DAM_RESET_OFFSET 0xb90001bc
+ #define QCA956X_DAM_RESET_SIZE 0x4
+ #define QCA956X_INLINE_CHKSUM_ENG BIT(27)
+@@ -384,6 +413,7 @@
+ #define QCA955X_PLL_CLK_CTRL_REG 0x08
+ #define QCA955X_PLL_ETH_XMII_CONTROL_REG 0x28
+ #define QCA955X_PLL_ETH_SGMII_CONTROL_REG 0x48
++#define QCA955X_PLL_ETH_SGMII_SERDES_REG 0x4c
+
+ #define QCA955X_PLL_CPU_CONFIG_NFRAC_SHIFT 0
+ #define QCA955X_PLL_CPU_CONFIG_NFRAC_MASK 0x3f
+@@ -416,12 +446,18 @@
+ #define QCA955X_PLL_CLK_CTRL_DDRCLK_FROM_DDRPLL BIT(21)
+ #define QCA955X_PLL_CLK_CTRL_AHBCLK_FROM_DDRPLL BIT(24)
+
++#define QCA955X_PLL_ETH_SGMII_SERDES_LOCK_DETECT BIT(2)
++#define QCA955X_PLL_ETH_SGMII_SERDES_PLL_REFCLK BIT(1)
++#define QCA955X_PLL_ETH_SGMII_SERDES_EN_PLL BIT(0)
++
+ #define QCA956X_PLL_CPU_CONFIG_REG 0x00
+ #define QCA956X_PLL_CPU_CONFIG1_REG 0x04
+ #define QCA956X_PLL_DDR_CONFIG_REG 0x08
+ #define QCA956X_PLL_DDR_CONFIG1_REG 0x0c
+ #define QCA956X_PLL_CLK_CTRL_REG 0x10
++#define QCA956X_PLL_SWITCH_CLOCK_CONTROL_REG 0x28
+ #define QCA956X_PLL_ETH_XMII_CONTROL_REG 0x30
++#define QCA956X_PLL_ETH_SGMII_SERDES_REG 0x4c
+
+ #define QCA956X_PLL_CPU_CONFIG_REFDIV_SHIFT 12
+ #define QCA956X_PLL_CPU_CONFIG_REFDIV_MASK 0x1f
+@@ -460,6 +496,31 @@
+ #define QCA956X_PLL_CLK_CTRL_CPU_DDRCLK_FROM_CPUPLL BIT(21)
+ #define QCA956X_PLL_CLK_CTRL_AHBCLK_FROM_DDRPLL BIT(24)
+
++#define QCA956X_PLL_SWITCH_CLOCK_SPARE_I2C_CLK_SELB BIT(5)
++#define QCA956X_PLL_SWITCH_CLOCK_SPARE_MDIO_CLK_SEL0_1 BIT(6)
++#define QCA956X_PLL_SWITCH_CLOCK_SPARE_UART1_CLK_SEL BIT(7)
++#define QCA956X_PLL_SWITCH_CLOCK_SPARE_USB_REFCLK_FREQ_SEL_SHIFT 8
++#define QCA956X_PLL_SWITCH_CLOCK_SPARE_USB_REFCLK_FREQ_SEL_MASK 0xf
++#define QCA956X_PLL_SWITCH_CLOCK_SPARE_EN_PLL_TOP BIT(12)
++#define QCA956X_PLL_SWITCH_CLOCK_SPARE_MDIO_CLK_SEL0_2 BIT(13)
++#define QCA956X_PLL_SWITCH_CLOCK_SPARE_MDIO_CLK_SEL1_1 BIT(14)
++#define QCA956X_PLL_SWITCH_CLOCK_SPARE_MDIO_CLK_SEL1_2 BIT(15)
++#define QCA956X_PLL_SWITCH_CLOCK_SPARE_SWITCH_FUNC_TST_MODE BIT(16)
++#define QCA956X_PLL_SWITCH_CLOCK_SPARE_EEE_ENABLE BIT(17)
++#define QCA956X_PLL_SWITCH_CLOCK_SPARE_OEN_CLK125M_PLL BIT(18)
++#define QCA956X_PLL_SWITCH_CLOCK_SPARE_SWITCHCLK_SEL BIT(19)
++
++#define QCA956X_PLL_ETH_XMII_TX_INVERT BIT(1)
++#define QCA956X_PLL_ETH_XMII_GIGE BIT(25)
++#define QCA956X_PLL_ETH_XMII_RX_DELAY_SHIFT 28
++#define QCA956X_PLL_ETH_XMII_RX_DELAY_MASK 0x3
++#define QCA956X_PLL_ETH_XMII_TX_DELAY_SHIFT 26
++#define QCA956X_PLL_ETH_XMII_TX_DELAY_MASK 3
++
++#define QCA956X_PLL_ETH_SGMII_SERDES_LOCK_DETECT BIT(2)
++#define QCA956X_PLL_ETH_SGMII_SERDES_PLL_REFCLK BIT(1)
++#define QCA956X_PLL_ETH_SGMII_SERDES_EN_PLL BIT(0)
++
+ /*
+ * USB_CONFIG block
+ */
+@@ -657,6 +718,25 @@
+ #define QCA955X_RESET_MBOX BIT(1)
+ #define QCA955X_RESET_I2S BIT(0)
+
++#define QCA956X_RESET_EXTERNAL BIT(28)
++#define QCA956X_RESET_FULL_CHIP BIT(24)
++#define QCA956X_RESET_GE1_MDIO BIT(23)
++#define QCA956X_RESET_GE0_MDIO BIT(22)
++#define QCA956X_RESET_CPU_NMI BIT(21)
++#define QCA956X_RESET_CPU_COLD BIT(20)
++#define QCA956X_RESET_DMA BIT(19)
++#define QCA956X_RESET_DDR BIT(16)
++#define QCA956X_RESET_GE1_MAC BIT(13)
++#define QCA956X_RESET_SGMII_ANALOG BIT(12)
++#define QCA956X_RESET_USB_PHY_ANALOG BIT(11)
++#define QCA956X_RESET_GE0_MAC BIT(9)
++#define QCA956X_RESET_SGMII BIT(8)
++#define QCA956X_RESET_USB_HOST BIT(5)
++#define QCA956X_RESET_USB_PHY BIT(4)
++#define QCA956X_RESET_USBSUS_OVERRIDE BIT(3)
++#define QCA956X_RESET_SWITCH_ANALOG BIT(2)
++#define QCA956X_RESET_SWITCH BIT(0)
++
+ #define AR933X_BOOTSTRAP_MDIO_GPIO_EN BIT(18)
+ #define AR933X_BOOTSTRAP_EEPBUSY BIT(4)
+ #define AR933X_BOOTSTRAP_USB_MODE_HOST BIT(3)
+@@ -1189,6 +1269,7 @@
+ */
+
+ #define QCA955X_GMAC_REG_ETH_CFG 0x00
++#define QCA955X_GMAC_REG_SGMII_SERDES 0x18
+
+ #define QCA955X_ETH_CFG_RGMII_EN BIT(0)
+ #define QCA955X_ETH_CFG_MII_GE0 BIT(1)
+@@ -1210,16 +1291,58 @@
+ #define QCA955X_ETH_CFG_TXE_DELAY_MASK 0x3
+ #define QCA955X_ETH_CFG_TXE_DELAY_SHIFT 20
+
++#define QCA955X_SGMII_SERDES_LOCK_DETECT_STATUS BIT(15)
++#define QCA955X_SGMII_SERDES_RES_CALIBRATION_SHIFT 23
++#define QCA955X_SGMII_SERDES_RES_CALIBRATION_MASK 0xf
+ /*
+ * QCA956X GMAC Interface
+ */
+
+-#define QCA956X_GMAC_REG_ETH_CFG 0x00
++#define QCA956X_GMAC_REG_ETH_CFG 0x00
++#define QCA956X_GMAC_REG_SGMII_RESET 0x14
++#define QCA956X_GMAC_REG_SGMII_SERDES 0x18
++#define QCA956X_GMAC_REG_MR_AN_CONTROL 0x1c
++#define QCA956X_GMAC_REG_SGMII_CONFIG 0x34
++#define QCA956X_GMAC_REG_SGMII_DEBUG 0x58
+
++#define QCA956X_ETH_CFG_RGMII_EN BIT(0)
++#define QCA956X_ETH_CFG_GE0_SGMII BIT(6)
+ #define QCA956X_ETH_CFG_SW_ONLY_MODE BIT(7)
+-#define QCA956X_ETH_CFG_SW_PHY_SWAP BIT(8)
++#define QCA956X_ETH_CFG_SW_PHY_SWAP BIT(8)
+ #define QCA956X_ETH_CFG_SW_PHY_ADDR_SWAP BIT(9)
+ #define QCA956X_ETH_CFG_SW_APB_ACCESS BIT(10)
+ #define QCA956X_ETH_CFG_SW_ACC_MSB_FIRST BIT(13)
++#define QCA956X_ETH_CFG_RXD_DELAY_MASK 0x3
++#define QCA956X_ETH_CFG_RXD_DELAY_SHIFT 14
++#define QCA956X_ETH_CFG_RDV_DELAY_MASK 0x3
++#define QCA956X_ETH_CFG_RDV_DELAY_SHIFT 16
++
++#define QCA956X_SGMII_RESET_RX_CLK_N_RESET 0x0
++#define QCA956X_SGMII_RESET_RX_CLK_N BIT(0)
++#define QCA956X_SGMII_RESET_TX_CLK_N BIT(1)
++#define QCA956X_SGMII_RESET_RX_125M_N BIT(2)
++#define QCA956X_SGMII_RESET_TX_125M_N BIT(3)
++#define QCA956X_SGMII_RESET_HW_RX_125M_N BIT(4)
++
++#define QCA956X_SGMII_SERDES_CDR_BW_MASK 0x3
++#define QCA956X_SGMII_SERDES_CDR_BW_SHIFT 1
++#define QCA956X_SGMII_SERDES_TX_DR_CTRL_MASK 0x7
++#define QCA956X_SGMII_SERDES_TX_DR_CTRL_SHIFT 4
++#define QCA956X_SGMII_SERDES_PLL_BW BIT(8)
++#define QCA956X_SGMII_SERDES_VCO_FAST BIT(9)
++#define QCA956X_SGMII_SERDES_VCO_SLOW BIT(10)
++#define QCA956X_SGMII_SERDES_LOCK_DETECT_STATUS BIT(15)
++#define QCA956X_SGMII_SERDES_EN_SIGNAL_DETECT BIT(16)
++#define QCA956X_SGMII_SERDES_FIBER_SDO BIT(17)
++#define QCA956X_SGMII_SERDES_RES_CALIBRATION_SHIFT 23
++#define QCA956X_SGMII_SERDES_RES_CALIBRATION_MASK 0xf
++#define QCA956X_SGMII_SERDES_VCO_REG_SHIFT 27
++#define QCA956X_SGMII_SERDES_VCO_REG_MASK 0xf
++
++#define QCA956X_MR_AN_CONTROL_AN_ENABLE BIT(12)
++#define QCA956X_MR_AN_CONTROL_PHY_RESET BIT(15)
++
++#define QCA956X_SGMII_CONFIG_MODE_CTRL_SHIFT 0
++#define QCA956X_SGMII_CONFIG_MODE_CTRL_MASK 0x7
+
+ #endif /* __ASM_MACH_AR71XX_REGS_H */