led.c 3.6 KB

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