162306a36Sopenharmony_ci/* SPDX-License-Identifier: GPL-2.0 */ 262306a36Sopenharmony_ci/* 362306a36Sopenharmony_ci * mt8192-afe-common.h -- Mediatek 8192 audio driver definitions 462306a36Sopenharmony_ci * 562306a36Sopenharmony_ci * Copyright (c) 2020 MediaTek Inc. 662306a36Sopenharmony_ci * Author: Shane Chien <shane.chien@mediatek.com> 762306a36Sopenharmony_ci */ 862306a36Sopenharmony_ci 962306a36Sopenharmony_ci#ifndef _MT_8192_AFE_COMMON_H_ 1062306a36Sopenharmony_ci#define _MT_8192_AFE_COMMON_H_ 1162306a36Sopenharmony_ci 1262306a36Sopenharmony_ci#include <linux/list.h> 1362306a36Sopenharmony_ci#include <linux/regmap.h> 1462306a36Sopenharmony_ci#include <sound/soc.h> 1562306a36Sopenharmony_ci 1662306a36Sopenharmony_ci#include "../common/mtk-base-afe.h" 1762306a36Sopenharmony_ci#include "mt8192-reg.h" 1862306a36Sopenharmony_ci 1962306a36Sopenharmony_cienum { 2062306a36Sopenharmony_ci MT8192_MEMIF_DL1, 2162306a36Sopenharmony_ci MT8192_MEMIF_DL12, 2262306a36Sopenharmony_ci MT8192_MEMIF_DL2, 2362306a36Sopenharmony_ci MT8192_MEMIF_DL3, 2462306a36Sopenharmony_ci MT8192_MEMIF_DL4, 2562306a36Sopenharmony_ci MT8192_MEMIF_DL5, 2662306a36Sopenharmony_ci MT8192_MEMIF_DL6, 2762306a36Sopenharmony_ci MT8192_MEMIF_DL7, 2862306a36Sopenharmony_ci MT8192_MEMIF_DL8, 2962306a36Sopenharmony_ci MT8192_MEMIF_DL9, 3062306a36Sopenharmony_ci MT8192_MEMIF_DAI, 3162306a36Sopenharmony_ci MT8192_MEMIF_DAI2, 3262306a36Sopenharmony_ci MT8192_MEMIF_MOD_DAI, 3362306a36Sopenharmony_ci MT8192_MEMIF_VUL12, 3462306a36Sopenharmony_ci MT8192_MEMIF_VUL2, 3562306a36Sopenharmony_ci MT8192_MEMIF_VUL3, 3662306a36Sopenharmony_ci MT8192_MEMIF_VUL4, 3762306a36Sopenharmony_ci MT8192_MEMIF_VUL5, 3862306a36Sopenharmony_ci MT8192_MEMIF_VUL6, 3962306a36Sopenharmony_ci MT8192_MEMIF_AWB, 4062306a36Sopenharmony_ci MT8192_MEMIF_AWB2, 4162306a36Sopenharmony_ci MT8192_MEMIF_HDMI, 4262306a36Sopenharmony_ci MT8192_MEMIF_NUM, 4362306a36Sopenharmony_ci MT8192_DAI_ADDA = MT8192_MEMIF_NUM, 4462306a36Sopenharmony_ci MT8192_DAI_ADDA_CH34, 4562306a36Sopenharmony_ci MT8192_DAI_AP_DMIC, 4662306a36Sopenharmony_ci MT8192_DAI_AP_DMIC_CH34, 4762306a36Sopenharmony_ci MT8192_DAI_VOW, 4862306a36Sopenharmony_ci MT8192_DAI_CONNSYS_I2S, 4962306a36Sopenharmony_ci MT8192_DAI_I2S_0, 5062306a36Sopenharmony_ci MT8192_DAI_I2S_1, 5162306a36Sopenharmony_ci MT8192_DAI_I2S_2, 5262306a36Sopenharmony_ci MT8192_DAI_I2S_3, 5362306a36Sopenharmony_ci MT8192_DAI_I2S_5, 5462306a36Sopenharmony_ci MT8192_DAI_I2S_6, 5562306a36Sopenharmony_ci MT8192_DAI_I2S_7, 5662306a36Sopenharmony_ci MT8192_DAI_I2S_8, 5762306a36Sopenharmony_ci MT8192_DAI_I2S_9, 5862306a36Sopenharmony_ci MT8192_DAI_HW_GAIN_1, 5962306a36Sopenharmony_ci MT8192_DAI_HW_GAIN_2, 6062306a36Sopenharmony_ci MT8192_DAI_SRC_1, 6162306a36Sopenharmony_ci MT8192_DAI_SRC_2, 6262306a36Sopenharmony_ci MT8192_DAI_PCM_1, 6362306a36Sopenharmony_ci MT8192_DAI_PCM_2, 6462306a36Sopenharmony_ci MT8192_DAI_TDM, 6562306a36Sopenharmony_ci MT8192_DAI_NUM, 6662306a36Sopenharmony_ci}; 6762306a36Sopenharmony_ci 6862306a36Sopenharmony_cienum { 6962306a36Sopenharmony_ci MT8192_IRQ_0, 7062306a36Sopenharmony_ci MT8192_IRQ_1, 7162306a36Sopenharmony_ci MT8192_IRQ_2, 7262306a36Sopenharmony_ci MT8192_IRQ_3, 7362306a36Sopenharmony_ci MT8192_IRQ_4, 7462306a36Sopenharmony_ci MT8192_IRQ_5, 7562306a36Sopenharmony_ci MT8192_IRQ_6, 7662306a36Sopenharmony_ci MT8192_IRQ_7, 7762306a36Sopenharmony_ci MT8192_IRQ_8, 7862306a36Sopenharmony_ci MT8192_IRQ_9, 7962306a36Sopenharmony_ci MT8192_IRQ_10, 8062306a36Sopenharmony_ci MT8192_IRQ_11, 8162306a36Sopenharmony_ci MT8192_IRQ_12, 8262306a36Sopenharmony_ci MT8192_IRQ_13, 8362306a36Sopenharmony_ci MT8192_IRQ_14, 8462306a36Sopenharmony_ci MT8192_IRQ_15, 8562306a36Sopenharmony_ci MT8192_IRQ_16, 8662306a36Sopenharmony_ci MT8192_IRQ_17, 8762306a36Sopenharmony_ci MT8192_IRQ_18, 8862306a36Sopenharmony_ci MT8192_IRQ_19, 8962306a36Sopenharmony_ci MT8192_IRQ_20, 9062306a36Sopenharmony_ci MT8192_IRQ_21, 9162306a36Sopenharmony_ci MT8192_IRQ_22, 9262306a36Sopenharmony_ci MT8192_IRQ_23, 9362306a36Sopenharmony_ci MT8192_IRQ_24, 9462306a36Sopenharmony_ci MT8192_IRQ_25, 9562306a36Sopenharmony_ci MT8192_IRQ_26, 9662306a36Sopenharmony_ci MT8192_IRQ_31, /* used only for TDM */ 9762306a36Sopenharmony_ci MT8192_IRQ_NUM, 9862306a36Sopenharmony_ci}; 9962306a36Sopenharmony_ci 10062306a36Sopenharmony_cienum { 10162306a36Sopenharmony_ci MTKAIF_PROTOCOL_1 = 0, 10262306a36Sopenharmony_ci MTKAIF_PROTOCOL_2, 10362306a36Sopenharmony_ci MTKAIF_PROTOCOL_2_CLK_P2, 10462306a36Sopenharmony_ci}; 10562306a36Sopenharmony_ci 10662306a36Sopenharmony_cienum { 10762306a36Sopenharmony_ci MTK_AFE_ADDA_DL_GAIN_MUTE = 0, 10862306a36Sopenharmony_ci MTK_AFE_ADDA_DL_GAIN_NORMAL = 0xf74f, 10962306a36Sopenharmony_ci /* SA suggest apply -0.3db to audio/speech path */ 11062306a36Sopenharmony_ci}; 11162306a36Sopenharmony_ci 11262306a36Sopenharmony_ci/* MCLK */ 11362306a36Sopenharmony_cienum { 11462306a36Sopenharmony_ci MT8192_I2S0_MCK = 0, 11562306a36Sopenharmony_ci MT8192_I2S1_MCK, 11662306a36Sopenharmony_ci MT8192_I2S2_MCK, 11762306a36Sopenharmony_ci MT8192_I2S3_MCK, 11862306a36Sopenharmony_ci MT8192_I2S4_MCK, 11962306a36Sopenharmony_ci MT8192_I2S4_BCK, 12062306a36Sopenharmony_ci MT8192_I2S5_MCK, 12162306a36Sopenharmony_ci MT8192_I2S6_MCK, 12262306a36Sopenharmony_ci MT8192_I2S7_MCK, 12362306a36Sopenharmony_ci MT8192_I2S8_MCK, 12462306a36Sopenharmony_ci MT8192_I2S9_MCK, 12562306a36Sopenharmony_ci MT8192_MCK_NUM, 12662306a36Sopenharmony_ci}; 12762306a36Sopenharmony_ci 12862306a36Sopenharmony_cistruct clk; 12962306a36Sopenharmony_ci 13062306a36Sopenharmony_cistruct mt8192_afe_private { 13162306a36Sopenharmony_ci struct clk **clk; 13262306a36Sopenharmony_ci struct regmap *topckgen; 13362306a36Sopenharmony_ci struct regmap *apmixedsys; 13462306a36Sopenharmony_ci struct regmap *infracfg; 13562306a36Sopenharmony_ci int stf_positive_gain_db; 13662306a36Sopenharmony_ci int pm_runtime_bypass_reg_ctl; 13762306a36Sopenharmony_ci 13862306a36Sopenharmony_ci /* dai */ 13962306a36Sopenharmony_ci bool dai_on[MT8192_DAI_NUM]; 14062306a36Sopenharmony_ci void *dai_priv[MT8192_DAI_NUM]; 14162306a36Sopenharmony_ci 14262306a36Sopenharmony_ci /* adda */ 14362306a36Sopenharmony_ci int mtkaif_protocol; 14462306a36Sopenharmony_ci int mtkaif_chosen_phase[4]; 14562306a36Sopenharmony_ci int mtkaif_phase_cycle[4]; 14662306a36Sopenharmony_ci int mtkaif_calibration_num_phase; 14762306a36Sopenharmony_ci int mtkaif_dmic; 14862306a36Sopenharmony_ci int mtkaif_dmic_ch34; 14962306a36Sopenharmony_ci int mtkaif_adda6_only; 15062306a36Sopenharmony_ci 15162306a36Sopenharmony_ci /* mck */ 15262306a36Sopenharmony_ci int mck_rate[MT8192_MCK_NUM]; 15362306a36Sopenharmony_ci}; 15462306a36Sopenharmony_ci 15562306a36Sopenharmony_ciint mt8192_dai_adda_register(struct mtk_base_afe *afe); 15662306a36Sopenharmony_ciint mt8192_dai_i2s_register(struct mtk_base_afe *afe); 15762306a36Sopenharmony_ciint mt8192_dai_hw_gain_register(struct mtk_base_afe *afe); 15862306a36Sopenharmony_ciint mt8192_dai_src_register(struct mtk_base_afe *afe); 15962306a36Sopenharmony_ciint mt8192_dai_pcm_register(struct mtk_base_afe *afe); 16062306a36Sopenharmony_ciint mt8192_dai_tdm_register(struct mtk_base_afe *afe); 16162306a36Sopenharmony_ci 16262306a36Sopenharmony_ciint mt8192_dai_i2s_set_share(struct mtk_base_afe *afe, const char *main_i2s_name, 16362306a36Sopenharmony_ci const char *secondary_i2s_name); 16462306a36Sopenharmony_ci 16562306a36Sopenharmony_ciunsigned int mt8192_general_rate_transform(struct device *dev, 16662306a36Sopenharmony_ci unsigned int rate); 16762306a36Sopenharmony_ciunsigned int mt8192_rate_transform(struct device *dev, 16862306a36Sopenharmony_ci unsigned int rate, int aud_blk); 16962306a36Sopenharmony_ci 17062306a36Sopenharmony_ciint mt8192_dai_set_priv(struct mtk_base_afe *afe, int id, 17162306a36Sopenharmony_ci int priv_size, const void *priv_data); 17262306a36Sopenharmony_ci 17362306a36Sopenharmony_ci#endif 174