162306a36Sopenharmony_ci/* SPDX-License-Identifier: GPL-2.0 */
262306a36Sopenharmony_ci/*
362306a36Sopenharmony_ci * mt2701-afe-common.h  --  Mediatek 2701 audio driver definitions
462306a36Sopenharmony_ci *
562306a36Sopenharmony_ci * Copyright (c) 2016 MediaTek Inc.
662306a36Sopenharmony_ci * Author: Garlic Tseng <garlic.tseng@mediatek.com>
762306a36Sopenharmony_ci */
862306a36Sopenharmony_ci
962306a36Sopenharmony_ci#ifndef _MT_2701_AFE_COMMON_H_
1062306a36Sopenharmony_ci#define _MT_2701_AFE_COMMON_H_
1162306a36Sopenharmony_ci
1262306a36Sopenharmony_ci#include <sound/soc.h>
1362306a36Sopenharmony_ci#include <linux/clk.h>
1462306a36Sopenharmony_ci#include <linux/regmap.h>
1562306a36Sopenharmony_ci#include "mt2701-reg.h"
1662306a36Sopenharmony_ci#include "../common/mtk-base-afe.h"
1762306a36Sopenharmony_ci
1862306a36Sopenharmony_ci#define MT2701_PLL_DOMAIN_0_RATE	98304000
1962306a36Sopenharmony_ci#define MT2701_PLL_DOMAIN_1_RATE	90316800
2062306a36Sopenharmony_ci
2162306a36Sopenharmony_cienum {
2262306a36Sopenharmony_ci	MT2701_MEMIF_DL1,
2362306a36Sopenharmony_ci	MT2701_MEMIF_DL2,
2462306a36Sopenharmony_ci	MT2701_MEMIF_DL3,
2562306a36Sopenharmony_ci	MT2701_MEMIF_DL4,
2662306a36Sopenharmony_ci	MT2701_MEMIF_DL5,
2762306a36Sopenharmony_ci	MT2701_MEMIF_DL_SINGLE_NUM,
2862306a36Sopenharmony_ci	MT2701_MEMIF_DLM = MT2701_MEMIF_DL_SINGLE_NUM,
2962306a36Sopenharmony_ci	MT2701_MEMIF_UL1,
3062306a36Sopenharmony_ci	MT2701_MEMIF_UL2,
3162306a36Sopenharmony_ci	MT2701_MEMIF_UL3,
3262306a36Sopenharmony_ci	MT2701_MEMIF_UL4,
3362306a36Sopenharmony_ci	MT2701_MEMIF_UL5,
3462306a36Sopenharmony_ci	MT2701_MEMIF_DLBT,
3562306a36Sopenharmony_ci	MT2701_MEMIF_ULBT,
3662306a36Sopenharmony_ci	MT2701_MEMIF_NUM,
3762306a36Sopenharmony_ci	MT2701_IO_I2S = MT2701_MEMIF_NUM,
3862306a36Sopenharmony_ci	MT2701_IO_2ND_I2S,
3962306a36Sopenharmony_ci	MT2701_IO_3RD_I2S,
4062306a36Sopenharmony_ci	MT2701_IO_4TH_I2S,
4162306a36Sopenharmony_ci	MT2701_IO_5TH_I2S,
4262306a36Sopenharmony_ci	MT2701_IO_6TH_I2S,
4362306a36Sopenharmony_ci	MT2701_IO_MRG,
4462306a36Sopenharmony_ci};
4562306a36Sopenharmony_ci
4662306a36Sopenharmony_cienum {
4762306a36Sopenharmony_ci	MT2701_IRQ_ASYS_IRQ1,
4862306a36Sopenharmony_ci	MT2701_IRQ_ASYS_IRQ2,
4962306a36Sopenharmony_ci	MT2701_IRQ_ASYS_IRQ3,
5062306a36Sopenharmony_ci	MT2701_IRQ_ASYS_END,
5162306a36Sopenharmony_ci};
5262306a36Sopenharmony_ci
5362306a36Sopenharmony_cienum audio_base_clock {
5462306a36Sopenharmony_ci	MT2701_INFRA_SYS_AUDIO,
5562306a36Sopenharmony_ci	MT2701_TOP_AUD_MCLK_SRC0,
5662306a36Sopenharmony_ci	MT2701_TOP_AUD_MCLK_SRC1,
5762306a36Sopenharmony_ci	MT2701_TOP_AUD_A1SYS,
5862306a36Sopenharmony_ci	MT2701_TOP_AUD_A2SYS,
5962306a36Sopenharmony_ci	MT2701_AUDSYS_AFE,
6062306a36Sopenharmony_ci	MT2701_AUDSYS_AFE_CONN,
6162306a36Sopenharmony_ci	MT2701_AUDSYS_A1SYS,
6262306a36Sopenharmony_ci	MT2701_AUDSYS_A2SYS,
6362306a36Sopenharmony_ci	MT2701_BASE_CLK_NUM,
6462306a36Sopenharmony_ci};
6562306a36Sopenharmony_ci
6662306a36Sopenharmony_cistruct mt2701_i2s_data {
6762306a36Sopenharmony_ci	int i2s_ctrl_reg;
6862306a36Sopenharmony_ci	int i2s_asrc_fs_shift;
6962306a36Sopenharmony_ci	int i2s_asrc_fs_mask;
7062306a36Sopenharmony_ci};
7162306a36Sopenharmony_ci
7262306a36Sopenharmony_cistruct mt2701_i2s_path {
7362306a36Sopenharmony_ci	int mclk_rate;
7462306a36Sopenharmony_ci	int on[MTK_STREAM_NUM];
7562306a36Sopenharmony_ci	int occupied[MTK_STREAM_NUM];
7662306a36Sopenharmony_ci	const struct mt2701_i2s_data *i2s_data[MTK_STREAM_NUM];
7762306a36Sopenharmony_ci	struct clk *hop_ck[MTK_STREAM_NUM];
7862306a36Sopenharmony_ci	struct clk *sel_ck;
7962306a36Sopenharmony_ci	struct clk *div_ck;
8062306a36Sopenharmony_ci	struct clk *mclk_ck;
8162306a36Sopenharmony_ci	struct clk *asrco_ck;
8262306a36Sopenharmony_ci};
8362306a36Sopenharmony_ci
8462306a36Sopenharmony_cistruct mt2701_soc_variants {
8562306a36Sopenharmony_ci	bool has_one_heart_mode;
8662306a36Sopenharmony_ci	int i2s_num;
8762306a36Sopenharmony_ci};
8862306a36Sopenharmony_ci
8962306a36Sopenharmony_cistruct mt2701_afe_private {
9062306a36Sopenharmony_ci	struct mt2701_i2s_path *i2s_path;
9162306a36Sopenharmony_ci	struct clk *base_ck[MT2701_BASE_CLK_NUM];
9262306a36Sopenharmony_ci	struct clk *mrgif_ck;
9362306a36Sopenharmony_ci	bool mrg_enable[MTK_STREAM_NUM];
9462306a36Sopenharmony_ci
9562306a36Sopenharmony_ci	const struct mt2701_soc_variants *soc;
9662306a36Sopenharmony_ci};
9762306a36Sopenharmony_ci
9862306a36Sopenharmony_ci#endif
99