0001
0002
0003
0004
0005
0006
0007
0008
0009 #include <linux/pm_runtime.h>
0010
0011 #include "mt8192-afe-common.h"
0012
0013 enum {
0014 MTK_AFE_RATE_8K = 0,
0015 MTK_AFE_RATE_11K = 1,
0016 MTK_AFE_RATE_12K = 2,
0017 MTK_AFE_RATE_384K = 3,
0018 MTK_AFE_RATE_16K = 4,
0019 MTK_AFE_RATE_22K = 5,
0020 MTK_AFE_RATE_24K = 6,
0021 MTK_AFE_RATE_352K = 7,
0022 MTK_AFE_RATE_32K = 8,
0023 MTK_AFE_RATE_44K = 9,
0024 MTK_AFE_RATE_48K = 10,
0025 MTK_AFE_RATE_88K = 11,
0026 MTK_AFE_RATE_96K = 12,
0027 MTK_AFE_RATE_176K = 13,
0028 MTK_AFE_RATE_192K = 14,
0029 MTK_AFE_RATE_260K = 15,
0030 };
0031
0032 enum {
0033 MTK_AFE_DAI_MEMIF_RATE_8K = 0,
0034 MTK_AFE_DAI_MEMIF_RATE_16K = 1,
0035 MTK_AFE_DAI_MEMIF_RATE_32K = 2,
0036 MTK_AFE_DAI_MEMIF_RATE_48K = 3,
0037 };
0038
0039 enum {
0040 MTK_AFE_PCM_RATE_8K = 0,
0041 MTK_AFE_PCM_RATE_16K = 1,
0042 MTK_AFE_PCM_RATE_32K = 2,
0043 MTK_AFE_PCM_RATE_48K = 3,
0044 };
0045
0046 unsigned int mt8192_general_rate_transform(struct device *dev,
0047 unsigned int rate)
0048 {
0049 switch (rate) {
0050 case 8000:
0051 return MTK_AFE_RATE_8K;
0052 case 11025:
0053 return MTK_AFE_RATE_11K;
0054 case 12000:
0055 return MTK_AFE_RATE_12K;
0056 case 16000:
0057 return MTK_AFE_RATE_16K;
0058 case 22050:
0059 return MTK_AFE_RATE_22K;
0060 case 24000:
0061 return MTK_AFE_RATE_24K;
0062 case 32000:
0063 return MTK_AFE_RATE_32K;
0064 case 44100:
0065 return MTK_AFE_RATE_44K;
0066 case 48000:
0067 return MTK_AFE_RATE_48K;
0068 case 88200:
0069 return MTK_AFE_RATE_88K;
0070 case 96000:
0071 return MTK_AFE_RATE_96K;
0072 case 176400:
0073 return MTK_AFE_RATE_176K;
0074 case 192000:
0075 return MTK_AFE_RATE_192K;
0076 case 260000:
0077 return MTK_AFE_RATE_260K;
0078 case 352800:
0079 return MTK_AFE_RATE_352K;
0080 case 384000:
0081 return MTK_AFE_RATE_384K;
0082 default:
0083 dev_warn(dev, "%s(), rate %u invalid, use %d!!!\n",
0084 __func__,
0085 rate, MTK_AFE_RATE_48K);
0086 return MTK_AFE_RATE_48K;
0087 }
0088 }
0089
0090 static unsigned int dai_memif_rate_transform(struct device *dev,
0091 unsigned int rate)
0092 {
0093 switch (rate) {
0094 case 8000:
0095 return MTK_AFE_DAI_MEMIF_RATE_8K;
0096 case 16000:
0097 return MTK_AFE_DAI_MEMIF_RATE_16K;
0098 case 32000:
0099 return MTK_AFE_DAI_MEMIF_RATE_32K;
0100 case 48000:
0101 return MTK_AFE_DAI_MEMIF_RATE_48K;
0102 default:
0103 dev_warn(dev, "%s(), rate %u invalid, use %d!!!\n",
0104 __func__,
0105 rate, MTK_AFE_DAI_MEMIF_RATE_16K);
0106 return MTK_AFE_DAI_MEMIF_RATE_16K;
0107 }
0108 }
0109
0110 static unsigned int pcm_rate_transform(struct device *dev,
0111 unsigned int rate)
0112 {
0113 switch (rate) {
0114 case 8000:
0115 return MTK_AFE_PCM_RATE_8K;
0116 case 16000:
0117 return MTK_AFE_PCM_RATE_16K;
0118 case 32000:
0119 return MTK_AFE_PCM_RATE_32K;
0120 case 48000:
0121 return MTK_AFE_PCM_RATE_48K;
0122 default:
0123 dev_warn(dev, "%s(), rate %u invalid, use %d!!!\n",
0124 __func__,
0125 rate, MTK_AFE_PCM_RATE_32K);
0126 return MTK_AFE_PCM_RATE_32K;
0127 }
0128 }
0129
0130 unsigned int mt8192_rate_transform(struct device *dev,
0131 unsigned int rate, int aud_blk)
0132 {
0133 switch (aud_blk) {
0134 case MT8192_MEMIF_DAI:
0135 case MT8192_MEMIF_MOD_DAI:
0136 return dai_memif_rate_transform(dev, rate);
0137 case MT8192_DAI_PCM_1:
0138 case MT8192_DAI_PCM_2:
0139 return pcm_rate_transform(dev, rate);
0140 default:
0141 return mt8192_general_rate_transform(dev, rate);
0142 }
0143 }
0144
0145 int mt8192_dai_set_priv(struct mtk_base_afe *afe, int id,
0146 int priv_size, const void *priv_data)
0147 {
0148 struct mt8192_afe_private *afe_priv = afe->platform_priv;
0149 void *temp_data;
0150
0151 temp_data = devm_kzalloc(afe->dev,
0152 priv_size,
0153 GFP_KERNEL);
0154 if (!temp_data)
0155 return -ENOMEM;
0156
0157 if (priv_data)
0158 memcpy(temp_data, priv_data, priv_size);
0159
0160 afe_priv->dai_priv[id] = temp_data;
0161
0162 return 0;
0163 }