kernel_samsung_a34x-permissive/sound/soc/mediatek/common/mtk-sp-spk-amp.h
2024-04-28 15:49:01 +02:00

125 lines
3.4 KiB
C
Executable file

/* SPDX-License-Identifier: GPL-2.0 */
/*
* Copyright (C) 2018 MediaTek Inc.
*/
#ifndef _MTK_SP_SPK_AMP_H
#define _MTK_SP_SPK_AMP_H
struct mtk_spk_i2c_ctrl {
int (*i2c_probe)(struct i2c_client *client,
const struct i2c_device_id *device_id);
int (*i2c_remove)(struct i2c_client *client);
void (*i2c_shutdown)(struct i2c_client *client);
const char *stream_name;
const char *codec_dai_name;
const char *codec_name;
};
#define MTK_SPK_NOT_SMARTPA_STR "MTK_SPK_NOT_SMARTPA"
#if defined(CONFIG_SND_SOC_AW8896)
#define MTK_SPK_AWINIC_AW8896_STR "MTK_SPK_AWINIC_AW8896"
#endif
#if defined(CONFIG_SND_SMARTPA_AW882XX)
#define MTK_SPK_AWINIC_AW882XX_STR "MTK_SPK_AWINIC_AW882XX"
#endif
#ifdef CONFIG_SND_SOC_CS35L41
#define MTK_SPK_CIRRUS_CS35L41_STR "MTK_SPK_CIRRUS_CS35L41"
#endif
#ifdef CONFIG_SND_SOC_CS35L43
#define MTK_SPK_CIRRUS_CS35L43_STR "MTK_SPK_CIRRUS_CS35L43"
#endif
#ifdef CONFIG_SND_SOC_TFA9878
#define MTK_SPK_GOODIX_TFA9878_STR "MTK_SPK_GOODIX_TFA9878"
#endif
#define MTK_SPK_RICHTEK_RT5509_STR "MTK_SPK_RICHTEK_RT5509"
#define MTK_SPK_MEDIATEK_MT6660_STR "MTK_SPK_MEDIATEK_MT6660"
#define MTK_SPK_MEDIATEK_RT5512_STR "MTK_SPK_MEDIATEK_RT5512"
#define MTK_SPK_NXP_TFA98XX_STR "MTK_SPK_NXP_TFAXXXX"
#define MTK_SPK_I2S_0_STR "MTK_SPK_I2S_0"
#define MTK_SPK_I2S_1_STR "MTK_SPK_I2S_1"
#define MTK_SPK_I2S_2_STR "MTK_SPK_I2S_2"
#define MTK_SPK_I2S_3_STR "MTK_SPK_I2S_3"
#define MTK_SPK_I2S_5_STR "MTK_SPK_I2S_5"
#define MTK_SPK_I2S_6_STR "MTK_SPK_I2S_6"
#define MTK_SPK_I2S_7_STR "MTK_SPK_I2S_7"
#define MTK_SPK_I2S_8_STR "MTK_SPK_I2S_8"
#define MTK_SPK_I2S_9_STR "MTK_SPK_I2S_9"
#define MTK_SPK_TINYCONN_I2S_0_STR "MTK_SPK_TINYCONN_I2S_0"
enum mtk_spk_type {
MTK_SPK_NOT_SMARTPA = 0,
#if defined(CONFIG_SND_SOC_AW8896)
MTK_SPK_AWINIC_AW8896,
#endif
#if defined(CONFIG_SND_SMARTPA_AW882XX)
MTK_SPK_AWINIC_AW882XX,
#endif
#ifdef CONFIG_SND_SOC_CS35L41
MTK_SPK_CIRRUS_CS35L41,
#endif
#ifdef CONFIG_SND_SOC_CS35L43
MTK_SPK_CIRRUS_CS35L43,
#endif
#ifdef CONFIG_SND_SOC_TFA9878
MTK_SPK_GOODIX_TFA9878,
#endif
#if defined(CONFIG_SND_SOC_RT5509)
MTK_SPK_RICHTEK_RT5509,
#endif
#if defined(CONFIG_SND_SOC_MT6660)
MTK_SPK_MEDIATEK_MT6660,
#endif
#if defined(CONFIG_SND_SOC_TFA9874)
MTK_SPK_NXP_TFA98XX,
#endif
#if defined(CONFIG_SND_SOC_RT5512)
MTK_SPK_MEDIATEK_RT5512,
#endif
MTK_SPK_TYPE_NUM
};
enum mtk_spk_i2s_type {
MTK_SPK_I2S_TYPE_INVALID = -1,
MTK_SPK_I2S_0,
MTK_SPK_I2S_1,
MTK_SPK_I2S_2,
MTK_SPK_I2S_3,
MTK_SPK_I2S_5,
MTK_SPK_I2S_6,
MTK_SPK_I2S_7,
MTK_SPK_I2S_8,
MTK_SPK_I2S_9,
MTK_SPK_TINYCONN_I2S_0,
MTK_SPK_TINYCONN_I2S_1,
MTK_SPK_TINYCONN_I2S_2,
MTK_SPK_TINYCONN_I2S_3,
MTK_SPK_TINYCONN_I2S_5,
MTK_SPK_TINYCONN_I2S_6,
MTK_SPK_TINYCONN_I2S_7,
MTK_SPK_TINYCONN_I2S_8,
MTK_SPK_TINYCONN_I2S_9,
MTK_SPK_I2S_TYPE_NUM
};
int mtk_spk_get_type(void);
int mtk_spk_get_i2s_out_type(void);
int mtk_spk_get_i2s_in_type(void);
int mtk_ext_spk_get_status(void);
void mtk_ext_spk_enable(int enable);
int mtk_spk_update_info(struct snd_soc_card *card,
struct platform_device *pdev,
int *spk_out_dai_link_idx, int *spk_ref_dai_link_idx,
const struct snd_soc_ops *i2s_ops);
int mtk_spk_update_dai_link(struct snd_soc_card *card,
struct platform_device *pdev,
const struct snd_soc_ops *i2s_ops);
int mtk_spk_send_ipi_buf_to_dsp(void *data_buffer, uint32_t data_size);
int mtk_spk_recv_ipi_buf_from_dsp(int8_t *buffer,
int16_t size,
uint32_t *buf_len);
#endif