// SPDX-License-Identifier: GPL-2.0+ /* * Copyright (c) 2019 MediaTek Inc. */ #ifndef __DRV_CLK_MT6873_PG_H #define __DRV_CLK_MT6873_PG_H enum subsys_id { SYS_MD1 = 0, SYS_CONN = 1, SYS_MFG0 = 2, SYS_MFG1 = 3, SYS_MFG2 = 4, SYS_MFG3 = 5, SYS_MFG4 = 6, SYS_MFG5 = 7, SYS_MFG6 = 8, SYS_ISP = 9, SYS_ISP2 = 10, SYS_IPE = 11, SYS_VDE = 12, SYS_VDE2 = 13, SYS_VEN = 14, //SYS_VEN_CORE1 = 15, SYS_MDP = 15, SYS_DIS = 16, SYS_AUDIO = 17, SYS_ADSP = 18, SYS_CAM = 19, SYS_CAM_RAWA = 20, SYS_CAM_RAWB = 21, SYS_CAM_RAWC = 22, SYS_DP_TX = 23, SYS_VPU = 24, SYS_MSDC = 25, NR_SYSS = 26, }; struct pg_callbacks { struct list_head list; void (*before_off)(enum subsys_id sys); void (*after_on)(enum subsys_id sys); void (*debug_dump)(enum subsys_id sys); }; /* register new pg_callbacks and return previous pg_callbacks. */ extern struct pg_callbacks *register_pg_callback(struct pg_callbacks *pgcb); extern int spm_topaxi_protect(unsigned int mask_value, int en); extern int spm_topaxi_protect_1(unsigned int mask_value, int en); extern int cam_mtcmos_patch(int on); extern void check_mm0_clk_sts(void); extern void check_img_clk_sts(void); extern void check_ipe_clk_sts(void); extern void check_ven_clk_sts(void); extern void check_cam_clk_sts(void); extern unsigned int mt_get_abist_freq(unsigned int ID); extern unsigned int mt_get_ckgen_freq(unsigned int ID); extern void print_enabled_clks_once(void); extern void mtk_wcn_cmb_stub_clock_fail_dump(void); extern int get_sw_req_vcore_opp(void); void enable_subsys_hwcg(enum subsys_id id); void mtk_check_subsys_swcg(enum subsys_id id); /* * Resident in clkdbg-mt6873.c * For debug use. */ void print_subsys_reg(char *subsys_name); /*ram console api*/ /* *[0] bus protect reg *[1] pwr_status *[2] pwr_status 2 *[others] local function use */ #ifdef CONFIG_MTK_RAM_CONSOLE extern void aee_rr_rec_clk(int id, u32 val); #endif #endif /* __DRV_CLK_MT6873_PG_H */