ramips: use uncached address in detect_mem_size
[openwrt.git] / target / linux / ramips / files / arch / mips / ralink / rt305x / mach-f5d8235-v2.c
1 /*
2 * Belkin F5D8235 v2 board support
3 *
4 * Copyright (C) 2010 Roman Yeryomin <roman@advem.lv>
5 *
6 * This program is free software; you can redistribute it and/or modify it
7 * under the terms of the GNU General Public License version 2 as published
8 * by the Free Software Foundation.
9 */
10
11 #include <linux/init.h>
12 #include <linux/platform_device.h>
13 #include <linux/mtd/mtd.h>
14 #include <linux/mtd/partitions.h>
15 #include <linux/mtd/physmap.h>
16
17 #include <linux/rtl8366.h>
18
19 #include <asm/mach-ralink/machine.h>
20 #include <asm/mach-ralink/dev-gpio-buttons.h>
21 #include <asm/mach-ralink/dev-gpio-leds.h>
22 #include <asm/mach-ralink/rt305x.h>
23 #include <asm/mach-ralink/rt305x_regs.h>
24
25 #include "devices.h"
26
27 #define F5D8235_V2_GPIO_LED_INTERNET_BLUE 5
28 #define F5D8235_V2_GPIO_LED_INTERNET_AMBER 6
29 #define F5D8235_V2_GPIO_LED_MODEM_BLUE 11
30 #define F5D8235_V2_GPIO_LED_MODEM_AMBER 8
31 #define F5D8235_V2_GPIO_LED_ROUTER 9
32 #define F5D8235_V2_GPIO_LED_STORAGE_BLUE 23
33 #define F5D8235_V2_GPIO_LED_STORAGE_AMBER 22
34 #define F5D8235_V2_GPIO_LED_SECURITY_BLUE 13
35 #define F5D8235_V2_GPIO_LED_SECURITY_AMBER 12
36
37 static struct gpio_led f5d8235v2_leds_gpio[] __initdata = {
38 {
39 .name = "f5d8235v2:blue:internet",
40 .gpio = F5D8235_V2_GPIO_LED_INTERNET_BLUE,
41 .active_low = 1,
42 }, {
43 .name = "f5d8235v2:amber:internet",
44 .gpio = F5D8235_V2_GPIO_LED_INTERNET_AMBER,
45 .active_low = 1,
46 }, {
47 .name = "f5d8235v2:blue:modem",
48 .gpio = F5D8235_V2_GPIO_LED_MODEM_BLUE,
49 .active_low = 1,
50 }, {
51 .name = "f5d8235v2:amber:modem",
52 .gpio = F5D8235_V2_GPIO_LED_MODEM_AMBER,
53 .active_low = 1,
54 }, {
55 .name = "f5d8235v2:blue:router",
56 .gpio = F5D8235_V2_GPIO_LED_ROUTER,
57 .active_low = 1,
58 }, {
59 .name = "f5d8235v2:blue:storage",
60 .gpio = F5D8235_V2_GPIO_LED_STORAGE_BLUE,
61 .active_low = 1,
62 }, {
63 .name = "f5d8235v2:amber:storage",
64 .gpio = F5D8235_V2_GPIO_LED_STORAGE_AMBER,
65 .active_low = 1,
66 }, {
67 .name = "f5d8235v2:blue:security",
68 .gpio = F5D8235_V2_GPIO_LED_SECURITY_BLUE,
69 .active_low = 1,
70 }, {
71 .name = "f5d8235v2:amber:security",
72 .gpio = F5D8235_V2_GPIO_LED_SECURITY_AMBER,
73 .active_low = 1,
74 }
75 };
76
77 static struct mtd_partition f5d8235v2_partitions[] = {
78 {
79 .name = "u-boot",
80 .offset = 0,
81 .size = 0x050000,
82 .mask_flags = MTD_WRITEABLE,
83 }, {
84 .name = "kernel and rootfs",
85 .offset = 0x050000,
86 .size = 0x790000,
87 }, {
88 .name = "rootfs",
89 .offset = 0x1D0000,
90 .size = 0x610000,
91 }, {
92 .name = "nvram",
93 .offset = 0x7E0000,
94 .size = 0x010000,
95 }, {
96 .name = "factory",
97 .offset = 0x7F0000,
98 .size = 0x010000,
99 }
100 };
101
102 static struct physmap_flash_data f5d8235v2_flash_data = {
103 .nr_parts = ARRAY_SIZE(f5d8235v2_partitions),
104 .parts = f5d8235v2_partitions,
105 };
106
107
108 static struct rtl8366_platform_data f5d8235v2_switch_data = {
109 .gpio_sda = RT305X_GPIO_I2C_SD,
110 .gpio_sck = RT305X_GPIO_I2C_SCLK,
111 };
112
113 static struct platform_device f5d8235v2_switch = {
114 .name = RTL8366RB_DRIVER_NAME,
115 .id = -1,
116 .dev = {
117 .platform_data = &f5d8235v2_switch_data,
118 }
119 };
120
121 static void __init f5d8235v2_init(void)
122 {
123 rt305x_gpio_init((RT305X_GPIO_MODE_GPIO <<
124 RT305X_GPIO_MODE_UART0_SHIFT) |
125 RT305X_GPIO_MODE_I2C |
126 RT305X_GPIO_MODE_SPI |
127 RT305X_GPIO_MODE_MDIO);
128 rt305x_register_flash(0, &f5d8235v2_flash_data);
129 ramips_register_gpio_leds(-1, ARRAY_SIZE(f5d8235v2_leds_gpio),
130 f5d8235v2_leds_gpio);
131 rt305x_esw_data.vlan_config = RT305X_ESW_VLAN_CONFIG_NONE;
132 rt305x_register_ethernet();
133 platform_device_register(&f5d8235v2_switch);
134 rt305x_register_wifi();
135 rt305x_register_wdt();
136 rt305x_register_usb();
137 }
138
139 MIPS_MACHINE(RAMIPS_MACH_F5D8235_V2, "F5D8235_V2", "Belkin F5D8235 v2",
140 f5d8235v2_init);
This page took 0.049438 seconds and 5 git commands to generate.