Commit 414e3cab authored by Ravulapati Vishnu vardhan rao's avatar Ravulapati Vishnu vardhan rao Committed by Mark Brown

ASoC: amd: Adding support for ALC1015 codec in machine driver

Adding support for ALC1015 RTK codec in machine driver.
Passing specific card structure based on its ACPI ID.
Signed-off-by: default avatarRavulapati Vishnu vardhan rao <Vishnuvardhanrao.Ravulapati@amd.com>
Link: https://lore.kernel.org/r/20200728160255.31020-4-Vishnuvardhanrao.Ravulapati@amd.comSigned-off-by: default avatarMark Brown <broonie@kernel.org>
parent 0fe4b561
...@@ -33,6 +33,7 @@ config SND_SOC_AMD_RV_RT5682_MACH ...@@ -33,6 +33,7 @@ config SND_SOC_AMD_RV_RT5682_MACH
select SND_SOC_MAX98357A select SND_SOC_MAX98357A
select SND_SOC_CROS_EC_CODEC select SND_SOC_CROS_EC_CODEC
select I2C_CROS_EC_TUNNEL select I2C_CROS_EC_TUNNEL
select SND_SOC_RT1015
depends on SND_SOC_AMD_ACP3x && I2C && CROS_EC depends on SND_SOC_AMD_ACP3x && I2C && CROS_EC
help help
This option enables machine driver for RT5682 and MAX9835. This option enables machine driver for RT5682 and MAX9835.
......
...@@ -21,6 +21,7 @@ ...@@ -21,6 +21,7 @@
#include "raven/acp3x.h" #include "raven/acp3x.h"
#include "../codecs/rt5682.h" #include "../codecs/rt5682.h"
#include "../codecs/rt1015.h"
#define PCO_PLAT_CLK 48000000 #define PCO_PLAT_CLK 48000000
#define RT5682_PLL_FREQ (48000 * 512) #define RT5682_PLL_FREQ (48000 * 512)
...@@ -247,7 +248,18 @@ SND_SOC_DAILINK_DEF(cros_ec, ...@@ -247,7 +248,18 @@ SND_SOC_DAILINK_DEF(cros_ec,
SND_SOC_DAILINK_DEF(platform, SND_SOC_DAILINK_DEF(platform,
DAILINK_COMP_ARRAY(COMP_PLATFORM("acp3x_rv_i2s_dma.0"))); DAILINK_COMP_ARRAY(COMP_PLATFORM("acp3x_rv_i2s_dma.0")));
static struct snd_soc_dai_link acp3x_dai_5682_98357[] = { static struct snd_soc_codec_conf rt1015_conf[] = {
{
.dlc = COMP_CODEC_CONF("i2c-10EC1015:00"),
.name_prefix = "Left",
},
{
.dlc = COMP_CODEC_CONF("i2c-10EC1015:01"),
.name_prefix = "Right",
},
};
static struct snd_soc_dai_link acp3x_dai[] = {
{ {
.name = "acp3x-5682-play", .name = "acp3x-5682-play",
.stream_name = "Playback", .stream_name = "Playback",
...@@ -317,8 +329,8 @@ static const struct snd_kcontrol_new acp3x_5682_mc_controls[] = { ...@@ -317,8 +329,8 @@ static const struct snd_kcontrol_new acp3x_5682_mc_controls[] = {
static struct snd_soc_card acp3x_5682 = { static struct snd_soc_card acp3x_5682 = {
.name = "acp3xalc5682m98357", .name = "acp3xalc5682m98357",
.owner = THIS_MODULE, .owner = THIS_MODULE,
.dai_link = acp3x_dai_5682_98357, .dai_link = acp3x_dai,
.num_links = ARRAY_SIZE(acp3x_dai_5682_98357), .num_links = ARRAY_SIZE(acp3x_dai),
.dapm_widgets = acp3x_5682_widgets, .dapm_widgets = acp3x_5682_widgets,
.num_dapm_widgets = ARRAY_SIZE(acp3x_5682_widgets), .num_dapm_widgets = ARRAY_SIZE(acp3x_5682_widgets),
.dapm_routes = acp3x_5682_audio_route, .dapm_routes = acp3x_5682_audio_route,
...@@ -327,6 +339,47 @@ static struct snd_soc_card acp3x_5682 = { ...@@ -327,6 +339,47 @@ static struct snd_soc_card acp3x_5682 = {
.num_controls = ARRAY_SIZE(acp3x_5682_mc_controls), .num_controls = ARRAY_SIZE(acp3x_5682_mc_controls),
}; };
static const struct snd_soc_dapm_widget acp3x_1015_widgets[] = {
SND_SOC_DAPM_HP("Headphone Jack", NULL),
SND_SOC_DAPM_MIC("Headset Mic", NULL),
SND_SOC_DAPM_MUX("Dmic Mux", SND_SOC_NOPM, 0, 0,
&acp3x_dmic_mux_control),
SND_SOC_DAPM_SPK("Left Spk", NULL),
SND_SOC_DAPM_SPK("Right Spk", NULL),
};
static const struct snd_soc_dapm_route acp3x_1015_route[] = {
{"Headphone Jack", NULL, "HPOL"},
{"Headphone Jack", NULL, "HPOR"},
{"IN1P", NULL, "Headset Mic"},
{"Dmic Mux", "Front Mic", "DMIC"},
{"Dmic Mux", "Rear Mic", "DMIC"},
{"Left Spk", NULL, "Left SPO"},
{"Right Spk", NULL, "Right SPO"},
};
static const struct snd_kcontrol_new acp3x_mc_1015_controls[] = {
SOC_DAPM_PIN_SWITCH("Headphone Jack"),
SOC_DAPM_PIN_SWITCH("Headset Mic"),
SOC_DAPM_PIN_SWITCH("Left Spk"),
SOC_DAPM_PIN_SWITCH("Right Spk"),
};
static struct snd_soc_card acp3x_1015 = {
.name = "acp3xalc56821015",
.owner = THIS_MODULE,
.dai_link = acp3x_dai,
.num_links = ARRAY_SIZE(acp3x_dai),
.dapm_widgets = acp3x_1015_widgets,
.num_dapm_widgets = ARRAY_SIZE(acp3x_1015_widgets),
.dapm_routes = acp3x_1015_route,
.num_dapm_routes = ARRAY_SIZE(acp3x_1015_route),
.codec_conf = rt1015_conf,
.num_configs = ARRAY_SIZE(rt1015_conf),
.controls = acp3x_mc_1015_controls,
.num_controls = ARRAY_SIZE(acp3x_mc_1015_controls),
};
void *soc_is_rltk_max(struct device *dev) void *soc_is_rltk_max(struct device *dev)
{ {
const struct acpi_device_id *match; const struct acpi_device_id *match;
...@@ -375,6 +428,7 @@ static int acp3x_probe(struct platform_device *pdev) ...@@ -375,6 +428,7 @@ static int acp3x_probe(struct platform_device *pdev)
static const struct acpi_device_id acp3x_audio_acpi_match[] = { static const struct acpi_device_id acp3x_audio_acpi_match[] = {
{ "AMDI5682", (unsigned long)&acp3x_5682}, { "AMDI5682", (unsigned long)&acp3x_5682},
{ "AMDI1015", (unsigned long)&acp3x_1015},
{}, {},
}; };
MODULE_DEVICE_TABLE(acpi, acp3x_audio_acpi_match); MODULE_DEVICE_TABLE(acpi, acp3x_audio_acpi_match);
...@@ -391,5 +445,6 @@ static struct platform_driver acp3x_audio = { ...@@ -391,5 +445,6 @@ static struct platform_driver acp3x_audio = {
module_platform_driver(acp3x_audio); module_platform_driver(acp3x_audio);
MODULE_AUTHOR("akshu.agrawal@amd.com"); MODULE_AUTHOR("akshu.agrawal@amd.com");
MODULE_DESCRIPTION("ALC5682 & MAX98357 audio support"); MODULE_AUTHOR("Vishnuvardhanrao.Ravulapati@amd.com");
MODULE_DESCRIPTION("ALC5682 ALC1015 & MAX98357 audio support");
MODULE_LICENSE("GPL v2"); MODULE_LICENSE("GPL v2");
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment