1 // SPDX-License-Identifier: GPL-2.0
2 /*
3  * Copyright (c) 2016, NVIDIA CORPORATION.
4  */
5 
6 #include <common.h>
7 #include <dm.h>
8 #include <dm/device-internal.h>
9 #include <log.h>
10 #include <malloc.h>
11 #include <reset.h>
12 #include <dm/test.h>
13 #include <asm/reset.h>
14 #include <test/test.h>
15 #include <test/ut.h>
16 
17 /* This must match the specifier for mbox-names="test" in the DT node */
18 #define TEST_RESET_ID 2
19 
20 /* This is the other reset phandle specifier handled by bulk */
21 #define OTHER_RESET_ID 2
22 
23 /* Base test of the reset uclass */
dm_test_reset_base(struct unit_test_state * uts)24 static int dm_test_reset_base(struct unit_test_state *uts)
25 {
26 	struct udevice *dev;
27 	struct reset_ctl reset_method1, reset_method1_1;
28 	struct reset_ctl reset_method2, reset_method2_1;
29 	struct reset_ctl reset_method3, reset_method3_1;
30 	struct reset_ctl reset_method4, reset_method4_1;
31 
32 	/* Get the device using the reset device */
33 	ut_assertok(uclass_get_device_by_name(UCLASS_MISC, "reset-ctl-test",
34 					      &dev));
35 
36 	/* Get the same reset port in 2 different ways and compare */
37 	ut_assertok(reset_get_by_index(dev, 0, &reset_method1));
38 	ut_assertok(reset_get_by_name(dev, NULL, &reset_method1_1));
39 	ut_assertok(reset_get_by_index(dev, 1, &reset_method2));
40 	ut_assertok(reset_get_by_index_nodev(dev_ofnode(dev), 1,
41 					     &reset_method2_1));
42 	ut_assertok(reset_get_by_index(dev, 2, &reset_method3));
43 	ut_assertok(reset_get_by_index_nodev(dev_ofnode(dev), 2,
44 					     &reset_method3_1));
45 	ut_assertok(reset_get_by_index(dev, 3, &reset_method4));
46 	ut_assertok(reset_get_by_index_nodev(dev_ofnode(dev), 3,
47 					     &reset_method4_1));
48 
49 	ut_asserteq(reset_method1.id, reset_method1_1.id);
50 	ut_asserteq(reset_method2.id, reset_method2_1.id);
51 	ut_asserteq(reset_method3.id, reset_method3_1.id);
52 	ut_asserteq(reset_method4.id, reset_method4_1.id);
53 
54 	ut_asserteq(true, reset_method1.id != reset_method2.id);
55 	ut_asserteq(true, reset_method1.id != reset_method3.id);
56 	ut_asserteq(true, reset_method1.id != reset_method4.id);
57 	ut_asserteq(true, reset_method2.id != reset_method3.id);
58 	ut_asserteq(true, reset_method2.id != reset_method4.id);
59 	ut_asserteq(true, reset_method3.id != reset_method4.id);
60 
61 	ut_asserteq(true, reset_method1_1.id != reset_method2_1.id);
62 	ut_asserteq(true, reset_method1_1.id != reset_method3_1.id);
63 	ut_asserteq(true, reset_method1_1.id != reset_method4_1.id);
64 	ut_asserteq(true, reset_method2_1.id != reset_method3_1.id);
65 	ut_asserteq(true, reset_method2_1.id != reset_method4_1.id);
66 	ut_asserteq(true, reset_method3_1.id != reset_method4_1.id);
67 
68 	return 0;
69 }
70 
71 DM_TEST(dm_test_reset_base, UT_TESTF_SCAN_FDT);
72 
dm_test_reset(struct unit_test_state * uts)73 static int dm_test_reset(struct unit_test_state *uts)
74 {
75 	struct udevice *dev_reset;
76 	struct udevice *dev_test;
77 
78 	ut_assertok(uclass_get_device_by_name(UCLASS_RESET, "reset-ctl",
79 					      &dev_reset));
80 	ut_asserteq(0, sandbox_reset_query(dev_reset, TEST_RESET_ID));
81 
82 	ut_assertok(uclass_get_device_by_name(UCLASS_MISC, "reset-ctl-test",
83 					      &dev_test));
84 	ut_assertok(sandbox_reset_test_get(dev_test));
85 
86 	ut_assertok(sandbox_reset_test_assert(dev_test));
87 	ut_asserteq(1, sandbox_reset_query(dev_reset, TEST_RESET_ID));
88 
89 	ut_assertok(sandbox_reset_test_deassert(dev_test));
90 	ut_asserteq(0, sandbox_reset_query(dev_reset, TEST_RESET_ID));
91 
92 	ut_asserteq(1, sandbox_reset_is_requested(dev_reset, TEST_RESET_ID));
93 	ut_assertok(sandbox_reset_test_free(dev_test));
94 	ut_asserteq(0, sandbox_reset_is_requested(dev_reset, TEST_RESET_ID));
95 
96 	return 0;
97 }
98 DM_TEST(dm_test_reset, UT_TESTF_SCAN_FDT);
99 
dm_test_reset_devm(struct unit_test_state * uts)100 static int dm_test_reset_devm(struct unit_test_state *uts)
101 {
102 	struct udevice *dev_reset;
103 	struct udevice *dev_test;
104 
105 	ut_assertok(uclass_get_device_by_name(UCLASS_RESET, "reset-ctl",
106 					      &dev_reset));
107 	ut_asserteq(0, sandbox_reset_query(dev_reset, TEST_RESET_ID));
108 	ut_assertok(uclass_get_device_by_name(UCLASS_MISC, "reset-ctl-test",
109 					      &dev_test));
110 	ut_assertok(sandbox_reset_test_get_devm(dev_test));
111 
112 	ut_assertok(sandbox_reset_test_assert(dev_test));
113 	ut_asserteq(1, sandbox_reset_query(dev_reset, TEST_RESET_ID));
114 	ut_assertok(sandbox_reset_test_deassert(dev_test));
115 	ut_asserteq(0, sandbox_reset_query(dev_reset, TEST_RESET_ID));
116 
117 	ut_asserteq(1, sandbox_reset_is_requested(dev_reset, TEST_RESET_ID));
118 	ut_assertok(device_remove(dev_test, DM_REMOVE_NORMAL));
119 	ut_asserteq(0, sandbox_reset_is_requested(dev_reset, TEST_RESET_ID));
120 
121 	return 0;
122 }
123 DM_TEST(dm_test_reset_devm, UT_TESTF_SCAN_FDT);
124 
dm_test_reset_bulk(struct unit_test_state * uts)125 static int dm_test_reset_bulk(struct unit_test_state *uts)
126 {
127 	struct udevice *dev_reset;
128 	struct udevice *dev_test;
129 
130 	ut_assertok(uclass_get_device_by_name(UCLASS_RESET, "reset-ctl",
131 					      &dev_reset));
132 	ut_asserteq(0, sandbox_reset_query(dev_reset, TEST_RESET_ID));
133 	ut_asserteq(0, sandbox_reset_query(dev_reset, OTHER_RESET_ID));
134 
135 	ut_assertok(uclass_get_device_by_name(UCLASS_MISC, "reset-ctl-test",
136 					      &dev_test));
137 	ut_assertok(sandbox_reset_test_get_bulk(dev_test));
138 
139 	ut_assertok(sandbox_reset_test_assert_bulk(dev_test));
140 	ut_asserteq(1, sandbox_reset_query(dev_reset, TEST_RESET_ID));
141 	ut_asserteq(1, sandbox_reset_query(dev_reset, OTHER_RESET_ID));
142 
143 	ut_assertok(sandbox_reset_test_deassert_bulk(dev_test));
144 	ut_asserteq(0, sandbox_reset_query(dev_reset, TEST_RESET_ID));
145 	ut_asserteq(0, sandbox_reset_query(dev_reset, OTHER_RESET_ID));
146 
147 	ut_assertok(sandbox_reset_test_release_bulk(dev_test));
148 	ut_asserteq(1, sandbox_reset_query(dev_reset, TEST_RESET_ID));
149 	ut_asserteq(1, sandbox_reset_query(dev_reset, OTHER_RESET_ID));
150 
151 	return 0;
152 }
153 DM_TEST(dm_test_reset_bulk, UT_TESTF_SCAN_FDT);
154 
dm_test_reset_bulk_devm(struct unit_test_state * uts)155 static int dm_test_reset_bulk_devm(struct unit_test_state *uts)
156 {
157 	struct udevice *dev_reset;
158 	struct udevice *dev_test;
159 
160 	ut_assertok(uclass_get_device_by_name(UCLASS_RESET, "reset-ctl",
161 					      &dev_reset));
162 	ut_asserteq(0, sandbox_reset_query(dev_reset, TEST_RESET_ID));
163 	ut_asserteq(0, sandbox_reset_query(dev_reset, OTHER_RESET_ID));
164 
165 	ut_assertok(uclass_get_device_by_name(UCLASS_MISC, "reset-ctl-test",
166 					      &dev_test));
167 	ut_assertok(sandbox_reset_test_get_bulk_devm(dev_test));
168 
169 	ut_assertok(sandbox_reset_test_assert_bulk(dev_test));
170 	ut_asserteq(1, sandbox_reset_query(dev_reset, TEST_RESET_ID));
171 	ut_asserteq(1, sandbox_reset_query(dev_reset, OTHER_RESET_ID));
172 
173 	ut_assertok(sandbox_reset_test_deassert_bulk(dev_test));
174 	ut_asserteq(0, sandbox_reset_query(dev_reset, TEST_RESET_ID));
175 	ut_asserteq(0, sandbox_reset_query(dev_reset, OTHER_RESET_ID));
176 
177 	ut_asserteq(1, sandbox_reset_is_requested(dev_reset, OTHER_RESET_ID));
178 	ut_asserteq(1, sandbox_reset_is_requested(dev_reset, TEST_RESET_ID));
179 	ut_assertok(device_remove(dev_test, DM_REMOVE_NORMAL));
180 	ut_asserteq(0, sandbox_reset_is_requested(dev_reset, TEST_RESET_ID));
181 	ut_asserteq(0, sandbox_reset_is_requested(dev_reset, OTHER_RESET_ID));
182 
183 	return 0;
184 }
185 DM_TEST(dm_test_reset_bulk_devm, UT_TESTF_SCAN_FDT);
186