Lines Matching +full:sun9i +full:- +full:a80 +full:- +full:ahb +full:- +full:clk
1 // SPDX-License-Identifier: GPL-2.0-or-later
5 * Maxime Ripard <maxime.ripard@free-electrons.com>
8 #include <linux/clk.h>
17 struct clk *bus_clk;
18 struct clk *mod_clk;
30 return -ENOMEM; in sun6i_drc_bind()
33 drc->reset = devm_reset_control_get(dev, NULL); in sun6i_drc_bind()
34 if (IS_ERR(drc->reset)) { in sun6i_drc_bind()
36 return PTR_ERR(drc->reset); in sun6i_drc_bind()
39 ret = reset_control_deassert(drc->reset); in sun6i_drc_bind()
45 drc->bus_clk = devm_clk_get(dev, "ahb"); in sun6i_drc_bind()
46 if (IS_ERR(drc->bus_clk)) { in sun6i_drc_bind()
48 ret = PTR_ERR(drc->bus_clk); in sun6i_drc_bind()
51 clk_prepare_enable(drc->bus_clk); in sun6i_drc_bind()
53 drc->mod_clk = devm_clk_get(dev, "mod"); in sun6i_drc_bind()
54 if (IS_ERR(drc->mod_clk)) { in sun6i_drc_bind()
56 ret = PTR_ERR(drc->mod_clk); in sun6i_drc_bind()
60 ret = clk_set_rate_exclusive(drc->mod_clk, 300000000); in sun6i_drc_bind()
66 clk_prepare_enable(drc->mod_clk); in sun6i_drc_bind()
71 clk_disable_unprepare(drc->bus_clk); in sun6i_drc_bind()
73 reset_control_assert(drc->reset); in sun6i_drc_bind()
82 clk_rate_exclusive_put(drc->mod_clk); in sun6i_drc_unbind()
83 clk_disable_unprepare(drc->mod_clk); in sun6i_drc_unbind()
84 clk_disable_unprepare(drc->bus_clk); in sun6i_drc_unbind()
85 reset_control_assert(drc->reset); in sun6i_drc_unbind()
95 return component_add(&pdev->dev, &sun6i_drc_ops); in sun6i_drc_probe()
100 component_del(&pdev->dev, &sun6i_drc_ops); in sun6i_drc_remove()
104 { .compatible = "allwinner,sun6i-a31-drc" },
105 { .compatible = "allwinner,sun6i-a31s-drc" },
106 { .compatible = "allwinner,sun8i-a23-drc" },
107 { .compatible = "allwinner,sun8i-a33-drc" },
108 { .compatible = "allwinner,sun9i-a80-drc" },
117 .name = "sun6i-drc",
123 MODULE_AUTHOR("Maxime Ripard <maxime.ripard@free-electrons.com>");