162306a36Sopenharmony_ci// SPDX-License-Identifier: GPL-2.0
262306a36Sopenharmony_ci/*
362306a36Sopenharmony_ci * Copyright (c) 2018 MediaTek Inc.
462306a36Sopenharmony_ci * Author: Owen Chen <owen.chen@mediatek.com>
562306a36Sopenharmony_ci */
662306a36Sopenharmony_ci
762306a36Sopenharmony_ci#include <linux/clk-provider.h>
862306a36Sopenharmony_ci#include <linux/of.h>
962306a36Sopenharmony_ci#include <linux/of_address.h>
1062306a36Sopenharmony_ci#include <linux/slab.h>
1162306a36Sopenharmony_ci#include <linux/mfd/syscon.h>
1262306a36Sopenharmony_ci#include <linux/mod_devicetable.h>
1362306a36Sopenharmony_ci#include <linux/platform_device.h>
1462306a36Sopenharmony_ci
1562306a36Sopenharmony_ci#include "clk-gate.h"
1662306a36Sopenharmony_ci#include "clk-mtk.h"
1762306a36Sopenharmony_ci#include "clk-mux.h"
1862306a36Sopenharmony_ci#include "clk-pll.h"
1962306a36Sopenharmony_ci
2062306a36Sopenharmony_ci#include <dt-bindings/clock/mt6765-clk.h>
2162306a36Sopenharmony_ci
2262306a36Sopenharmony_ci/*fmeter div select 4*/
2362306a36Sopenharmony_ci#define _DIV4_ 1
2462306a36Sopenharmony_ci
2562306a36Sopenharmony_cistatic DEFINE_SPINLOCK(mt6765_clk_lock);
2662306a36Sopenharmony_ci
2762306a36Sopenharmony_ci/* Total 12 subsys */
2862306a36Sopenharmony_cistatic void __iomem *cksys_base;
2962306a36Sopenharmony_cistatic void __iomem *apmixed_base;
3062306a36Sopenharmony_ci
3162306a36Sopenharmony_ci/* CKSYS */
3262306a36Sopenharmony_ci#define CLK_SCP_CFG_0		(cksys_base + 0x200)
3362306a36Sopenharmony_ci#define CLK_SCP_CFG_1		(cksys_base + 0x204)
3462306a36Sopenharmony_ci
3562306a36Sopenharmony_ci/* CG */
3662306a36Sopenharmony_ci#define AP_PLL_CON3		(apmixed_base + 0x0C)
3762306a36Sopenharmony_ci#define PLLON_CON0		(apmixed_base + 0x44)
3862306a36Sopenharmony_ci#define PLLON_CON1		(apmixed_base + 0x48)
3962306a36Sopenharmony_ci
4062306a36Sopenharmony_ci/* clk cfg update */
4162306a36Sopenharmony_ci#define CLK_CFG_0		0x40
4262306a36Sopenharmony_ci#define CLK_CFG_0_SET		0x44
4362306a36Sopenharmony_ci#define CLK_CFG_0_CLR		0x48
4462306a36Sopenharmony_ci#define CLK_CFG_1		0x50
4562306a36Sopenharmony_ci#define CLK_CFG_1_SET		0x54
4662306a36Sopenharmony_ci#define CLK_CFG_1_CLR		0x58
4762306a36Sopenharmony_ci#define CLK_CFG_2		0x60
4862306a36Sopenharmony_ci#define CLK_CFG_2_SET		0x64
4962306a36Sopenharmony_ci#define CLK_CFG_2_CLR		0x68
5062306a36Sopenharmony_ci#define CLK_CFG_3		0x70
5162306a36Sopenharmony_ci#define CLK_CFG_3_SET		0x74
5262306a36Sopenharmony_ci#define CLK_CFG_3_CLR		0x78
5362306a36Sopenharmony_ci#define CLK_CFG_4		0x80
5462306a36Sopenharmony_ci#define CLK_CFG_4_SET		0x84
5562306a36Sopenharmony_ci#define CLK_CFG_4_CLR		0x88
5662306a36Sopenharmony_ci#define CLK_CFG_5		0x90
5762306a36Sopenharmony_ci#define CLK_CFG_5_SET		0x94
5862306a36Sopenharmony_ci#define CLK_CFG_5_CLR		0x98
5962306a36Sopenharmony_ci#define CLK_CFG_6		0xa0
6062306a36Sopenharmony_ci#define CLK_CFG_6_SET		0xa4
6162306a36Sopenharmony_ci#define CLK_CFG_6_CLR		0xa8
6262306a36Sopenharmony_ci#define CLK_CFG_7		0xb0
6362306a36Sopenharmony_ci#define CLK_CFG_7_SET		0xb4
6462306a36Sopenharmony_ci#define CLK_CFG_7_CLR		0xb8
6562306a36Sopenharmony_ci#define CLK_CFG_8		0xc0
6662306a36Sopenharmony_ci#define CLK_CFG_8_SET		0xc4
6762306a36Sopenharmony_ci#define CLK_CFG_8_CLR		0xc8
6862306a36Sopenharmony_ci#define CLK_CFG_9		0xd0
6962306a36Sopenharmony_ci#define CLK_CFG_9_SET		0xd4
7062306a36Sopenharmony_ci#define CLK_CFG_9_CLR		0xd8
7162306a36Sopenharmony_ci#define CLK_CFG_10		0xe0
7262306a36Sopenharmony_ci#define CLK_CFG_10_SET		0xe4
7362306a36Sopenharmony_ci#define CLK_CFG_10_CLR		0xe8
7462306a36Sopenharmony_ci#define CLK_CFG_UPDATE		0x004
7562306a36Sopenharmony_ci
7662306a36Sopenharmony_cistatic const struct mtk_fixed_clk fixed_clks[] = {
7762306a36Sopenharmony_ci	FIXED_CLK(CLK_TOP_F_FRTC, "f_frtc_ck", "clk32k", 32768),
7862306a36Sopenharmony_ci	FIXED_CLK(CLK_TOP_CLK26M, "clk_26m_ck", "clk26m", 26000000),
7962306a36Sopenharmony_ci	FIXED_CLK(CLK_TOP_DMPLL, "dmpll_ck", NULL, 466000000),
8062306a36Sopenharmony_ci};
8162306a36Sopenharmony_ci
8262306a36Sopenharmony_cistatic const struct mtk_fixed_factor top_divs[] = {
8362306a36Sopenharmony_ci	FACTOR(CLK_TOP_SYSPLL, "syspll_ck", "mainpll", 1, 1),
8462306a36Sopenharmony_ci	FACTOR(CLK_TOP_SYSPLL_D2, "syspll_d2", "mainpll", 1, 2),
8562306a36Sopenharmony_ci	FACTOR(CLK_TOP_SYSPLL1_D2, "syspll1_d2", "syspll_d2", 1, 2),
8662306a36Sopenharmony_ci	FACTOR(CLK_TOP_SYSPLL1_D4, "syspll1_d4", "syspll_d2", 1, 4),
8762306a36Sopenharmony_ci	FACTOR(CLK_TOP_SYSPLL1_D8, "syspll1_d8", "syspll_d2", 1, 8),
8862306a36Sopenharmony_ci	FACTOR(CLK_TOP_SYSPLL1_D16, "syspll1_d16", "syspll_d2", 1, 16),
8962306a36Sopenharmony_ci	FACTOR(CLK_TOP_SYSPLL_D3, "syspll_d3", "mainpll", 1, 3),
9062306a36Sopenharmony_ci	FACTOR(CLK_TOP_SYSPLL2_D2, "syspll2_d2", "syspll_d3", 1, 2),
9162306a36Sopenharmony_ci	FACTOR(CLK_TOP_SYSPLL2_D4, "syspll2_d4", "syspll_d3", 1, 4),
9262306a36Sopenharmony_ci	FACTOR(CLK_TOP_SYSPLL2_D8, "syspll2_d8", "syspll_d3", 1, 8),
9362306a36Sopenharmony_ci	FACTOR(CLK_TOP_SYSPLL_D5, "syspll_d5", "mainpll", 1, 5),
9462306a36Sopenharmony_ci	FACTOR(CLK_TOP_SYSPLL3_D2, "syspll3_d2", "syspll_d5", 1, 2),
9562306a36Sopenharmony_ci	FACTOR(CLK_TOP_SYSPLL3_D4, "syspll3_d4", "syspll_d5", 1, 4),
9662306a36Sopenharmony_ci	FACTOR(CLK_TOP_SYSPLL_D7, "syspll_d7", "mainpll", 1, 7),
9762306a36Sopenharmony_ci	FACTOR(CLK_TOP_SYSPLL4_D2, "syspll4_d2", "syspll_d7", 1, 2),
9862306a36Sopenharmony_ci	FACTOR(CLK_TOP_SYSPLL4_D4, "syspll4_d4", "syspll_d7", 1, 4),
9962306a36Sopenharmony_ci	FACTOR(CLK_TOP_UNIVPLL, "univpll", "univ2pll", 1, 2),
10062306a36Sopenharmony_ci	FACTOR(CLK_TOP_USB20_192M, "usb20_192m_ck", "univpll", 2, 13),
10162306a36Sopenharmony_ci	FACTOR(CLK_TOP_USB20_192M_D4, "usb20_192m_d4", "usb20_192m_ck", 1, 4),
10262306a36Sopenharmony_ci	FACTOR(CLK_TOP_USB20_192M_D8, "usb20_192m_d8", "usb20_192m_ck", 1, 8),
10362306a36Sopenharmony_ci	FACTOR(CLK_TOP_USB20_192M_D16,
10462306a36Sopenharmony_ci	       "usb20_192m_d16", "usb20_192m_ck", 1, 16),
10562306a36Sopenharmony_ci	FACTOR(CLK_TOP_USB20_192M_D32,
10662306a36Sopenharmony_ci	       "usb20_192m_d32", "usb20_192m_ck", 1, 32),
10762306a36Sopenharmony_ci	FACTOR(CLK_TOP_UNIVPLL_D2, "univpll_d2", "univpll", 1, 2),
10862306a36Sopenharmony_ci	FACTOR(CLK_TOP_UNIVPLL1_D2, "univpll1_d2", "univpll_d2", 1, 2),
10962306a36Sopenharmony_ci	FACTOR(CLK_TOP_UNIVPLL1_D4, "univpll1_d4", "univpll_d2", 1, 4),
11062306a36Sopenharmony_ci	FACTOR(CLK_TOP_UNIVPLL_D3, "univpll_d3", "univpll", 1, 3),
11162306a36Sopenharmony_ci	FACTOR(CLK_TOP_UNIVPLL2_D2, "univpll2_d2", "univpll_d3", 1, 2),
11262306a36Sopenharmony_ci	FACTOR(CLK_TOP_UNIVPLL2_D4, "univpll2_d4", "univpll_d3", 1, 4),
11362306a36Sopenharmony_ci	FACTOR(CLK_TOP_UNIVPLL2_D8, "univpll2_d8", "univpll_d3", 1, 8),
11462306a36Sopenharmony_ci	FACTOR(CLK_TOP_UNIVPLL2_D32, "univpll2_d32", "univpll_d3", 1, 32),
11562306a36Sopenharmony_ci	FACTOR(CLK_TOP_UNIVPLL_D5, "univpll_d5", "univpll", 1, 5),
11662306a36Sopenharmony_ci	FACTOR(CLK_TOP_UNIVPLL3_D2, "univpll3_d2", "univpll_d5", 1, 2),
11762306a36Sopenharmony_ci	FACTOR(CLK_TOP_UNIVPLL3_D4, "univpll3_d4", "univpll_d5", 1, 4),
11862306a36Sopenharmony_ci	FACTOR(CLK_TOP_MMPLL, "mmpll_ck", "mmpll", 1, 1),
11962306a36Sopenharmony_ci	FACTOR(CLK_TOP_MMPLL_D2, "mmpll_d2", "mmpll_ck", 1, 2),
12062306a36Sopenharmony_ci	FACTOR(CLK_TOP_MPLL, "mpll_ck", "mpll", 1, 1),
12162306a36Sopenharmony_ci	FACTOR(CLK_TOP_DA_MPLL_104M_DIV, "mpll_104m_div", "mpll_ck", 1, 2),
12262306a36Sopenharmony_ci	FACTOR(CLK_TOP_DA_MPLL_52M_DIV, "mpll_52m_div", "mpll_ck", 1, 4),
12362306a36Sopenharmony_ci	FACTOR(CLK_TOP_MFGPLL, "mfgpll_ck", "mfgpll", 1, 1),
12462306a36Sopenharmony_ci	FACTOR(CLK_TOP_MSDCPLL, "msdcpll_ck", "msdcpll", 1, 1),
12562306a36Sopenharmony_ci	FACTOR(CLK_TOP_MSDCPLL_D2, "msdcpll_d2", "msdcpll_ck", 1, 2),
12662306a36Sopenharmony_ci	FACTOR(CLK_TOP_APLL1, "apll1_ck", "apll1", 1, 1),
12762306a36Sopenharmony_ci	FACTOR(CLK_TOP_APLL1_D2, "apll1_d2", "apll1_ck", 1, 2),
12862306a36Sopenharmony_ci	FACTOR(CLK_TOP_APLL1_D4, "apll1_d4", "apll1_ck", 1, 4),
12962306a36Sopenharmony_ci	FACTOR(CLK_TOP_APLL1_D8, "apll1_d8", "apll1_ck", 1, 8),
13062306a36Sopenharmony_ci	FACTOR(CLK_TOP_ULPOSC1, "ulposc1_ck", "ulposc1", 1, 1),
13162306a36Sopenharmony_ci	FACTOR(CLK_TOP_ULPOSC1_D2, "ulposc1_d2", "ulposc1_ck", 1, 2),
13262306a36Sopenharmony_ci	FACTOR(CLK_TOP_ULPOSC1_D4, "ulposc1_d4", "ulposc1_ck", 1, 4),
13362306a36Sopenharmony_ci	FACTOR(CLK_TOP_ULPOSC1_D8, "ulposc1_d8", "ulposc1_ck", 1, 8),
13462306a36Sopenharmony_ci	FACTOR(CLK_TOP_ULPOSC1_D16, "ulposc1_d16", "ulposc1_ck", 1, 16),
13562306a36Sopenharmony_ci	FACTOR(CLK_TOP_ULPOSC1_D32, "ulposc1_d32", "ulposc1_ck", 1, 32),
13662306a36Sopenharmony_ci	FACTOR(CLK_TOP_F_F26M, "f_f26m_ck", "clk_26m_ck", 1, 1),
13762306a36Sopenharmony_ci	FACTOR(CLK_TOP_AXI, "axi_ck", "axi_sel", 1, 1),
13862306a36Sopenharmony_ci	FACTOR(CLK_TOP_MM, "mm_ck", "mm_sel", 1, 1),
13962306a36Sopenharmony_ci	FACTOR(CLK_TOP_SCP, "scp_ck", "scp_sel", 1, 1),
14062306a36Sopenharmony_ci	FACTOR(CLK_TOP_MFG, "mfg_ck", "mfg_sel", 1, 1),
14162306a36Sopenharmony_ci	FACTOR(CLK_TOP_F_FUART, "f_fuart_ck", "uart_sel", 1, 1),
14262306a36Sopenharmony_ci	FACTOR(CLK_TOP_SPI, "spi_ck", "spi_sel", 1, 1),
14362306a36Sopenharmony_ci	FACTOR(CLK_TOP_MSDC50_0, "msdc50_0_ck", "msdc50_0_sel", 1, 1),
14462306a36Sopenharmony_ci	FACTOR(CLK_TOP_MSDC30_1, "msdc30_1_ck", "msdc30_1_sel", 1, 1),
14562306a36Sopenharmony_ci	FACTOR(CLK_TOP_AUDIO, "audio_ck", "audio_sel", 1, 1),
14662306a36Sopenharmony_ci	FACTOR(CLK_TOP_AUD_1, "aud_1_ck", "aud_1_sel", 1, 1),
14762306a36Sopenharmony_ci	FACTOR(CLK_TOP_AUD_ENGEN1, "aud_engen1_ck", "aud_engen1_sel", 1, 1),
14862306a36Sopenharmony_ci	FACTOR(CLK_TOP_F_FDISP_PWM, "f_fdisp_pwm_ck", "disp_pwm_sel", 1, 1),
14962306a36Sopenharmony_ci	FACTOR(CLK_TOP_SSPM, "sspm_ck", "sspm_sel", 1, 1),
15062306a36Sopenharmony_ci	FACTOR(CLK_TOP_DXCC, "dxcc_ck", "dxcc_sel", 1, 1),
15162306a36Sopenharmony_ci	FACTOR(CLK_TOP_I2C, "i2c_ck", "i2c_sel", 1, 1),
15262306a36Sopenharmony_ci	FACTOR(CLK_TOP_F_FPWM, "f_fpwm_ck", "pwm_sel", 1, 1),
15362306a36Sopenharmony_ci	FACTOR(CLK_TOP_F_FSENINF, "f_fseninf_ck", "seninf_sel", 1, 1),
15462306a36Sopenharmony_ci	FACTOR(CLK_TOP_AES_FDE, "aes_fde_ck", "aes_fde_sel", 1, 1),
15562306a36Sopenharmony_ci	FACTOR(CLK_TOP_F_BIST2FPC, "f_bist2fpc_ck", "univpll2_d2", 1, 1),
15662306a36Sopenharmony_ci	FACTOR(CLK_TOP_ARMPLL_DIVIDER_PLL0, "arm_div_pll0", "syspll_d2", 1, 1),
15762306a36Sopenharmony_ci	FACTOR(CLK_TOP_ARMPLL_DIVIDER_PLL1, "arm_div_pll1", "syspll_ck", 1, 1),
15862306a36Sopenharmony_ci	FACTOR(CLK_TOP_ARMPLL_DIVIDER_PLL2, "arm_div_pll2", "univpll_d2", 1, 1),
15962306a36Sopenharmony_ci	FACTOR(CLK_TOP_DA_USB20_48M_DIV,
16062306a36Sopenharmony_ci	       "usb20_48m_div", "usb20_192m_d4", 1, 1),
16162306a36Sopenharmony_ci	FACTOR(CLK_TOP_DA_UNIV_48M_DIV, "univ_48m_div", "usb20_192m_d4", 1, 1),
16262306a36Sopenharmony_ci};
16362306a36Sopenharmony_ci
16462306a36Sopenharmony_cistatic const char * const axi_parents[] = {
16562306a36Sopenharmony_ci	"clk26m",
16662306a36Sopenharmony_ci	"syspll_d7",
16762306a36Sopenharmony_ci	"syspll1_d4",
16862306a36Sopenharmony_ci	"syspll3_d2"
16962306a36Sopenharmony_ci};
17062306a36Sopenharmony_ci
17162306a36Sopenharmony_cistatic const char * const mem_parents[] = {
17262306a36Sopenharmony_ci	"clk26m",
17362306a36Sopenharmony_ci	"dmpll_ck",
17462306a36Sopenharmony_ci	"apll1_ck"
17562306a36Sopenharmony_ci};
17662306a36Sopenharmony_ci
17762306a36Sopenharmony_cistatic const char * const mm_parents[] = {
17862306a36Sopenharmony_ci	"clk26m",
17962306a36Sopenharmony_ci	"mmpll_ck",
18062306a36Sopenharmony_ci	"syspll1_d2",
18162306a36Sopenharmony_ci	"syspll_d5",
18262306a36Sopenharmony_ci	"syspll1_d4",
18362306a36Sopenharmony_ci	"univpll_d5",
18462306a36Sopenharmony_ci	"univpll1_d2",
18562306a36Sopenharmony_ci	"mmpll_d2"
18662306a36Sopenharmony_ci};
18762306a36Sopenharmony_ci
18862306a36Sopenharmony_cistatic const char * const scp_parents[] = {
18962306a36Sopenharmony_ci	"clk26m",
19062306a36Sopenharmony_ci	"syspll4_d2",
19162306a36Sopenharmony_ci	"univpll2_d2",
19262306a36Sopenharmony_ci	"syspll1_d2",
19362306a36Sopenharmony_ci	"univpll1_d2",
19462306a36Sopenharmony_ci	"syspll_d3",
19562306a36Sopenharmony_ci	"univpll_d3"
19662306a36Sopenharmony_ci};
19762306a36Sopenharmony_ci
19862306a36Sopenharmony_cistatic const char * const mfg_parents[] = {
19962306a36Sopenharmony_ci	"clk26m",
20062306a36Sopenharmony_ci	"mfgpll_ck",
20162306a36Sopenharmony_ci	"syspll_d3",
20262306a36Sopenharmony_ci	"univpll_d3"
20362306a36Sopenharmony_ci};
20462306a36Sopenharmony_ci
20562306a36Sopenharmony_cistatic const char * const atb_parents[] = {
20662306a36Sopenharmony_ci	"clk26m",
20762306a36Sopenharmony_ci	"syspll1_d4",
20862306a36Sopenharmony_ci	"syspll1_d2"
20962306a36Sopenharmony_ci};
21062306a36Sopenharmony_ci
21162306a36Sopenharmony_cistatic const char * const camtg_parents[] = {
21262306a36Sopenharmony_ci	"clk26m",
21362306a36Sopenharmony_ci	"usb20_192m_d8",
21462306a36Sopenharmony_ci	"univpll2_d8",
21562306a36Sopenharmony_ci	"usb20_192m_d4",
21662306a36Sopenharmony_ci	"univpll2_d32",
21762306a36Sopenharmony_ci	"usb20_192m_d16",
21862306a36Sopenharmony_ci	"usb20_192m_d32"
21962306a36Sopenharmony_ci};
22062306a36Sopenharmony_ci
22162306a36Sopenharmony_cistatic const char * const uart_parents[] = {
22262306a36Sopenharmony_ci	"clk26m",
22362306a36Sopenharmony_ci	"univpll2_d8"
22462306a36Sopenharmony_ci};
22562306a36Sopenharmony_ci
22662306a36Sopenharmony_cistatic const char * const spi_parents[] = {
22762306a36Sopenharmony_ci	"clk26m",
22862306a36Sopenharmony_ci	"syspll3_d2",
22962306a36Sopenharmony_ci	"syspll4_d2",
23062306a36Sopenharmony_ci	"syspll2_d4"
23162306a36Sopenharmony_ci};
23262306a36Sopenharmony_ci
23362306a36Sopenharmony_cistatic const char * const msdc5hclk_parents[] = {
23462306a36Sopenharmony_ci	"clk26m",
23562306a36Sopenharmony_ci	"syspll1_d2",
23662306a36Sopenharmony_ci	"univpll1_d4",
23762306a36Sopenharmony_ci	"syspll2_d2"
23862306a36Sopenharmony_ci};
23962306a36Sopenharmony_ci
24062306a36Sopenharmony_cistatic const char * const msdc50_0_parents[] = {
24162306a36Sopenharmony_ci	"clk26m",
24262306a36Sopenharmony_ci	"msdcpll_ck",
24362306a36Sopenharmony_ci	"syspll2_d2",
24462306a36Sopenharmony_ci	"syspll4_d2",
24562306a36Sopenharmony_ci	"univpll1_d2",
24662306a36Sopenharmony_ci	"syspll1_d2",
24762306a36Sopenharmony_ci	"univpll_d5",
24862306a36Sopenharmony_ci	"univpll1_d4"
24962306a36Sopenharmony_ci};
25062306a36Sopenharmony_ci
25162306a36Sopenharmony_cistatic const char * const msdc30_1_parents[] = {
25262306a36Sopenharmony_ci	"clk26m",
25362306a36Sopenharmony_ci	"msdcpll_d2",
25462306a36Sopenharmony_ci	"univpll2_d2",
25562306a36Sopenharmony_ci	"syspll2_d2",
25662306a36Sopenharmony_ci	"syspll1_d4",
25762306a36Sopenharmony_ci	"univpll1_d4",
25862306a36Sopenharmony_ci	"usb20_192m_d4",
25962306a36Sopenharmony_ci	"syspll2_d4"
26062306a36Sopenharmony_ci};
26162306a36Sopenharmony_ci
26262306a36Sopenharmony_cistatic const char * const audio_parents[] = {
26362306a36Sopenharmony_ci	"clk26m",
26462306a36Sopenharmony_ci	"syspll3_d4",
26562306a36Sopenharmony_ci	"syspll4_d4",
26662306a36Sopenharmony_ci	"syspll1_d16"
26762306a36Sopenharmony_ci};
26862306a36Sopenharmony_ci
26962306a36Sopenharmony_cistatic const char * const aud_intbus_parents[] = {
27062306a36Sopenharmony_ci	"clk26m",
27162306a36Sopenharmony_ci	"syspll1_d4",
27262306a36Sopenharmony_ci	"syspll4_d2"
27362306a36Sopenharmony_ci};
27462306a36Sopenharmony_ci
27562306a36Sopenharmony_cistatic const char * const aud_1_parents[] = {
27662306a36Sopenharmony_ci	"clk26m",
27762306a36Sopenharmony_ci	"apll1_ck"
27862306a36Sopenharmony_ci};
27962306a36Sopenharmony_ci
28062306a36Sopenharmony_cistatic const char * const aud_engen1_parents[] = {
28162306a36Sopenharmony_ci	"clk26m",
28262306a36Sopenharmony_ci	"apll1_d2",
28362306a36Sopenharmony_ci	"apll1_d4",
28462306a36Sopenharmony_ci	"apll1_d8"
28562306a36Sopenharmony_ci};
28662306a36Sopenharmony_ci
28762306a36Sopenharmony_cistatic const char * const disp_pwm_parents[] = {
28862306a36Sopenharmony_ci	"clk26m",
28962306a36Sopenharmony_ci	"univpll2_d4",
29062306a36Sopenharmony_ci	"ulposc1_d2",
29162306a36Sopenharmony_ci	"ulposc1_d8"
29262306a36Sopenharmony_ci};
29362306a36Sopenharmony_ci
29462306a36Sopenharmony_cistatic const char * const sspm_parents[] = {
29562306a36Sopenharmony_ci	"clk26m",
29662306a36Sopenharmony_ci	"syspll1_d2",
29762306a36Sopenharmony_ci	"syspll_d3"
29862306a36Sopenharmony_ci};
29962306a36Sopenharmony_ci
30062306a36Sopenharmony_cistatic const char * const dxcc_parents[] = {
30162306a36Sopenharmony_ci	"clk26m",
30262306a36Sopenharmony_ci	"syspll1_d2",
30362306a36Sopenharmony_ci	"syspll1_d4",
30462306a36Sopenharmony_ci	"syspll1_d8"
30562306a36Sopenharmony_ci};
30662306a36Sopenharmony_ci
30762306a36Sopenharmony_cistatic const char * const usb_top_parents[] = {
30862306a36Sopenharmony_ci	"clk26m",
30962306a36Sopenharmony_ci	"univpll3_d4"
31062306a36Sopenharmony_ci};
31162306a36Sopenharmony_ci
31262306a36Sopenharmony_cistatic const char * const spm_parents[] = {
31362306a36Sopenharmony_ci	"clk26m",
31462306a36Sopenharmony_ci	"syspll1_d8"
31562306a36Sopenharmony_ci};
31662306a36Sopenharmony_ci
31762306a36Sopenharmony_cistatic const char * const i2c_parents[] = {
31862306a36Sopenharmony_ci	"clk26m",
31962306a36Sopenharmony_ci	"univpll3_d4",
32062306a36Sopenharmony_ci	"univpll3_d2",
32162306a36Sopenharmony_ci	"syspll1_d8",
32262306a36Sopenharmony_ci	"syspll2_d8"
32362306a36Sopenharmony_ci};
32462306a36Sopenharmony_ci
32562306a36Sopenharmony_cistatic const char * const pwm_parents[] = {
32662306a36Sopenharmony_ci	"clk26m",
32762306a36Sopenharmony_ci	"univpll3_d4",
32862306a36Sopenharmony_ci	"syspll1_d8"
32962306a36Sopenharmony_ci};
33062306a36Sopenharmony_ci
33162306a36Sopenharmony_cistatic const char * const seninf_parents[] = {
33262306a36Sopenharmony_ci	"clk26m",
33362306a36Sopenharmony_ci	"univpll1_d4",
33462306a36Sopenharmony_ci	"univpll1_d2",
33562306a36Sopenharmony_ci	"univpll2_d2"
33662306a36Sopenharmony_ci};
33762306a36Sopenharmony_ci
33862306a36Sopenharmony_cistatic const char * const aes_fde_parents[] = {
33962306a36Sopenharmony_ci	"clk26m",
34062306a36Sopenharmony_ci	"msdcpll_ck",
34162306a36Sopenharmony_ci	"univpll_d3",
34262306a36Sopenharmony_ci	"univpll2_d2",
34362306a36Sopenharmony_ci	"univpll1_d2",
34462306a36Sopenharmony_ci	"syspll1_d2"
34562306a36Sopenharmony_ci};
34662306a36Sopenharmony_ci
34762306a36Sopenharmony_cistatic const char * const ulposc_parents[] = {
34862306a36Sopenharmony_ci	"clk26m",
34962306a36Sopenharmony_ci	"ulposc1_d4",
35062306a36Sopenharmony_ci	"ulposc1_d8",
35162306a36Sopenharmony_ci	"ulposc1_d16",
35262306a36Sopenharmony_ci	"ulposc1_d32"
35362306a36Sopenharmony_ci};
35462306a36Sopenharmony_ci
35562306a36Sopenharmony_cistatic const char * const camtm_parents[] = {
35662306a36Sopenharmony_ci	"clk26m",
35762306a36Sopenharmony_ci	"univpll1_d4",
35862306a36Sopenharmony_ci	"univpll1_d2",
35962306a36Sopenharmony_ci	"univpll2_d2"
36062306a36Sopenharmony_ci};
36162306a36Sopenharmony_ci
36262306a36Sopenharmony_ci#define INVALID_UPDATE_REG 0xFFFFFFFF
36362306a36Sopenharmony_ci#define INVALID_UPDATE_SHIFT -1
36462306a36Sopenharmony_ci#define INVALID_MUX_GATE -1
36562306a36Sopenharmony_ci
36662306a36Sopenharmony_cistatic const struct mtk_mux top_muxes[] = {
36762306a36Sopenharmony_ci	/* CLK_CFG_0 */
36862306a36Sopenharmony_ci	MUX_GATE_CLR_SET_UPD_FLAGS(CLK_TOP_AXI_SEL, "axi_sel", axi_parents,
36962306a36Sopenharmony_ci			      CLK_CFG_0, CLK_CFG_0_SET, CLK_CFG_0_CLR,
37062306a36Sopenharmony_ci			      0, 2, 7, CLK_CFG_UPDATE, 0,
37162306a36Sopenharmony_ci			      CLK_IS_CRITICAL | CLK_SET_RATE_PARENT),
37262306a36Sopenharmony_ci	MUX_GATE_CLR_SET_UPD_FLAGS(CLK_TOP_MEM_SEL, "mem_sel", mem_parents,
37362306a36Sopenharmony_ci			      CLK_CFG_0, CLK_CFG_0_SET, CLK_CFG_0_CLR,
37462306a36Sopenharmony_ci			      8, 2, 15, CLK_CFG_UPDATE, 1,
37562306a36Sopenharmony_ci			      CLK_IS_CRITICAL | CLK_SET_RATE_PARENT),
37662306a36Sopenharmony_ci	MUX_GATE_CLR_SET_UPD(CLK_TOP_MM_SEL, "mm_sel", mm_parents, CLK_CFG_0,
37762306a36Sopenharmony_ci			CLK_CFG_0_SET, CLK_CFG_0_CLR, 16, 3, 23,
37862306a36Sopenharmony_ci			CLK_CFG_UPDATE, 2),
37962306a36Sopenharmony_ci	MUX_GATE_CLR_SET_UPD(CLK_TOP_SCP_SEL, "scp_sel", scp_parents, CLK_CFG_0,
38062306a36Sopenharmony_ci			CLK_CFG_0_SET, CLK_CFG_0_CLR, 24, 3, 31,
38162306a36Sopenharmony_ci			CLK_CFG_UPDATE, 3),
38262306a36Sopenharmony_ci	/* CLK_CFG_1 */
38362306a36Sopenharmony_ci	MUX_GATE_CLR_SET_UPD(CLK_TOP_MFG_SEL, "mfg_sel", mfg_parents, CLK_CFG_1,
38462306a36Sopenharmony_ci			CLK_CFG_1_SET, CLK_CFG_1_CLR, 0, 2, 7,
38562306a36Sopenharmony_ci			CLK_CFG_UPDATE, 4),
38662306a36Sopenharmony_ci	MUX_GATE_CLR_SET_UPD(CLK_TOP_ATB_SEL, "atb_sel", atb_parents, CLK_CFG_1,
38762306a36Sopenharmony_ci			CLK_CFG_1_SET, CLK_CFG_1_CLR, 8, 2, 15,
38862306a36Sopenharmony_ci			CLK_CFG_UPDATE, 5),
38962306a36Sopenharmony_ci	MUX_GATE_CLR_SET_UPD(CLK_TOP_CAMTG_SEL, "camtg_sel",
39062306a36Sopenharmony_ci			camtg_parents, CLK_CFG_1, CLK_CFG_1_SET,
39162306a36Sopenharmony_ci			CLK_CFG_1_CLR, 16, 3, 23, CLK_CFG_UPDATE, 6),
39262306a36Sopenharmony_ci	MUX_GATE_CLR_SET_UPD(CLK_TOP_CAMTG1_SEL, "camtg1_sel", camtg_parents,
39362306a36Sopenharmony_ci			CLK_CFG_1, CLK_CFG_1_SET, CLK_CFG_1_CLR,
39462306a36Sopenharmony_ci			24, 3, 31, CLK_CFG_UPDATE, 7),
39562306a36Sopenharmony_ci	/* CLK_CFG_2 */
39662306a36Sopenharmony_ci	MUX_GATE_CLR_SET_UPD(CLK_TOP_CAMTG2_SEL, "camtg2_sel",
39762306a36Sopenharmony_ci			camtg_parents, CLK_CFG_2, CLK_CFG_2_SET,
39862306a36Sopenharmony_ci			CLK_CFG_2_CLR, 0, 3, 7, CLK_CFG_UPDATE, 8),
39962306a36Sopenharmony_ci	MUX_GATE_CLR_SET_UPD(CLK_TOP_CAMTG3_SEL, "camtg3_sel", camtg_parents,
40062306a36Sopenharmony_ci			CLK_CFG_2, CLK_CFG_2_SET, CLK_CFG_2_CLR,
40162306a36Sopenharmony_ci			8, 3, 15, CLK_CFG_UPDATE, 9),
40262306a36Sopenharmony_ci	MUX_GATE_CLR_SET_UPD(CLK_TOP_UART_SEL, "uart_sel", uart_parents,
40362306a36Sopenharmony_ci			CLK_CFG_2, CLK_CFG_2_SET, CLK_CFG_2_CLR, 16, 1, 23,
40462306a36Sopenharmony_ci			CLK_CFG_UPDATE, 10),
40562306a36Sopenharmony_ci	MUX_GATE_CLR_SET_UPD(CLK_TOP_SPI_SEL, "spi_sel", spi_parents, CLK_CFG_2,
40662306a36Sopenharmony_ci			CLK_CFG_2_SET, CLK_CFG_2_CLR, 24, 2, 31,
40762306a36Sopenharmony_ci			CLK_CFG_UPDATE, 11),
40862306a36Sopenharmony_ci	/* CLK_CFG_3 */
40962306a36Sopenharmony_ci	MUX_GATE_CLR_SET_UPD_FLAGS(CLK_TOP_MSDC50_0_HCLK_SEL, "msdc5hclk",
41062306a36Sopenharmony_ci			msdc5hclk_parents, CLK_CFG_3, CLK_CFG_3_SET,
41162306a36Sopenharmony_ci			CLK_CFG_3_CLR, 0, 2, 7, CLK_CFG_UPDATE, 12, 0),
41262306a36Sopenharmony_ci	MUX_GATE_CLR_SET_UPD_FLAGS(CLK_TOP_MSDC50_0_SEL, "msdc50_0_sel",
41362306a36Sopenharmony_ci			msdc50_0_parents, CLK_CFG_3, CLK_CFG_3_SET,
41462306a36Sopenharmony_ci			CLK_CFG_3_CLR, 8, 3, 15, CLK_CFG_UPDATE, 13, 0),
41562306a36Sopenharmony_ci	MUX_GATE_CLR_SET_UPD_FLAGS(CLK_TOP_MSDC30_1_SEL, "msdc30_1_sel",
41662306a36Sopenharmony_ci			msdc30_1_parents, CLK_CFG_3, CLK_CFG_3_SET,
41762306a36Sopenharmony_ci			CLK_CFG_3_CLR, 16, 3, 23, CLK_CFG_UPDATE, 14, 0),
41862306a36Sopenharmony_ci	MUX_GATE_CLR_SET_UPD(CLK_TOP_AUDIO_SEL, "audio_sel", audio_parents,
41962306a36Sopenharmony_ci			CLK_CFG_3, CLK_CFG_3_SET, CLK_CFG_3_CLR,
42062306a36Sopenharmony_ci			24, 2, 31, CLK_CFG_UPDATE, 15),
42162306a36Sopenharmony_ci	/* CLK_CFG_4 */
42262306a36Sopenharmony_ci	MUX_GATE_CLR_SET_UPD(CLK_TOP_AUD_INTBUS_SEL, "aud_intbus_sel",
42362306a36Sopenharmony_ci			aud_intbus_parents, CLK_CFG_4, CLK_CFG_4_SET,
42462306a36Sopenharmony_ci			CLK_CFG_4_CLR, 0, 2, 7, CLK_CFG_UPDATE, 16),
42562306a36Sopenharmony_ci	MUX_GATE_CLR_SET_UPD(CLK_TOP_AUD_1_SEL, "aud_1_sel", aud_1_parents,
42662306a36Sopenharmony_ci			CLK_CFG_4, CLK_CFG_4_SET, CLK_CFG_4_CLR,
42762306a36Sopenharmony_ci			8, 1, 15, CLK_CFG_UPDATE, 17),
42862306a36Sopenharmony_ci	MUX_GATE_CLR_SET_UPD(CLK_TOP_AUD_ENGEN1_SEL, "aud_engen1_sel",
42962306a36Sopenharmony_ci			aud_engen1_parents, CLK_CFG_4, CLK_CFG_4_SET,
43062306a36Sopenharmony_ci			CLK_CFG_4_CLR, 16, 2, 23, CLK_CFG_UPDATE, 18),
43162306a36Sopenharmony_ci	MUX_GATE_CLR_SET_UPD(CLK_TOP_DISP_PWM_SEL, "disp_pwm_sel",
43262306a36Sopenharmony_ci			disp_pwm_parents, CLK_CFG_4, CLK_CFG_4_SET,
43362306a36Sopenharmony_ci			CLK_CFG_4_CLR, 24, 2, 31, CLK_CFG_UPDATE, 19),
43462306a36Sopenharmony_ci	/* CLK_CFG_5 */
43562306a36Sopenharmony_ci	MUX_GATE_CLR_SET_UPD(CLK_TOP_SSPM_SEL, "sspm_sel", sspm_parents,
43662306a36Sopenharmony_ci			CLK_CFG_5, CLK_CFG_5_SET, CLK_CFG_5_CLR, 0, 2, 7,
43762306a36Sopenharmony_ci			CLK_CFG_UPDATE, 20),
43862306a36Sopenharmony_ci	MUX_GATE_CLR_SET_UPD(CLK_TOP_DXCC_SEL, "dxcc_sel", dxcc_parents,
43962306a36Sopenharmony_ci			CLK_CFG_5, CLK_CFG_5_SET, CLK_CFG_5_CLR, 8, 2, 15,
44062306a36Sopenharmony_ci			CLK_CFG_UPDATE, 21),
44162306a36Sopenharmony_ci	MUX_GATE_CLR_SET_UPD(CLK_TOP_USB_TOP_SEL, "usb_top_sel",
44262306a36Sopenharmony_ci			usb_top_parents, CLK_CFG_5, CLK_CFG_5_SET,
44362306a36Sopenharmony_ci			CLK_CFG_5_CLR, 16, 1, 23, CLK_CFG_UPDATE, 22),
44462306a36Sopenharmony_ci	MUX_GATE_CLR_SET_UPD(CLK_TOP_SPM_SEL, "spm_sel", spm_parents, CLK_CFG_5,
44562306a36Sopenharmony_ci			CLK_CFG_5_SET, CLK_CFG_5_CLR, 24, 1, 31,
44662306a36Sopenharmony_ci			CLK_CFG_UPDATE, 23),
44762306a36Sopenharmony_ci	/* CLK_CFG_6 */
44862306a36Sopenharmony_ci	MUX_GATE_CLR_SET_UPD(CLK_TOP_I2C_SEL, "i2c_sel", i2c_parents, CLK_CFG_6,
44962306a36Sopenharmony_ci			CLK_CFG_6_SET, CLK_CFG_6_CLR, 0, 3, 7, CLK_CFG_UPDATE,
45062306a36Sopenharmony_ci			24),
45162306a36Sopenharmony_ci	MUX_GATE_CLR_SET_UPD(CLK_TOP_PWM_SEL, "pwm_sel", pwm_parents, CLK_CFG_6,
45262306a36Sopenharmony_ci			CLK_CFG_6_SET, CLK_CFG_6_CLR, 8, 2, 15, CLK_CFG_UPDATE,
45362306a36Sopenharmony_ci			25),
45462306a36Sopenharmony_ci	MUX_GATE_CLR_SET_UPD(CLK_TOP_SENINF_SEL, "seninf_sel", seninf_parents,
45562306a36Sopenharmony_ci			CLK_CFG_6, CLK_CFG_6_SET, CLK_CFG_6_CLR, 16, 2, 23,
45662306a36Sopenharmony_ci			CLK_CFG_UPDATE, 26),
45762306a36Sopenharmony_ci	MUX_GATE_CLR_SET_UPD(CLK_TOP_AES_FDE_SEL, "aes_fde_sel",
45862306a36Sopenharmony_ci			aes_fde_parents, CLK_CFG_6, CLK_CFG_6_SET,
45962306a36Sopenharmony_ci			CLK_CFG_6_CLR, 24, 3, 31, CLK_CFG_UPDATE, 27),
46062306a36Sopenharmony_ci	/* CLK_CFG_7 */
46162306a36Sopenharmony_ci	MUX_GATE_CLR_SET_UPD_FLAGS(CLK_TOP_PWRAP_ULPOSC_SEL, "ulposc_sel",
46262306a36Sopenharmony_ci			      ulposc_parents, CLK_CFG_7, CLK_CFG_7_SET,
46362306a36Sopenharmony_ci			      CLK_CFG_7_CLR, 0, 3, 7, CLK_CFG_UPDATE, 28,
46462306a36Sopenharmony_ci			      CLK_IS_CRITICAL | CLK_SET_RATE_PARENT),
46562306a36Sopenharmony_ci	MUX_GATE_CLR_SET_UPD(CLK_TOP_CAMTM_SEL, "camtm_sel", camtm_parents,
46662306a36Sopenharmony_ci			CLK_CFG_7, CLK_CFG_7_SET, CLK_CFG_7_CLR, 8, 2, 15,
46762306a36Sopenharmony_ci			CLK_CFG_UPDATE, 29),
46862306a36Sopenharmony_ci};
46962306a36Sopenharmony_ci
47062306a36Sopenharmony_cistatic const struct mtk_gate_regs top0_cg_regs = {
47162306a36Sopenharmony_ci	.set_ofs = 0x0,
47262306a36Sopenharmony_ci	.clr_ofs = 0x0,
47362306a36Sopenharmony_ci	.sta_ofs = 0x0,
47462306a36Sopenharmony_ci};
47562306a36Sopenharmony_ci
47662306a36Sopenharmony_cistatic const struct mtk_gate_regs top1_cg_regs = {
47762306a36Sopenharmony_ci	.set_ofs = 0x104,
47862306a36Sopenharmony_ci	.clr_ofs = 0x104,
47962306a36Sopenharmony_ci	.sta_ofs = 0x104,
48062306a36Sopenharmony_ci};
48162306a36Sopenharmony_ci
48262306a36Sopenharmony_cistatic const struct mtk_gate_regs top2_cg_regs = {
48362306a36Sopenharmony_ci	.set_ofs = 0x320,
48462306a36Sopenharmony_ci	.clr_ofs = 0x320,
48562306a36Sopenharmony_ci	.sta_ofs = 0x320,
48662306a36Sopenharmony_ci};
48762306a36Sopenharmony_ci
48862306a36Sopenharmony_ci#define GATE_TOP0(_id, _name, _parent, _shift)				\
48962306a36Sopenharmony_ci	GATE_MTK(_id, _name, _parent, &top0_cg_regs, _shift, &mtk_clk_gate_ops_no_setclr)
49062306a36Sopenharmony_ci
49162306a36Sopenharmony_ci#define GATE_TOP1(_id, _name, _parent, _shift)				\
49262306a36Sopenharmony_ci	GATE_MTK(_id, _name, _parent, &top1_cg_regs, _shift, &mtk_clk_gate_ops_no_setclr_inv)
49362306a36Sopenharmony_ci
49462306a36Sopenharmony_ci#define GATE_TOP2(_id, _name, _parent, _shift)				\
49562306a36Sopenharmony_ci	GATE_MTK(_id, _name, _parent, &top2_cg_regs, _shift, &mtk_clk_gate_ops_no_setclr)
49662306a36Sopenharmony_ci
49762306a36Sopenharmony_cistatic const struct mtk_gate top_clks[] = {
49862306a36Sopenharmony_ci	/* TOP0 */
49962306a36Sopenharmony_ci	GATE_TOP0(CLK_TOP_MD_32K, "md_32k", "f_frtc_ck", 8),
50062306a36Sopenharmony_ci	GATE_TOP0(CLK_TOP_MD_26M, "md_26m", "f_f26m_ck", 9),
50162306a36Sopenharmony_ci	GATE_TOP0(CLK_TOP_MD2_32K, "md2_32k", "f_frtc_ck", 10),
50262306a36Sopenharmony_ci	GATE_TOP0(CLK_TOP_MD2_26M, "md2_26m", "f_f26m_ck", 11),
50362306a36Sopenharmony_ci	/* TOP1 */
50462306a36Sopenharmony_ci	GATE_TOP1(CLK_TOP_ARMPLL_DIVIDER_PLL0_EN,
50562306a36Sopenharmony_ci		  "arm_div_pll0_en", "arm_div_pll0", 3),
50662306a36Sopenharmony_ci	GATE_TOP1(CLK_TOP_ARMPLL_DIVIDER_PLL1_EN,
50762306a36Sopenharmony_ci		  "arm_div_pll1_en", "arm_div_pll1", 4),
50862306a36Sopenharmony_ci	GATE_TOP1(CLK_TOP_ARMPLL_DIVIDER_PLL2_EN,
50962306a36Sopenharmony_ci		  "arm_div_pll2_en", "arm_div_pll2", 5),
51062306a36Sopenharmony_ci	GATE_TOP1(CLK_TOP_FMEM_OCC_DRC_EN, "drc_en", "univpll2_d2", 6),
51162306a36Sopenharmony_ci	GATE_TOP1(CLK_TOP_USB20_48M_EN, "usb20_48m_en", "usb20_48m_div", 8),
51262306a36Sopenharmony_ci	GATE_TOP1(CLK_TOP_UNIVPLL_48M_EN, "univpll_48m_en", "univ_48m_div", 9),
51362306a36Sopenharmony_ci	GATE_TOP1(CLK_TOP_F_UFS_MP_SAP_CFG_EN, "ufs_sap", "f_f26m_ck", 12),
51462306a36Sopenharmony_ci	GATE_TOP1(CLK_TOP_F_BIST2FPC_EN, "bist2fpc", "f_bist2fpc_ck", 16),
51562306a36Sopenharmony_ci	/* TOP2 */
51662306a36Sopenharmony_ci	GATE_TOP2(CLK_TOP_APLL12_DIV0, "apll12_div0", "aud_1_ck", 2),
51762306a36Sopenharmony_ci	GATE_TOP2(CLK_TOP_APLL12_DIV1, "apll12_div1", "aud_1_ck", 3),
51862306a36Sopenharmony_ci	GATE_TOP2(CLK_TOP_APLL12_DIV2, "apll12_div2", "aud_1_ck", 4),
51962306a36Sopenharmony_ci	GATE_TOP2(CLK_TOP_APLL12_DIV3, "apll12_div3", "aud_1_ck", 5),
52062306a36Sopenharmony_ci};
52162306a36Sopenharmony_ci
52262306a36Sopenharmony_cistatic const struct mtk_gate_regs ifr2_cg_regs = {
52362306a36Sopenharmony_ci	.set_ofs = 0x80,
52462306a36Sopenharmony_ci	.clr_ofs = 0x84,
52562306a36Sopenharmony_ci	.sta_ofs = 0x90,
52662306a36Sopenharmony_ci};
52762306a36Sopenharmony_ci
52862306a36Sopenharmony_cistatic const struct mtk_gate_regs ifr3_cg_regs = {
52962306a36Sopenharmony_ci	.set_ofs = 0x88,
53062306a36Sopenharmony_ci	.clr_ofs = 0x8c,
53162306a36Sopenharmony_ci	.sta_ofs = 0x94,
53262306a36Sopenharmony_ci};
53362306a36Sopenharmony_ci
53462306a36Sopenharmony_cistatic const struct mtk_gate_regs ifr4_cg_regs = {
53562306a36Sopenharmony_ci	.set_ofs = 0xa4,
53662306a36Sopenharmony_ci	.clr_ofs = 0xa8,
53762306a36Sopenharmony_ci	.sta_ofs = 0xac,
53862306a36Sopenharmony_ci};
53962306a36Sopenharmony_ci
54062306a36Sopenharmony_cistatic const struct mtk_gate_regs ifr5_cg_regs = {
54162306a36Sopenharmony_ci	.set_ofs = 0xc0,
54262306a36Sopenharmony_ci	.clr_ofs = 0xc4,
54362306a36Sopenharmony_ci	.sta_ofs = 0xc8,
54462306a36Sopenharmony_ci};
54562306a36Sopenharmony_ci
54662306a36Sopenharmony_ci#define GATE_IFR2(_id, _name, _parent, _shift)				\
54762306a36Sopenharmony_ci	GATE_MTK(_id, _name, _parent, &ifr2_cg_regs, _shift, &mtk_clk_gate_ops_setclr)
54862306a36Sopenharmony_ci
54962306a36Sopenharmony_ci#define GATE_IFR3(_id, _name, _parent, _shift)				\
55062306a36Sopenharmony_ci	GATE_MTK(_id, _name, _parent, &ifr3_cg_regs, _shift, &mtk_clk_gate_ops_setclr)
55162306a36Sopenharmony_ci
55262306a36Sopenharmony_ci#define GATE_IFR4(_id, _name, _parent, _shift)				\
55362306a36Sopenharmony_ci	GATE_MTK(_id, _name, _parent, &ifr4_cg_regs, _shift, &mtk_clk_gate_ops_setclr)
55462306a36Sopenharmony_ci
55562306a36Sopenharmony_ci#define GATE_IFR5(_id, _name, _parent, _shift)				\
55662306a36Sopenharmony_ci	GATE_MTK(_id, _name, _parent, &ifr5_cg_regs, _shift, &mtk_clk_gate_ops_setclr)
55762306a36Sopenharmony_ci
55862306a36Sopenharmony_cistatic const struct mtk_gate ifr_clks[] = {
55962306a36Sopenharmony_ci	/* INFRA_TOPAXI */
56062306a36Sopenharmony_ci	/* INFRA PERI */
56162306a36Sopenharmony_ci	/* INFRA mode 0 */
56262306a36Sopenharmony_ci	GATE_IFR2(CLK_IFR_ICUSB, "ifr_icusb", "axi_ck", 8),
56362306a36Sopenharmony_ci	GATE_IFR2(CLK_IFR_GCE, "ifr_gce", "axi_ck", 9),
56462306a36Sopenharmony_ci	GATE_IFR2(CLK_IFR_THERM, "ifr_therm", "axi_ck", 10),
56562306a36Sopenharmony_ci	GATE_IFR2(CLK_IFR_I2C_AP, "ifr_i2c_ap", "i2c_ck", 11),
56662306a36Sopenharmony_ci	GATE_IFR2(CLK_IFR_I2C_CCU, "ifr_i2c_ccu", "i2c_ck", 12),
56762306a36Sopenharmony_ci	GATE_IFR2(CLK_IFR_I2C_SSPM, "ifr_i2c_sspm", "i2c_ck", 13),
56862306a36Sopenharmony_ci	GATE_IFR2(CLK_IFR_I2C_RSV, "ifr_i2c_rsv", "i2c_ck", 14),
56962306a36Sopenharmony_ci	GATE_IFR2(CLK_IFR_PWM_HCLK, "ifr_pwm_hclk", "axi_ck", 15),
57062306a36Sopenharmony_ci	GATE_IFR2(CLK_IFR_PWM1, "ifr_pwm1", "f_fpwm_ck", 16),
57162306a36Sopenharmony_ci	GATE_IFR2(CLK_IFR_PWM2, "ifr_pwm2", "f_fpwm_ck", 17),
57262306a36Sopenharmony_ci	GATE_IFR2(CLK_IFR_PWM3, "ifr_pwm3", "f_fpwm_ck", 18),
57362306a36Sopenharmony_ci	GATE_IFR2(CLK_IFR_PWM4, "ifr_pwm4", "f_fpwm_ck", 19),
57462306a36Sopenharmony_ci	GATE_IFR2(CLK_IFR_PWM5, "ifr_pwm5", "f_fpwm_ck", 20),
57562306a36Sopenharmony_ci	GATE_IFR2(CLK_IFR_PWM, "ifr_pwm", "f_fpwm_ck", 21),
57662306a36Sopenharmony_ci	GATE_IFR2(CLK_IFR_UART0, "ifr_uart0", "f_fuart_ck", 22),
57762306a36Sopenharmony_ci	GATE_IFR2(CLK_IFR_UART1, "ifr_uart1", "f_fuart_ck", 23),
57862306a36Sopenharmony_ci	GATE_IFR2(CLK_IFR_GCE_26M, "ifr_gce_26m", "f_f26m_ck", 27),
57962306a36Sopenharmony_ci	GATE_IFR2(CLK_IFR_CQ_DMA_FPC, "ifr_dma", "axi_ck", 28),
58062306a36Sopenharmony_ci	GATE_IFR2(CLK_IFR_BTIF, "ifr_btif", "axi_ck", 31),
58162306a36Sopenharmony_ci	/* INFRA mode 1 */
58262306a36Sopenharmony_ci	GATE_IFR3(CLK_IFR_SPI0, "ifr_spi0", "spi_ck", 1),
58362306a36Sopenharmony_ci	GATE_IFR3(CLK_IFR_MSDC0, "ifr_msdc0", "msdc5hclk", 2),
58462306a36Sopenharmony_ci	GATE_IFR3(CLK_IFR_MSDC1, "ifr_msdc1", "axi_ck", 4),
58562306a36Sopenharmony_ci	GATE_IFR3(CLK_IFR_TRNG, "ifr_trng", "axi_ck", 9),
58662306a36Sopenharmony_ci	GATE_IFR3(CLK_IFR_AUXADC, "ifr_auxadc", "f_f26m_ck", 10),
58762306a36Sopenharmony_ci	GATE_IFR3(CLK_IFR_CCIF1_AP, "ifr_ccif1_ap", "axi_ck", 12),
58862306a36Sopenharmony_ci	GATE_IFR3(CLK_IFR_CCIF1_MD, "ifr_ccif1_md", "axi_ck", 13),
58962306a36Sopenharmony_ci	GATE_IFR3(CLK_IFR_AUXADC_MD, "ifr_auxadc_md", "f_f26m_ck", 14),
59062306a36Sopenharmony_ci	GATE_IFR3(CLK_IFR_AP_DMA, "ifr_ap_dma", "axi_ck", 18),
59162306a36Sopenharmony_ci	GATE_IFR3(CLK_IFR_DEVICE_APC, "ifr_dapc", "axi_ck", 20),
59262306a36Sopenharmony_ci	GATE_IFR3(CLK_IFR_CCIF_AP, "ifr_ccif_ap", "axi_ck", 23),
59362306a36Sopenharmony_ci	GATE_IFR3(CLK_IFR_AUDIO, "ifr_audio", "axi_ck", 25),
59462306a36Sopenharmony_ci	GATE_IFR3(CLK_IFR_CCIF_MD, "ifr_ccif_md", "axi_ck", 26),
59562306a36Sopenharmony_ci	/* INFRA mode 2 */
59662306a36Sopenharmony_ci	GATE_IFR4(CLK_IFR_RG_PWM_FBCLK6, "ifr_pwmfb", "f_f26m_ck", 0),
59762306a36Sopenharmony_ci	GATE_IFR4(CLK_IFR_DISP_PWM, "ifr_disp_pwm", "f_fdisp_pwm_ck", 2),
59862306a36Sopenharmony_ci	GATE_IFR4(CLK_IFR_CLDMA_BCLK, "ifr_cldmabclk", "axi_ck", 3),
59962306a36Sopenharmony_ci	GATE_IFR4(CLK_IFR_AUDIO_26M_BCLK, "ifr_audio26m", "f_f26m_ck", 4),
60062306a36Sopenharmony_ci	GATE_IFR4(CLK_IFR_SPI1, "ifr_spi1", "spi_ck", 6),
60162306a36Sopenharmony_ci	GATE_IFR4(CLK_IFR_I2C4, "ifr_i2c4", "i2c_ck", 7),
60262306a36Sopenharmony_ci	GATE_IFR4(CLK_IFR_SPI2, "ifr_spi2", "spi_ck", 9),
60362306a36Sopenharmony_ci	GATE_IFR4(CLK_IFR_SPI3, "ifr_spi3", "spi_ck", 10),
60462306a36Sopenharmony_ci	GATE_IFR4(CLK_IFR_I2C5, "ifr_i2c5", "i2c_ck", 18),
60562306a36Sopenharmony_ci	GATE_IFR4(CLK_IFR_I2C5_ARBITER, "ifr_i2c5a", "i2c_ck", 19),
60662306a36Sopenharmony_ci	GATE_IFR4(CLK_IFR_I2C5_IMM, "ifr_i2c5_imm", "i2c_ck", 20),
60762306a36Sopenharmony_ci	GATE_IFR4(CLK_IFR_I2C1_ARBITER, "ifr_i2c1a", "i2c_ck", 21),
60862306a36Sopenharmony_ci	GATE_IFR4(CLK_IFR_I2C1_IMM, "ifr_i2c1_imm", "i2c_ck", 22),
60962306a36Sopenharmony_ci	GATE_IFR4(CLK_IFR_I2C2_ARBITER, "ifr_i2c2a", "i2c_ck", 23),
61062306a36Sopenharmony_ci	GATE_IFR4(CLK_IFR_I2C2_IMM, "ifr_i2c2_imm", "i2c_ck", 24),
61162306a36Sopenharmony_ci	GATE_IFR4(CLK_IFR_SPI4, "ifr_spi4", "spi_ck", 25),
61262306a36Sopenharmony_ci	GATE_IFR4(CLK_IFR_SPI5, "ifr_spi5", "spi_ck", 26),
61362306a36Sopenharmony_ci	GATE_IFR4(CLK_IFR_CQ_DMA, "ifr_cq_dma", "axi_ck", 27),
61462306a36Sopenharmony_ci	GATE_IFR4(CLK_IFR_FAES_FDE, "ifr_faes_fde_ck", "aes_fde_ck", 29),
61562306a36Sopenharmony_ci	/* INFRA mode 3 */
61662306a36Sopenharmony_ci	GATE_IFR5(CLK_IFR_MSDC0_SELF, "ifr_msdc0sf", "msdc50_0_ck", 0),
61762306a36Sopenharmony_ci	GATE_IFR5(CLK_IFR_MSDC1_SELF, "ifr_msdc1sf", "msdc50_0_ck", 1),
61862306a36Sopenharmony_ci	GATE_IFR5(CLK_IFR_I2C6, "ifr_i2c6", "i2c_ck", 6),
61962306a36Sopenharmony_ci	GATE_IFR5(CLK_IFR_AP_MSDC0, "ifr_ap_msdc0", "msdc50_0_ck", 7),
62062306a36Sopenharmony_ci	GATE_IFR5(CLK_IFR_MD_MSDC0, "ifr_md_msdc0", "msdc50_0_ck", 8),
62162306a36Sopenharmony_ci	GATE_IFR5(CLK_IFR_MSDC0_SRC, "ifr_msdc0_clk", "msdc50_0_ck", 9),
62262306a36Sopenharmony_ci	GATE_IFR5(CLK_IFR_MSDC1_SRC, "ifr_msdc1_clk", "msdc30_1_ck", 10),
62362306a36Sopenharmony_ci	GATE_IFR5(CLK_IFR_MCU_PM_BCLK, "ifr_mcu_pm_bclk", "axi_ck", 17),
62462306a36Sopenharmony_ci	GATE_IFR5(CLK_IFR_CCIF2_AP, "ifr_ccif2_ap", "axi_ck", 18),
62562306a36Sopenharmony_ci	GATE_IFR5(CLK_IFR_CCIF2_MD, "ifr_ccif2_md", "axi_ck", 19),
62662306a36Sopenharmony_ci	GATE_IFR5(CLK_IFR_CCIF3_AP, "ifr_ccif3_ap", "axi_ck", 20),
62762306a36Sopenharmony_ci	GATE_IFR5(CLK_IFR_CCIF3_MD, "ifr_ccif3_md", "axi_ck", 21),
62862306a36Sopenharmony_ci};
62962306a36Sopenharmony_ci
63062306a36Sopenharmony_ci/* additional CCF control for mipi26M race condition(disp/camera) */
63162306a36Sopenharmony_cistatic const struct mtk_gate_regs apmixed_cg_regs = {
63262306a36Sopenharmony_ci	.set_ofs = 0x14,
63362306a36Sopenharmony_ci	.clr_ofs = 0x14,
63462306a36Sopenharmony_ci	.sta_ofs = 0x14,
63562306a36Sopenharmony_ci};
63662306a36Sopenharmony_ci
63762306a36Sopenharmony_ci#define GATE_APMIXED(_id, _name, _parent, _shift)			\
63862306a36Sopenharmony_ci	GATE_MTK(_id, _name, _parent, &apmixed_cg_regs, _shift, &mtk_clk_gate_ops_no_setclr_inv)
63962306a36Sopenharmony_ci
64062306a36Sopenharmony_cistatic const struct mtk_gate apmixed_clks[] = {
64162306a36Sopenharmony_ci	/* AUDIO0 */
64262306a36Sopenharmony_ci	GATE_APMIXED(CLK_APMIXED_SSUSB26M, "apmixed_ssusb26m", "f_f26m_ck",
64362306a36Sopenharmony_ci		     4),
64462306a36Sopenharmony_ci	GATE_APMIXED(CLK_APMIXED_APPLL26M, "apmixed_appll26m", "f_f26m_ck",
64562306a36Sopenharmony_ci		     5),
64662306a36Sopenharmony_ci	GATE_APMIXED(CLK_APMIXED_MIPIC0_26M, "apmixed_mipic026m", "f_f26m_ck",
64762306a36Sopenharmony_ci		     6),
64862306a36Sopenharmony_ci	GATE_APMIXED(CLK_APMIXED_MDPLLGP26M, "apmixed_mdpll26m", "f_f26m_ck",
64962306a36Sopenharmony_ci		     7),
65062306a36Sopenharmony_ci	GATE_APMIXED(CLK_APMIXED_MMSYS_F26M, "apmixed_mmsys26m", "f_f26m_ck",
65162306a36Sopenharmony_ci		     8),
65262306a36Sopenharmony_ci	GATE_APMIXED(CLK_APMIXED_UFS26M, "apmixed_ufs26m", "f_f26m_ck",
65362306a36Sopenharmony_ci		     9),
65462306a36Sopenharmony_ci	GATE_APMIXED(CLK_APMIXED_MIPIC1_26M, "apmixed_mipic126m", "f_f26m_ck",
65562306a36Sopenharmony_ci		     11),
65662306a36Sopenharmony_ci	GATE_APMIXED(CLK_APMIXED_MEMPLL26M, "apmixed_mempll26m", "f_f26m_ck",
65762306a36Sopenharmony_ci		     13),
65862306a36Sopenharmony_ci	GATE_APMIXED(CLK_APMIXED_CLKSQ_LVPLL_26M, "apmixed_lvpll26m",
65962306a36Sopenharmony_ci		     "f_f26m_ck", 14),
66062306a36Sopenharmony_ci	GATE_APMIXED(CLK_APMIXED_MIPID0_26M, "apmixed_mipid026m", "f_f26m_ck",
66162306a36Sopenharmony_ci		     16),
66262306a36Sopenharmony_ci};
66362306a36Sopenharmony_ci
66462306a36Sopenharmony_ci#define MT6765_PLL_FMAX		(3800UL * MHZ)
66562306a36Sopenharmony_ci#define MT6765_PLL_FMIN		(1500UL * MHZ)
66662306a36Sopenharmony_ci
66762306a36Sopenharmony_ci#define CON0_MT6765_RST_BAR	BIT(23)
66862306a36Sopenharmony_ci
66962306a36Sopenharmony_ci#define PLL_INFO_NULL		(0xFF)
67062306a36Sopenharmony_ci
67162306a36Sopenharmony_ci#define PLL_B(_id, _name, _reg, _pwr_reg, _en_mask, _flags, _pcwbits,	\
67262306a36Sopenharmony_ci		_pcwibits, _pd_reg, _pd_shift, _tuner_reg, _tuner_en_reg,\
67362306a36Sopenharmony_ci		_tuner_en_bit, _pcw_reg, _pcw_shift, _div_table) {\
67462306a36Sopenharmony_ci		.id = _id,						\
67562306a36Sopenharmony_ci		.name = _name,						\
67662306a36Sopenharmony_ci		.reg = _reg,						\
67762306a36Sopenharmony_ci		.pwr_reg = _pwr_reg,					\
67862306a36Sopenharmony_ci		.en_mask = _en_mask,					\
67962306a36Sopenharmony_ci		.flags = _flags,					\
68062306a36Sopenharmony_ci		.rst_bar_mask = CON0_MT6765_RST_BAR,			\
68162306a36Sopenharmony_ci		.fmax = MT6765_PLL_FMAX,				\
68262306a36Sopenharmony_ci		.fmin = MT6765_PLL_FMIN,				\
68362306a36Sopenharmony_ci		.pcwbits = _pcwbits,					\
68462306a36Sopenharmony_ci		.pcwibits = _pcwibits,					\
68562306a36Sopenharmony_ci		.pd_reg = _pd_reg,					\
68662306a36Sopenharmony_ci		.pd_shift = _pd_shift,					\
68762306a36Sopenharmony_ci		.tuner_reg = _tuner_reg,				\
68862306a36Sopenharmony_ci		.tuner_en_reg = _tuner_en_reg,				\
68962306a36Sopenharmony_ci		.tuner_en_bit = _tuner_en_bit,				\
69062306a36Sopenharmony_ci		.pcw_reg = _pcw_reg,					\
69162306a36Sopenharmony_ci		.pcw_shift = _pcw_shift,				\
69262306a36Sopenharmony_ci		.div_table = _div_table,				\
69362306a36Sopenharmony_ci	}
69462306a36Sopenharmony_ci
69562306a36Sopenharmony_ci#define PLL(_id, _name, _reg, _pwr_reg, _en_mask, _flags, _pcwbits,	\
69662306a36Sopenharmony_ci			_pcwibits, _pd_reg, _pd_shift, _tuner_reg,	\
69762306a36Sopenharmony_ci			_tuner_en_reg, _tuner_en_bit, _pcw_reg,	\
69862306a36Sopenharmony_ci			_pcw_shift)	\
69962306a36Sopenharmony_ci		PLL_B(_id, _name, _reg, _pwr_reg, _en_mask, _flags,	\
70062306a36Sopenharmony_ci			_pcwbits, _pcwibits, _pd_reg, _pd_shift,	\
70162306a36Sopenharmony_ci			_tuner_reg, _tuner_en_reg, _tuner_en_bit,	\
70262306a36Sopenharmony_ci			_pcw_reg, _pcw_shift, NULL)	\
70362306a36Sopenharmony_ci
70462306a36Sopenharmony_cistatic const struct mtk_pll_data plls[] = {
70562306a36Sopenharmony_ci	PLL(CLK_APMIXED_ARMPLL_L, "armpll_l", 0x021C, 0x0228, 0,
70662306a36Sopenharmony_ci	    PLL_AO, 22, 8, 0x0220, 24, 0, 0, 0, 0x0220, 0),
70762306a36Sopenharmony_ci	PLL(CLK_APMIXED_ARMPLL, "armpll", 0x020C, 0x0218, 0,
70862306a36Sopenharmony_ci	    PLL_AO, 22, 8, 0x0210, 24, 0, 0, 0, 0x0210, 0),
70962306a36Sopenharmony_ci	PLL(CLK_APMIXED_CCIPLL, "ccipll", 0x022C, 0x0238, 0,
71062306a36Sopenharmony_ci	    PLL_AO, 22, 8, 0x0230, 24, 0, 0, 0, 0x0230, 0),
71162306a36Sopenharmony_ci	PLL(CLK_APMIXED_MAINPLL, "mainpll", 0x023C, 0x0248, 0,
71262306a36Sopenharmony_ci	    (HAVE_RST_BAR | PLL_AO), 22, 8, 0x0240, 24, 0, 0, 0, 0x0240,
71362306a36Sopenharmony_ci	    0),
71462306a36Sopenharmony_ci	PLL(CLK_APMIXED_MFGPLL, "mfgpll", 0x024C, 0x0258, 0,
71562306a36Sopenharmony_ci	    0, 22, 8, 0x0250, 24, 0, 0, 0, 0x0250, 0),
71662306a36Sopenharmony_ci	PLL(CLK_APMIXED_MMPLL, "mmpll", 0x025C, 0x0268, 0,
71762306a36Sopenharmony_ci	    0, 22, 8, 0x0260, 24, 0, 0, 0, 0x0260, 0),
71862306a36Sopenharmony_ci	PLL(CLK_APMIXED_UNIV2PLL, "univ2pll", 0x026C, 0x0278, 0,
71962306a36Sopenharmony_ci	    HAVE_RST_BAR, 22, 8, 0x0270, 24, 0, 0, 0, 0x0270, 0),
72062306a36Sopenharmony_ci	PLL(CLK_APMIXED_MSDCPLL, "msdcpll", 0x027C, 0x0288, 0,
72162306a36Sopenharmony_ci	    0, 22, 8, 0x0280, 24, 0, 0, 0, 0x0280, 0),
72262306a36Sopenharmony_ci	PLL(CLK_APMIXED_APLL1, "apll1", 0x028C, 0x029C, 0,
72362306a36Sopenharmony_ci	    0, 32, 8, 0x0290, 24, 0x0040, 0x000C, 0, 0x0294, 0),
72462306a36Sopenharmony_ci	PLL(CLK_APMIXED_MPLL, "mpll", 0x02A0, 0x02AC, 0,
72562306a36Sopenharmony_ci	    PLL_AO, 22, 8, 0x02A4, 24, 0, 0, 0, 0x02A4, 0),
72662306a36Sopenharmony_ci};
72762306a36Sopenharmony_ci
72862306a36Sopenharmony_cistatic int clk_mt6765_apmixed_probe(struct platform_device *pdev)
72962306a36Sopenharmony_ci{
73062306a36Sopenharmony_ci	struct clk_hw_onecell_data *clk_data;
73162306a36Sopenharmony_ci	int r;
73262306a36Sopenharmony_ci	struct device_node *node = pdev->dev.of_node;
73362306a36Sopenharmony_ci	void __iomem *base;
73462306a36Sopenharmony_ci
73562306a36Sopenharmony_ci	base = devm_platform_ioremap_resource(pdev, 0);
73662306a36Sopenharmony_ci	if (IS_ERR(base))
73762306a36Sopenharmony_ci		return PTR_ERR(base);
73862306a36Sopenharmony_ci
73962306a36Sopenharmony_ci	clk_data = mtk_alloc_clk_data(CLK_APMIXED_NR_CLK);
74062306a36Sopenharmony_ci	if (!clk_data)
74162306a36Sopenharmony_ci		return -ENOMEM;
74262306a36Sopenharmony_ci
74362306a36Sopenharmony_ci	mtk_clk_register_plls(node, plls, ARRAY_SIZE(plls), clk_data);
74462306a36Sopenharmony_ci
74562306a36Sopenharmony_ci	mtk_clk_register_gates(&pdev->dev, node, apmixed_clks,
74662306a36Sopenharmony_ci			       ARRAY_SIZE(apmixed_clks), clk_data);
74762306a36Sopenharmony_ci	r = of_clk_add_hw_provider(node, of_clk_hw_onecell_get, clk_data);
74862306a36Sopenharmony_ci
74962306a36Sopenharmony_ci	if (r)
75062306a36Sopenharmony_ci		pr_err("%s(): could not register clock provider: %d\n",
75162306a36Sopenharmony_ci		       __func__, r);
75262306a36Sopenharmony_ci
75362306a36Sopenharmony_ci	apmixed_base = base;
75462306a36Sopenharmony_ci	/* MPLL, CCIPLL, MAINPLL set HW mode, TDCLKSQ, CLKSQ1 */
75562306a36Sopenharmony_ci	writel(readl(AP_PLL_CON3) & 0xFFFFFFE1, AP_PLL_CON3);
75662306a36Sopenharmony_ci	writel(readl(PLLON_CON0) & 0x01041041, PLLON_CON0);
75762306a36Sopenharmony_ci	writel(readl(PLLON_CON1) & 0x01041041, PLLON_CON1);
75862306a36Sopenharmony_ci
75962306a36Sopenharmony_ci	return r;
76062306a36Sopenharmony_ci}
76162306a36Sopenharmony_ci
76262306a36Sopenharmony_cistatic int clk_mt6765_top_probe(struct platform_device *pdev)
76362306a36Sopenharmony_ci{
76462306a36Sopenharmony_ci	int r;
76562306a36Sopenharmony_ci	struct device_node *node = pdev->dev.of_node;
76662306a36Sopenharmony_ci	void __iomem *base;
76762306a36Sopenharmony_ci	struct clk_hw_onecell_data *clk_data;
76862306a36Sopenharmony_ci
76962306a36Sopenharmony_ci	base = devm_platform_ioremap_resource(pdev, 0);
77062306a36Sopenharmony_ci	if (IS_ERR(base))
77162306a36Sopenharmony_ci		return PTR_ERR(base);
77262306a36Sopenharmony_ci
77362306a36Sopenharmony_ci	clk_data = mtk_alloc_clk_data(CLK_TOP_NR_CLK);
77462306a36Sopenharmony_ci	if (!clk_data)
77562306a36Sopenharmony_ci		return -ENOMEM;
77662306a36Sopenharmony_ci
77762306a36Sopenharmony_ci	mtk_clk_register_fixed_clks(fixed_clks, ARRAY_SIZE(fixed_clks),
77862306a36Sopenharmony_ci				    clk_data);
77962306a36Sopenharmony_ci	mtk_clk_register_factors(top_divs, ARRAY_SIZE(top_divs),
78062306a36Sopenharmony_ci				 clk_data);
78162306a36Sopenharmony_ci	mtk_clk_register_muxes(&pdev->dev, top_muxes,
78262306a36Sopenharmony_ci			       ARRAY_SIZE(top_muxes), node,
78362306a36Sopenharmony_ci			       &mt6765_clk_lock, clk_data);
78462306a36Sopenharmony_ci	mtk_clk_register_gates(&pdev->dev, node, top_clks,
78562306a36Sopenharmony_ci			       ARRAY_SIZE(top_clks), clk_data);
78662306a36Sopenharmony_ci
78762306a36Sopenharmony_ci	r = of_clk_add_hw_provider(node, of_clk_hw_onecell_get, clk_data);
78862306a36Sopenharmony_ci
78962306a36Sopenharmony_ci	if (r)
79062306a36Sopenharmony_ci		pr_err("%s(): could not register clock provider: %d\n",
79162306a36Sopenharmony_ci		       __func__, r);
79262306a36Sopenharmony_ci
79362306a36Sopenharmony_ci	cksys_base = base;
79462306a36Sopenharmony_ci	/* [4]:no need */
79562306a36Sopenharmony_ci	writel(readl(CLK_SCP_CFG_0) | 0x3EF, CLK_SCP_CFG_0);
79662306a36Sopenharmony_ci	/*[1,2,3,8]: no need*/
79762306a36Sopenharmony_ci	writel(readl(CLK_SCP_CFG_1) | 0x1, CLK_SCP_CFG_1);
79862306a36Sopenharmony_ci
79962306a36Sopenharmony_ci	return r;
80062306a36Sopenharmony_ci}
80162306a36Sopenharmony_ci
80262306a36Sopenharmony_cistatic int clk_mt6765_ifr_probe(struct platform_device *pdev)
80362306a36Sopenharmony_ci{
80462306a36Sopenharmony_ci	struct clk_hw_onecell_data *clk_data;
80562306a36Sopenharmony_ci	int r;
80662306a36Sopenharmony_ci	struct device_node *node = pdev->dev.of_node;
80762306a36Sopenharmony_ci	void __iomem *base;
80862306a36Sopenharmony_ci
80962306a36Sopenharmony_ci	base = devm_platform_ioremap_resource(pdev, 0);
81062306a36Sopenharmony_ci	if (IS_ERR(base))
81162306a36Sopenharmony_ci		return PTR_ERR(base);
81262306a36Sopenharmony_ci
81362306a36Sopenharmony_ci	clk_data = mtk_alloc_clk_data(CLK_IFR_NR_CLK);
81462306a36Sopenharmony_ci	if (!clk_data)
81562306a36Sopenharmony_ci		return -ENOMEM;
81662306a36Sopenharmony_ci
81762306a36Sopenharmony_ci	mtk_clk_register_gates(&pdev->dev, node, ifr_clks,
81862306a36Sopenharmony_ci			       ARRAY_SIZE(ifr_clks), clk_data);
81962306a36Sopenharmony_ci	r = of_clk_add_hw_provider(node, of_clk_hw_onecell_get, clk_data);
82062306a36Sopenharmony_ci
82162306a36Sopenharmony_ci	if (r)
82262306a36Sopenharmony_ci		pr_err("%s(): could not register clock provider: %d\n",
82362306a36Sopenharmony_ci		       __func__, r);
82462306a36Sopenharmony_ci
82562306a36Sopenharmony_ci	return r;
82662306a36Sopenharmony_ci}
82762306a36Sopenharmony_ci
82862306a36Sopenharmony_cistatic const struct of_device_id of_match_clk_mt6765[] = {
82962306a36Sopenharmony_ci	{
83062306a36Sopenharmony_ci		.compatible = "mediatek,mt6765-apmixedsys",
83162306a36Sopenharmony_ci		.data = clk_mt6765_apmixed_probe,
83262306a36Sopenharmony_ci	}, {
83362306a36Sopenharmony_ci		.compatible = "mediatek,mt6765-topckgen",
83462306a36Sopenharmony_ci		.data = clk_mt6765_top_probe,
83562306a36Sopenharmony_ci	}, {
83662306a36Sopenharmony_ci		.compatible = "mediatek,mt6765-infracfg",
83762306a36Sopenharmony_ci		.data = clk_mt6765_ifr_probe,
83862306a36Sopenharmony_ci	}, {
83962306a36Sopenharmony_ci		/* sentinel */
84062306a36Sopenharmony_ci	}
84162306a36Sopenharmony_ci};
84262306a36Sopenharmony_ciMODULE_DEVICE_TABLE(of, of_match_clk_mt6765);
84362306a36Sopenharmony_ci
84462306a36Sopenharmony_cistatic int clk_mt6765_probe(struct platform_device *pdev)
84562306a36Sopenharmony_ci{
84662306a36Sopenharmony_ci	int (*clk_probe)(struct platform_device *d);
84762306a36Sopenharmony_ci	int r;
84862306a36Sopenharmony_ci
84962306a36Sopenharmony_ci	clk_probe = of_device_get_match_data(&pdev->dev);
85062306a36Sopenharmony_ci	if (!clk_probe)
85162306a36Sopenharmony_ci		return -EINVAL;
85262306a36Sopenharmony_ci
85362306a36Sopenharmony_ci	r = clk_probe(pdev);
85462306a36Sopenharmony_ci	if (r)
85562306a36Sopenharmony_ci		dev_err(&pdev->dev,
85662306a36Sopenharmony_ci			"could not register clock provider: %s: %d\n",
85762306a36Sopenharmony_ci			pdev->name, r);
85862306a36Sopenharmony_ci
85962306a36Sopenharmony_ci	return r;
86062306a36Sopenharmony_ci}
86162306a36Sopenharmony_ci
86262306a36Sopenharmony_cistatic struct platform_driver clk_mt6765_drv = {
86362306a36Sopenharmony_ci	.probe = clk_mt6765_probe,
86462306a36Sopenharmony_ci	.driver = {
86562306a36Sopenharmony_ci		.name = "clk-mt6765",
86662306a36Sopenharmony_ci		.of_match_table = of_match_clk_mt6765,
86762306a36Sopenharmony_ci	},
86862306a36Sopenharmony_ci};
86962306a36Sopenharmony_ci
87062306a36Sopenharmony_cistatic int __init clk_mt6765_init(void)
87162306a36Sopenharmony_ci{
87262306a36Sopenharmony_ci	return platform_driver_register(&clk_mt6765_drv);
87362306a36Sopenharmony_ci}
87462306a36Sopenharmony_ci
87562306a36Sopenharmony_ciarch_initcall(clk_mt6765_init);
87662306a36Sopenharmony_ciMODULE_LICENSE("GPL");
877