]> git.sur5r.net Git - u-boot/blobdiff - test/dm/clk.c
watchdog: cadence: Use live-tree functions
[u-boot] / test / dm / clk.c
index 712a1e674a5550c975f2e886f4ed5273cb074897..b06906a3ecfa42ac84383f56ecb1baf9e0ab9562 100644 (file)
@@ -1,7 +1,6 @@
+// SPDX-License-Identifier: GPL-2.0+
 /*
  * Copyright (C) 2015 Google, Inc
- *
- * SPDX-License-Identifier:    GPL-2.0+
  */
 
 #include <common.h>
@@ -101,3 +100,40 @@ static int dm_test_clk(struct unit_test_state *uts)
        return 0;
 }
 DM_TEST(dm_test_clk, DM_TESTF_SCAN_FDT);
+
+static int dm_test_clk_bulk(struct unit_test_state *uts)
+{
+       struct udevice *dev_clk, *dev_test;
+
+       ut_assertok(uclass_get_device_by_name(UCLASS_CLK, "clk-sbox",
+                                             &dev_clk));
+       ut_assertok(uclass_get_device_by_name(UCLASS_MISC, "clk-test",
+                                             &dev_test));
+       ut_assertok(sandbox_clk_test_get_bulk(dev_test));
+
+       ut_asserteq(0, sandbox_clk_query_enable(dev_clk, SANDBOX_CLK_ID_SPI));
+       ut_asserteq(0, sandbox_clk_query_enable(dev_clk, SANDBOX_CLK_ID_I2C));
+
+       /* Fixed clock does not support enable, thus should not fail */
+       ut_assertok(sandbox_clk_test_enable_bulk(dev_test));
+       ut_asserteq(1, sandbox_clk_query_enable(dev_clk, SANDBOX_CLK_ID_SPI));
+       ut_asserteq(1, sandbox_clk_query_enable(dev_clk, SANDBOX_CLK_ID_I2C));
+
+       /* Fixed clock does not support disable, thus should not fail */
+       ut_assertok(sandbox_clk_test_disable_bulk(dev_test));
+       ut_asserteq(0, sandbox_clk_query_enable(dev_clk, SANDBOX_CLK_ID_SPI));
+       ut_asserteq(0, sandbox_clk_query_enable(dev_clk, SANDBOX_CLK_ID_I2C));
+
+       /* Fixed clock does not support enable, thus should not fail */
+       ut_assertok(sandbox_clk_test_enable_bulk(dev_test));
+       ut_asserteq(1, sandbox_clk_query_enable(dev_clk, SANDBOX_CLK_ID_SPI));
+       ut_asserteq(1, sandbox_clk_query_enable(dev_clk, SANDBOX_CLK_ID_I2C));
+
+       /* Fixed clock does not support disable, thus should not fail */
+       ut_assertok(sandbox_clk_test_release_bulk(dev_test));
+       ut_asserteq(0, sandbox_clk_query_enable(dev_clk, SANDBOX_CLK_ID_SPI));
+       ut_asserteq(0, sandbox_clk_query_enable(dev_clk, SANDBOX_CLK_ID_I2C));
+
+       return 0;
+}
+DM_TEST(dm_test_clk_bulk, DM_TESTF_SCAN_FDT);