183d290c5STom Rini // SPDX-License-Identifier: GPL-2.0+
23c43fba3SSimon Glass /*
33c43fba3SSimon Glass * Copyright (C) 2015 Google, Inc
43c43fba3SSimon Glass */
53c43fba3SSimon Glass
63c43fba3SSimon Glass #include <common.h>
73c43fba3SSimon Glass #include <dm.h>
83c43fba3SSimon Glass #include <led.h>
93c43fba3SSimon Glass #include <asm/gpio.h>
103c43fba3SSimon Glass #include <dm/test.h>
113c43fba3SSimon Glass #include <test/ut.h>
123c43fba3SSimon Glass
133c43fba3SSimon Glass /* Base test of the led uclass */
dm_test_led_base(struct unit_test_state * uts)143c43fba3SSimon Glass static int dm_test_led_base(struct unit_test_state *uts)
153c43fba3SSimon Glass {
163c43fba3SSimon Glass struct udevice *dev;
173c43fba3SSimon Glass
183c43fba3SSimon Glass /* Get the top-level device */
193c43fba3SSimon Glass ut_assertok(uclass_get_device(UCLASS_LED, 0, &dev));
203c43fba3SSimon Glass ut_assertok(uclass_get_device(UCLASS_LED, 1, &dev));
213c43fba3SSimon Glass ut_assertok(uclass_get_device(UCLASS_LED, 2, &dev));
22274fb461SPatrick Bruenn ut_assertok(uclass_get_device(UCLASS_LED, 3, &dev));
23274fb461SPatrick Bruenn ut_assertok(uclass_get_device(UCLASS_LED, 4, &dev));
24274fb461SPatrick Bruenn ut_asserteq(-ENODEV, uclass_get_device(UCLASS_LED, 5, &dev));
253c43fba3SSimon Glass
263c43fba3SSimon Glass return 0;
273c43fba3SSimon Glass }
283c43fba3SSimon Glass DM_TEST(dm_test_led_base, DM_TESTF_SCAN_PDATA | DM_TESTF_SCAN_FDT);
293c43fba3SSimon Glass
30274fb461SPatrick Bruenn /* Test of the LED 'default-state' device tree property */
dm_test_led_default_state(struct unit_test_state * uts)31274fb461SPatrick Bruenn static int dm_test_led_default_state(struct unit_test_state *uts)
32274fb461SPatrick Bruenn {
33274fb461SPatrick Bruenn struct udevice *dev;
34274fb461SPatrick Bruenn
35*17585e2dSPatrick Delaunay /* configure the default state (auto-probe) */
36*17585e2dSPatrick Delaunay led_default_state();
37*17585e2dSPatrick Delaunay
38274fb461SPatrick Bruenn /* Check that we handle the default-state property correctly. */
39274fb461SPatrick Bruenn ut_assertok(led_get_by_label("sandbox:default_on", &dev));
40274fb461SPatrick Bruenn ut_asserteq(LEDST_ON, led_get_state(dev));
41274fb461SPatrick Bruenn
42274fb461SPatrick Bruenn ut_assertok(led_get_by_label("sandbox:default_off", &dev));
43274fb461SPatrick Bruenn ut_asserteq(LEDST_OFF, led_get_state(dev));
44274fb461SPatrick Bruenn
45274fb461SPatrick Bruenn return 0;
46274fb461SPatrick Bruenn }
47274fb461SPatrick Bruenn DM_TEST(dm_test_led_default_state, DM_TESTF_SCAN_PDATA | DM_TESTF_SCAN_FDT);
48274fb461SPatrick Bruenn
493c43fba3SSimon Glass /* Test of the led uclass using the led_gpio driver */
dm_test_led_gpio(struct unit_test_state * uts)503c43fba3SSimon Glass static int dm_test_led_gpio(struct unit_test_state *uts)
513c43fba3SSimon Glass {
523c43fba3SSimon Glass const int offset = 1;
533c43fba3SSimon Glass struct udevice *dev, *gpio;
543c43fba3SSimon Glass
553c43fba3SSimon Glass /*
563c43fba3SSimon Glass * Check that we can manipulate an LED. LED 1 is connected to GPIO
573c43fba3SSimon Glass * bank gpio_a, offset 1.
583c43fba3SSimon Glass */
593c43fba3SSimon Glass ut_assertok(uclass_get_device(UCLASS_LED, 1, &dev));
603c43fba3SSimon Glass ut_assertok(uclass_get_device(UCLASS_GPIO, 1, &gpio));
613c43fba3SSimon Glass ut_asserteq(0, sandbox_gpio_get_value(gpio, offset));
62ddae9fcdSSimon Glass ut_assertok(led_set_state(dev, LEDST_ON));
633c43fba3SSimon Glass ut_asserteq(1, sandbox_gpio_get_value(gpio, offset));
648f4b6123SSimon Glass ut_asserteq(LEDST_ON, led_get_state(dev));
65ddae9fcdSSimon Glass
66ddae9fcdSSimon Glass ut_assertok(led_set_state(dev, LEDST_OFF));
673c43fba3SSimon Glass ut_asserteq(0, sandbox_gpio_get_value(gpio, offset));
688f4b6123SSimon Glass ut_asserteq(LEDST_OFF, led_get_state(dev));
693c43fba3SSimon Glass
703c43fba3SSimon Glass return 0;
713c43fba3SSimon Glass }
723c43fba3SSimon Glass DM_TEST(dm_test_led_gpio, DM_TESTF_SCAN_PDATA | DM_TESTF_SCAN_FDT);
733c43fba3SSimon Glass
749413ad4fSSimon Glass /* Test that we can toggle LEDs */
dm_test_led_toggle(struct unit_test_state * uts)759413ad4fSSimon Glass static int dm_test_led_toggle(struct unit_test_state *uts)
769413ad4fSSimon Glass {
779413ad4fSSimon Glass const int offset = 1;
789413ad4fSSimon Glass struct udevice *dev, *gpio;
799413ad4fSSimon Glass
809413ad4fSSimon Glass /*
819413ad4fSSimon Glass * Check that we can manipulate an LED. LED 1 is connected to GPIO
829413ad4fSSimon Glass * bank gpio_a, offset 1.
839413ad4fSSimon Glass */
849413ad4fSSimon Glass ut_assertok(uclass_get_device(UCLASS_LED, 1, &dev));
859413ad4fSSimon Glass ut_assertok(uclass_get_device(UCLASS_GPIO, 1, &gpio));
869413ad4fSSimon Glass ut_asserteq(0, sandbox_gpio_get_value(gpio, offset));
879413ad4fSSimon Glass ut_assertok(led_set_state(dev, LEDST_TOGGLE));
889413ad4fSSimon Glass ut_asserteq(1, sandbox_gpio_get_value(gpio, offset));
899413ad4fSSimon Glass ut_asserteq(LEDST_ON, led_get_state(dev));
909413ad4fSSimon Glass
919413ad4fSSimon Glass ut_assertok(led_set_state(dev, LEDST_TOGGLE));
929413ad4fSSimon Glass ut_asserteq(0, sandbox_gpio_get_value(gpio, offset));
939413ad4fSSimon Glass ut_asserteq(LEDST_OFF, led_get_state(dev));
949413ad4fSSimon Glass
959413ad4fSSimon Glass return 0;
969413ad4fSSimon Glass }
979413ad4fSSimon Glass DM_TEST(dm_test_led_toggle, DM_TESTF_SCAN_PDATA | DM_TESTF_SCAN_FDT);
989413ad4fSSimon Glass
993c43fba3SSimon Glass /* Test obtaining an LED by label */
dm_test_led_label(struct unit_test_state * uts)1003c43fba3SSimon Glass static int dm_test_led_label(struct unit_test_state *uts)
1013c43fba3SSimon Glass {
1023c43fba3SSimon Glass struct udevice *dev, *cmp;
1033c43fba3SSimon Glass
1043c43fba3SSimon Glass ut_assertok(led_get_by_label("sandbox:red", &dev));
1053c43fba3SSimon Glass ut_asserteq(1, device_active(dev));
1063c43fba3SSimon Glass ut_assertok(uclass_get_device(UCLASS_LED, 1, &cmp));
1073c43fba3SSimon Glass ut_asserteq_ptr(dev, cmp);
1083c43fba3SSimon Glass
1093c43fba3SSimon Glass ut_assertok(led_get_by_label("sandbox:green", &dev));
1103c43fba3SSimon Glass ut_asserteq(1, device_active(dev));
1113c43fba3SSimon Glass ut_assertok(uclass_get_device(UCLASS_LED, 2, &cmp));
1123c43fba3SSimon Glass ut_asserteq_ptr(dev, cmp);
1133c43fba3SSimon Glass
1143c43fba3SSimon Glass ut_asserteq(-ENODEV, led_get_by_label("sandbox:blue", &dev));
1153c43fba3SSimon Glass
1163c43fba3SSimon Glass return 0;
1173c43fba3SSimon Glass }
1183c43fba3SSimon Glass DM_TEST(dm_test_led_label, DM_TESTF_SCAN_PDATA | DM_TESTF_SCAN_FDT);
11953378dacSSimon Glass
12053378dacSSimon Glass /* Test LED blinking */
12153378dacSSimon Glass #ifdef CONFIG_LED_BLINK
dm_test_led_blink(struct unit_test_state * uts)12253378dacSSimon Glass static int dm_test_led_blink(struct unit_test_state *uts)
12353378dacSSimon Glass {
12453378dacSSimon Glass const int offset = 1;
12553378dacSSimon Glass struct udevice *dev, *gpio;
12653378dacSSimon Glass
12753378dacSSimon Glass /*
12853378dacSSimon Glass * Check that we get an error when trying to blink an LED, since it is
12953378dacSSimon Glass * not supported by the GPIO LED driver.
13053378dacSSimon Glass */
13153378dacSSimon Glass ut_assertok(uclass_get_device(UCLASS_LED, 1, &dev));
13253378dacSSimon Glass ut_assertok(uclass_get_device(UCLASS_GPIO, 1, &gpio));
13353378dacSSimon Glass ut_asserteq(0, sandbox_gpio_get_value(gpio, offset));
13453378dacSSimon Glass ut_asserteq(-ENOSYS, led_set_state(dev, LEDST_BLINK));
13553378dacSSimon Glass ut_asserteq(0, sandbox_gpio_get_value(gpio, offset));
13653378dacSSimon Glass ut_asserteq(LEDST_OFF, led_get_state(dev));
13753378dacSSimon Glass ut_asserteq(-ENOSYS, led_set_period(dev, 100));
13853378dacSSimon Glass
13953378dacSSimon Glass return 0;
14053378dacSSimon Glass }
14153378dacSSimon Glass DM_TEST(dm_test_led_blink, DM_TESTF_SCAN_PDATA | DM_TESTF_SCAN_FDT);
14253378dacSSimon Glass #endif
143