1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
|
#include <linux/init.h>
#include <linux/platform_device.h>
#include <linux/leds.h>
#include <linux/gpio.h>
#include <linux/gpio_buttons.h>
#include <linux/mtd/mtd.h>
#include <linux/mtd/partitions.h>
#include <linux/mtd/physmap.h>
#include <linux/input.h>
#include <linux/etherdevice.h>
#include <machine.h>
#include <ifxmips.h>
#include <ifxmips_prom.h>
#include "arcaydian.h"
#include "devices.h"
#define ARV45XX_BRN 0x3f0000
#define ARV45XX_BRN_MAC 0x3f0016
#define ARV45XX_EBU_GPIO_START 0x14000000
#define ARV45XX_EBU_GPIO_SIZE 0x00001000
#define ARV4520_LATCH_SWITCH (1 << 10)
#ifdef CONFIG_MTD_PARTITIONS
static struct mtd_partition arv45xx_partitions[] =
{
{
.name = "uboot",
.offset = 0x0,
.size = 0x20000,
},
{
.name = "uboot_env",
.offset = 0x20000,
.size = 0x0,
},
{
.name = "kernel",
.offset = 0x0,
.size = 0x0,
},
{
.name = "rootfs",
.offset = 0x0,
.size = 0x0,
},
{
.name = "board_config",
.offset = 0x3f0000,
.size = 0x10000,
},
{
.name = "openwrt",
.offset = 0x0,
.size = 0x0,
},
};
#endif
static struct physmap_flash_data arv45xx_flash_data = {
#ifdef CONFIG_MTD_PARTITIONS
.nr_parts = ARRAY_SIZE(arv45xx_partitions),
.parts = arv45xx_partitions,
#endif
};
static struct gpio_led
arv4518_leds_gpio[] __initdata = {
{ .name = "ifx:blue:power", .gpio = 3, .active_low = 1, },
{ .name = "ifx:blue:adsl", .gpio = 4, .active_low = 1, },
{ .name = "ifx:blue:internet", .gpio = 5, .active_low = 1, },
{ .name = "ifx:red:power", .gpio = 6, .active_low = 1, },
{ .name = "ifx:yello:wps", .gpio = 7, .active_low = 1, },
{ .name = "ifx:red:wps", .gpio = 9, .active_low = 1, },
{ .name = "ifx:blue:voip", .gpio = 32, .active_low = 1, },
{ .name = "ifx:blue:fxs1", .gpio = 33, .active_low = 1, },
{ .name = "ifx:blue:fxs2", .gpio = 34, .active_low = 1, },
{ .name = "ifx:blue:fxo", .gpio = 35, .active_low = 1, },
{ .name = "ifx:blue:voice", .gpio = 36, .active_low = 1, },
{ .name = "ifx:blue:usb", .gpio = 37, .active_low = 1, },
{ .name = "ifx:blue:wlan", .gpio = 38, .active_low = 1, },
};
static struct gpio_led
arv4520_leds_gpio[] __initdata = {
{ .name = "ifx:blue:power", .gpio = 3, .active_low = 1, },
{ .name = "ifx:blue:adsl", .gpio = 4, .active_low = 1, },
{ .name = "ifx:blue:internet", .gpio = 5, .active_low = 1, },
{ .name = "ifx:red:power", .gpio = 6, .active_low = 1, },
{ .name = "ifx:yello:wps", .gpio = 7, .active_low = 1, },
{ .name = "ifx:red:wps", .gpio = 9, .active_low = 1, },
{ .name = "ifx:blue:voip", .gpio = 32, .active_low = 1, },
{ .name = "ifx:blue:fxs1", .gpio = 33, .active_low = 1, },
{ .name = "ifx:blue:fxs2", .gpio = 34, .active_low = 1, },
{ .name = "ifx:blue:fxo", .gpio = 35, .active_low = 1, },
{ .name = "ifx:blue:voice", .gpio = 36, .active_low = 1, },
{ .name = "ifx:blue:usb", .gpio = 37, .active_low = 1, },
{ .name = "ifx:blue:wlan", .gpio = 38, .active_low = 1, },
};
static struct gpio_led arv4525_leds_gpio[] __initdata = {
{ .name = "ifx:green:festnetz", .gpio = 4, .active_low = 1, },
{ .name = "ifx:green:internet", .gpio = 5, .active_low = 1, },
{ .name = "ifx:green:dsl", .gpio = 6, .active_low = 1, },
{ .name = "ifx:green:wlan", .gpio = 8, .active_low = 1, },
{ .name = "ifx:green:online", .gpio = 9, .active_low = 1, },
};
static struct resource arv45xx_ebu_resource =
{
.name = "ebu-gpio",
.start = ARV45XX_EBU_GPIO_START,
.end = ARV45XX_EBU_GPIO_START + ARV45XX_EBU_GPIO_SIZE - 1,
.flags = IORESOURCE_MEM,
};
static void __init
arv4518_init(void)
{
static unsigned char mac[6];
if(!ifxmix_detect_brn_block(ARV45XX_BRN))
ifxmips_find_brn_mac(ARV45XX_BRN_MAC, mac);
else
random_ether_addr(mac);
ifxmips_register_gpio();
danube_register_ebu_gpio(&arv45xx_ebu_resource, ARV4520_LATCH_SWITCH);
ifxmips_register_mtd(&arv45xx_flash_data);
danube_register_pci(PCI_CLOCK_EXT, 0);
ifxmips_register_wdt();
ifxmips_register_gpio_leds(arv4518_leds_gpio, ARRAY_SIZE(arv4518_leds_gpio));
danube_register_ethernet(mac, REV_MII_MODE);
danube_register_tapi();
}
MIPS_MACHINE(IFXMIPS_MACH_ARV4518,
"ARV4518",
"ARV4518 - SMC7908A-ISP",
arv4518_init);
static void __init
arv4520_init(void)
{
static unsigned char mac[6];
if(!ifxmix_detect_brn_block(ARV45XX_BRN))
ifxmips_find_brn_mac(ARV45XX_BRN_MAC, mac);
else
random_ether_addr(mac);
ifxmips_register_gpio();
danube_register_ebu_gpio(&arv45xx_ebu_resource, ARV4520_LATCH_SWITCH);
ifxmips_register_mtd(&arv45xx_flash_data);
danube_register_pci(PCI_CLOCK_EXT, 0);
ifxmips_register_wdt();
ifxmips_register_gpio_leds(arv4520_leds_gpio, ARRAY_SIZE(arv4520_leds_gpio));
danube_register_ethernet(mac, REV_MII_MODE);
danube_register_tapi();
}
MIPS_MACHINE(IFXMIPS_MACH_ARV4520,
"ARV452",
"ARV4520 - Airties WAV-281, Arcor A800",
arv4520_init);
static void __init
arv4525_init(void)
{
static unsigned char mac[6];
if(!ifxmix_detect_brn_block(ARV45XX_BRN))
ifxmips_find_brn_mac(ARV45XX_BRN_MAC, mac);
else
random_ether_addr(mac);
ifxmips_register_gpio();
ifxmips_register_mtd(&arv45xx_flash_data);
danube_register_pci(PCI_CLOCK_INT, 0);
ifxmips_register_wdt();
ifxmips_register_gpio_leds(arv4525_leds_gpio, ARRAY_SIZE(arv4525_leds_gpio));
danube_register_ethernet(mac, MII_MODE);
danube_register_tapi();
}
MIPS_MACHINE(IFXMIPS_MACH_ARV4525,
"ARV4525",
"ARV4525 - Speedport W502V",
arv4525_init);
|