Explorar el Código

ramips: register rtl8366s device on the RT-N15 board

SVN-Revision: 19403
Gabor Juhos hace 16 años
padre
commit
4af1f533bb

+ 21 - 2
target/linux/ramips/files/arch/mips/ralink/rt288x/mach-rt-n15.c

@@ -1,7 +1,7 @@
 /*
 /*
  *  Asus RT-N15 board support
  *  Asus RT-N15 board support
  *
  *
- *  Copyright (C) 2009 Gabor Juhos <[email protected]>
+ *  Copyright (C) 2009-2010 Gabor Juhos <[email protected]>
  *
  *
  *  This program is free software; you can redistribute it and/or modify it
  *  This program is free software; you can redistribute it and/or modify it
  *  under the terms of the GNU General Public License version 2 as published
  *  under the terms of the GNU General Public License version 2 as published
@@ -14,6 +14,7 @@
 #include <linux/mtd/partitions.h>
 #include <linux/mtd/partitions.h>
 #include <linux/mtd/physmap.h>
 #include <linux/mtd/physmap.h>
 #include <linux/leds.h>
 #include <linux/leds.h>
+#include <linux/rtl8366s.h>
 
 
 #include <asm/mach-ralink/machine.h>
 #include <asm/mach-ralink/machine.h>
 #include <asm/mach-ralink/dev_gpio_leds.h>
 #include <asm/mach-ralink/dev_gpio_leds.h>
@@ -26,6 +27,9 @@
 #define RT_N15_GPIO_BUTTON_WPS		0
 #define RT_N15_GPIO_BUTTON_WPS		0
 #define RT_N15_GPIO_BUTTON_RESET	12
 #define RT_N15_GPIO_BUTTON_RESET	12
 
 
+#define RT_N15_GPIO_RTL8366_SCK		2
+#define RT_N15_GPIO_RTL8366_SDA		1
+
 #ifdef CONFIG_MTD_PARTITIONS
 #ifdef CONFIG_MTD_PARTITIONS
 static struct mtd_partition rt_n15_partitions[] = {
 static struct mtd_partition rt_n15_partitions[] = {
 	{
 	{
@@ -74,14 +78,29 @@ static struct gpio_led rt_n15_leds_gpio[] __initdata = {
 	}
 	}
 };
 };
 
 
+static struct rtl8366s_platform_data rt_n15_rtl8366s_data = {
+	.gpio_sda        = RT_N15_GPIO_RTL8366_SDA,
+	.gpio_sck        = RT_N15_GPIO_RTL8366_SCK,
+};
+
+static struct platform_device rt_n15_rtl8366s_device = {
+	.name		= RTL8366S_DRIVER_NAME,
+	.id		= -1,
+	.dev = {
+		.platform_data	= &rt_n15_rtl8366s_data,
+	}
+};
+
 static void __init rt_n15_init(void)
 static void __init rt_n15_init(void)
 {
 {
-	rt288x_gpio_init(RT2880_GPIO_MODE_UART0);
+	rt288x_gpio_init(RT2880_GPIO_MODE_UART0 | RT2880_GPIO_MODE_I2C);
 
 
 	rt288x_register_flash(0, &rt_n15_flash_data);
 	rt288x_register_flash(0, &rt_n15_flash_data);
 
 
 	ramips_register_gpio_leds(-1, ARRAY_SIZE(rt_n15_leds_gpio),
 	ramips_register_gpio_leds(-1, ARRAY_SIZE(rt_n15_leds_gpio),
 				  rt_n15_leds_gpio);
 				  rt_n15_leds_gpio);
+
+	platform_device_register(&rt_n15_rtl8366s_device);
 }
 }
 
 
 MIPS_MACHINE(RAMIPS_MACH_RT_N15, "RT-N15", "Asus RT-N15", rt_n15_init);
 MIPS_MACHINE(RAMIPS_MACH_RT_N15, "RT-N15", "Asus RT-N15", rt_n15_init);

+ 3 - 0
target/linux/ramips/rt288x/config-2.6.30

@@ -118,6 +118,8 @@ CONFIG_RALINK_RT288X=y
 # CONFIG_RALINK_RT305X is not set
 # CONFIG_RALINK_RT305X is not set
 CONFIG_RT288X_MACH_RT_N15=y
 CONFIG_RT288X_MACH_RT_N15=y
 CONFIG_RT288X_MACH_WZR_AGL300NH=y
 CONFIG_RT288X_MACH_WZR_AGL300NH=y
+CONFIG_RTL8366S_PHY=y
+CONFIG_RTL8366_SMI=y
 CONFIG_SCHED_OMIT_FRAME_POINTER=y
 CONFIG_SCHED_OMIT_FRAME_POINTER=y
 # CONFIG_SCSI_DMA is not set
 # CONFIG_SCSI_DMA is not set
 # CONFIG_SERIAL_8250_EXTENDED is not set
 # CONFIG_SERIAL_8250_EXTENDED is not set
@@ -139,6 +141,7 @@ CONFIG_SERIAL_8250_RT288X=y
 # CONFIG_SLOW_WORK is not set
 # CONFIG_SLOW_WORK is not set
 CONFIG_SLUB=y
 CONFIG_SLUB=y
 CONFIG_SOC_RT288X=y
 CONFIG_SOC_RT288X=y
+CONFIG_SWCONFIG=y
 CONFIG_SYS_HAS_CPU_MIPS32_R1=y
 CONFIG_SYS_HAS_CPU_MIPS32_R1=y
 CONFIG_SYS_HAS_CPU_MIPS32_R2=y
 CONFIG_SYS_HAS_CPU_MIPS32_R2=y
 CONFIG_SYS_HAS_EARLY_PRINTK=y
 CONFIG_SYS_HAS_EARLY_PRINTK=y