| /* SPDX-License-Identifier: GPL-2.0 */ |
| /* |
| * mt8188-afe-common.h -- MediaTek 8188 audio driver definitions |
| * |
| * Copyright (c) 2022 MediaTek Inc. |
| * Author: Bicycle Tsai <bicycle.tsai@mediatek.com> |
| * Trevor Wu <trevor.wu@mediatek.com> |
| * Chun-Chia Chiu <chun-chia.chiu@mediatek.com> |
| */ |
| |
| #ifndef _MT_8188_AFE_COMMON_H_ |
| #define _MT_8188_AFE_COMMON_H_ |
| |
| #include <linux/list.h> |
| #include <linux/regmap.h> |
| #include <sound/soc.h> |
| #include "../common/mtk-base-afe.h" |
| |
| enum { |
| MT8188_DAI_START, |
| MT8188_AFE_MEMIF_START = MT8188_DAI_START, |
| MT8188_AFE_MEMIF_DL2 = MT8188_AFE_MEMIF_START, |
| MT8188_AFE_MEMIF_DL3, |
| MT8188_AFE_MEMIF_DL6, |
| MT8188_AFE_MEMIF_DL7, |
| MT8188_AFE_MEMIF_DL8, |
| MT8188_AFE_MEMIF_DL10, |
| MT8188_AFE_MEMIF_DL11, |
| MT8188_AFE_MEMIF_UL_START, |
| MT8188_AFE_MEMIF_UL1 = MT8188_AFE_MEMIF_UL_START, |
| MT8188_AFE_MEMIF_UL2, |
| MT8188_AFE_MEMIF_UL3, |
| MT8188_AFE_MEMIF_UL4, |
| MT8188_AFE_MEMIF_UL5, |
| MT8188_AFE_MEMIF_UL6, |
| MT8188_AFE_MEMIF_UL8, |
| MT8188_AFE_MEMIF_UL9, |
| MT8188_AFE_MEMIF_UL10, |
| MT8188_AFE_MEMIF_END, |
| MT8188_AFE_MEMIF_NUM = (MT8188_AFE_MEMIF_END - MT8188_AFE_MEMIF_START), |
| MT8188_AFE_IO_START = MT8188_AFE_MEMIF_END, |
| MT8188_AFE_IO_ADDA = MT8188_AFE_IO_START, |
| MT8188_AFE_IO_DMIC_IN, |
| MT8188_AFE_IO_DPTX, |
| MT8188_AFE_IO_ETDM_START, |
| MT8188_AFE_IO_ETDM1_IN = MT8188_AFE_IO_ETDM_START, |
| MT8188_AFE_IO_ETDM2_IN, |
| MT8188_AFE_IO_ETDM1_OUT, |
| MT8188_AFE_IO_ETDM2_OUT, |
| MT8188_AFE_IO_ETDM3_OUT, |
| MT8188_AFE_IO_ETDM_END, |
| MT8188_AFE_IO_ETDM_NUM = |
| (MT8188_AFE_IO_ETDM_END - MT8188_AFE_IO_ETDM_START), |
| MT8188_AFE_IO_PCM = MT8188_AFE_IO_ETDM_END, |
| MT8188_AFE_IO_END, |
| MT8188_AFE_IO_NUM = (MT8188_AFE_IO_END - MT8188_AFE_IO_START), |
| MT8188_DAI_END = MT8188_AFE_IO_END, |
| MT8188_DAI_NUM = (MT8188_DAI_END - MT8188_DAI_START), |
| }; |
| |
| enum { |
| MT8188_TOP_CG_A1SYS_TIMING, |
| MT8188_TOP_CG_A2SYS_TIMING, |
| MT8188_TOP_CG_26M_TIMING, |
| MT8188_TOP_CG_NUM, |
| }; |
| |
| enum { |
| MT8188_AFE_IRQ_1, |
| MT8188_AFE_IRQ_2, |
| MT8188_AFE_IRQ_3, |
| MT8188_AFE_IRQ_8, |
| MT8188_AFE_IRQ_9, |
| MT8188_AFE_IRQ_10, |
| MT8188_AFE_IRQ_13, |
| MT8188_AFE_IRQ_14, |
| MT8188_AFE_IRQ_15, |
| MT8188_AFE_IRQ_16, |
| MT8188_AFE_IRQ_17, |
| MT8188_AFE_IRQ_18, |
| MT8188_AFE_IRQ_19, |
| MT8188_AFE_IRQ_20, |
| MT8188_AFE_IRQ_21, |
| MT8188_AFE_IRQ_22, |
| MT8188_AFE_IRQ_23, |
| MT8188_AFE_IRQ_24, |
| MT8188_AFE_IRQ_25, |
| MT8188_AFE_IRQ_26, |
| MT8188_AFE_IRQ_27, |
| MT8188_AFE_IRQ_28, |
| MT8188_AFE_IRQ_NUM, |
| }; |
| |
| enum { |
| MT8188_ETDM_OUT1_1X_EN = 9, |
| MT8188_ETDM_OUT2_1X_EN = 10, |
| MT8188_ETDM_OUT3_1X_EN = 11, |
| MT8188_ETDM_IN1_1X_EN = 12, |
| MT8188_ETDM_IN2_1X_EN = 13, |
| MT8188_ETDM_IN1_NX_EN = 25, |
| MT8188_ETDM_IN2_NX_EN = 26, |
| }; |
| |
| enum { |
| MT8188_MTKAIF_MISO_0, |
| MT8188_MTKAIF_MISO_1, |
| MT8188_MTKAIF_MISO_NUM, |
| }; |
| |
| struct mtk_dai_memif_irq_priv { |
| unsigned int asys_timing_sel; |
| }; |
| |
| struct mtkaif_param { |
| bool mtkaif_calibration_ok; |
| int mtkaif_chosen_phase[MT8188_MTKAIF_MISO_NUM]; |
| int mtkaif_phase_cycle[MT8188_MTKAIF_MISO_NUM]; |
| int mtkaif_dmic_on; |
| }; |
| |
| struct clk; |
| |
| struct mt8188_afe_private { |
| struct clk **clk; |
| struct clk_lookup **lookup; |
| struct regmap *topckgen; |
| int pm_runtime_bypass_reg_ctl; |
| spinlock_t afe_ctrl_lock; /* Lock for afe control */ |
| struct mtk_dai_memif_irq_priv irq_priv[MT8188_AFE_IRQ_NUM]; |
| struct mtkaif_param mtkaif_params; |
| |
| /* dai */ |
| void *dai_priv[MT8188_DAI_NUM]; |
| }; |
| |
| int mt8188_afe_fs_timing(unsigned int rate); |
| /* dai register */ |
| int mt8188_dai_adda_register(struct mtk_base_afe *afe); |
| int mt8188_dai_etdm_register(struct mtk_base_afe *afe); |
| int mt8188_dai_pcm_register(struct mtk_base_afe *afe); |
| |
| #define MT8188_SOC_ENUM_EXT(xname, xenum, xhandler_get, xhandler_put, id) \ |
| { \ |
| .iface = SNDRV_CTL_ELEM_IFACE_MIXER, .name = xname, \ |
| .info = snd_soc_info_enum_double, \ |
| .get = xhandler_get, .put = xhandler_put, \ |
| .device = id, \ |
| .private_value = (unsigned long)&(xenum), \ |
| } |
| |
| #endif |