// SPDX-License-Identifier: GPL-2.0 /* * Copyright (c) 2022 Yassine Oudjana */ #include #include #include "clk-gate.h" #include "clk-mtk.h" #include #define IMG_CG_CON 0x00 #define IMG_CG_SET 0x04 #define IMG_CG_CLR 0x08 static struct mtk_gate_regs imgsys_cg_regs = { .set_ofs = IMG_CG_SET, .clr_ofs = IMG_CG_CLR, .sta_ofs = IMG_CG_CON, }; static const struct mtk_gate imgsys_gates[] = { GATE_MTK(CLK_IMG_SMI_LARB2, "smi_larb2", "mm_sel", &imgsys_cg_regs, 0, &mtk_clk_gate_ops_setclr), GATE_MTK(CLK_IMG_CAM_SMI, "cam_smi", "mm_sel", &imgsys_cg_regs, 5, &mtk_clk_gate_ops_setclr), GATE_MTK(CLK_IMG_CAM_CAM, "cam_cam", "mm_sel", &imgsys_cg_regs, 6, &mtk_clk_gate_ops_setclr), GATE_MTK(CLK_IMG_SEN_TG, "sen_tg", "mm_sel", &imgsys_cg_regs, 7, &mtk_clk_gate_ops_setclr), GATE_MTK(CLK_IMG_SEN_CAM, "sen_cam", "mm_sel", &imgsys_cg_regs, 8, &mtk_clk_gate_ops_setclr), GATE_MTK(CLK_IMG_CAM_SV, "cam_sv", "mm_sel", &imgsys_cg_regs, 9, &mtk_clk_gate_ops_setclr), GATE_MTK(CLK_IMG_SUFOD, "sufod", "mm_sel", &imgsys_cg_regs, 10, &mtk_clk_gate_ops_setclr), GATE_MTK(CLK_IMG_FD, "fd", "mm_sel", &imgsys_cg_regs, 11, &mtk_clk_gate_ops_setclr), }; static const struct mtk_clk_desc imgsys_clks = { .clks = imgsys_gates, .num_clks = ARRAY_SIZE(imgsys_gates), }; static const struct of_device_id of_match_mt6735_imgsys[] = { { .compatible = "mediatek,mt6735-imgsys", .data = &imgsys_clks }, { /* sentinel */ } }; static struct platform_driver clk_mt6735_imgsys = { .probe = mtk_clk_simple_probe, .remove = mtk_clk_simple_remove, .driver = { .name = "clk-mt6735-imgsys", .of_match_table = of_match_mt6735_imgsys, }, }; module_platform_driver(clk_mt6735_imgsys); MODULE_AUTHOR("Yassine Oudjana "); MODULE_DESCRIPTION("MediaTek MT6735 imgsys clock driver"); MODULE_LICENSE("GPL");