xref: /openbmc/u-boot/test/dm/led.c (revision 17585e2dc33c23b3ea37daf485ced880c8fea3f8)
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