diff options
author | Gabor Juhos <juhosg@openwrt.org> | 2009-12-09 08:03:31 +0000 |
---|---|---|
committer | Gabor Juhos <juhosg@openwrt.org> | 2009-12-09 08:03:31 +0000 |
commit | 2b988fa855579e5861fbebeac8c04d5fd5767419 (patch) | |
tree | 9543cfaa86ff51b93e9e5ec319a0f7e2978be46a /target/linux/ar71xx/files | |
parent | 2bff4bf4e5660346e78f1529043ae9241bf4f480 (diff) | |
download | upstream-2b988fa855579e5861fbebeac8c04d5fd5767419.tar.gz upstream-2b988fa855579e5861fbebeac8c04d5fd5767419.tar.bz2 upstream-2b988fa855579e5861fbebeac8c04d5fd5767419.zip |
ar71xx: register rtl8366-smi device on the DIR-825 B1 board
SVN-Revision: 18710
Diffstat (limited to 'target/linux/ar71xx/files')
-rw-r--r-- | target/linux/ar71xx/files/arch/mips/ar71xx/mach-dir-825-b1.c | 25 |
1 files changed, 21 insertions, 4 deletions
diff --git a/target/linux/ar71xx/files/arch/mips/ar71xx/mach-dir-825-b1.c b/target/linux/ar71xx/files/arch/mips/ar71xx/mach-dir-825-b1.c index ae95febd36..4fdb9fb5b4 100644 --- a/target/linux/ar71xx/files/arch/mips/ar71xx/mach-dir-825-b1.c +++ b/target/linux/ar71xx/files/arch/mips/ar71xx/mach-dir-825-b1.c @@ -19,6 +19,7 @@ #include <linux/pci.h> #include <linux/ath9k_platform.h> #include <linux/delay.h> +#include <linux/rtl8366_smi.h> #include <asm/mips_machine.h> #include <asm/mach-ar71xx/ar71xx.h> @@ -36,6 +37,9 @@ #define DIR825B1_GPIO_BTN_RESET 3 #define DIR825B1_GPIO_BTN_POWERSAVE 8 +#define DIR825B1_GPIO_RTL8366_SDA 5 +#define DIR825B1_GPIO_RTL8366_SCK 7 + #define DIR825B1_BUTTONS_POLL_INTERVAL 20 #define DIR825B1_CAL_LOCATION_0 0x1f661000 @@ -137,6 +141,19 @@ static struct gpio_button dir825b1_gpio_buttons[] __initdata = { } }; +static struct rtl8366_smi_platform_data dir825b1_rtl8366_smi_data = { + .gpio_sda = DIR825B1_GPIO_RTL8366_SDA, + .gpio_sck = DIR825B1_GPIO_RTL8366_SCK, +}; + +static struct platform_device dir825b1_rtl8366_smi_device = { + .name = "rtl8366-smi", + .id = -1, + .dev = { + .platform_data = &dir825b1_rtl8366_smi_data, + } +}; + #ifdef CONFIG_PCI static struct ar71xx_pci_irq dir825b1_pci_irqs[] __initdata = { { @@ -267,16 +284,15 @@ static void __init dir825b1_setup(void) ar71xx_add_device_mdio(0x0); + ar71xx_eth0_data.mii_bus_dev = &dir825b1_rtl8366_smi_device.dev; ar71xx_eth0_data.phy_if_mode = PHY_INTERFACE_MODE_RGMII; - ar71xx_eth0_data.phy_mask = 0x1e; ar71xx_eth0_data.speed = SPEED_1000; ar71xx_eth0_data.duplex = DUPLEX_FULL; ar71xx_eth0_pll_data.pll_1000 = 0x11110000; + ar71xx_eth1_data.mii_bus_dev = &dir825b1_rtl8366_smi_device.dev; ar71xx_eth1_data.phy_if_mode = PHY_INTERFACE_MODE_RGMII; - ar71xx_eth1_data.phy_mask = 0xc0; - ar71xx_eth1_data.speed = SPEED_1000; - ar71xx_eth1_data.duplex = DUPLEX_FULL; + ar71xx_eth1_data.phy_mask = 0x10; ar71xx_eth1_pll_data.pll_1000 = 0x11110000; ar71xx_add_device_eth(0); @@ -294,6 +310,7 @@ static void __init dir825b1_setup(void) ar71xx_add_device_usb(); + platform_device_register(&dir825b1_rtl8366_smi_device); dir825b1_pci_init(); } |