led.c 4.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139
  1. // SPDX-License-Identifier: GPL-2.0+
  2. /*
  3. * Copyright (C) 2015 Google, Inc
  4. */
  5. #include <common.h>
  6. #include <dm.h>
  7. #include <led.h>
  8. #include <asm/gpio.h>
  9. #include <dm/test.h>
  10. #include <test/ut.h>
  11. /* Base test of the led uclass */
  12. static int dm_test_led_base(struct unit_test_state *uts)
  13. {
  14. struct udevice *dev;
  15. /* Get the top-level device */
  16. ut_assertok(uclass_get_device(UCLASS_LED, 0, &dev));
  17. ut_assertok(uclass_get_device(UCLASS_LED, 1, &dev));
  18. ut_assertok(uclass_get_device(UCLASS_LED, 2, &dev));
  19. ut_assertok(uclass_get_device(UCLASS_LED, 3, &dev));
  20. ut_assertok(uclass_get_device(UCLASS_LED, 4, &dev));
  21. ut_asserteq(-ENODEV, uclass_get_device(UCLASS_LED, 5, &dev));
  22. return 0;
  23. }
  24. DM_TEST(dm_test_led_base, DM_TESTF_SCAN_PDATA | DM_TESTF_SCAN_FDT);
  25. /* Test of the LED 'default-state' device tree property */
  26. static int dm_test_led_default_state(struct unit_test_state *uts)
  27. {
  28. struct udevice *dev;
  29. /* Check that we handle the default-state property correctly. */
  30. ut_assertok(led_get_by_label("sandbox:default_on", &dev));
  31. ut_asserteq(LEDST_ON, led_get_state(dev));
  32. ut_assertok(led_get_by_label("sandbox:default_off", &dev));
  33. ut_asserteq(LEDST_OFF, led_get_state(dev));
  34. return 0;
  35. }
  36. DM_TEST(dm_test_led_default_state, DM_TESTF_SCAN_PDATA | DM_TESTF_SCAN_FDT);
  37. /* Test of the led uclass using the led_gpio driver */
  38. static int dm_test_led_gpio(struct unit_test_state *uts)
  39. {
  40. const int offset = 1;
  41. struct udevice *dev, *gpio;
  42. /*
  43. * Check that we can manipulate an LED. LED 1 is connected to GPIO
  44. * bank gpio_a, offset 1.
  45. */
  46. ut_assertok(uclass_get_device(UCLASS_LED, 1, &dev));
  47. ut_assertok(uclass_get_device(UCLASS_GPIO, 1, &gpio));
  48. ut_asserteq(0, sandbox_gpio_get_value(gpio, offset));
  49. ut_assertok(led_set_state(dev, LEDST_ON));
  50. ut_asserteq(1, sandbox_gpio_get_value(gpio, offset));
  51. ut_asserteq(LEDST_ON, led_get_state(dev));
  52. ut_assertok(led_set_state(dev, LEDST_OFF));
  53. ut_asserteq(0, sandbox_gpio_get_value(gpio, offset));
  54. ut_asserteq(LEDST_OFF, led_get_state(dev));
  55. return 0;
  56. }
  57. DM_TEST(dm_test_led_gpio, DM_TESTF_SCAN_PDATA | DM_TESTF_SCAN_FDT);
  58. /* Test that we can toggle LEDs */
  59. static int dm_test_led_toggle(struct unit_test_state *uts)
  60. {
  61. const int offset = 1;
  62. struct udevice *dev, *gpio;
  63. /*
  64. * Check that we can manipulate an LED. LED 1 is connected to GPIO
  65. * bank gpio_a, offset 1.
  66. */
  67. ut_assertok(uclass_get_device(UCLASS_LED, 1, &dev));
  68. ut_assertok(uclass_get_device(UCLASS_GPIO, 1, &gpio));
  69. ut_asserteq(0, sandbox_gpio_get_value(gpio, offset));
  70. ut_assertok(led_set_state(dev, LEDST_TOGGLE));
  71. ut_asserteq(1, sandbox_gpio_get_value(gpio, offset));
  72. ut_asserteq(LEDST_ON, led_get_state(dev));
  73. ut_assertok(led_set_state(dev, LEDST_TOGGLE));
  74. ut_asserteq(0, sandbox_gpio_get_value(gpio, offset));
  75. ut_asserteq(LEDST_OFF, led_get_state(dev));
  76. return 0;
  77. }
  78. DM_TEST(dm_test_led_toggle, DM_TESTF_SCAN_PDATA | DM_TESTF_SCAN_FDT);
  79. /* Test obtaining an LED by label */
  80. static int dm_test_led_label(struct unit_test_state *uts)
  81. {
  82. struct udevice *dev, *cmp;
  83. ut_assertok(led_get_by_label("sandbox:red", &dev));
  84. ut_asserteq(1, device_active(dev));
  85. ut_assertok(uclass_get_device(UCLASS_LED, 1, &cmp));
  86. ut_asserteq_ptr(dev, cmp);
  87. ut_assertok(led_get_by_label("sandbox:green", &dev));
  88. ut_asserteq(1, device_active(dev));
  89. ut_assertok(uclass_get_device(UCLASS_LED, 2, &cmp));
  90. ut_asserteq_ptr(dev, cmp);
  91. ut_asserteq(-ENODEV, led_get_by_label("sandbox:blue", &dev));
  92. return 0;
  93. }
  94. DM_TEST(dm_test_led_label, DM_TESTF_SCAN_PDATA | DM_TESTF_SCAN_FDT);
  95. /* Test LED blinking */
  96. #ifdef CONFIG_LED_BLINK
  97. static int dm_test_led_blink(struct unit_test_state *uts)
  98. {
  99. const int offset = 1;
  100. struct udevice *dev, *gpio;
  101. /*
  102. * Check that we get an error when trying to blink an LED, since it is
  103. * not supported by the GPIO LED driver.
  104. */
  105. ut_assertok(uclass_get_device(UCLASS_LED, 1, &dev));
  106. ut_assertok(uclass_get_device(UCLASS_GPIO, 1, &gpio));
  107. ut_asserteq(0, sandbox_gpio_get_value(gpio, offset));
  108. ut_asserteq(-ENOSYS, led_set_state(dev, LEDST_BLINK));
  109. ut_asserteq(0, sandbox_gpio_get_value(gpio, offset));
  110. ut_asserteq(LEDST_OFF, led_get_state(dev));
  111. ut_asserteq(-ENOSYS, led_set_period(dev, 100));
  112. return 0;
  113. }
  114. DM_TEST(dm_test_led_blink, DM_TESTF_SCAN_PDATA | DM_TESTF_SCAN_FDT);
  115. #endif