2 * Atheros AP9X reference board PCI initialization
4 * Copyright (C) 2009-2012 Gabor Juhos <juhosg@openwrt.org>
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.
11 #include <linux/pci.h>
12 #include <linux/ath9k_platform.h>
13 #include <linux/delay.h>
15 #include <asm/mach-ath79/ath79.h>
17 #include "dev-ap9x-pci.h"
18 #include "pci-ath9k-fixup.h"
21 static struct ath9k_platform_data ap9x_wmac0_data
= {
24 static struct ath9k_platform_data ap9x_wmac1_data
= {
27 static char ap9x_wmac0_mac
[6];
28 static char ap9x_wmac1_mac
[6];
30 __init
void ap9x_pci_setup_wmac_led_pin(unsigned wmac
, int pin
)
34 ap9x_wmac0_data
.led_pin
= pin
;
37 ap9x_wmac1_data
.led_pin
= pin
;
42 __init
void ap9x_pci_setup_wmac_led_name(unsigned wmac
, const char *led_name
)
46 ap9x_wmac0_data
.led_name
= led_name
;
49 ap9x_wmac1_data
.led_name
= led_name
;
54 __init
struct ath9k_platform_data
*ap9x_pci_get_wmac_data(unsigned wmac
)
58 return &ap9x_wmac0_data
;
61 return &ap9x_wmac1_data
;
67 __init
void ap9x_pci_setup_wmac_gpio(unsigned wmac
, u32 mask
, u32 val
)
71 ap9x_wmac0_data
.gpio_mask
= mask
;
72 ap9x_wmac0_data
.gpio_val
= val
;
75 ap9x_wmac1_data
.gpio_mask
= mask
;
76 ap9x_wmac1_data
.gpio_val
= val
;
81 __init
void ap9x_pci_setup_wmac_leds(unsigned wmac
, struct gpio_led
*leds
,
86 ap9x_wmac0_data
.leds
= leds
;
87 ap9x_wmac0_data
.num_leds
= num_leds
;
90 ap9x_wmac1_data
.leds
= leds
;
91 ap9x_wmac1_data
.num_leds
= num_leds
;
96 __init
void ap9x_pci_setup_wmac_btns(unsigned wmac
,
97 struct gpio_keys_button
*btns
,
98 unsigned num_btns
, unsigned poll_interval
)
100 struct ath9k_platform_data
*ap9x_wmac_data
;
102 if (!(ap9x_wmac_data
= ap9x_pci_get_wmac_data(wmac
)))
105 ap9x_wmac_data
->btns
= btns
;
106 ap9x_wmac_data
->num_btns
= num_btns
;
107 ap9x_wmac_data
->btn_poll_interval
= poll_interval
;
110 static int ap91_pci_plat_dev_init(struct pci_dev
*dev
)
112 switch (PCI_SLOT(dev
->devfn
)) {
114 dev
->dev
.platform_data
= &ap9x_wmac0_data
;
121 __init
void ap91_pci_init(u8
*cal_data
, u8
*mac_addr
)
124 memcpy(ap9x_wmac0_data
.eeprom_data
, cal_data
,
125 sizeof(ap9x_wmac0_data
.eeprom_data
));
128 memcpy(ap9x_wmac0_mac
, mac_addr
, sizeof(ap9x_wmac0_mac
));
129 ap9x_wmac0_data
.macaddr
= ap9x_wmac0_mac
;
132 ath79_pci_set_plat_dev_init(ap91_pci_plat_dev_init
);
133 ath79_register_pci();
135 pci_enable_ath9k_fixup(0, ap9x_wmac0_data
.eeprom_data
);
138 __init
void ap91_pci_init_simple(void)
140 ap91_pci_init(NULL
, NULL
);
141 ap9x_wmac0_data
.eeprom_name
= "pci_wmac0.eeprom";
144 static int ap94_pci_plat_dev_init(struct pci_dev
*dev
)
146 switch (PCI_SLOT(dev
->devfn
)) {
148 dev
->dev
.platform_data
= &ap9x_wmac0_data
;
152 dev
->dev
.platform_data
= &ap9x_wmac1_data
;
159 __init
void ap94_pci_init(u8
*cal_data0
, u8
*mac_addr0
,
160 u8
*cal_data1
, u8
*mac_addr1
)
163 memcpy(ap9x_wmac0_data
.eeprom_data
, cal_data0
,
164 sizeof(ap9x_wmac0_data
.eeprom_data
));
167 memcpy(ap9x_wmac1_data
.eeprom_data
, cal_data1
,
168 sizeof(ap9x_wmac1_data
.eeprom_data
));
171 memcpy(ap9x_wmac0_mac
, mac_addr0
, sizeof(ap9x_wmac0_mac
));
172 ap9x_wmac0_data
.macaddr
= ap9x_wmac0_mac
;
176 memcpy(ap9x_wmac1_mac
, mac_addr1
, sizeof(ap9x_wmac1_mac
));
177 ap9x_wmac1_data
.macaddr
= ap9x_wmac1_mac
;
180 ath79_pci_set_plat_dev_init(ap94_pci_plat_dev_init
);
181 ath79_register_pci();
183 pci_enable_ath9k_fixup(17, ap9x_wmac0_data
.eeprom_data
);
184 pci_enable_ath9k_fixup(18, ap9x_wmac1_data
.eeprom_data
);