070-mac80211-led-blink-api.patch 2.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465
  1. backports: use old led api on old kernel versions.
  2. Usage of a new led api was introduced in mac80211, this patch make
  3. backports use the old api on older kernel versions. This could cause a
  4. problem with the led, the transmit led could stay on if nothing is
  5. transfered.
  6. This backports the following upstream commit:
  7. commit e47f2509e5f182f4df144406de6f2bc78179d57e
  8. Author: Fabio Baltieri <[email protected]>
  9. Date: Thu Jul 25 12:00:26 2013 +0200
  10. mac80211: use oneshot blink API for LED triggers
  11. --- a/net/mac80211/ieee80211_i.h
  12. +++ b/net/mac80211/ieee80211_i.h
  13. @@ -1122,6 +1122,9 @@ struct ieee80211_local {
  14. u32 dot11TransmittedFrameCount;
  15. #ifdef CPTCFG_MAC80211_LEDS
  16. +#if LINUX_VERSION_CODE < KERNEL_VERSION(3,6,0)
  17. + int tx_led_counter, rx_led_counter;
  18. +#endif
  19. struct led_trigger *tx_led, *rx_led, *assoc_led, *radio_led;
  20. struct tpt_led_trigger *tpt_led_trigger;
  21. char tx_led_name[32], rx_led_name[32],
  22. --- a/net/mac80211/led.c
  23. +++ b/net/mac80211/led.c
  24. @@ -16,18 +16,36 @@
  25. void ieee80211_led_rx(struct ieee80211_local *local)
  26. {
  27. +#if LINUX_VERSION_CODE >= KERNEL_VERSION(3,6,0)
  28. unsigned long led_delay = MAC80211_BLINK_DELAY;
  29. +#endif
  30. if (unlikely(!local->rx_led))
  31. return;
  32. +#if LINUX_VERSION_CODE >= KERNEL_VERSION(3,6,0)
  33. led_trigger_blink_oneshot(local->rx_led, &led_delay, &led_delay, 0);
  34. +#else
  35. + if (local->rx_led_counter++ % 2 == 0)
  36. + led_trigger_event(local->rx_led, LED_OFF);
  37. + else
  38. + led_trigger_event(local->rx_led, LED_FULL);
  39. +#endif
  40. }
  41. void ieee80211_led_tx(struct ieee80211_local *local)
  42. {
  43. +#if LINUX_VERSION_CODE >= KERNEL_VERSION(3,6,0)
  44. unsigned long led_delay = MAC80211_BLINK_DELAY;
  45. +#endif
  46. if (unlikely(!local->tx_led))
  47. return;
  48. +#if LINUX_VERSION_CODE >= KERNEL_VERSION(3,6,0)
  49. led_trigger_blink_oneshot(local->tx_led, &led_delay, &led_delay, 0);
  50. +#else
  51. + if (local->tx_led_counter++ % 2 == 0)
  52. + led_trigger_event(local->tx_led, LED_OFF);
  53. + else
  54. + led_trigger_event(local->tx_led, LED_FULL);
  55. +#endif
  56. }
  57. void ieee80211_led_assoc(struct ieee80211_local *local, bool associated)