blob: 4fd249bf64e845f8f00de3278463367d93a89ac7 [file] [log] [blame]
Simon Glass31680482015-03-25 12:23:05 -06001/*
2 * Copyright (C) 2015 Google, Inc
3 *
4 * SPDX-License-Identifier: GPL-2.0+
5 */
6
7#include <common.h>
Simon Glassa73bda42015-11-08 23:47:45 -07008#include <console.h>
Simon Glass31680482015-03-25 12:23:05 -06009#include <dm.h>
10#include <usb.h>
11#include <asm/io.h>
Simon Glass2d7c4992015-11-08 23:47:44 -070012#include <asm/state.h>
Simon Glassc0ccc722015-11-08 23:48:08 -070013#include <asm/test.h>
Simon Glass2d7c4992015-11-08 23:47:44 -070014#include <dm/device-internal.h>
Simon Glass31680482015-03-25 12:23:05 -060015#include <dm/test.h>
Simon Glass4700fe52015-11-08 23:48:01 -070016#include <dm/uclass-internal.h>
Joe Hershberger3a77be52015-05-20 14:27:27 -050017#include <test/ut.h>
Simon Glass31680482015-03-25 12:23:05 -060018
Simon Glass4700fe52015-11-08 23:48:01 -070019DECLARE_GLOBAL_DATA_PTR;
20
Simon Glass31680482015-03-25 12:23:05 -060021/* Test that sandbox USB works correctly */
Joe Hershberger3a77be52015-05-20 14:27:27 -050022static int dm_test_usb_base(struct unit_test_state *uts)
Simon Glass31680482015-03-25 12:23:05 -060023{
24 struct udevice *bus;
25
26 ut_asserteq(-ENODEV, uclass_get_device_by_seq(UCLASS_USB, 0, &bus));
27 ut_assertok(uclass_get_device(UCLASS_USB, 0, &bus));
28 ut_asserteq(-ENODEV, uclass_get_device_by_seq(UCLASS_USB, 2, &bus));
29
30 return 0;
31}
32DM_TEST(dm_test_usb_base, DM_TESTF_SCAN_PDATA | DM_TESTF_SCAN_FDT);
33
34/*
35 * Test that we can use the flash stick. This is more of a functional test. It
36 * covers scanning the bug, setting up a hub and a flash stick and reading
37 * data from the flash stick.
38 */
Joe Hershberger3a77be52015-05-20 14:27:27 -050039static int dm_test_usb_flash(struct unit_test_state *uts)
Simon Glass31680482015-03-25 12:23:05 -060040{
41 struct udevice *dev;
Simon Glasse3394752016-02-29 15:25:34 -070042 struct blk_desc *dev_desc;
Simon Glass31680482015-03-25 12:23:05 -060043 char cmp[1024];
44
Simon Glass2d7c4992015-11-08 23:47:44 -070045 state_set_skip_delays(true);
Simon Glass31680482015-03-25 12:23:05 -060046 ut_assertok(usb_init());
47 ut_assertok(uclass_get_device(UCLASS_MASS_STORAGE, 0, &dev));
Simon Glasse6649a62016-02-29 15:25:43 -070048 ut_assertok(blk_get_device_by_str("usb", "0", &dev_desc));
Simon Glass31680482015-03-25 12:23:05 -060049
50 /* Read a few blocks and look for the string we expect */
51 ut_asserteq(512, dev_desc->blksz);
52 memset(cmp, '\0', sizeof(cmp));
Simon Glass2ee8ada2016-02-29 15:25:52 -070053 ut_asserteq(2, blk_dread(dev_desc, 0, 2, cmp));
Simon Glass31680482015-03-25 12:23:05 -060054 ut_assertok(strcmp(cmp, "this is a test"));
Simon Glass582b76e2016-02-29 15:26:02 -070055 ut_assertok(usb_stop());
Simon Glass31680482015-03-25 12:23:05 -060056
57 return 0;
58}
59DM_TEST(dm_test_usb_flash, DM_TESTF_SCAN_PDATA | DM_TESTF_SCAN_FDT);
Simon Glass4700fe52015-11-08 23:48:01 -070060
61/* test that we can handle multiple storage devices */
62static int dm_test_usb_multi(struct unit_test_state *uts)
63{
64 struct udevice *dev;
65
66 state_set_skip_delays(true);
67 ut_assertok(usb_init());
68 ut_assertok(uclass_get_device(UCLASS_MASS_STORAGE, 0, &dev));
69 ut_assertok(uclass_get_device(UCLASS_MASS_STORAGE, 1, &dev));
70 ut_assertok(uclass_get_device(UCLASS_MASS_STORAGE, 2, &dev));
Simon Glass582b76e2016-02-29 15:26:02 -070071 ut_assertok(usb_stop());
Simon Glass4700fe52015-11-08 23:48:01 -070072
73 return 0;
74}
75DM_TEST(dm_test_usb_multi, DM_TESTF_SCAN_PDATA | DM_TESTF_SCAN_FDT);
76
77static int count_usb_devices(void)
78{
79 struct udevice *hub;
80 struct uclass *uc;
81 int count = 0;
82 int ret;
83
84 ret = uclass_get(UCLASS_USB_HUB, &uc);
85 if (ret)
86 return ret;
87
88 uclass_foreach_dev(hub, uc) {
89 struct udevice *dev;
90
91 count++;
92 for (device_find_first_child(hub, &dev);
93 dev;
94 device_find_next_child(&dev)) {
95 count++;
96 }
97 }
98
99 return count;
100}
101
Bin Mengb6189f22017-10-01 06:19:45 -0700102/* test that no USB devices are found after we stop the stack */
103static int dm_test_usb_stop(struct unit_test_state *uts)
Simon Glass4700fe52015-11-08 23:48:01 -0700104{
Bin Mengb6189f22017-10-01 06:19:45 -0700105 struct udevice *dev;
Simon Glass4700fe52015-11-08 23:48:01 -0700106
107 /* Scan and check that all devices are present */
108 state_set_skip_delays(true);
109 ut_assertok(usb_init());
110 ut_assertok(uclass_get_device(UCLASS_MASS_STORAGE, 0, &dev));
111 ut_assertok(uclass_get_device(UCLASS_MASS_STORAGE, 1, &dev));
112 ut_assertok(uclass_get_device(UCLASS_MASS_STORAGE, 2, &dev));
Simon Glassf0bfd6d2016-01-07 10:23:42 -0700113 ut_asserteq(6, count_usb_devices());
Simon Glass846bb372015-11-08 23:48:02 -0700114 ut_assertok(usb_stop());
Bin Mengb6189f22017-10-01 06:19:45 -0700115 ut_asserteq(0, count_usb_devices());
Simon Glass846bb372015-11-08 23:48:02 -0700116
117 return 0;
118}
Bin Mengb6189f22017-10-01 06:19:45 -0700119DM_TEST(dm_test_usb_stop, DM_TESTF_SCAN_PDATA | DM_TESTF_SCAN_FDT);
Simon Glassc0ccc722015-11-08 23:48:08 -0700120
121static int dm_test_usb_keyb(struct unit_test_state *uts)
122{
123 struct udevice *dev;
124
125 state_set_skip_delays(true);
126 ut_assertok(usb_init());
127
128 /* Initially there should be no characters */
129 ut_asserteq(0, tstc());
130
131 ut_assertok(uclass_get_device_by_name(UCLASS_USB_EMUL, "keyb",
132 &dev));
133
134 /*
135 * Add a string to the USB keyboard buffer - it should appear in
136 * stdin
137 */
138 ut_assertok(sandbox_usb_keyb_add_string(dev, "ab"));
139 ut_asserteq(1, tstc());
140 ut_asserteq('a', getc());
141 ut_asserteq(1, tstc());
142 ut_asserteq('b', getc());
143 ut_asserteq(0, tstc());
144
145 ut_assertok(usb_stop());
146
147 return 0;
148}
149DM_TEST(dm_test_usb_keyb, DM_TESTF_SCAN_PDATA | DM_TESTF_SCAN_FDT);