ledtrig-audio.c 1.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465
  1. // SPDX-License-Identifier: GPL-2.0
  2. //
  3. // Audio Mute LED trigger
  4. //
  5. #include <linux/kernel.h>
  6. #include <linux/leds.h>
  7. #include <linux/module.h>
  8. #include "../leds.h"
  9. static enum led_brightness audio_state[NUM_AUDIO_LEDS];
  10. static int ledtrig_audio_mute_activate(struct led_classdev *led_cdev)
  11. {
  12. led_set_brightness_nosleep(led_cdev, audio_state[LED_AUDIO_MUTE]);
  13. return 0;
  14. }
  15. static int ledtrig_audio_micmute_activate(struct led_classdev *led_cdev)
  16. {
  17. led_set_brightness_nosleep(led_cdev, audio_state[LED_AUDIO_MICMUTE]);
  18. return 0;
  19. }
  20. static struct led_trigger ledtrig_audio[NUM_AUDIO_LEDS] = {
  21. [LED_AUDIO_MUTE] = {
  22. .name = "audio-mute",
  23. .activate = ledtrig_audio_mute_activate,
  24. },
  25. [LED_AUDIO_MICMUTE] = {
  26. .name = "audio-micmute",
  27. .activate = ledtrig_audio_micmute_activate,
  28. },
  29. };
  30. enum led_brightness ledtrig_audio_get(enum led_audio type)
  31. {
  32. return audio_state[type];
  33. }
  34. EXPORT_SYMBOL_GPL(ledtrig_audio_get);
  35. void ledtrig_audio_set(enum led_audio type, enum led_brightness state)
  36. {
  37. audio_state[type] = state;
  38. led_trigger_event(&ledtrig_audio[type], state);
  39. }
  40. EXPORT_SYMBOL_GPL(ledtrig_audio_set);
  41. static int __init ledtrig_audio_init(void)
  42. {
  43. led_trigger_register(&ledtrig_audio[LED_AUDIO_MUTE]);
  44. led_trigger_register(&ledtrig_audio[LED_AUDIO_MICMUTE]);
  45. return 0;
  46. }
  47. module_init(ledtrig_audio_init);
  48. static void __exit ledtrig_audio_exit(void)
  49. {
  50. led_trigger_unregister(&ledtrig_audio[LED_AUDIO_MUTE]);
  51. led_trigger_unregister(&ledtrig_audio[LED_AUDIO_MICMUTE]);
  52. }
  53. module_exit(ledtrig_audio_exit);
  54. MODULE_DESCRIPTION("LED trigger for audio mute control");
  55. MODULE_LICENSE("GPL v2");