Path: blob/master/sound/soc/mediatek/mt8189/mt8189-afe-clk.h
38237 views
/* SPDX-License-Identifier: GPL-2.0 */1/*2* mt8189-afe-clk.h -- Mediatek 8189 afe clock ctrl definition3*4* Copyright (c) 2025 MediaTek Inc.5* Author: Darren Ye <[email protected]>6*/78#ifndef _MT8189_AFE_CLOCK_CTRL_H_9#define _MT8189_AFE_CLOCK_CTRL_H_1011/* APLL */12#define APLL1_W_NAME "APLL1"13#define APLL2_W_NAME "APLL2"1415enum {16MT8189_APLL1,17MT8189_APLL2,18};1920enum {21MT8189_CLK_TOP_MUX_AUDIOINTBUS,22MT8189_CLK_TOP_MUX_AUD_ENG1,23MT8189_CLK_TOP_MUX_AUD_ENG2,24MT8189_CLK_TOP_MUX_AUDIO_H,25/* pll */26MT8189_CLK_TOP_APLL1_CK,27MT8189_CLK_TOP_APLL2_CK,28/* divider */29MT8189_CLK_TOP_APLL1_D4,30MT8189_CLK_TOP_APLL2_D4,31MT8189_CLK_TOP_APLL12_DIV_I2SIN0,32MT8189_CLK_TOP_APLL12_DIV_I2SIN1,33MT8189_CLK_TOP_APLL12_DIV_I2SOUT0,34MT8189_CLK_TOP_APLL12_DIV_I2SOUT1,35MT8189_CLK_TOP_APLL12_DIV_FMI2S,36MT8189_CLK_TOP_APLL12_DIV_TDMOUT_M,37MT8189_CLK_TOP_APLL12_DIV_TDMOUT_B,38/* mux */39MT8189_CLK_TOP_MUX_AUD_1,40MT8189_CLK_TOP_MUX_AUD_2,41MT8189_CLK_TOP_I2SIN0_M_SEL,42MT8189_CLK_TOP_I2SIN1_M_SEL,43MT8189_CLK_TOP_I2SOUT0_M_SEL,44MT8189_CLK_TOP_I2SOUT1_M_SEL,45MT8189_CLK_TOP_FMI2S_M_SEL,46MT8189_CLK_TOP_TDMOUT_M_SEL,47/* top 26m */48MT8189_CLK_TOP_CLK26M,49/* peri */50MT8189_CLK_PERAO_AUDIO_SLV_CK_PERI,51MT8189_CLK_PERAO_AUDIO_MST_CK_PERI,52MT8189_CLK_PERAO_INTBUS_CK_PERI,53MT8189_CLK_NUM,54};5556struct mtk_base_afe;5758int mt8189_mck_enable(struct mtk_base_afe *afe, int mck_id, int rate);59int mt8189_mck_disable(struct mtk_base_afe *afe, int mck_id);60int mt8189_get_apll_rate(struct mtk_base_afe *afe, int apll);61int mt8189_get_apll_by_rate(struct mtk_base_afe *afe, int rate);62int mt8189_get_apll_by_name(struct mtk_base_afe *afe, const char *name);63int mt8189_init_clock(struct mtk_base_afe *afe);64int mt8189_afe_enable_clk(struct mtk_base_afe *afe, struct clk *clk);65void mt8189_afe_disable_clk(struct mtk_base_afe *afe, struct clk *clk);66int mt8189_apll1_enable(struct mtk_base_afe *afe);67void mt8189_apll1_disable(struct mtk_base_afe *afe);68int mt8189_apll2_enable(struct mtk_base_afe *afe);69void mt8189_apll2_disable(struct mtk_base_afe *afe);70int mt8189_afe_enable_main_clock(struct mtk_base_afe *afe);71void mt8189_afe_disable_main_clock(struct mtk_base_afe *afe);72int mt8189_afe_enable_reg_rw_clk(struct mtk_base_afe *afe);73int mt8189_afe_disable_reg_rw_clk(struct mtk_base_afe *afe);7475#endif767778