1 // SPDX-License-Identifier: GPL-2.0
3 * Copyright (C) 2020, Linaro Limited
5 * Tests scmi_agent uclass and the SCMI drivers implemented in other
6 * uclass devices probe when a SCMI server exposes resources.
8 * Note in test.dts the protocol@10 node in agent 1. Protocol 0x10 is not
9 * implemented in U-Boot SCMI components but the implementation is exepected
10 * to not complain on unknown protocol IDs, as long as it is not used. Note
11 * in test.dts tests that SCMI drivers probing does not fail for such an
12 * unknown SCMI protocol ID.
19 #include <asm/scmi_test.h>
20 #include <dm/device-internal.h>
22 #include <linux/kconfig.h>
23 #include <power/regulator.h>
26 static int ut_assert_scmi_state_preprobe(struct unit_test_state *uts)
28 struct sandbox_scmi_service *scmi_ctx = sandbox_scmi_service_ctx();
30 ut_assertnonnull(scmi_ctx);
31 if (scmi_ctx->agent_count)
32 ut_asserteq(2, scmi_ctx->agent_count);
37 static int ut_assert_scmi_state_postprobe(struct unit_test_state *uts,
40 struct sandbox_scmi_devices *scmi_devices;
41 struct sandbox_scmi_service *scmi_ctx;
42 struct sandbox_scmi_agent *agent0;
43 struct sandbox_scmi_agent *agent1;
45 /* Device references to check context against test sequence */
46 scmi_devices = sandbox_scmi_devices_ctx(dev);
48 ut_assertnonnull(scmi_devices);
49 ut_asserteq(3, scmi_devices->clk_count);
50 ut_asserteq(1, scmi_devices->reset_count);
51 ut_asserteq(2, scmi_devices->regul_count);
53 /* State of the simulated SCMI server exposed */
54 scmi_ctx = sandbox_scmi_service_ctx();
55 agent0 = scmi_ctx->agent[0];
56 agent1 = scmi_ctx->agent[1];
58 ut_asserteq(2, scmi_ctx->agent_count);
60 ut_assertnonnull(agent0);
61 ut_asserteq(2, agent0->clk_count);
62 ut_assertnonnull(agent0->clk);
63 ut_asserteq(1, agent0->reset_count);
64 ut_assertnonnull(agent0->reset);
65 ut_asserteq(2, agent0->voltd_count);
66 ut_assertnonnull(agent0->voltd);
68 ut_assertnonnull(agent1);
69 ut_assertnonnull(agent1->clk);
70 ut_asserteq(1, agent1->clk_count);
75 static int load_sandbox_scmi_test_devices(struct unit_test_state *uts,
80 ret = ut_assert_scmi_state_preprobe(uts);
84 ut_assertok(uclass_get_device_by_name(UCLASS_MISC, "sandbox_scmi",
86 ut_assertnonnull(*dev);
88 return ut_assert_scmi_state_postprobe(uts, *dev);
91 static int release_sandbox_scmi_test_devices(struct unit_test_state *uts,
94 ut_assertok(device_remove(dev, DM_REMOVE_NORMAL));
96 /* Not sure test devices are fully removed, agent may not be visible */
101 * Test SCMI states when loading and releasing resources
102 * related to SCMI drivers.
104 static int dm_test_scmi_sandbox_agent(struct unit_test_state *uts)
106 struct udevice *dev = NULL;
109 ret = load_sandbox_scmi_test_devices(uts, &dev);
111 ret = release_sandbox_scmi_test_devices(uts, dev);
115 DM_TEST(dm_test_scmi_sandbox_agent, UT_TESTF_SCAN_FDT);
117 static int dm_test_scmi_clocks(struct unit_test_state *uts)
119 struct sandbox_scmi_devices *scmi_devices;
120 struct sandbox_scmi_service *scmi_ctx;
121 struct sandbox_scmi_agent *agent0;
122 struct sandbox_scmi_agent *agent1;
123 struct udevice *dev = NULL;
127 ret = load_sandbox_scmi_test_devices(uts, &dev);
131 scmi_devices = sandbox_scmi_devices_ctx(dev);
132 scmi_ctx = sandbox_scmi_service_ctx();
133 agent0 = scmi_ctx->agent[0];
134 agent1 = scmi_ctx->agent[1];
136 /* Test SCMI clocks rate manipulation */
137 ut_asserteq(1000, clk_get_rate(&scmi_devices->clk[0]));
138 ut_asserteq(333, clk_get_rate(&scmi_devices->clk[1]));
139 ut_asserteq(44, clk_get_rate(&scmi_devices->clk[2]));
141 ret_dev = clk_set_rate(&scmi_devices->clk[1], 1088);
142 ut_assert(!ret_dev || ret_dev == 1088);
144 ut_asserteq(1000, agent0->clk[0].rate);
145 ut_asserteq(1088, agent0->clk[1].rate);
146 ut_asserteq(44, agent1->clk[0].rate);
148 ut_asserteq(1000, clk_get_rate(&scmi_devices->clk[0]));
149 ut_asserteq(1088, clk_get_rate(&scmi_devices->clk[1]));
150 ut_asserteq(44, clk_get_rate(&scmi_devices->clk[2]));
152 /* restore original rate for further tests */
153 ret_dev = clk_set_rate(&scmi_devices->clk[1], 333);
154 ut_assert(!ret_dev || ret_dev == 333);
156 /* Test SCMI clocks gating manipulation */
157 ut_assert(!agent0->clk[0].enabled);
158 ut_assert(!agent0->clk[1].enabled);
159 ut_assert(!agent1->clk[0].enabled);
161 ut_asserteq(0, clk_enable(&scmi_devices->clk[1]));
162 ut_asserteq(0, clk_enable(&scmi_devices->clk[2]));
164 ut_assert(!agent0->clk[0].enabled);
165 ut_assert(agent0->clk[1].enabled);
166 ut_assert(agent1->clk[0].enabled);
168 ut_assertok(clk_disable(&scmi_devices->clk[1]));
169 ut_assertok(clk_disable(&scmi_devices->clk[2]));
171 ut_assert(!agent0->clk[0].enabled);
172 ut_assert(!agent0->clk[1].enabled);
173 ut_assert(!agent1->clk[0].enabled);
175 return release_sandbox_scmi_test_devices(uts, dev);
177 DM_TEST(dm_test_scmi_clocks, UT_TESTF_SCAN_FDT);
179 static int dm_test_scmi_resets(struct unit_test_state *uts)
181 struct sandbox_scmi_devices *scmi_devices;
182 struct sandbox_scmi_service *scmi_ctx;
183 struct sandbox_scmi_agent *agent0;
184 struct udevice *dev = NULL;
187 ret = load_sandbox_scmi_test_devices(uts, &dev);
191 scmi_devices = sandbox_scmi_devices_ctx(dev);
192 scmi_ctx = sandbox_scmi_service_ctx();
193 agent0 = scmi_ctx->agent[0];
195 /* Test SCMI resect controller manipulation */
196 ut_assert(!agent0->reset[0].asserted)
198 ut_assertok(reset_assert(&scmi_devices->reset[0]));
199 ut_assert(agent0->reset[0].asserted)
201 ut_assertok(reset_deassert(&scmi_devices->reset[0]));
202 ut_assert(!agent0->reset[0].asserted);
204 return release_sandbox_scmi_test_devices(uts, dev);
206 DM_TEST(dm_test_scmi_resets, UT_TESTF_SCAN_FDT);
208 static int dm_test_scmi_voltage_domains(struct unit_test_state *uts)
210 struct sandbox_scmi_devices *scmi_devices;
211 struct sandbox_scmi_service *scmi_ctx;
212 struct sandbox_scmi_agent *agent0;
213 struct dm_regulator_uclass_plat *uc_pdata;
215 struct udevice *regul0_dev;
217 ut_assertok(load_sandbox_scmi_test_devices(uts, &dev));
219 scmi_devices = sandbox_scmi_devices_ctx(dev);
220 scmi_ctx = sandbox_scmi_service_ctx();
221 agent0 = scmi_ctx->agent[0];
223 /* Set/Get an SCMI voltage domain level */
224 regul0_dev = scmi_devices->regul[0];
225 ut_assert(regul0_dev);
227 uc_pdata = dev_get_uclass_plat(regul0_dev);
230 ut_assertok(regulator_set_value(regul0_dev, uc_pdata->min_uV));
231 ut_asserteq(agent0->voltd[0].voltage_uv, uc_pdata->min_uV);
233 ut_assert(regulator_get_value(regul0_dev) == uc_pdata->min_uV);
235 ut_assertok(regulator_set_value(regul0_dev, uc_pdata->max_uV));
236 ut_asserteq(agent0->voltd[0].voltage_uv, uc_pdata->max_uV);
238 ut_assert(regulator_get_value(regul0_dev) == uc_pdata->max_uV);
240 /* Enable/disable SCMI voltage domains */
241 ut_assertok(regulator_set_enable(scmi_devices->regul[0], false));
242 ut_assertok(regulator_set_enable(scmi_devices->regul[1], false));
243 ut_assert(!agent0->voltd[0].enabled);
244 ut_assert(!agent0->voltd[1].enabled);
246 ut_assertok(regulator_set_enable(scmi_devices->regul[0], true));
247 ut_assert(agent0->voltd[0].enabled);
248 ut_assert(!agent0->voltd[1].enabled);
250 ut_assertok(regulator_set_enable(scmi_devices->regul[1], true));
251 ut_assert(agent0->voltd[0].enabled);
252 ut_assert(agent0->voltd[1].enabled);
254 ut_assertok(regulator_set_enable(scmi_devices->regul[0], false));
255 ut_assert(!agent0->voltd[0].enabled);
256 ut_assert(agent0->voltd[1].enabled);
258 return release_sandbox_scmi_test_devices(uts, dev);
260 DM_TEST(dm_test_scmi_voltage_domains, UT_TESTF_SCAN_FDT);