mirror of
https://github.com/nxp-imx/linux-imx.git
synced 2025-09-03 02:16:09 +02:00

MT8188 will support SOF. In SOF, be_hw_params_fixup callback are used to configure BE hardware parameters. However, playback and capture stream share the same callback function in which it can't know the stream type. It's possible to require different parameters for playback and capture stream, so separate them into two dais for SOF usage. Signed-off-by: Trevor Wu <trevor.wu@mediatek.com> Reviewed-by: Alexandre Mergnat <amergnat@baylibre.com> Link: https://lore.kernel.org/r/20230526093150.22923-2-trevor.wu@mediatek.com Signed-off-by: Mark Brown <broonie@kernel.org>
153 lines
3.7 KiB
C
153 lines
3.7 KiB
C
/* 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_DL_SRC = 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_UL_SRC,
|
|
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
|