Index: target/linux/ar71xx/files/arch/mips/include/asm/mach-ar71xx/ar71xx.h
===
--- target/linux/ar71xx/files/arch/mips/include/asm/mach-ar71xx/ar71xx.h
(revision
24746)
+++ target/linux/ar71xx/files/arch/mips/include/asm/mach-ar71xx/ar71xx.h
(working
copy)
@@ -152,6 +152,8 @@
#define AR724X_DDR_DIV_SHIFT 22
#define AR724X_DDR_DIV_MASK 0x3
+#define AR7242_PLL_REG_ETH0_INT_CLOCK 0x2C
+
#define AR91XX_PLL_REG_CPU_CONFIG 0x00
#define AR91XX_PLL_REG_ETH_CONFIG 0x04
#define AR91XX_PLL_REG_ETH0_INT_CLOCK 0x14
Index: target/linux/ar71xx/files/arch/mips/ar71xx/devices.c
===
--- target/linux/ar71xx/files/arch/mips/ar71xx/devices.c (revision 24746)
+++ target/linux/ar71xx/files/arch/mips/ar71xx/devices.c (working copy)
@@ -94,7 +94,6 @@
ar71xx_mdio_resources[0].end = AR71XX_GE1_BASE + 0x200 - 1;
break;
case AR71XX_SOC_AR7242:
- ar71xx_mdio_data.is_ar7240 = 1;
break;
default:
break;
@@ -196,6 +195,19 @@
/* TODO */
}
+static void ar7242_set_pll_ge0(int speed)
+{
+ u32 val = ar71xx_get_eth_pll(0, speed);
+
+ ar71xx_set_pll(AR71XX_PLL_REG_SEC_CONFIG, AR7242_PLL_REG_ETH0_INT_CLOCK,
+ val, AR71XX_ETH0_PLL_SHIFT);
+}
+
+static void ar7242_set_pll_ge1(int speed)
+{
+ /* TODO */
+}
+
static void ar91xx_set_pll_ge0(int speed)
{
u32 val = ar71xx_get_eth_pll(0, speed);
@@ -316,6 +328,10 @@
#define AR724X_PLL_VAL_100 0x1099
#define AR724X_PLL_VAL_10 0x00991099
+#define AR7242_PLL_VAL_1000 0x1600
+#define AR7242_PLL_VAL_100 0x0101
+#define AR7242_PLL_VAL_10 0x1616
+
#define AR91XX_PLL_VAL_1000 0x1a00
#define AR91XX_PLL_VAL_100 0x13000a44
#define AR91XX_PLL_VAL_10 0x00441099
@@ -347,11 +363,16 @@
case AR71XX_SOC_AR7240:
case AR71XX_SOC_AR7241:
- case AR71XX_SOC_AR7242:
pll_10 = AR724X_PLL_VAL_10;
pll_100 = AR724X_PLL_VAL_100;
pll_1000 = AR724X_PLL_VAL_1000;
break;
+
+ case AR71XX_SOC_AR7242:
+ pll_10 = AR7242_PLL_VAL_10;
+ pll_100 = AR7242_PLL_VAL_100;
+ pll_1000 = AR7242_PLL_VAL_1000;
+ break;
case AR71XX_SOC_AR9130:
case AR71XX_SOC_AR9132:
@@ -443,7 +464,6 @@
break;
case AR71XX_SOC_AR7241:
- case AR71XX_SOC_AR7242:
ar71xx_eth0_data.reset_bit |= AR724X_RESET_GE0_MDIO;
ar71xx_eth1_data.reset_bit |= AR724X_RESET_GE1_MDIO;
/* fall through */
@@ -462,6 +482,25 @@
pdata-fifo_cfg3 = 0x01f00140;
break;
+ case AR71XX_SOC_AR7242:
+ ar71xx_eth1_data.reset_bit |= AR724X_RESET_GE1_MDIO;
+ pdata-ddr_flush = id ? ar724x_ddr_flush_ge1
+ : ar724x_ddr_flush_ge0;
+ pdata-set_pll = id ? ar7242_set_pll_ge1
+ : ar7242_set_pll_ge0;
+ pdata-is_ar724x = 1;
+
+ if (!pdata-fifo_cfg1)
+ pdata-fifo_cfg1 = 0x0010;
+ if (!pdata-fifo_cfg2)
+ pdata-fifo_cfg2 = 0x015500aa;
+ if (!pdata-fifo_cfg3)
+ pdata-fifo_cfg3 = 0x01f00140;
+
+ pdata-has_gbit = 1;
+ break;
+
+
case AR71XX_SOC_AR9130:
pdata-ddr_flush = id ? ar91xx_ddr_flush_ge1
: ar91xx_ddr_flush_ge0;
Index: target/linux/ar71xx/files/arch/mips/ar71xx/mach-pb92.c
===
--- target/linux/ar71xx/files/arch/mips/ar71xx/mach-pb92.c (revision 24746)
+++ target/linux/ar71xx/files/arch/mips/ar71xx/mach-pb92.c (working copy)
@@ -80,25 +80,22 @@
}
};
+#define PB92_WAN_PHYMASK 0x02
+#define PB92_LAN_PHYMASK 0x1D
static void __init pb92_init(void)
{
u8 *mac = (u8 *) KSEG1ADDR(0x1fff);
ar71xx_add_device_m25p80(pb92_flash_data);
- ar71xx_add_device_mdio(~0);
+ ar71xx_add_device_mdio(~(PB92_WAN_PHYMASK | PB92_LAN_PHYMASK));
ar71xx_init_mac(ar71xx_eth0_data.mac_addr, mac, 0);
- ar71xx_eth0_data.phy_if_mode = PHY_INTERFACE_MODE_RMII;
+ ar71xx_eth0_data.phy_if_mode = PHY_INTERFACE_MODE_RGMII;
+ ar71xx_eth0_data.phy_mask = PB92_WAN_PHYMASK | PB92_LAN_PHYMASK;
ar71xx_eth0_data.speed = SPEED_1000;
ar71xx_eth0_data.duplex = DUPLEX_FULL;
- ar71xx_init_mac(ar71xx_eth1_data.mac_addr, mac, 1);
- ar71xx_eth1_data.phy_if_mode = PHY_INTERFACE_MODE_RMII;
- ar71xx_eth1_data.speed = SPEED_1000;
- ar71xx_eth1_data.duplex = DUPLEX_FULL;
-
ar71xx_add_device_eth(0);
- ar71xx_add_device_eth(1);
ar71xx_add_device_gpio_buttons(-1, PB92_BUTTONS_POLL_INTERVAL,
ARRAY_SIZE(pb92_gpio_buttons),
===
Signed-off-by: Jess Zhu jess@gmail.com
___
openwrt-devel mailing list
openwrt-devel@lists.openwrt.org
https://lists.openwrt.org/mailman/listinfo/openwrt-devel