mirror of
https://github.com/followmsi/android_kernel_google_msm.git
synced 2024-11-06 23:17:41 +00:00
Revert "Revert "ASoC: msm: Add support for voice over HDMI""
This reverts commit b8b0d13a57e18d3ec33dc2647f567cd62e9d5967.
This commit is contained in:
parent
1681b2682b
commit
7d9e3a5dcd
9 changed files with 69 additions and 2 deletions
|
@ -2257,6 +2257,7 @@ static struct platform_device *common_devices[] __initdata = {
|
|||
&apq_cpudai_slimbus_2_rx,
|
||||
&apq_cpudai_slimbus_2_tx,
|
||||
&apq_cpudai_slimbus_3_rx,
|
||||
&apq_cpudai_slimbus_3_tx,
|
||||
&apq8064_rpm_device,
|
||||
&apq8064_rpm_log_device,
|
||||
&apq8064_rpm_stat_device,
|
||||
|
|
|
@ -832,6 +832,11 @@ struct platform_device apq_cpudai_slimbus_3_rx = {
|
|||
.id = 0x4006,
|
||||
};
|
||||
|
||||
struct platform_device apq_cpudai_slimbus_3_tx = {
|
||||
.name = "msm-dai-q6",
|
||||
.id = 0x4007,
|
||||
};
|
||||
|
||||
static struct resource resources_ssbi_pmic1[] = {
|
||||
{
|
||||
.start = MSM_PMIC1_SSBI_CMD_PHYS,
|
||||
|
|
|
@ -284,6 +284,7 @@ extern struct platform_device apq_cpudai_slimbus_1_tx;
|
|||
extern struct platform_device apq_cpudai_slimbus_2_rx;
|
||||
extern struct platform_device apq_cpudai_slimbus_2_tx;
|
||||
extern struct platform_device apq_cpudai_slimbus_3_rx;
|
||||
extern struct platform_device apq_cpudai_slimbus_3_tx;
|
||||
extern struct platform_device apq_cpudai_slim_4_rx;
|
||||
extern struct platform_device apq_cpudai_slim_4_tx;
|
||||
|
||||
|
|
|
@ -1782,6 +1782,7 @@ static struct platform_device *common_devices[] __initdata = {
|
|||
&apq_cpudai_slimbus_2_rx,
|
||||
&apq_cpudai_slimbus_2_tx,
|
||||
&apq_cpudai_slimbus_3_rx,
|
||||
&apq_cpudai_slimbus_3_tx,
|
||||
&apq8064_rpm_device,
|
||||
&apq8064_rpm_log_device,
|
||||
&apq8064_rpm_stat_device,
|
||||
|
|
|
@ -71,7 +71,8 @@ enum {
|
|||
SLIM_1_TX_1 = 146, /* BT-SCO and USB RX */
|
||||
SLIM_3_RX_1 = 151, /* External echo-cancellation ref */
|
||||
SLIM_3_RX_2 = 152, /* External echo-cancellation ref */
|
||||
SLIM_3_TX_1 = 147, /* HDMI RX */
|
||||
SLIM_3_TX_1 = 153, /* HDMI RX */
|
||||
SLIM_3_TX_2 = 154, /* HDMI RX */
|
||||
SLIM_4_TX_1 = 148, /* In-call recording RX */
|
||||
SLIM_4_TX_2 = 149, /* In-call recording RX */
|
||||
SLIM_4_RX_1 = 150, /* In-call music delivery TX */
|
||||
|
@ -1078,6 +1079,7 @@ static int msm_slimbus_3_hw_params(struct snd_pcm_substream *substream,
|
|||
struct snd_soc_dai *cpu_dai = rtd->cpu_dai;
|
||||
int ret = 0;
|
||||
unsigned int rx_ch[2] = {SLIM_3_RX_1, SLIM_3_RX_2};
|
||||
unsigned int tx_ch[2] = {SLIM_3_TX_1, SLIM_3_TX_2};
|
||||
|
||||
if (substream->stream == SNDRV_PCM_STREAM_PLAYBACK) {
|
||||
pr_debug("%s: slim_3_rx_ch %d, sch %d %d\n",
|
||||
|
@ -1093,7 +1095,16 @@ static int msm_slimbus_3_hw_params(struct snd_pcm_substream *substream,
|
|||
goto end;
|
||||
}
|
||||
} else {
|
||||
pr_err("%s: SLIMBUS_3_TX not defined for this DAI\n", __func__);
|
||||
pr_debug("%s: MDM RX -> SLIMBUS_3_TX -> APQ HDMI ch: %d, %d\n",
|
||||
__func__, tx_ch[0], tx_ch[1]);
|
||||
|
||||
ret = snd_soc_dai_set_channel_map(cpu_dai, 2, tx_ch, 0, 0);
|
||||
if (ret < 0) {
|
||||
pr_err("%s: Erorr %d setting SLIM_3 TX channel map\n",
|
||||
__func__, ret);
|
||||
|
||||
goto end;
|
||||
}
|
||||
}
|
||||
|
||||
end:
|
||||
|
@ -1301,6 +1312,22 @@ static int msm_slim_3_rx_be_hw_params_fixup(struct snd_soc_pcm_runtime *rtd,
|
|||
return 0;
|
||||
}
|
||||
|
||||
static int msm_slim_3_tx_be_hw_params_fixup(struct snd_soc_pcm_runtime *rtd,
|
||||
struct snd_pcm_hw_params *params)
|
||||
{
|
||||
struct snd_interval *rate = hw_param_interval(params,
|
||||
SNDRV_PCM_HW_PARAM_RATE);
|
||||
|
||||
struct snd_interval *channels = hw_param_interval(params,
|
||||
SNDRV_PCM_HW_PARAM_CHANNELS);
|
||||
|
||||
pr_debug("%s()\n", __func__);
|
||||
rate->min = rate->max = 48000;
|
||||
channels->min = channels->max = 2;
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int msm_be_hw_params_fixup(struct snd_soc_pcm_runtime *rtd,
|
||||
struct snd_pcm_hw_params *params)
|
||||
{
|
||||
|
@ -2002,6 +2029,18 @@ static struct snd_soc_dai_link msm_dai[] = {
|
|||
.ops = &msm_slimbus_3_be_ops,
|
||||
.ignore_pmdown_time = 1, /* this dainlink has playback support */
|
||||
},
|
||||
{
|
||||
.name = LPASS_BE_SLIMBUS_3_TX,
|
||||
.stream_name = "Slimbus3 Capture",
|
||||
.cpu_dai_name = "msm-dai-q6.16391",
|
||||
.platform_name = "msm-pcm-routing",
|
||||
.codec_name = "msm-stub-codec.1",
|
||||
.codec_dai_name = "msm-stub-tx",
|
||||
.no_pcm = 1,
|
||||
.be_id = MSM_BACKEND_DAI_SLIMBUS_3_TX,
|
||||
.be_hw_params_fixup = msm_slim_3_tx_be_hw_params_fixup,
|
||||
.ops = &msm_slimbus_3_be_ops,
|
||||
},
|
||||
};
|
||||
|
||||
struct snd_soc_card snd_soc_card_msm = {
|
||||
|
|
|
@ -681,6 +681,7 @@ static int msm_dai_q6_hw_params(struct snd_pcm_substream *substream,
|
|||
case SLIMBUS_1_TX:
|
||||
case SLIMBUS_2_RX:
|
||||
case SLIMBUS_2_TX:
|
||||
case SLIMBUS_3_TX:
|
||||
case SLIMBUS_4_RX:
|
||||
case SLIMBUS_4_TX:
|
||||
rc = msm_dai_q6_slim_bus_hw_params(params, dai,
|
||||
|
@ -1425,6 +1426,7 @@ static int msm_dai_q6_set_channel_map(struct snd_soc_dai *dai,
|
|||
case SLIMBUS_0_TX:
|
||||
case SLIMBUS_1_TX:
|
||||
case SLIMBUS_2_TX:
|
||||
case SLIMBUS_3_TX:
|
||||
case SLIMBUS_4_TX:
|
||||
/* channel number to be between 128 and 255. For RX port
|
||||
* use channel numbers from 138 to 144, for TX port
|
||||
|
@ -1852,6 +1854,7 @@ static __devinit int msm_dai_q6_dev_probe(struct platform_device *pdev)
|
|||
break;
|
||||
case SLIMBUS_0_TX:
|
||||
case SLIMBUS_4_TX:
|
||||
case SLIMBUS_3_TX:
|
||||
rc = snd_soc_register_dai(&pdev->dev,
|
||||
&msm_dai_q6_slimbus_tx_dai);
|
||||
break;
|
||||
|
|
|
@ -184,6 +184,7 @@ static struct msm_pcm_routing_bdai_data msm_bedais[MSM_BACKEND_DAI_MAX] = {
|
|||
{ SLIMBUS_4_RX, 0, 0, 0, 0, 0},
|
||||
{ SLIMBUS_4_TX, 0, 0, 0, 0, 0},
|
||||
{ SLIMBUS_3_RX, 0, 0, 0, 0, 0},
|
||||
{ SLIMBUS_3_TX, 0, 0, 0, 0, 0},
|
||||
{ SLIMBUS_EXTPROC_RX, 0, 0, 0, 0, 0},
|
||||
{ SLIMBUS_EXTPROC_RX, 0, 0, 0, 0, 0},
|
||||
{ SLIMBUS_EXTPROC_RX, 0, 0, 0, 0, 0},
|
||||
|
@ -1688,6 +1689,9 @@ static const struct snd_kcontrol_new tx_voice_stub_mixer_controls[] = {
|
|||
SOC_SINGLE_EXT("MI2S_TX", MSM_BACKEND_DAI_MI2S_TX,
|
||||
MSM_FRONTEND_DAI_VOICE_STUB, 1, 0, msm_routing_get_voice_stub_mixer,
|
||||
msm_routing_put_voice_stub_mixer),
|
||||
SOC_SINGLE_EXT("SLIM_3_TX", MSM_BACKEND_DAI_SLIMBUS_3_TX,
|
||||
MSM_FRONTEND_DAI_VOICE_STUB, 1, 0, msm_routing_get_voice_stub_mixer,
|
||||
msm_routing_put_voice_stub_mixer),
|
||||
};
|
||||
|
||||
static const struct snd_kcontrol_new sbus_0_rx_port_mixer_controls[] = {
|
||||
|
@ -1745,6 +1749,9 @@ static const struct snd_kcontrol_new hdmi_rx_port_mixer_controls[] = {
|
|||
SOC_SINGLE_EXT("MI2S_TX", MSM_BACKEND_DAI_HDMI_RX,
|
||||
MSM_BACKEND_DAI_MI2S_TX, 1, 0, msm_routing_get_port_mixer,
|
||||
msm_routing_put_port_mixer),
|
||||
SOC_SINGLE_EXT("SLIM_3_TX", MSM_BACKEND_DAI_HDMI_RX,
|
||||
MSM_BACKEND_DAI_SLIMBUS_3_TX, 1, 0, msm_routing_get_port_mixer,
|
||||
msm_routing_put_port_mixer),
|
||||
};
|
||||
|
||||
static const struct snd_kcontrol_new sec_i2s_rx_port_mixer_controls[] = {
|
||||
|
@ -2126,6 +2133,7 @@ static const struct snd_soc_dapm_widget msm_qdsp6_widgets[] = {
|
|||
SND_SOC_DAPM_AIF_IN("SLIMBUS_1_TX", "Slimbus1 Capture", 0, 0, 0, 0),
|
||||
SND_SOC_DAPM_AIF_IN("STUB_1_TX", "Stub1 Capture", 0, 0, 0, 0),
|
||||
SND_SOC_DAPM_AIF_OUT("SLIMBUS_3_RX", "Slimbus3 Playback", 0, 0, 0, 0),
|
||||
SND_SOC_DAPM_AIF_IN("SLIMBUS_3_TX", "Slimbus3 Capture", 0, 0, 0, 0),
|
||||
|
||||
/* Switch Definitions */
|
||||
SND_SOC_DAPM_SWITCH("SLIMBUS_DL_HL", SND_SOC_NOPM, 0, 0,
|
||||
|
@ -2471,6 +2479,7 @@ static const struct snd_soc_dapm_route intercon[] = {
|
|||
{"Voice Stub Tx Mixer", "INTERNAL_BT_SCO_TX", "INT_BT_SCO_TX"},
|
||||
{"Voice Stub Tx Mixer", "STUB_1_TX_HL", "STUB_1_TX"},
|
||||
{"Voice Stub Tx Mixer", "MI2S_TX", "MI2S_TX"},
|
||||
{"Voice Stub Tx Mixer", "SLIM_3_TX", "SLIMBUS_3_TX"},
|
||||
{"VOICE_STUB_UL", NULL, "Voice Stub Tx Mixer"},
|
||||
|
||||
{"STUB_RX Mixer", "Voice Stub", "VOICE_STUB_DL"},
|
||||
|
@ -2480,6 +2489,7 @@ static const struct snd_soc_dapm_route intercon[] = {
|
|||
{"INTERNAL_BT_SCO_RX_Voice Mixer", "Voice Stub", "VOICE_STUB_DL"},
|
||||
{"MI2S_RX_Voice Mixer", "Voice Stub", "VOICE_STUB_DL"},
|
||||
{"MI2S_RX", NULL, "MI2S_RX_Voice Mixer"},
|
||||
{"HDMI_RX_Voice Mixer", "Voice Stub", "VOICE_STUB_DL"},
|
||||
|
||||
{"SLIMBUS_3_RX_Voice Mixer", "Voice Stub", "VOICE_STUB_DL"},
|
||||
{"SLIMBUS_3_RX", NULL, "SLIMBUS_3_RX_Voice Mixer"},
|
||||
|
@ -2494,6 +2504,7 @@ static const struct snd_soc_dapm_route intercon[] = {
|
|||
|
||||
|
||||
{"HDMI_RX Port Mixer", "MI2S_TX", "MI2S_TX"},
|
||||
{"HDMI_RX Port Mixer", "SLIM_3_TX", "SLIMBUS_3_TX"},
|
||||
{"HDMI", NULL, "HDMI_RX Port Mixer"},
|
||||
|
||||
{"SEC_I2S_RX Port Mixer", "MI2S_TX", "MI2S_TX"},
|
||||
|
|
|
@ -41,6 +41,7 @@
|
|||
#define LPASS_BE_SLIMBUS_1_TX "(Backend) SLIMBUS_1_TX"
|
||||
#define LPASS_BE_STUB_1_TX "(Backend) STUB_1_TX"
|
||||
#define LPASS_BE_SLIMBUS_3_RX "(Backend) SLIMBUS_3_RX"
|
||||
#define LPASS_BE_SLIMBUS_3_TX "(Backend) SLIMBUS_3_TX"
|
||||
#define LPASS_BE_SLIMBUS_4_RX "(Backend) SLIMBUS_4_RX"
|
||||
#define LPASS_BE_SLIMBUS_4_TX "(Backend) SLIMBUS_4_TX"
|
||||
|
||||
|
@ -97,6 +98,7 @@ enum {
|
|||
MSM_BACKEND_DAI_SLIMBUS_4_RX,
|
||||
MSM_BACKEND_DAI_SLIMBUS_4_TX,
|
||||
MSM_BACKEND_DAI_SLIMBUS_3_RX,
|
||||
MSM_BACKEND_DAI_SLIMBUS_3_TX,
|
||||
MSM_BACKEND_DAI_EXTPROC_RX,
|
||||
MSM_BACKEND_DAI_EXTPROC_TX,
|
||||
MSM_BACKEND_DAI_EXTPROC_EC_TX,
|
||||
|
|
|
@ -169,6 +169,7 @@ int afe_get_port_type(u16 port_id)
|
|||
case SLIMBUS_0_TX:
|
||||
case SLIMBUS_1_TX:
|
||||
case SLIMBUS_2_TX:
|
||||
case SLIMBUS_3_TX:
|
||||
case INT_FM_TX:
|
||||
case VOICE_RECORD_RX:
|
||||
case INT_BT_SCO_TX:
|
||||
|
@ -214,6 +215,7 @@ int afe_validate_port(u16 port_id)
|
|||
case SLIMBUS_2_RX:
|
||||
case SLIMBUS_2_TX:
|
||||
case SLIMBUS_3_RX:
|
||||
case SLIMBUS_3_TX:
|
||||
case INT_BT_SCO_RX:
|
||||
case INT_BT_SCO_TX:
|
||||
case INT_BT_A2DP_RX:
|
||||
|
@ -283,6 +285,7 @@ int afe_get_port_index(u16 port_id)
|
|||
case SLIMBUS_2_RX: return IDX_SLIMBUS_2_RX;
|
||||
case SLIMBUS_2_TX: return IDX_SLIMBUS_2_TX;
|
||||
case SLIMBUS_3_RX: return IDX_SLIMBUS_3_RX;
|
||||
case SLIMBUS_3_TX: return IDX_SLIMBUS_3_TX;
|
||||
case INT_BT_SCO_RX: return IDX_INT_BT_SCO_RX;
|
||||
case INT_BT_SCO_TX: return IDX_INT_BT_SCO_TX;
|
||||
case INT_BT_A2DP_RX: return IDX_INT_BT_A2DP_RX;
|
||||
|
@ -319,6 +322,7 @@ int afe_sizeof_cfg_cmd(u16 port_id)
|
|||
case SLIMBUS_2_RX:
|
||||
case SLIMBUS_2_TX:
|
||||
case SLIMBUS_3_RX:
|
||||
case SLIMBUS_3_TX:
|
||||
case SLIMBUS_4_RX:
|
||||
case SLIMBUS_4_TX:
|
||||
ret_size = SIZEOF_CFG_CMD(afe_port_slimbus_sch_cfg);
|
||||
|
|
Loading…
Reference in a new issue