diff options
author | Gabor Juhos <juhosg@openwrt.org> | 2011-01-04 15:28:29 -0500 |
---|---|---|
committer | Ralf Baechle <ralf@linux-mips.org> | 2011-01-18 13:30:28 -0500 |
commit | f5b35d0b16a08e6c1e7c8a41fa87ad10cf9aefa4 (patch) | |
tree | fd4991f97b52aa714f5aebe955a2b897dbca0ecc /arch | |
parent | aa6695ec8b51da7aaa245310073ddd39a306a77f (diff) |
MIPS: ath79: add common WMAC device for AR913X based boards
Add common platform_device and helper code to make the registration
of the built-in wireless MAC easier on the Atheros AR9130/AR9132
based boards. Also register the WMAC device on the AR81 board.
Signed-off-by: Gabor Juhos <juhosg@openwrt.org>
Cc: linux-mips@linux-mips.org
Cc: Imre Kaloz <kaloz@openwrt.org>,
Cc: Luis R. Rodriguez <lrodriguez@atheros.com>
Cc: Cliff Holden <Cliff.Holden@Atheros.com>
Cc: Kathy Giori <Kathy.Giori@Atheros.com>
Patchwork: https://patchwork.linux-mips.org/patch/1962/
Signed-off-by: Ralf Baechle <ralf@linux-mips.org>
Diffstat (limited to 'arch')
-rw-r--r-- | arch/mips/ath79/Kconfig | 5 | ||||
-rw-r--r-- | arch/mips/ath79/Makefile | 1 | ||||
-rw-r--r-- | arch/mips/ath79/dev-ar913x-wmac.c | 60 | ||||
-rw-r--r-- | arch/mips/ath79/dev-ar913x-wmac.h | 17 | ||||
-rw-r--r-- | arch/mips/ath79/mach-ap81.c | 6 | ||||
-rw-r--r-- | arch/mips/include/asm/mach-ath79/ar71xx_regs.h | 3 |
6 files changed, 92 insertions, 0 deletions
diff --git a/arch/mips/ath79/Kconfig b/arch/mips/ath79/Kconfig index 2e397708e2f7..b05828260f7f 100644 --- a/arch/mips/ath79/Kconfig +++ b/arch/mips/ath79/Kconfig | |||
@@ -5,6 +5,7 @@ menu "Atheros AR71XX/AR724X/AR913X machine selection" | |||
5 | config ATH79_MACH_AP81 | 5 | config ATH79_MACH_AP81 |
6 | bool "Atheros AP81 reference board" | 6 | bool "Atheros AP81 reference board" |
7 | select SOC_AR913X | 7 | select SOC_AR913X |
8 | select ATH79_DEV_AR913X_WMAC | ||
8 | select ATH79_DEV_GPIO_BUTTONS | 9 | select ATH79_DEV_GPIO_BUTTONS |
9 | select ATH79_DEV_LEDS_GPIO | 10 | select ATH79_DEV_LEDS_GPIO |
10 | select ATH79_DEV_SPI | 11 | select ATH79_DEV_SPI |
@@ -33,6 +34,10 @@ config SOC_AR724X | |||
33 | config SOC_AR913X | 34 | config SOC_AR913X |
34 | def_bool n | 35 | def_bool n |
35 | 36 | ||
37 | config ATH79_DEV_AR913X_WMAC | ||
38 | depends on SOC_AR913X | ||
39 | def_bool n | ||
40 | |||
36 | config ATH79_DEV_GPIO_BUTTONS | 41 | config ATH79_DEV_GPIO_BUTTONS |
37 | def_bool n | 42 | def_bool n |
38 | 43 | ||
diff --git a/arch/mips/ath79/Makefile b/arch/mips/ath79/Makefile index a245e3645271..c33d4653007c 100644 --- a/arch/mips/ath79/Makefile +++ b/arch/mips/ath79/Makefile | |||
@@ -16,6 +16,7 @@ obj-$(CONFIG_EARLY_PRINTK) += early_printk.o | |||
16 | # Devices | 16 | # Devices |
17 | # | 17 | # |
18 | obj-y += dev-common.o | 18 | obj-y += dev-common.o |
19 | obj-$(CONFIG_ATH79_DEV_AR913X_WMAC) += dev-ar913x-wmac.o | ||
19 | obj-$(CONFIG_ATH79_DEV_GPIO_BUTTONS) += dev-gpio-buttons.o | 20 | obj-$(CONFIG_ATH79_DEV_GPIO_BUTTONS) += dev-gpio-buttons.o |
20 | obj-$(CONFIG_ATH79_DEV_LEDS_GPIO) += dev-leds-gpio.o | 21 | obj-$(CONFIG_ATH79_DEV_LEDS_GPIO) += dev-leds-gpio.o |
21 | obj-$(CONFIG_ATH79_DEV_SPI) += dev-spi.o | 22 | obj-$(CONFIG_ATH79_DEV_SPI) += dev-spi.o |
diff --git a/arch/mips/ath79/dev-ar913x-wmac.c b/arch/mips/ath79/dev-ar913x-wmac.c new file mode 100644 index 000000000000..48f425a5ba28 --- /dev/null +++ b/arch/mips/ath79/dev-ar913x-wmac.c | |||
@@ -0,0 +1,60 @@ | |||
1 | /* | ||
2 | * Atheros AR913X SoC built-in WMAC device support | ||
3 | * | ||
4 | * Copyright (C) 2008-2010 Gabor Juhos <juhosg@openwrt.org> | ||
5 | * Copyright (C) 2008 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 <linux/init.h> | ||
13 | #include <linux/delay.h> | ||
14 | #include <linux/irq.h> | ||
15 | #include <linux/platform_device.h> | ||
16 | #include <linux/ath9k_platform.h> | ||
17 | |||
18 | #include <asm/mach-ath79/ath79.h> | ||
19 | #include <asm/mach-ath79/ar71xx_regs.h> | ||
20 | #include "dev-ar913x-wmac.h" | ||
21 | |||
22 | static struct ath9k_platform_data ar913x_wmac_data; | ||
23 | |||
24 | static struct resource ar913x_wmac_resources[] = { | ||
25 | { | ||
26 | .start = AR913X_WMAC_BASE, | ||
27 | .end = AR913X_WMAC_BASE + AR913X_WMAC_SIZE - 1, | ||
28 | .flags = IORESOURCE_MEM, | ||
29 | }, { | ||
30 | .start = ATH79_CPU_IRQ_IP2, | ||
31 | .end = ATH79_CPU_IRQ_IP2, | ||
32 | .flags = IORESOURCE_IRQ, | ||
33 | }, | ||
34 | }; | ||
35 | |||
36 | static struct platform_device ar913x_wmac_device = { | ||
37 | .name = "ath9k", | ||
38 | .id = -1, | ||
39 | .resource = ar913x_wmac_resources, | ||
40 | .num_resources = ARRAY_SIZE(ar913x_wmac_resources), | ||
41 | .dev = { | ||
42 | .platform_data = &ar913x_wmac_data, | ||
43 | }, | ||
44 | }; | ||
45 | |||
46 | void __init ath79_register_ar913x_wmac(u8 *cal_data) | ||
47 | { | ||
48 | if (cal_data) | ||
49 | memcpy(ar913x_wmac_data.eeprom_data, cal_data, | ||
50 | sizeof(ar913x_wmac_data.eeprom_data)); | ||
51 | |||
52 | /* reset the WMAC */ | ||
53 | ath79_device_reset_set(AR913X_RESET_AMBA2WMAC); | ||
54 | mdelay(10); | ||
55 | |||
56 | ath79_device_reset_clear(AR913X_RESET_AMBA2WMAC); | ||
57 | mdelay(10); | ||
58 | |||
59 | platform_device_register(&ar913x_wmac_device); | ||
60 | } | ||
diff --git a/arch/mips/ath79/dev-ar913x-wmac.h b/arch/mips/ath79/dev-ar913x-wmac.h new file mode 100644 index 000000000000..579d562bbda8 --- /dev/null +++ b/arch/mips/ath79/dev-ar913x-wmac.h | |||
@@ -0,0 +1,17 @@ | |||
1 | /* | ||
2 | * Atheros AR913X SoC built-in WMAC device support | ||
3 | * | ||
4 | * Copyright (C) 2008-2010 Gabor Juhos <juhosg@openwrt.org> | ||
5 | * Copyright (C) 2008 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 | #ifndef _ATH79_DEV_AR913X_WMAC_H | ||
13 | #define _ATH79_DEV_AR913X_WMAC_H | ||
14 | |||
15 | void ath79_register_ar913x_wmac(u8 *cal_data); | ||
16 | |||
17 | #endif /* _ATH79_DEV_AR913X_WMAC_H */ | ||
diff --git a/arch/mips/ath79/mach-ap81.c b/arch/mips/ath79/mach-ap81.c index 4e4ccd4f80d9..eee4c121deb4 100644 --- a/arch/mips/ath79/mach-ap81.c +++ b/arch/mips/ath79/mach-ap81.c | |||
@@ -10,6 +10,7 @@ | |||
10 | */ | 10 | */ |
11 | 11 | ||
12 | #include "machtypes.h" | 12 | #include "machtypes.h" |
13 | #include "dev-ar913x-wmac.h" | ||
13 | #include "dev-gpio-buttons.h" | 14 | #include "dev-gpio-buttons.h" |
14 | #include "dev-leds-gpio.h" | 15 | #include "dev-leds-gpio.h" |
15 | #include "dev-spi.h" | 16 | #include "dev-spi.h" |
@@ -25,6 +26,8 @@ | |||
25 | #define AP81_KEYS_POLL_INTERVAL 20 /* msecs */ | 26 | #define AP81_KEYS_POLL_INTERVAL 20 /* msecs */ |
26 | #define AP81_KEYS_DEBOUNCE_INTERVAL (3 * AP81_KEYS_POLL_INTERVAL) | 27 | #define AP81_KEYS_DEBOUNCE_INTERVAL (3 * AP81_KEYS_POLL_INTERVAL) |
27 | 28 | ||
29 | #define AP81_CAL_DATA_ADDR 0x1fff1000 | ||
30 | |||
28 | static struct gpio_led ap81_leds_gpio[] __initdata = { | 31 | static struct gpio_led ap81_leds_gpio[] __initdata = { |
29 | { | 32 | { |
30 | .name = "ap81:green:status", | 33 | .name = "ap81:green:status", |
@@ -79,6 +82,8 @@ static struct ath79_spi_platform_data ap81_spi_data = { | |||
79 | 82 | ||
80 | static void __init ap81_setup(void) | 83 | static void __init ap81_setup(void) |
81 | { | 84 | { |
85 | u8 *cal_data = (u8 *) KSEG1ADDR(AP81_CAL_DATA_ADDR); | ||
86 | |||
82 | ath79_register_leds_gpio(-1, ARRAY_SIZE(ap81_leds_gpio), | 87 | ath79_register_leds_gpio(-1, ARRAY_SIZE(ap81_leds_gpio), |
83 | ap81_leds_gpio); | 88 | ap81_leds_gpio); |
84 | ath79_register_gpio_keys_polled(-1, AP81_KEYS_POLL_INTERVAL, | 89 | ath79_register_gpio_keys_polled(-1, AP81_KEYS_POLL_INTERVAL, |
@@ -86,6 +91,7 @@ static void __init ap81_setup(void) | |||
86 | ap81_gpio_keys); | 91 | ap81_gpio_keys); |
87 | ath79_register_spi(&ap81_spi_data, ap81_spi_info, | 92 | ath79_register_spi(&ap81_spi_data, ap81_spi_info, |
88 | ARRAY_SIZE(ap81_spi_info)); | 93 | ARRAY_SIZE(ap81_spi_info)); |
94 | ath79_register_ar913x_wmac(cal_data); | ||
89 | } | 95 | } |
90 | 96 | ||
91 | MIPS_MACHINE(ATH79_MACH_AP81, "AP81", "Atheros AP81 reference board", | 97 | MIPS_MACHINE(ATH79_MACH_AP81, "AP81", "Atheros AP81 reference board", |
diff --git a/arch/mips/include/asm/mach-ath79/ar71xx_regs.h b/arch/mips/include/asm/mach-ath79/ar71xx_regs.h index 4f2b621638d9..cda1c8070b27 100644 --- a/arch/mips/include/asm/mach-ath79/ar71xx_regs.h +++ b/arch/mips/include/asm/mach-ath79/ar71xx_regs.h | |||
@@ -34,6 +34,9 @@ | |||
34 | #define AR71XX_RESET_BASE (AR71XX_APB_BASE + 0x00060000) | 34 | #define AR71XX_RESET_BASE (AR71XX_APB_BASE + 0x00060000) |
35 | #define AR71XX_RESET_SIZE 0x100 | 35 | #define AR71XX_RESET_SIZE 0x100 |
36 | 36 | ||
37 | #define AR913X_WMAC_BASE (AR71XX_APB_BASE + 0x000C0000) | ||
38 | #define AR913X_WMAC_SIZE 0x30000 | ||
39 | |||
37 | /* | 40 | /* |
38 | * DDR_CTRL block | 41 | * DDR_CTRL block |
39 | */ | 42 | */ |