From: Jo-Philipp Wich Date: Sun, 24 Jan 2010 23:31:49 +0000 (+0000) Subject: add initial support for the WZR-AGL300NH - patch by Joonas Lahtinen SVN-Revision: 19321 --- diff --git a/target/linux/ramips/files/arch/mips/include/asm/mach-ralink/machine.h b/target/linux/ramips/files/arch/mips/include/asm/mach-ralink/machine.h index 100ccfd71fcd..08e939d5d90d 100644 --- a/target/linux/ramips/files/arch/mips/include/asm/mach-ralink/machine.h +++ b/target/linux/ramips/files/arch/mips/include/asm/mach-ralink/machine.h @@ -1,6 +1,7 @@ /* * Ralink machine types * + * Copyright (C) 2010 Joonas Lahtinen * Copyright (C) 2009 Gabor Juhos * * This program is free software; you can redistribute it and/or modify it @@ -12,6 +13,7 @@ enum ramips_mach_type { RAMIPS_MACH_GENERIC, /* RT2880 based machines */ RAMIPS_MACH_RT_N15, /* Asus RT-N15 */ + RAMIPS_MACH_WZR_AGL300NH, /* Buffalo WZR-AGL300NH */ /* RT3050 based machines */ RAMIPS_MACH_DIR_300_REVB, /* D-Link DIR-300 rev B */ 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 5dad9c28fbbd..154d5f9f2600 100644 --- a/target/linux/ramips/files/arch/mips/ralink/common/prom.c +++ b/target/linux/ramips/files/arch/mips/ralink/common/prom.c @@ -1,6 +1,7 @@ /* * Ralink SoC specific prom routines * + * Copyright (C) 2010 Joonas Lahtinen * Copyright (C) 2009 Gabor Juhos * * This program is free software; you can redistribute it and/or modify it @@ -28,6 +29,9 @@ static struct board_rec boards[] __initdata = { { .name = "RT-N15", .mach_type = RAMIPS_MACH_RT_N15, + }, { + .name = "WZR-AGL300NH", + .mach_type = RAMIPS_MACH_WZR_AGL300NH, }, { .name = "DIR-300-revB", .mach_type = RAMIPS_MACH_DIR_300_REVB, diff --git a/target/linux/ramips/files/arch/mips/ralink/rt288x/Kconfig b/target/linux/ramips/files/arch/mips/ralink/rt288x/Kconfig index 3c7df5fcf739..1b0b85468b7c 100644 --- a/target/linux/ramips/files/arch/mips/ralink/rt288x/Kconfig +++ b/target/linux/ramips/files/arch/mips/ralink/rt288x/Kconfig @@ -7,6 +7,11 @@ config RT288X_MACH_RT_N15 default y select RALINK_DEV_GPIO_LEDS +config RT288X_MACH_WZR_AGL300NH + bool "Buffalo WZR-AGL300NH board support" + default y + select RALINK_DEV_GPIO_LEDS + endmenu endif diff --git a/target/linux/ramips/files/arch/mips/ralink/rt288x/Makefile b/target/linux/ramips/files/arch/mips/ralink/rt288x/Makefile index ab98fac7e5da..dda3e063fa82 100644 --- a/target/linux/ramips/files/arch/mips/ralink/rt288x/Makefile +++ b/target/linux/ramips/files/arch/mips/ralink/rt288x/Makefile @@ -1,6 +1,7 @@ # # Makefile for the Ralink RT288x SoC specific parts of the kernel # +# Copyright (C) 2010 Joonas Lahtinen # Copyright (C) 2008-2009 Gabor Juhos # Copyright (C) 2008 Imre Kaloz # @@ -13,3 +14,5 @@ obj-y := irq.o setup.o rt288x.o devices.o obj-$(CONFIG_EARLY_PRINTK) += early_printk.o obj-$(CONFIG_RT288X_MACH_RT_N15) += mach-rt-n15.o + +obj-$(CONFIG_RT288X_MACH_WZR_AGL300NH) += mach-wzr-agl300nh.o diff --git a/target/linux/ramips/files/arch/mips/ralink/rt288x/mach-wzr-agl300nh.c b/target/linux/ramips/files/arch/mips/ralink/rt288x/mach-wzr-agl300nh.c new file mode 100644 index 000000000000..c0a09cfb326c --- /dev/null +++ b/target/linux/ramips/files/arch/mips/ralink/rt288x/mach-wzr-agl300nh.c @@ -0,0 +1,105 @@ +/* + * Buffalo WZR-AGL300NH board support + * + * Copyright (C) 2010 Joonas Lahtinen + * + * 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 +#include +#include +#include +#include +#include + +#include +#include +#include +#include +#include + +#include "devices.h" + +#if 0 +#define WZR_AGL300NH_GPIO_LED_POWER XX +#define WZR_AGL300NH_GPIO_BUTTON_AOSS XX +#define WZR_AGL300NH_GPIO_BUTTON_RESET XX +#endif // 0 + +#ifdef CONFIG_MTD_PARTITIONS + +/* +From stock firmware: +mtd0: 00030000 00010000 "uboot" +mtd1: 00010000 00010000 "uboot_environ" +mtd2: 00010000 00010000 "factory_default" +mtd3: 000b0000 00010000 "linux" +mtd4: 002f0000 00010000 "rootfs" +mtd5: 00010000 00010000 "user_property" +*/ + +static struct mtd_partition wzr_agl300nh_partitions[] = { + { + .name = "uboot", + .offset = 0, + .size = 0x030000, + .mask_flags = MTD_WRITEABLE, + }, { + .name = "uboot_environ", + .offset = 0x030000, + .size = 0x010000, + .mask_flags = MTD_WRITEABLE, + }, { + .name = "factory_default", + .offset = 0x040000, + .size = 0x010000, + .mask_flags = MTD_WRITEABLE, + }, { + .name = "linux", + .offset = 0x050000, + .size = 0x0b0000, + }, { + .name = "rootfs", + .offset = 0x100000, + .size = 0x2f0000, + }, { + .name = "user_property", + .offset = 0x3f0000, + .size = 0x010000, + } +}; +#endif /* CONFIG_MTD_PARTITIONS */ + +static struct physmap_flash_data wzr_agl300nh_flash_data = { +#ifdef CONFIG_MTD_PARTITIONS + .nr_parts = ARRAY_SIZE(wzr_agl300nh_partitions), + .parts = wzr_agl300nh_partitions, +#endif +}; + +#if 0 +static struct gpio_led wzr_agl300nh_leds_gpio[] __initdata = { + { + .name = "wzr-agl300nh:green:power", + .gpio = WZR_AGL300NH_GPIO_LED_POWER, + .active_low = ??, + } +}; +#endif + +static void __init wzr_agl300nh_init(void) +{ + rt288x_gpio_init(RT2880_GPIO_MODE_UART0); + + rt288x_register_flash(0, &wzr_agl300nh_flash_data); + +/* + ramips_register_gpio_leds(-1, ARRAY_SIZE(wzr_agl300nh_leds_gpio), + wzr_agl300nh_leds_gpio); +*/ +} + +MIPS_MACHINE(RAMIPS_MACH_WZR_AGL300NH, "Buffalo WZR-AGL300NH", wzr_agl300nh_init); diff --git a/target/linux/ramips/rt288x/config-2.6.30 b/target/linux/ramips/rt288x/config-2.6.30 index 03a6797206ce..0167eb5aa9e6 100644 --- a/target/linux/ramips/rt288x/config-2.6.30 +++ b/target/linux/ramips/rt288x/config-2.6.30 @@ -13,8 +13,8 @@ CONFIG_BITREVERSE=y # CONFIG_CAVIUM_OCTEON_REFERENCE_BOARD is not set # CONFIG_CAVIUM_OCTEON_SIMULATOR is not set CONFIG_CC_OPTIMIZE_FOR_SIZE=y -CONFIG_CEVT_R4K_LIB=y CONFIG_CEVT_R4K=y +CONFIG_CEVT_R4K_LIB=y CONFIG_CMDLINE="console=ttyS1,57600 rootfstype=squashfs,jffs2" # CONFIG_CPU_BIG_ENDIAN is not set # CONFIG_CPU_CAVIUM_OCTEON is not set @@ -23,9 +23,9 @@ CONFIG_CPU_HAS_PREFETCH=y CONFIG_CPU_HAS_SYNC=y CONFIG_CPU_LITTLE_ENDIAN=y # CONFIG_CPU_LOONGSON2 is not set +CONFIG_CPU_MIPS32=y # CONFIG_CPU_MIPS32_R1 is not set CONFIG_CPU_MIPS32_R2=y -CONFIG_CPU_MIPS32=y # CONFIG_CPU_MIPS64_R1 is not set # CONFIG_CPU_MIPS64_R2 is not set CONFIG_CPU_MIPSR2=y @@ -47,16 +47,16 @@ CONFIG_CPU_SUPPORTS_HIGHMEM=y # CONFIG_CPU_TX39XX is not set # CONFIG_CPU_TX49XX is not set # CONFIG_CPU_VR41XX is not set -CONFIG_CSRC_R4K_LIB=y CONFIG_CSRC_R4K=y +CONFIG_CSRC_R4K_LIB=y CONFIG_DECOMPRESS_LZMA=y CONFIG_DEVPORT=y # CONFIG_DM9000 is not set CONFIG_DMA_NEED_PCI_MAP_STATE=y CONFIG_DMA_NONCOHERENT=y CONFIG_EARLY_PRINTK=y -CONFIG_GENERIC_CLOCKEVENTS_BUILD=y CONFIG_GENERIC_CLOCKEVENTS=y +CONFIG_GENERIC_CLOCKEVENTS_BUILD=y CONFIG_GENERIC_CMOS_UPDATE=y CONFIG_GENERIC_FIND_LAST_BIT=y CONFIG_GENERIC_FIND_NEXT_BIT=y @@ -88,8 +88,8 @@ CONFIG_IRQ_CPU=y # CONFIG_MACH_VR41XX is not set # CONFIG_MII is not set # CONFIG_MIKROTIK_RB532 is not set +CONFIG_MIPS=y # CONFIG_MIPS_COBALT is not set -# CONFIG_MIPS_FPU_EMU is not set CONFIG_MIPS_L1_CACHE_SHIFT=4 CONFIG_MIPS_MACHINE=y # CONFIG_MIPS_MALTA is not set @@ -97,8 +97,8 @@ CONFIG_MIPS_MT_DISABLED=y # CONFIG_MIPS_MT_SMP is not set # CONFIG_MIPS_MT_SMTC is not set CONFIG_MIPS_RALINK=y +# CONFIG_MIPS_RAMIPS_NET is not set # CONFIG_MIPS_SIM is not set -CONFIG_MIPS=y # CONFIG_MTD_CFI_INTELEXT is not set # CONFIG_MTD_COMPLEX_MAPPINGS is not set CONFIG_MTD_PHYSMAP=y @@ -117,6 +117,7 @@ CONFIG_RALINK_DEV_GPIO_LEDS=y CONFIG_RALINK_RT288X=y # CONFIG_RALINK_RT305X is not set CONFIG_RT288X_MACH_RT_N15=y +CONFIG_RT288X_MACH_WZR_AGL300NH=y CONFIG_SCHED_OMIT_FRAME_POINTER=y # CONFIG_SCSI_DMA is not set # CONFIG_SERIAL_8250_EXTENDED is not set