led-uclass.c 2.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117
  1. // SPDX-License-Identifier: GPL-2.0+
  2. /*
  3. * Copyright (c) 2015 Google, Inc
  4. * Written by Simon Glass <sjg@chromium.org>
  5. */
  6. #define LOG_CATEGORY UCLASS_LED
  7. #include <common.h>
  8. #include <dm.h>
  9. #include <errno.h>
  10. #include <led.h>
  11. #include <dm/device-internal.h>
  12. #include <dm/root.h>
  13. #include <dm/uclass-internal.h>
  14. int led_get_by_label(const char *label, struct udevice **devp)
  15. {
  16. struct udevice *dev;
  17. struct uclass *uc;
  18. int ret;
  19. ret = uclass_get(UCLASS_LED, &uc);
  20. if (ret)
  21. return ret;
  22. uclass_foreach_dev(dev, uc) {
  23. struct led_uc_plat *uc_plat = dev_get_uclass_plat(dev);
  24. /* Ignore the top-level LED node */
  25. if (uc_plat->label && !strcmp(label, uc_plat->label))
  26. return uclass_get_device_tail(dev, 0, devp);
  27. }
  28. return -ENODEV;
  29. }
  30. int led_set_state(struct udevice *dev, enum led_state_t state)
  31. {
  32. struct led_ops *ops = led_get_ops(dev);
  33. if (!ops->set_state)
  34. return -ENOSYS;
  35. return ops->set_state(dev, state);
  36. }
  37. enum led_state_t led_get_state(struct udevice *dev)
  38. {
  39. struct led_ops *ops = led_get_ops(dev);
  40. if (!ops->get_state)
  41. return -ENOSYS;
  42. return ops->get_state(dev);
  43. }
  44. #ifdef CONFIG_LED_BLINK
  45. int led_set_period(struct udevice *dev, int period_ms)
  46. {
  47. struct led_ops *ops = led_get_ops(dev);
  48. if (!ops->set_period)
  49. return -ENOSYS;
  50. return ops->set_period(dev, period_ms);
  51. }
  52. #endif
  53. static int led_post_bind(struct udevice *dev)
  54. {
  55. struct led_uc_plat *uc_plat = dev_get_uclass_plat(dev);
  56. const char *default_state;
  57. uc_plat->label = dev_read_string(dev, "label");
  58. if (!uc_plat->label)
  59. uc_plat->label = ofnode_get_name(dev_ofnode(dev));
  60. uc_plat->default_state = LEDST_COUNT;
  61. default_state = dev_read_string(dev, "default-state");
  62. if (!default_state)
  63. return 0;
  64. if (!strncmp(default_state, "on", 2))
  65. uc_plat->default_state = LEDST_ON;
  66. else if (!strncmp(default_state, "off", 3))
  67. uc_plat->default_state = LEDST_OFF;
  68. else
  69. return 0;
  70. /*
  71. * In case the LED has default-state DT property, trigger
  72. * probe() to configure its default state during startup.
  73. */
  74. dev_or_flags(dev, DM_FLAG_PROBE_AFTER_BIND);
  75. return 0;
  76. }
  77. static int led_post_probe(struct udevice *dev)
  78. {
  79. struct led_uc_plat *uc_plat = dev_get_uclass_plat(dev);
  80. if (uc_plat->default_state == LEDST_ON ||
  81. uc_plat->default_state == LEDST_OFF)
  82. led_set_state(dev, uc_plat->default_state);
  83. return 0;
  84. }
  85. UCLASS_DRIVER(led) = {
  86. .id = UCLASS_LED,
  87. .name = "led",
  88. .per_device_plat_auto = sizeof(struct led_uc_plat),
  89. .post_bind = led_post_bind,
  90. .post_probe = led_post_probe,
  91. };