diff options
author | Bob Copeland <me@bobcopeland.com> | 2009-03-08 00:10:21 -0500 |
---|---|---|
committer | John W. Linville <linville@tuxdriver.com> | 2009-03-16 18:09:37 -0400 |
commit | cdb02dc6146950155e79a4e3225e1b58cf2b0c54 (patch) | |
tree | ae8163c32e94353cd57343f0edebcf4380a8dae7 | |
parent | 0ed4548f81b69363a6257dbc23086fc9fe4a23cb (diff) |
ath5k: use a table for LED parameters
Put the device id-to-gpio mapping in a table to make it easier to add
new devices. The list of supported devices is unchanged.
Signed-off-by: Bob Copeland <me@bobcopeland.com>
Acked-by: Jiri Slaby <jirislaby@gmail.com>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
-rw-r--r-- | drivers/net/wireless/ath5k/led.c | 53 |
1 files changed, 28 insertions, 25 deletions
diff --git a/drivers/net/wireless/ath5k/led.c b/drivers/net/wireless/ath5k/led.c index 7cef2bb408df..e365fbd34237 100644 --- a/drivers/net/wireless/ath5k/led.c +++ b/drivers/net/wireless/ath5k/led.c | |||
@@ -43,6 +43,29 @@ | |||
43 | #include "ath5k.h" | 43 | #include "ath5k.h" |
44 | #include "base.h" | 44 | #include "base.h" |
45 | 45 | ||
46 | #define ATH_SDEVICE(subv,subd) \ | ||
47 | .vendor = PCI_ANY_ID, .device = PCI_ANY_ID, \ | ||
48 | .subvendor = (subv), .subdevice = (subd) | ||
49 | |||
50 | #define ATH_LED(pin,polarity) .driver_data = (((pin) << 8) | (polarity)) | ||
51 | #define ATH_PIN(data) ((data) >> 8) | ||
52 | #define ATH_POLARITY(data) ((data) & 0xff) | ||
53 | |||
54 | /* Devices we match on for LED config info (typically laptops) */ | ||
55 | static const struct pci_device_id ath5k_led_devices[] = { | ||
56 | /* IBM-specific AR5212 */ | ||
57 | { PCI_VDEVICE(ATHEROS, PCI_DEVICE_ID_ATHEROS_AR5212_IBM), ATH_LED(0, 0) }, | ||
58 | /* AR5211 */ | ||
59 | { PCI_VDEVICE(ATHEROS, PCI_DEVICE_ID_ATHEROS_AR5211), ATH_LED(0, 0) }, | ||
60 | /* HP Compaq nc6xx, nc4000, nx6000 */ | ||
61 | { ATH_SDEVICE(PCI_VENDOR_ID_COMPAQ, PCI_ANY_ID), ATH_LED(1, 1) }, | ||
62 | /* Acer Aspire One A150 (maximlevitsky@gmail.com) */ | ||
63 | { ATH_SDEVICE(PCI_VENDOR_ID_FOXCONN, PCI_ANY_ID), ATH_LED(3, 0) }, | ||
64 | /* E-machines E510 (tuliom@gmail.com) */ | ||
65 | { ATH_SDEVICE(PCI_VENDOR_ID_AMBIT, PCI_ANY_ID), ATH_LED(3, 0) }, | ||
66 | { } | ||
67 | }; | ||
68 | |||
46 | void ath5k_led_enable(struct ath5k_softc *sc) | 69 | void ath5k_led_enable(struct ath5k_softc *sc) |
47 | { | 70 | { |
48 | if (test_bit(ATH_STAT_LEDSOFT, sc->status)) { | 71 | if (test_bit(ATH_STAT_LEDSOFT, sc->status)) { |
@@ -114,39 +137,19 @@ void ath5k_unregister_leds(struct ath5k_softc *sc) | |||
114 | ath5k_unregister_led(&sc->tx_led); | 137 | ath5k_unregister_led(&sc->tx_led); |
115 | } | 138 | } |
116 | 139 | ||
117 | |||
118 | int ath5k_init_leds(struct ath5k_softc *sc) | 140 | int ath5k_init_leds(struct ath5k_softc *sc) |
119 | { | 141 | { |
120 | int ret = 0; | 142 | int ret = 0; |
121 | struct ieee80211_hw *hw = sc->hw; | 143 | struct ieee80211_hw *hw = sc->hw; |
122 | struct pci_dev *pdev = sc->pdev; | 144 | struct pci_dev *pdev = sc->pdev; |
123 | char name[ATH5K_LED_MAX_NAME_LEN + 1]; | 145 | char name[ATH5K_LED_MAX_NAME_LEN + 1]; |
146 | const struct pci_device_id *match; | ||
124 | 147 | ||
125 | /* | 148 | match = pci_match_id(&ath5k_led_devices[0], pdev); |
126 | * Auto-enable soft led processing for IBM cards and for | 149 | if (match) { |
127 | * 5211 minipci cards. | ||
128 | */ | ||
129 | if (pdev->device == PCI_DEVICE_ID_ATHEROS_AR5212_IBM || | ||
130 | pdev->device == PCI_DEVICE_ID_ATHEROS_AR5211) { | ||
131 | __set_bit(ATH_STAT_LEDSOFT, sc->status); | ||
132 | sc->led_pin = 0; | ||
133 | sc->led_on = 0; /* active low */ | ||
134 | } | ||
135 | /* Enable softled on PIN1 on HP Compaq nc6xx, nc4000 & nx5000 laptops */ | ||
136 | if (pdev->subsystem_vendor == PCI_VENDOR_ID_COMPAQ) { | ||
137 | __set_bit(ATH_STAT_LEDSOFT, sc->status); | ||
138 | sc->led_pin = 1; | ||
139 | sc->led_on = 1; /* active high */ | ||
140 | } | ||
141 | /* | ||
142 | * Pin 3 on Foxconn chips used in Acer Aspire One (0x105b:e008) and | ||
143 | * in emachines notebooks with AMBIT subsystem. | ||
144 | */ | ||
145 | if (pdev->subsystem_vendor == PCI_VENDOR_ID_FOXCONN || | ||
146 | pdev->subsystem_vendor == PCI_VENDOR_ID_AMBIT) { | ||
147 | __set_bit(ATH_STAT_LEDSOFT, sc->status); | 150 | __set_bit(ATH_STAT_LEDSOFT, sc->status); |
148 | sc->led_pin = 3; | 151 | sc->led_pin = ATH_PIN(match->driver_data); |
149 | sc->led_on = 0; /* active low */ | 152 | sc->led_on = ATH_POLARITY(match->driver_data); |
150 | } | 153 | } |
151 | 154 | ||
152 | if (!test_bit(ATH_STAT_LEDSOFT, sc->status)) | 155 | if (!test_bit(ATH_STAT_LEDSOFT, sc->status)) |