blob: 1c78d497f93064b1f4dd728ed5e0c2633e5cf01d [file] [log] [blame]
Gabor Juhosaa6695e2011-01-04 21:28:28 +01001/*
2 * Atheros AP81 board support
3 *
4 * Copyright (C) 2009-2010 Gabor Juhos <juhosg@openwrt.org>
5 * Copyright (C) 2009 Imre Kaloz <kaloz@openwrt.org>
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 "machtypes.h"
Gabor Juhos009b9d52011-11-18 00:17:54 +000013#include "dev-wmac.h"
Gabor Juhosaa6695e2011-01-04 21:28:28 +010014#include "dev-gpio-buttons.h"
15#include "dev-leds-gpio.h"
16#include "dev-spi.h"
Gabor Juhos7e98aa42011-06-05 23:38:46 +020017#include "dev-usb.h"
Gabor Juhosaa6695e2011-01-04 21:28:28 +010018
19#define AP81_GPIO_LED_STATUS 1
20#define AP81_GPIO_LED_AOSS 3
21#define AP81_GPIO_LED_WLAN 6
22#define AP81_GPIO_LED_POWER 14
23
24#define AP81_GPIO_BTN_SW4 12
25#define AP81_GPIO_BTN_SW1 21
26
27#define AP81_KEYS_POLL_INTERVAL 20 /* msecs */
28#define AP81_KEYS_DEBOUNCE_INTERVAL (3 * AP81_KEYS_POLL_INTERVAL)
29
Gabor Juhosf5b35d02011-01-04 21:28:29 +010030#define AP81_CAL_DATA_ADDR 0x1fff1000
31
Gabor Juhosaa6695e2011-01-04 21:28:28 +010032static struct gpio_led ap81_leds_gpio[] __initdata = {
33 {
34 .name = "ap81:green:status",
35 .gpio = AP81_GPIO_LED_STATUS,
36 .active_low = 1,
37 }, {
38 .name = "ap81:amber:aoss",
39 .gpio = AP81_GPIO_LED_AOSS,
40 .active_low = 1,
41 }, {
42 .name = "ap81:green:wlan",
43 .gpio = AP81_GPIO_LED_WLAN,
44 .active_low = 1,
45 }, {
46 .name = "ap81:green:power",
47 .gpio = AP81_GPIO_LED_POWER,
48 .active_low = 1,
49 }
50};
51
52static struct gpio_keys_button ap81_gpio_keys[] __initdata = {
53 {
54 .desc = "sw1",
55 .type = EV_KEY,
56 .code = BTN_0,
57 .debounce_interval = AP81_KEYS_DEBOUNCE_INTERVAL,
58 .gpio = AP81_GPIO_BTN_SW1,
59 .active_low = 1,
60 } , {
61 .desc = "sw4",
62 .type = EV_KEY,
63 .code = BTN_1,
64 .debounce_interval = AP81_KEYS_DEBOUNCE_INTERVAL,
65 .gpio = AP81_GPIO_BTN_SW4,
66 .active_low = 1,
67 }
68};
69
70static struct spi_board_info ap81_spi_info[] = {
71 {
72 .bus_num = 0,
73 .chip_select = 0,
74 .max_speed_hz = 25000000,
75 .modalias = "m25p64",
76 }
77};
78
79static struct ath79_spi_platform_data ap81_spi_data = {
80 .bus_num = 0,
Ralf Baechle70342282013-01-22 12:59:30 +010081 .num_chipselect = 1,
Gabor Juhosaa6695e2011-01-04 21:28:28 +010082};
83
84static void __init ap81_setup(void)
85{
Gabor Juhosf5b35d02011-01-04 21:28:29 +010086 u8 *cal_data = (u8 *) KSEG1ADDR(AP81_CAL_DATA_ADDR);
87
Gabor Juhosaa6695e2011-01-04 21:28:28 +010088 ath79_register_leds_gpio(-1, ARRAY_SIZE(ap81_leds_gpio),
89 ap81_leds_gpio);
90 ath79_register_gpio_keys_polled(-1, AP81_KEYS_POLL_INTERVAL,
91 ARRAY_SIZE(ap81_gpio_keys),
92 ap81_gpio_keys);
93 ath79_register_spi(&ap81_spi_data, ap81_spi_info,
94 ARRAY_SIZE(ap81_spi_info));
Gabor Juhos67b0f0f2011-11-18 00:17:53 +000095 ath79_register_wmac(cal_data);
Gabor Juhos7e98aa42011-06-05 23:38:46 +020096 ath79_register_usb();
Gabor Juhosaa6695e2011-01-04 21:28:28 +010097}
98
99MIPS_MACHINE(ATH79_MACH_AP81, "AP81", "Atheros AP81 reference board",
100 ap81_setup);