Merge tag 'efi-2020-01-rc2' of https://gitlab.denx.de/u-boot/custodians/u-boot-efi
[oweals/u-boot.git] / test / dm / clk.c
index 9ff6d9510343fd46755476223f0d8d2d288cf8e3..31335a543f176ad49fd4eee78b58cbcb6917cbb9 100644 (file)
+// SPDX-License-Identifier: GPL-2.0+
 /*
  * Copyright (C) 2015 Google, Inc
- *
- * SPDX-License-Identifier:    GPL-2.0+
  */
 
 #include <common.h>
 #include <clk.h>
 #include <dm.h>
-#include <asm/test.h>
+#include <asm/clk.h>
 #include <dm/test.h>
+#include <dm/device-internal.h>
 #include <linux/err.h>
 #include <test/ut.h>
 
-/* Test that we can find and adjust clocks */
+/* Base test of the clk uclass */
 static int dm_test_clk_base(struct unit_test_state *uts)
 {
-       struct udevice *clk;
-       ulong rate;
+       struct udevice *dev;
+       struct clk clk_method1;
+       struct clk clk_method2;
+
+       /* Get the device using the clk device */
+       ut_assertok(uclass_get_device_by_name(UCLASS_MISC, "clk-test", &dev));
 
-       ut_assertok(uclass_get_device(UCLASS_CLK, 0, &clk));
-       rate = clk_get_rate(clk);
-       ut_asserteq(SANDBOX_CLK_RATE, rate);
-       ut_asserteq(-EINVAL, clk_set_rate(clk, 0));
-       ut_assertok(clk_set_rate(clk, rate * 2));
-       ut_asserteq(SANDBOX_CLK_RATE * 2, clk_get_rate(clk));
+       /* Get the same clk port in 2 different ways and compare */
+       ut_assertok(clk_get_by_index(dev, 1, &clk_method1));
+       ut_assertok(clk_get_by_index_nodev(dev_ofnode(dev), 1, &clk_method2));
+       ut_asserteq(clk_is_match(&clk_method1, &clk_method2), true);
+       ut_asserteq(clk_method1.id, clk_method2.id);
 
        return 0;
 }
-DM_TEST(dm_test_clk_base, DM_TESTF_SCAN_PDATA | DM_TESTF_SCAN_FDT);
 
-/* Test that peripheral clocks work as expected */
-static int dm_test_clk_periph(struct unit_test_state *uts)
+DM_TEST(dm_test_clk_base, DM_TESTF_SCAN_FDT);
+
+static int dm_test_clk(struct unit_test_state *uts)
 {
-       struct udevice *clk;
+       struct udevice *dev_fixed, *dev_fixed_factor, *dev_clk, *dev_test;
        ulong rate;
 
-       ut_assertok(uclass_get_device(UCLASS_CLK, 0, &clk));
-       rate = clk_set_periph_rate(clk, PERIPH_ID_COUNT, 123);
-       ut_asserteq(-EINVAL, rate);
-       ut_asserteq(1, IS_ERR_VALUE(rate));
+       ut_assertok(uclass_get_device_by_name(UCLASS_CLK, "clk-fixed",
+                                             &dev_fixed));
+
+       ut_assertok(uclass_get_device_by_name(UCLASS_CLK, "clk-fixed-factor",
+                                             &dev_fixed_factor));
 
-       rate = clk_set_periph_rate(clk, PERIPH_ID_SPI, 123);
-       ut_asserteq(0, rate);
-       ut_asserteq(123, clk_get_periph_rate(clk, PERIPH_ID_SPI));
+       ut_assertok(uclass_get_device_by_name(UCLASS_CLK, "clk-sbox",
+                                             &dev_clk));
+       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));
+       ut_asserteq(0, sandbox_clk_query_rate(dev_clk, SANDBOX_CLK_ID_SPI));
+       ut_asserteq(0, sandbox_clk_query_rate(dev_clk, SANDBOX_CLK_ID_I2C));
 
-       rate = clk_set_periph_rate(clk, PERIPH_ID_SPI, 1234);
-       ut_asserteq(123, rate);
+       ut_assertok(uclass_get_device_by_name(UCLASS_MISC, "clk-test",
+                                             &dev_test));
+       ut_assertok(sandbox_clk_test_get(dev_test));
+       ut_assertok(sandbox_clk_test_devm_get(dev_test));
+       ut_assertok(sandbox_clk_test_valid(dev_test));
 
-       rate = clk_set_periph_rate(clk, PERIPH_ID_I2C, 567);
+       ut_asserteq(0, sandbox_clk_test_get_rate(dev_test,
+                                                SANDBOX_CLK_TEST_ID_DEVM_NULL));
+       ut_asserteq(0, sandbox_clk_test_set_rate(dev_test,
+                                                SANDBOX_CLK_TEST_ID_DEVM_NULL,
+                                                0));
+       ut_asserteq(0, sandbox_clk_test_enable(dev_test,
+                                              SANDBOX_CLK_TEST_ID_DEVM_NULL));
+       ut_asserteq(0, sandbox_clk_test_disable(dev_test,
+                                               SANDBOX_CLK_TEST_ID_DEVM_NULL));
 
-       rate = clk_set_periph_rate(clk, PERIPH_ID_SPI, 1234);
+       ut_asserteq(1234,
+                   sandbox_clk_test_get_rate(dev_test,
+                                             SANDBOX_CLK_TEST_ID_FIXED));
+       ut_asserteq(0, sandbox_clk_test_get_rate(dev_test,
+                                                SANDBOX_CLK_TEST_ID_SPI));
+       ut_asserteq(0, sandbox_clk_test_get_rate(dev_test,
+                                                SANDBOX_CLK_TEST_ID_I2C));
+       ut_asserteq(321, sandbox_clk_test_get_rate(dev_test,
+                                                  SANDBOX_CLK_TEST_ID_DEVM1));
+       ut_asserteq(0, sandbox_clk_test_get_rate(dev_test,
+                                                SANDBOX_CLK_TEST_ID_DEVM2));
+
+       rate = sandbox_clk_test_set_rate(dev_test, SANDBOX_CLK_TEST_ID_FIXED,
+                                        12345);
+       ut_assert(IS_ERR_VALUE(rate));
+       rate = sandbox_clk_test_get_rate(dev_test, SANDBOX_CLK_TEST_ID_FIXED);
        ut_asserteq(1234, rate);
 
-       ut_asserteq(567, clk_get_periph_rate(clk, PERIPH_ID_I2C));
+       ut_asserteq(0, sandbox_clk_test_set_rate(dev_test,
+                                                SANDBOX_CLK_TEST_ID_SPI,
+                                                1000));
+       ut_asserteq(0, sandbox_clk_test_set_rate(dev_test,
+                                                SANDBOX_CLK_TEST_ID_I2C,
+                                                2000));
+
+       ut_asserteq(1000, sandbox_clk_test_get_rate(dev_test,
+                                                   SANDBOX_CLK_TEST_ID_SPI));
+       ut_asserteq(2000, sandbox_clk_test_get_rate(dev_test,
+                                                   SANDBOX_CLK_TEST_ID_I2C));
+
+       ut_asserteq(1000, sandbox_clk_test_set_rate(dev_test,
+                                                   SANDBOX_CLK_TEST_ID_SPI,
+                                                   10000));
+       ut_asserteq(2000, sandbox_clk_test_set_rate(dev_test,
+                                                   SANDBOX_CLK_TEST_ID_I2C,
+                                                   20000));
+
+       rate = sandbox_clk_test_set_rate(dev_test, SANDBOX_CLK_TEST_ID_SPI, 0);
+       ut_assert(IS_ERR_VALUE(rate));
+       rate = sandbox_clk_test_set_rate(dev_test, SANDBOX_CLK_TEST_ID_I2C, 0);
+       ut_assert(IS_ERR_VALUE(rate));
+
+       ut_asserteq(10000, sandbox_clk_test_get_rate(dev_test,
+                                                    SANDBOX_CLK_TEST_ID_SPI));
+       ut_asserteq(20000, sandbox_clk_test_get_rate(dev_test,
+                                                    SANDBOX_CLK_TEST_ID_I2C));
+
+       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));
+       ut_asserteq(10000, sandbox_clk_query_rate(dev_clk, SANDBOX_CLK_ID_SPI));
+       ut_asserteq(20000, sandbox_clk_query_rate(dev_clk, SANDBOX_CLK_ID_I2C));
+
+       ut_assertok(sandbox_clk_test_enable(dev_test, SANDBOX_CLK_TEST_ID_SPI));
+       ut_asserteq(1, sandbox_clk_query_enable(dev_clk, SANDBOX_CLK_ID_SPI));
+       ut_asserteq(0, sandbox_clk_query_enable(dev_clk, SANDBOX_CLK_ID_I2C));
+
+       ut_assertok(sandbox_clk_test_enable(dev_test, SANDBOX_CLK_TEST_ID_I2C));
+       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));
+
+       ut_assertok(sandbox_clk_test_disable(dev_test,
+                                            SANDBOX_CLK_TEST_ID_SPI));
+       ut_asserteq(0, sandbox_clk_query_enable(dev_clk, SANDBOX_CLK_ID_SPI));
+       ut_asserteq(1, sandbox_clk_query_enable(dev_clk, SANDBOX_CLK_ID_I2C));
+
+       ut_assertok(sandbox_clk_test_disable(dev_test,
+                                            SANDBOX_CLK_TEST_ID_I2C));
+       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));
+
+       ut_asserteq(1, sandbox_clk_query_requested(dev_clk,
+                                                  SANDBOX_CLK_ID_SPI));
+       ut_asserteq(1, sandbox_clk_query_requested(dev_clk,
+                                                  SANDBOX_CLK_ID_I2C));
+       ut_asserteq(1, sandbox_clk_query_requested(dev_clk,
+                                                  SANDBOX_CLK_ID_UART2));
+       ut_assertok(sandbox_clk_test_free(dev_test));
+       ut_asserteq(0, sandbox_clk_query_requested(dev_clk,
+                                                  SANDBOX_CLK_ID_SPI));
+       ut_asserteq(0, sandbox_clk_query_requested(dev_clk,
+                                                  SANDBOX_CLK_ID_I2C));
+       ut_asserteq(0, sandbox_clk_query_requested(dev_clk,
+                                                  SANDBOX_CLK_ID_UART2));
+
+       ut_asserteq(1, sandbox_clk_query_requested(dev_clk,
+                                                  SANDBOX_CLK_ID_UART1));
+       ut_assertok(device_remove(dev_test, DM_REMOVE_NORMAL));
+       ut_asserteq(0, sandbox_clk_query_requested(dev_clk,
+                                                  SANDBOX_CLK_ID_UART1));
+       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));
+       ut_assertok(device_remove(dev_test, DM_REMOVE_NORMAL));
 
        return 0;
 }
-DM_TEST(dm_test_clk_periph, DM_TESTF_SCAN_PDATA | DM_TESTF_SCAN_FDT);
+DM_TEST(dm_test_clk_bulk, DM_TESTF_SCAN_FDT);