bee06fd5f18148a60d2581eec3eff360d6d15a95
[openwrt/svn-archive/archive.git] / target / linux / ramips / files / arch / mips / ralink / rt305x / mach-argus-atp52b.c
1 /*
2 * Argus ATP-52B router support
3 * http://www.argus-co.com/english/productsview.php?id=70&cid=81
4 *
5 * Copyright (C) 2011 Roman Yeryomin <roman@advem.lv>
6 *
7 * This program is free software; you can redistribute it and/or modify it
8 * under the terms of the GNU General Public License version 2 as published
9 * by the Free Software Foundation.
10 */
11
12 #include <linux/init.h>
13 #include <linux/platform_device.h>
14 #include <linux/mtd/mtd.h>
15 #include <linux/mtd/partitions.h>
16 #include <linux/mtd/physmap.h>
17
18 #include <asm/mach-ralink/machine.h>
19 #include <asm/mach-ralink/dev-gpio-buttons.h>
20 #include <asm/mach-ralink/dev-gpio-leds.h>
21 #include <asm/mach-ralink/rt305x.h>
22 #include <asm/mach-ralink/rt305x_regs.h>
23
24 #include "devices.h"
25
26 #define ARGUS_ATP52B_GPIO_LED_RUN 9
27 #define ARGUS_ATP52B_GPIO_LED_NET 13
28 #define ARGUS_ATP52B_GPIO_BUTTON_WPS 0
29 #define ARGUS_ATP52B_GPIO_BUTTON_RESET 10
30 #define ARGUS_ATP52B_BUTTONS_POLL_INTERVAL 20
31
32 static struct gpio_led argus_atp52b_leds_gpio[] __initdata = {
33 {
34 .name = "argus_atp52b:green:run",
35 .gpio = ARGUS_ATP52B_GPIO_LED_RUN,
36 .active_low = 1,
37 },
38 {
39 .name = "argus_atp52b:amber:net",
40 .gpio = ARGUS_ATP52B_GPIO_LED_NET,
41 .active_low = 1,
42 }
43 };
44
45 static struct gpio_button argus_atp52b_gpio_buttons[] __initdata = {
46 {
47 .desc = "wps",
48 .type = EV_KEY,
49 .code = KEY_WPS_BUTTON,
50 .threshold = 3,
51 .gpio = ARGUS_ATP52B_GPIO_BUTTON_WPS,
52 .active_low = 1,
53 },
54 {
55 .desc = "reset",
56 .type = EV_KEY,
57 .code = KEY_RESTART,
58 .threshold = 10,
59 .gpio = ARGUS_ATP52B_GPIO_BUTTON_RESET,
60 .active_low = 1,
61 }
62 };
63
64 #ifdef CONFIG_MTD_PARTITIONS
65 static struct mtd_partition argus_atp52b_partitions[] = {
66 {
67 .name = "bootloader",
68 .offset = 0,
69 .size = 0x030000,
70 .mask_flags = MTD_WRITEABLE,
71 }, {
72 .name = "config",
73 .offset = 0x030000,
74 .size = 0x010000,
75 }, {
76 .name = "factory",
77 .offset = 0x040000,
78 .size = 0x010000,
79 }, {
80 .name = "kernel",
81 .offset = 0x050000,
82 .size = 0x120000,
83 }, {
84 .name = "rootfs",
85 .offset = 0x170000,
86 .size = 0x680000,
87 }
88 };
89 #endif /* CONFIG_MTD_PARTITIONS */
90
91 static struct physmap_flash_data argus_atp52b_flash_data = {
92 #ifdef CONFIG_MTD_PARTITIONS
93 .nr_parts = ARRAY_SIZE(argus_atp52b_partitions),
94 .parts = argus_atp52b_partitions,
95 #endif
96 };
97
98 static void __init argus_atp52b_init(void)
99 {
100 rt305x_gpio_init(RT305X_GPIO_MODE_GPIO << RT305X_GPIO_MODE_UART0_SHIFT);
101 rt305x_register_flash(0, &argus_atp52b_flash_data);
102 ramips_register_gpio_leds(-1, ARRAY_SIZE(argus_atp52b_leds_gpio),
103 argus_atp52b_leds_gpio);
104 ramips_register_gpio_buttons(-1, ARGUS_ATP52B_BUTTONS_POLL_INTERVAL,
105 ARRAY_SIZE(argus_atp52b_gpio_buttons),
106 argus_atp52b_gpio_buttons);
107 rt305x_esw_data.vlan_config = RT305X_ESW_VLAN_CONFIG_WLLLL;
108 rt305x_register_ethernet();
109 rt305x_register_wifi();
110 rt305x_register_wdt();
111 }
112
113 MIPS_MACHINE(RAMIPS_MACH_ARGUS_ATP52B, "ARGUS_ATP52B", "Argus ATP-52B",
114 argus_atp52b_init);