Lines Matching +full:sun8i +full:- +full:h3 +full:- +full:de2 +full:- +full:clk

1 // SPDX-License-Identifier: GPL-2.0-only
6 #include <linux/clk.h>
7 #include <linux/clk-provider.h>
18 #include "ccu-sun8i-de2.h"
20 static SUNXI_CCU_GATE(bus_mixer0_clk, "bus-mixer0", "bus-de",
22 static SUNXI_CCU_GATE(bus_mixer1_clk, "bus-mixer1", "bus-de",
24 static SUNXI_CCU_GATE(bus_wb_clk, "bus-wb", "bus-de",
26 static SUNXI_CCU_GATE(bus_rot_clk, "bus-rot", "bus-de",
29 static SUNXI_CCU_GATE(mixer0_clk, "mixer0", "mixer0-div",
31 static SUNXI_CCU_GATE(mixer1_clk, "mixer1", "mixer1-div",
33 static SUNXI_CCU_GATE(wb_clk, "wb", "wb-div",
35 static SUNXI_CCU_GATE(rot_clk, "rot", "rot-div",
38 static SUNXI_CCU_M(mixer0_div_clk, "mixer0-div", "de", 0x0c, 0, 4,
40 static SUNXI_CCU_M(mixer1_div_clk, "mixer1-div", "de", 0x0c, 4, 4,
42 static SUNXI_CCU_M(wb_div_clk, "wb-div", "de", 0x0c, 8, 4,
44 static SUNXI_CCU_M(rot_div_clk, "rot-div", "de", 0x0c, 0x0c, 4,
47 static SUNXI_CCU_M(mixer0_div_a83_clk, "mixer0-div", "pll-de", 0x0c, 0, 4,
49 static SUNXI_CCU_M(mixer1_div_a83_clk, "mixer1-div", "pll-de", 0x0c, 4, 4,
51 static SUNXI_CCU_M(wb_div_a83_clk, "wb-div", "pll-de", 0x0c, 8, 4,
53 static SUNXI_CCU_M(rot_div_a83_clk, "rot-div", "pll-de", 0x0c, 0x0c, 4,
244 struct clk *bus_clk, *mod_clk; in sunxi_de2_clk_probe()
250 ccu_desc = of_device_get_match_data(&pdev->dev); in sunxi_de2_clk_probe()
252 return -EINVAL; in sunxi_de2_clk_probe()
258 bus_clk = devm_clk_get(&pdev->dev, "bus"); in sunxi_de2_clk_probe()
260 return dev_err_probe(&pdev->dev, PTR_ERR(bus_clk), in sunxi_de2_clk_probe()
261 "Couldn't get bus clk\n"); in sunxi_de2_clk_probe()
263 mod_clk = devm_clk_get(&pdev->dev, "mod"); in sunxi_de2_clk_probe()
265 return dev_err_probe(&pdev->dev, PTR_ERR(mod_clk), in sunxi_de2_clk_probe()
266 "Couldn't get mod clk\n"); in sunxi_de2_clk_probe()
268 rstc = devm_reset_control_get_exclusive(&pdev->dev, NULL); in sunxi_de2_clk_probe()
270 return dev_err_probe(&pdev->dev, PTR_ERR(rstc), in sunxi_de2_clk_probe()
276 dev_err(&pdev->dev, "Couldn't enable bus clk: %d\n", ret); in sunxi_de2_clk_probe()
282 dev_err(&pdev->dev, "Couldn't enable mod clk: %d\n", ret); in sunxi_de2_clk_probe()
289 dev_err(&pdev->dev, in sunxi_de2_clk_probe()
294 ret = devm_sunxi_ccu_probe(&pdev->dev, reg, ccu_desc); in sunxi_de2_clk_probe()
311 .compatible = "allwinner,sun8i-a83t-de2-clk",
315 .compatible = "allwinner,sun8i-h3-de2-clk",
319 .compatible = "allwinner,sun8i-r40-de2-clk",
323 .compatible = "allwinner,sun8i-v3s-de2-clk",
327 .compatible = "allwinner,sun50i-a64-de2-clk",
331 .compatible = "allwinner,sun50i-h5-de2-clk",
335 .compatible = "allwinner,sun50i-h6-de3-clk",
345 .name = "sunxi-de2-clks",
352 MODULE_DESCRIPTION("Support for the Allwinner SoCs DE2 CCU");