256 lines
5.5 KiB
C
256 lines
5.5 KiB
C
// SPDX-License-Identifier: GPL-2.0
|
|
//
|
|
// MediaTek ALSA SoC Audio Control
|
|
//
|
|
// Copyright (c) 2022 MediaTek Inc.
|
|
// Author: Jiaxin Yu <jiaxin.yu@mediatek.com>
|
|
|
|
#include "mt8186-afe-common.h"
|
|
#include <linux/pm_runtime.h>
|
|
|
|
enum {
|
|
MTK_AFE_RATE_8K = 0,
|
|
MTK_AFE_RATE_11K,
|
|
MTK_AFE_RATE_12K,
|
|
MTK_AFE_RATE_384K,
|
|
MTK_AFE_RATE_16K,
|
|
MTK_AFE_RATE_22K,
|
|
MTK_AFE_RATE_24K,
|
|
MTK_AFE_RATE_352K,
|
|
MTK_AFE_RATE_32K,
|
|
MTK_AFE_RATE_44K,
|
|
MTK_AFE_RATE_48K,
|
|
MTK_AFE_RATE_88K,
|
|
MTK_AFE_RATE_96K,
|
|
MTK_AFE_RATE_176K,
|
|
MTK_AFE_RATE_192K,
|
|
MTK_AFE_RATE_260K,
|
|
};
|
|
|
|
enum {
|
|
MTK_AFE_PCM_RATE_8K = 0,
|
|
MTK_AFE_PCM_RATE_16K,
|
|
MTK_AFE_PCM_RATE_32K,
|
|
MTK_AFE_PCM_RATE_48K,
|
|
};
|
|
|
|
enum {
|
|
MTK_AFE_TDM_RATE_8K = 0,
|
|
MTK_AFE_TDM_RATE_12K,
|
|
MTK_AFE_TDM_RATE_16K,
|
|
MTK_AFE_TDM_RATE_24K,
|
|
MTK_AFE_TDM_RATE_32K,
|
|
MTK_AFE_TDM_RATE_48K,
|
|
MTK_AFE_TDM_RATE_64K,
|
|
MTK_AFE_TDM_RATE_96K,
|
|
MTK_AFE_TDM_RATE_128K,
|
|
MTK_AFE_TDM_RATE_192K,
|
|
MTK_AFE_TDM_RATE_256K,
|
|
MTK_AFE_TDM_RATE_384K,
|
|
MTK_AFE_TDM_RATE_11K,
|
|
MTK_AFE_TDM_RATE_22K,
|
|
MTK_AFE_TDM_RATE_44K,
|
|
MTK_AFE_TDM_RATE_88K,
|
|
MTK_AFE_TDM_RATE_176K,
|
|
MTK_AFE_TDM_RATE_352K,
|
|
};
|
|
|
|
enum {
|
|
MTK_AFE_TDM_RELATCH_RATE_8K = 0,
|
|
MTK_AFE_TDM_RELATCH_RATE_11K,
|
|
MTK_AFE_TDM_RELATCH_RATE_12K,
|
|
MTK_AFE_TDM_RELATCH_RATE_16K,
|
|
MTK_AFE_TDM_RELATCH_RATE_22K,
|
|
MTK_AFE_TDM_RELATCH_RATE_24K,
|
|
MTK_AFE_TDM_RELATCH_RATE_32K,
|
|
MTK_AFE_TDM_RELATCH_RATE_44K,
|
|
MTK_AFE_TDM_RELATCH_RATE_48K,
|
|
MTK_AFE_TDM_RELATCH_RATE_88K,
|
|
MTK_AFE_TDM_RELATCH_RATE_96K,
|
|
MTK_AFE_TDM_RELATCH_RATE_176K,
|
|
MTK_AFE_TDM_RELATCH_RATE_192K,
|
|
MTK_AFE_TDM_RELATCH_RATE_352K,
|
|
MTK_AFE_TDM_RELATCH_RATE_384K,
|
|
};
|
|
|
|
unsigned int mt8186_general_rate_transform(struct device *dev, unsigned int rate)
|
|
{
|
|
switch (rate) {
|
|
case 8000:
|
|
return MTK_AFE_RATE_8K;
|
|
case 11025:
|
|
return MTK_AFE_RATE_11K;
|
|
case 12000:
|
|
return MTK_AFE_RATE_12K;
|
|
case 16000:
|
|
return MTK_AFE_RATE_16K;
|
|
case 22050:
|
|
return MTK_AFE_RATE_22K;
|
|
case 24000:
|
|
return MTK_AFE_RATE_24K;
|
|
case 32000:
|
|
return MTK_AFE_RATE_32K;
|
|
case 44100:
|
|
return MTK_AFE_RATE_44K;
|
|
case 48000:
|
|
return MTK_AFE_RATE_48K;
|
|
case 88200:
|
|
return MTK_AFE_RATE_88K;
|
|
case 96000:
|
|
return MTK_AFE_RATE_96K;
|
|
case 176400:
|
|
return MTK_AFE_RATE_176K;
|
|
case 192000:
|
|
return MTK_AFE_RATE_192K;
|
|
case 260000:
|
|
return MTK_AFE_RATE_260K;
|
|
case 352800:
|
|
return MTK_AFE_RATE_352K;
|
|
case 384000:
|
|
return MTK_AFE_RATE_384K;
|
|
default:
|
|
dev_err(dev, "%s(), rate %u invalid, use %d!!!\n",
|
|
__func__, rate, MTK_AFE_RATE_48K);
|
|
}
|
|
|
|
return MTK_AFE_RATE_48K;
|
|
}
|
|
|
|
static unsigned int tdm_rate_transform(struct device *dev, unsigned int rate)
|
|
{
|
|
switch (rate) {
|
|
case 8000:
|
|
return MTK_AFE_TDM_RATE_8K;
|
|
case 11025:
|
|
return MTK_AFE_TDM_RATE_11K;
|
|
case 12000:
|
|
return MTK_AFE_TDM_RATE_12K;
|
|
case 16000:
|
|
return MTK_AFE_TDM_RATE_16K;
|
|
case 22050:
|
|
return MTK_AFE_TDM_RATE_22K;
|
|
case 24000:
|
|
return MTK_AFE_TDM_RATE_24K;
|
|
case 32000:
|
|
return MTK_AFE_TDM_RATE_32K;
|
|
case 44100:
|
|
return MTK_AFE_TDM_RATE_44K;
|
|
case 48000:
|
|
return MTK_AFE_TDM_RATE_48K;
|
|
case 64000:
|
|
return MTK_AFE_TDM_RATE_64K;
|
|
case 88200:
|
|
return MTK_AFE_TDM_RATE_88K;
|
|
case 96000:
|
|
return MTK_AFE_TDM_RATE_96K;
|
|
case 128000:
|
|
return MTK_AFE_TDM_RATE_128K;
|
|
case 176400:
|
|
return MTK_AFE_TDM_RATE_176K;
|
|
case 192000:
|
|
return MTK_AFE_TDM_RATE_192K;
|
|
case 256000:
|
|
return MTK_AFE_TDM_RATE_256K;
|
|
case 352800:
|
|
return MTK_AFE_TDM_RATE_352K;
|
|
case 384000:
|
|
return MTK_AFE_TDM_RATE_384K;
|
|
default:
|
|
dev_err(dev, "%s(), rate %u invalid, use %d!!!\n",
|
|
__func__, rate, MTK_AFE_TDM_RATE_48K);
|
|
}
|
|
|
|
return MTK_AFE_TDM_RATE_48K;
|
|
}
|
|
|
|
static unsigned int pcm_rate_transform(struct device *dev, unsigned int rate)
|
|
{
|
|
switch (rate) {
|
|
case 8000:
|
|
return MTK_AFE_PCM_RATE_8K;
|
|
case 16000:
|
|
return MTK_AFE_PCM_RATE_16K;
|
|
case 32000:
|
|
return MTK_AFE_PCM_RATE_32K;
|
|
case 48000:
|
|
return MTK_AFE_PCM_RATE_48K;
|
|
default:
|
|
dev_err(dev, "%s(), rate %u invalid, use %d!!!\n",
|
|
__func__, rate, MTK_AFE_PCM_RATE_48K);
|
|
}
|
|
|
|
return MTK_AFE_PCM_RATE_48K;
|
|
}
|
|
|
|
unsigned int mt8186_tdm_relatch_rate_transform(struct device *dev, unsigned int rate)
|
|
{
|
|
switch (rate) {
|
|
case 8000:
|
|
return MTK_AFE_TDM_RELATCH_RATE_8K;
|
|
case 11025:
|
|
return MTK_AFE_TDM_RELATCH_RATE_11K;
|
|
case 12000:
|
|
return MTK_AFE_TDM_RELATCH_RATE_12K;
|
|
case 16000:
|
|
return MTK_AFE_TDM_RELATCH_RATE_16K;
|
|
case 22050:
|
|
return MTK_AFE_TDM_RELATCH_RATE_22K;
|
|
case 24000:
|
|
return MTK_AFE_TDM_RELATCH_RATE_24K;
|
|
case 32000:
|
|
return MTK_AFE_TDM_RELATCH_RATE_32K;
|
|
case 44100:
|
|
return MTK_AFE_TDM_RELATCH_RATE_44K;
|
|
case 48000:
|
|
return MTK_AFE_TDM_RELATCH_RATE_48K;
|
|
case 88200:
|
|
return MTK_AFE_TDM_RELATCH_RATE_88K;
|
|
case 96000:
|
|
return MTK_AFE_TDM_RELATCH_RATE_96K;
|
|
case 176400:
|
|
return MTK_AFE_TDM_RELATCH_RATE_176K;
|
|
case 192000:
|
|
return MTK_AFE_TDM_RELATCH_RATE_192K;
|
|
case 352800:
|
|
return MTK_AFE_TDM_RELATCH_RATE_352K;
|
|
case 384000:
|
|
return MTK_AFE_TDM_RELATCH_RATE_384K;
|
|
default:
|
|
dev_err(dev, "%s(), rate %u invalid, use %d!!!\n",
|
|
__func__, rate, MTK_AFE_TDM_RELATCH_RATE_48K);
|
|
}
|
|
|
|
return MTK_AFE_TDM_RELATCH_RATE_48K;
|
|
}
|
|
|
|
unsigned int mt8186_rate_transform(struct device *dev, unsigned int rate, int aud_blk)
|
|
{
|
|
switch (aud_blk) {
|
|
case MT8186_DAI_PCM:
|
|
return pcm_rate_transform(dev, rate);
|
|
case MT8186_DAI_TDM_IN:
|
|
return tdm_rate_transform(dev, rate);
|
|
default:
|
|
return mt8186_general_rate_transform(dev, rate);
|
|
}
|
|
}
|
|
|
|
int mt8186_dai_set_priv(struct mtk_base_afe *afe, int id, int priv_size, const void *priv_data)
|
|
{
|
|
struct mt8186_afe_private *afe_priv = afe->platform_priv;
|
|
void *temp_data;
|
|
|
|
temp_data = devm_kzalloc(afe->dev,
|
|
priv_size,
|
|
GFP_KERNEL);
|
|
if (!temp_data)
|
|
return -ENOMEM;
|
|
|
|
if (priv_data)
|
|
memcpy(temp_data, priv_data, priv_size);
|
|
|
|
afe_priv->dai_priv[id] = temp_data;
|
|
|
|
return 0;
|
|
}
|