diff options
| author | blogic <blogic@3c298f89-4303-0410-b956-a3cf2f4a3e73> | 2009-10-24 20:55:36 +0000 | 
|---|---|---|
| committer | blogic <blogic@3c298f89-4303-0410-b956-a3cf2f4a3e73> | 2009-10-24 20:55:36 +0000 | 
| commit | ffb4faa1d1991e8c64b4f9ca182d6b053812828f (patch) | |
| tree | 3f5964d2b706c20cbe19b0e1f278456ed473694b /target/linux/ramips/files/arch/mips/ralink | |
| parent | 06d45609f690dd4c74bb02aba6fc261f099c833d (diff) | |
[ramips] adds mach type for fonera20n
git-svn-id: svn://svn.openwrt.org/openwrt/trunk@18132 3c298f89-4303-0410-b956-a3cf2f4a3e73
Diffstat (limited to 'target/linux/ramips/files/arch/mips/ralink')
4 files changed, 109 insertions, 0 deletions
| diff --git a/target/linux/ramips/files/arch/mips/ralink/common/prom.c b/target/linux/ramips/files/arch/mips/ralink/common/prom.c index 20b8d5fb6..587f16110 100644 --- a/target/linux/ramips/files/arch/mips/ralink/common/prom.c +++ b/target/linux/ramips/files/arch/mips/ralink/common/prom.c @@ -41,6 +41,9 @@ static struct board_rec boards[] __initdata = {  	}, {  		.name		= "WHR-G300N",  		.mach_type	= RAMIPS_MACH_WHR_G300N, +	}, { +		.name		= "FONERA20N", +		.mach_type	= RAMIPS_MACH_FONERA20N,  	}  }; diff --git a/target/linux/ramips/files/arch/mips/ralink/rt305x/Kconfig b/target/linux/ramips/files/arch/mips/ralink/rt305x/Kconfig index 383f79d2b..ef52c05df 100644 --- a/target/linux/ramips/files/arch/mips/ralink/rt305x/Kconfig +++ b/target/linux/ramips/files/arch/mips/ralink/rt305x/Kconfig @@ -17,6 +17,11 @@ config RT305X_MACH_V22RW_2X2  	default y  	select RALINK_DEV_GPIO_LEDS +config RT305X_MACH_FONERA20N +	bool "La Fonera20N board support" +	default y +	select RALINK_DEV_GPIO_LEDS +  endmenu  endif diff --git a/target/linux/ramips/files/arch/mips/ralink/rt305x/Makefile b/target/linux/ramips/files/arch/mips/ralink/rt305x/Makefile index 4eeaf2139..a1278c305 100644 --- a/target/linux/ramips/files/arch/mips/ralink/rt305x/Makefile +++ b/target/linux/ramips/files/arch/mips/ralink/rt305x/Makefile @@ -14,3 +14,4 @@ obj-$(CONFIG_EARLY_PRINTK)		+= early_printk.o  obj-$(CONFIG_RT305X_MACH_DIR_300_REVB)	+= mach-dir-300-revb.o  obj-$(CONFIG_RT305X_MACH_V22RW_2X2)	+= mach-v22rw-2x2.o  obj-$(CONFIG_RT305X_MACH_WHR_G300N)	+= mach-whr-g300n.o +obj-$(CONFIG_RT305X_MACH_FONERA20N)	+= mach-fonera20n.o diff --git a/target/linux/ramips/files/arch/mips/ralink/rt305x/mach-fonera20n.c b/target/linux/ramips/files/arch/mips/ralink/rt305x/mach-fonera20n.c new file mode 100644 index 000000000..3a444caeb --- /dev/null +++ b/target/linux/ramips/files/arch/mips/ralink/rt305x/mach-fonera20n.c @@ -0,0 +1,100 @@ +/* + *  La Fonera20N board support + * + *  Copyright (C) 2009 John Crispin <blogic@openwrt.org> + * + *  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 + *  by the Free Software Foundation. + */ + +#include <linux/init.h> +#include <linux/platform_device.h> +#include <linux/mtd/mtd.h> +#include <linux/mtd/partitions.h> +#include <linux/mtd/physmap.h> +#include <linux/leds.h> + +#include <asm/mips_machine.h> +#include <asm/mach-ralink/machine.h> +#include <asm/mach-ralink/dev_gpio_leds.h> +#include <asm/mach-ralink/rt305x.h> +#include <asm/mach-ralink/rt305x_regs.h> + +#include "devices.h" + +#define FONERA20N_GPIO_BUTTON_RESET	12 +#define FONERA20N_GPIO_SWITCH		13 +#define FONERA20N_GPIO_LED_WIFI		7 +#define FONERA20N_GPIO_LED_POWER	9 +#define FONERA20N_GPIO_LED_USB		14 + +#ifdef CONFIG_MTD_PARTITIONS +static struct mtd_partition fonera20n_partitions[] = { +	{ +		.name	= "u-boot", +		.offset	= 0, +		.size	= 0x030000, +		.mask_flags = MTD_WRITEABLE, +	}, { +		.name	= "u-boot-env", +		.offset	= 0x030000, +		.size	= 0x010000, +		.mask_flags = MTD_WRITEABLE, +	}, { +		.name	= "factory", +		.offset	= 0x040000, +		.size	= 0x010000, +		.mask_flags = MTD_WRITEABLE, +	}, { +		.name	= "kernel", +		.offset	= 0x050000, +		.size	= 0x0a0000, +	}, { +		.name	= "rootfs", +		.offset	= 0x150000, +		.size	= 0x6b0000, +	}, { +		.name	= "openwrt", +		.offset	= 0x050000, +		.size	= 0x7b0000, +	} +}; +#endif /* CONFIG_MTD_PARTITIONS */ + +static struct physmap_flash_data fonera20n_flash_data = { +#ifdef CONFIG_MTD_PARTITIONS +	.nr_parts	= ARRAY_SIZE(fonera20n_partitions), +	.parts		= fonera20n_partitions, +#endif +}; + +static struct gpio_led fonera20n_leds_gpio[] __initdata = { +	{ +		.name		= "fonera20n:orange:wifi", +		.gpio		= FONERA20N_GPIO_LED_WIFI, +		.active_low	= 1, +	}, { +		.name		= "fonera20n:green:power", +		.gpio		= FONERA20N_GPIO_LED_POWER, +		.active_low	= 1, +	}, { +		.name		= "fonera20n:orange:usb", +		.gpio		= FONERA20N_GPIO_LED_USB, +		.active_low	= 1, +	} +}; + +static void __init fonera20n_init(void) +{ +	rt305x_gpio_init(RT305X_GPIO_MODE_GPIO << RT305X_GPIO_MODE_UART0_SHIFT); + +	rt305x_register_flash(0, &fonera20n_flash_data); + +	ramips_register_gpio_leds(-1, ARRAY_SIZE(fonera20n_leds_gpio), +				  fonera20n_leds_gpio); + +	rt305x_register_ethernet(); +} + +MIPS_MACHINE(RAMIPS_MACH_FONERA20N, "La Fonera 2.0N", fonera20n_init); | 
