|
|
@@ -196,7 +196,7 @@ Signed-off-by: Felix Fietkau <[email protected]>
|
|
|
return 0;
|
|
|
}
|
|
|
|
|
|
-@@ -136,12 +264,18 @@ void ath_deinit_leds(struct ath_softc *s
|
|
|
+@@ -136,17 +264,24 @@ void ath_deinit_leds(struct ath_softc *s
|
|
|
|
|
|
while (!list_empty(&sc->leds)) {
|
|
|
led = list_first_entry(&sc->leds, struct ath_led, list);
|
|
|
@@ -215,16 +215,27 @@ Signed-off-by: Felix Fietkau <[email protected]>
|
|
|
}
|
|
|
|
|
|
void ath_init_leds(struct ath_softc *sc)
|
|
|
-@@ -158,6 +292,8 @@ void ath_init_leds(struct ath_softc *sc)
|
|
|
+ {
|
|
|
+ struct ath9k_platform_data *pdata = sc->dev->platform_data;
|
|
|
++ struct device_node *np = sc->dev->of_node;
|
|
|
+ char led_name[32];
|
|
|
+ const char *trigger;
|
|
|
+ int i;
|
|
|
+@@ -156,6 +291,13 @@ void ath_init_leds(struct ath_softc *sc)
|
|
|
+ if (AR_SREV_9100(sc->sc_ah))
|
|
|
+ return;
|
|
|
|
|
|
++ if (!np)
|
|
|
++ ath9k_register_gpio_chip(sc);
|
|
|
++
|
|
|
++ /* setup gpio controller only if requested */
|
|
|
++ if (of_property_read_bool(np, "gpio-controller"))
|
|
|
++ ath9k_register_gpio_chip(sc);
|
|
|
++
|
|
|
ath_fill_led_pin(sc);
|
|
|
|
|
|
-+ ath9k_register_gpio_chip(sc);
|
|
|
-+
|
|
|
if (pdata && pdata->leds && pdata->num_leds)
|
|
|
- for (i = 0; i < pdata->num_leds; i++) {
|
|
|
- if (pdata->leds[i].gpio == sc->sc_ah->led_pin)
|
|
|
-@@ -183,6 +319,7 @@ void ath_init_leds(struct ath_softc *sc)
|
|
|
+@@ -183,6 +325,7 @@ void ath_init_leds(struct ath_softc *sc)
|
|
|
ath_create_gpio_led(sc, sc->sc_ah->led_pin, led_name, trigger,
|
|
|
!sc->sc_ah->config.led_active_high);
|
|
|
}
|