clk.c 8.5 KB

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