mx6ul_14x14_evk: Avoid overlap of environment over U-Boot proper
[oweals/u-boot.git] / test / dm / clk.c
1 // SPDX-License-Identifier: GPL-2.0+
2 /*
3  * Copyright (C) 2015 Google, Inc
4  */
5
6 #include <common.h>
7 #include <clk.h>
8 #include <dm.h>
9 #include <log.h>
10 #include <malloc.h>
11 #include <asm/clk.h>
12 #include <dm/test.h>
13 #include <dm/device-internal.h>
14 #include <linux/err.h>
15 #include <test/ut.h>
16
17 /* Base test of the clk uclass */
18 static int dm_test_clk_base(struct unit_test_state *uts)
19 {
20         struct udevice *dev;
21         struct clk clk_method1;
22         struct clk clk_method2;
23
24         /* Get the device using the clk device */
25         ut_assertok(uclass_get_device_by_name(UCLASS_MISC, "clk-test", &dev));
26
27         /* Get the same clk port in 2 different ways and compare */
28         ut_assertok(clk_get_by_index(dev, 1, &clk_method1));
29         ut_assertok(clk_get_by_index_nodev(dev_ofnode(dev), 1, &clk_method2));
30         ut_asserteq(clk_is_match(&clk_method1, &clk_method2), true);
31         ut_asserteq(clk_method1.id, clk_method2.id);
32
33         return 0;
34 }
35
36 DM_TEST(dm_test_clk_base, DM_TESTF_SCAN_FDT);
37
38 static int dm_test_clk(struct unit_test_state *uts)
39 {
40         struct udevice *dev_fixed, *dev_fixed_factor, *dev_clk, *dev_test;
41         ulong rate;
42
43         ut_assertok(uclass_get_device_by_name(UCLASS_CLK, "clk-fixed",
44                                               &dev_fixed));
45
46         ut_assertok(uclass_get_device_by_name(UCLASS_CLK, "clk-fixed-factor",
47                                               &dev_fixed_factor));
48
49         ut_assertok(uclass_get_device_by_name(UCLASS_CLK, "clk-sbox",
50                                               &dev_clk));
51         ut_asserteq(0, sandbox_clk_query_enable(dev_clk, SANDBOX_CLK_ID_SPI));
52         ut_asserteq(0, sandbox_clk_query_enable(dev_clk, SANDBOX_CLK_ID_I2C));
53         ut_asserteq(0, sandbox_clk_query_rate(dev_clk, SANDBOX_CLK_ID_SPI));
54         ut_asserteq(0, sandbox_clk_query_rate(dev_clk, SANDBOX_CLK_ID_I2C));
55
56         ut_assertok(uclass_get_device_by_name(UCLASS_MISC, "clk-test",
57                                               &dev_test));
58         ut_assertok(sandbox_clk_test_get(dev_test));
59         ut_assertok(sandbox_clk_test_devm_get(dev_test));
60         ut_assertok(sandbox_clk_test_valid(dev_test));
61
62         ut_asserteq(0, sandbox_clk_test_get_rate(dev_test,
63                                                  SANDBOX_CLK_TEST_ID_DEVM_NULL));
64         ut_asserteq(0, sandbox_clk_test_set_rate(dev_test,
65                                                  SANDBOX_CLK_TEST_ID_DEVM_NULL,
66                                                  0));
67         ut_asserteq(0, sandbox_clk_test_enable(dev_test,
68                                                SANDBOX_CLK_TEST_ID_DEVM_NULL));
69         ut_asserteq(0, sandbox_clk_test_disable(dev_test,
70                                                 SANDBOX_CLK_TEST_ID_DEVM_NULL));
71
72         ut_asserteq(1234,
73                     sandbox_clk_test_get_rate(dev_test,
74                                               SANDBOX_CLK_TEST_ID_FIXED));
75         ut_asserteq(0, sandbox_clk_test_get_rate(dev_test,
76                                                  SANDBOX_CLK_TEST_ID_SPI));
77         ut_asserteq(0, sandbox_clk_test_get_rate(dev_test,
78                                                  SANDBOX_CLK_TEST_ID_I2C));
79         ut_asserteq(321, sandbox_clk_test_get_rate(dev_test,
80                                                    SANDBOX_CLK_TEST_ID_DEVM1));
81         ut_asserteq(0, sandbox_clk_test_get_rate(dev_test,
82                                                  SANDBOX_CLK_TEST_ID_DEVM2));
83
84         rate = sandbox_clk_test_set_rate(dev_test, SANDBOX_CLK_TEST_ID_FIXED,
85                                          12345);
86         ut_assert(IS_ERR_VALUE(rate));
87         rate = sandbox_clk_test_get_rate(dev_test, SANDBOX_CLK_TEST_ID_FIXED);
88         ut_asserteq(1234, rate);
89
90         ut_asserteq(0, sandbox_clk_test_set_rate(dev_test,
91                                                  SANDBOX_CLK_TEST_ID_SPI,
92                                                  1000));
93         ut_asserteq(0, sandbox_clk_test_set_rate(dev_test,
94                                                  SANDBOX_CLK_TEST_ID_I2C,
95                                                  2000));
96
97         ut_asserteq(1000, sandbox_clk_test_get_rate(dev_test,
98                                                     SANDBOX_CLK_TEST_ID_SPI));
99         ut_asserteq(2000, sandbox_clk_test_get_rate(dev_test,
100                                                     SANDBOX_CLK_TEST_ID_I2C));
101
102         ut_asserteq(1000, sandbox_clk_test_set_rate(dev_test,
103                                                     SANDBOX_CLK_TEST_ID_SPI,
104                                                     10000));
105         ut_asserteq(2000, sandbox_clk_test_set_rate(dev_test,
106                                                     SANDBOX_CLK_TEST_ID_I2C,
107                                                     20000));
108
109         rate = sandbox_clk_test_set_rate(dev_test, SANDBOX_CLK_TEST_ID_SPI, 0);
110         ut_assert(IS_ERR_VALUE(rate));
111         rate = sandbox_clk_test_set_rate(dev_test, SANDBOX_CLK_TEST_ID_I2C, 0);
112         ut_assert(IS_ERR_VALUE(rate));
113
114         ut_asserteq(10000, sandbox_clk_test_get_rate(dev_test,
115                                                      SANDBOX_CLK_TEST_ID_SPI));
116         ut_asserteq(20000, sandbox_clk_test_get_rate(dev_test,
117                                                      SANDBOX_CLK_TEST_ID_I2C));
118
119         ut_asserteq(0, sandbox_clk_query_enable(dev_clk, SANDBOX_CLK_ID_SPI));
120         ut_asserteq(0, sandbox_clk_query_enable(dev_clk, SANDBOX_CLK_ID_I2C));
121         ut_asserteq(10000, sandbox_clk_query_rate(dev_clk, SANDBOX_CLK_ID_SPI));
122         ut_asserteq(20000, sandbox_clk_query_rate(dev_clk, SANDBOX_CLK_ID_I2C));
123
124         ut_assertok(sandbox_clk_test_enable(dev_test, SANDBOX_CLK_TEST_ID_SPI));
125         ut_asserteq(1, sandbox_clk_query_enable(dev_clk, SANDBOX_CLK_ID_SPI));
126         ut_asserteq(0, sandbox_clk_query_enable(dev_clk, SANDBOX_CLK_ID_I2C));
127
128         ut_assertok(sandbox_clk_test_enable(dev_test, SANDBOX_CLK_TEST_ID_I2C));
129         ut_asserteq(1, sandbox_clk_query_enable(dev_clk, SANDBOX_CLK_ID_SPI));
130         ut_asserteq(1, sandbox_clk_query_enable(dev_clk, SANDBOX_CLK_ID_I2C));
131
132         ut_assertok(sandbox_clk_test_disable(dev_test,
133                                              SANDBOX_CLK_TEST_ID_SPI));
134         ut_asserteq(0, sandbox_clk_query_enable(dev_clk, SANDBOX_CLK_ID_SPI));
135         ut_asserteq(1, sandbox_clk_query_enable(dev_clk, SANDBOX_CLK_ID_I2C));
136
137         ut_assertok(sandbox_clk_test_disable(dev_test,
138                                              SANDBOX_CLK_TEST_ID_I2C));
139         ut_asserteq(0, sandbox_clk_query_enable(dev_clk, SANDBOX_CLK_ID_SPI));
140         ut_asserteq(0, sandbox_clk_query_enable(dev_clk, SANDBOX_CLK_ID_I2C));
141
142         ut_asserteq(1, sandbox_clk_query_requested(dev_clk,
143                                                    SANDBOX_CLK_ID_SPI));
144         ut_asserteq(1, sandbox_clk_query_requested(dev_clk,
145                                                    SANDBOX_CLK_ID_I2C));
146         ut_asserteq(1, sandbox_clk_query_requested(dev_clk,
147                                                    SANDBOX_CLK_ID_UART2));
148         ut_assertok(sandbox_clk_test_free(dev_test));
149         ut_asserteq(0, sandbox_clk_query_requested(dev_clk,
150                                                    SANDBOX_CLK_ID_SPI));
151         ut_asserteq(0, sandbox_clk_query_requested(dev_clk,
152                                                    SANDBOX_CLK_ID_I2C));
153         ut_asserteq(0, sandbox_clk_query_requested(dev_clk,
154                                                    SANDBOX_CLK_ID_UART2));
155
156         ut_asserteq(1, sandbox_clk_query_requested(dev_clk,
157                                                    SANDBOX_CLK_ID_UART1));
158         ut_assertok(device_remove(dev_test, DM_REMOVE_NORMAL));
159         ut_asserteq(0, sandbox_clk_query_requested(dev_clk,
160                                                    SANDBOX_CLK_ID_UART1));
161         return 0;
162 }
163 DM_TEST(dm_test_clk, DM_TESTF_SCAN_FDT);
164
165 static int dm_test_clk_bulk(struct unit_test_state *uts)
166 {
167         struct udevice *dev_clk, *dev_test;
168
169         ut_assertok(uclass_get_device_by_name(UCLASS_CLK, "clk-sbox",
170                                               &dev_clk));
171         ut_assertok(uclass_get_device_by_name(UCLASS_MISC, "clk-test",
172                                               &dev_test));
173         ut_assertok(sandbox_clk_test_get_bulk(dev_test));
174
175         ut_asserteq(0, sandbox_clk_query_enable(dev_clk, SANDBOX_CLK_ID_SPI));
176         ut_asserteq(0, sandbox_clk_query_enable(dev_clk, SANDBOX_CLK_ID_I2C));
177
178         /* Fixed clock does not support enable, thus should not fail */
179         ut_assertok(sandbox_clk_test_enable_bulk(dev_test));
180         ut_asserteq(1, sandbox_clk_query_enable(dev_clk, SANDBOX_CLK_ID_SPI));
181         ut_asserteq(1, sandbox_clk_query_enable(dev_clk, SANDBOX_CLK_ID_I2C));
182
183         /* Fixed clock does not support disable, thus should not fail */
184         ut_assertok(sandbox_clk_test_disable_bulk(dev_test));
185         ut_asserteq(0, sandbox_clk_query_enable(dev_clk, SANDBOX_CLK_ID_SPI));
186         ut_asserteq(0, sandbox_clk_query_enable(dev_clk, SANDBOX_CLK_ID_I2C));
187
188         /* Fixed clock does not support enable, thus should not fail */
189         ut_assertok(sandbox_clk_test_enable_bulk(dev_test));
190         ut_asserteq(1, sandbox_clk_query_enable(dev_clk, SANDBOX_CLK_ID_SPI));
191         ut_asserteq(1, sandbox_clk_query_enable(dev_clk, SANDBOX_CLK_ID_I2C));
192
193         /* Fixed clock does not support disable, thus should not fail */
194         ut_assertok(sandbox_clk_test_release_bulk(dev_test));
195         ut_asserteq(0, sandbox_clk_query_enable(dev_clk, SANDBOX_CLK_ID_SPI));
196         ut_asserteq(0, sandbox_clk_query_enable(dev_clk, SANDBOX_CLK_ID_I2C));
197         ut_assertok(device_remove(dev_test, DM_REMOVE_NORMAL));
198
199         return 0;
200 }
201 DM_TEST(dm_test_clk_bulk, DM_TESTF_SCAN_FDT);