Commit f9372c9c authored by Mark Brown's avatar Mark Brown

ASoC: samsung: Add hookup of WM0010 on Speyside

The Speyside platform by default has a WM0010 fitted.  Now that we have
a public driver hook it up in the machine integration.
Signed-off-by: default avatarMark Brown <broonie@opensource.wolfsonmicro.com>
parent 1549c34b
...@@ -191,6 +191,7 @@ config SND_SOC_SPEYSIDE ...@@ -191,6 +191,7 @@ config SND_SOC_SPEYSIDE
select SND_SAMSUNG_I2S select SND_SAMSUNG_I2S
select SND_SOC_WM8996 select SND_SOC_WM8996
select SND_SOC_WM9081 select SND_SOC_WM9081
select SND_SOC_WM0010
select SND_SOC_WM1250_EV1 select SND_SOC_WM1250_EV1
config SND_SOC_TOBERMORY config SND_SOC_TOBERMORY
......
...@@ -25,7 +25,7 @@ static int speyside_set_bias_level(struct snd_soc_card *card, ...@@ -25,7 +25,7 @@ static int speyside_set_bias_level(struct snd_soc_card *card,
struct snd_soc_dapm_context *dapm, struct snd_soc_dapm_context *dapm,
enum snd_soc_bias_level level) enum snd_soc_bias_level level)
{ {
struct snd_soc_dai *codec_dai = card->rtd[0].codec_dai; struct snd_soc_dai *codec_dai = card->rtd[1].codec_dai;
int ret; int ret;
if (dapm->dev != codec_dai->dev) if (dapm->dev != codec_dai->dev)
...@@ -57,7 +57,7 @@ static int speyside_set_bias_level_post(struct snd_soc_card *card, ...@@ -57,7 +57,7 @@ static int speyside_set_bias_level_post(struct snd_soc_card *card,
struct snd_soc_dapm_context *dapm, struct snd_soc_dapm_context *dapm,
enum snd_soc_bias_level level) enum snd_soc_bias_level level)
{ {
struct snd_soc_dai *codec_dai = card->rtd[0].codec_dai; struct snd_soc_dai *codec_dai = card->rtd[1].codec_dai;
int ret; int ret;
if (dapm->dev != codec_dai->dev) if (dapm->dev != codec_dai->dev)
...@@ -126,6 +126,18 @@ static void speyside_set_polarity(struct snd_soc_codec *codec, ...@@ -126,6 +126,18 @@ static void speyside_set_polarity(struct snd_soc_codec *codec,
snd_soc_dapm_sync(&codec->dapm); snd_soc_dapm_sync(&codec->dapm);
} }
static int speyside_wm0010_init(struct snd_soc_pcm_runtime *rtd)
{
struct snd_soc_dai *dai = rtd->codec_dai;
int ret;
ret = snd_soc_dai_set_sysclk(dai, 0, MCLK_AUDIO_RATE, 0);
if (ret < 0)
return ret;
return 0;
}
static int speyside_wm8996_init(struct snd_soc_pcm_runtime *rtd) static int speyside_wm8996_init(struct snd_soc_pcm_runtime *rtd)
{ {
struct snd_soc_dai *dai = rtd->codec_dai; struct snd_soc_dai *dai = rtd->codec_dai;
...@@ -172,17 +184,37 @@ static int speyside_late_probe(struct snd_soc_card *card) ...@@ -172,17 +184,37 @@ static int speyside_late_probe(struct snd_soc_card *card)
return 0; return 0;
} }
static const struct snd_soc_pcm_stream dsp_codec_params = {
.formats = SNDRV_PCM_FMTBIT_S32_LE,
.rate_min = 48000,
.rate_max = 48000,
.channels_min = 2,
.channels_max = 2,
};
static struct snd_soc_dai_link speyside_dai[] = { static struct snd_soc_dai_link speyside_dai[] = {
{ {
.name = "CPU", .name = "CPU-DSP",
.stream_name = "CPU", .stream_name = "CPU-DSP",
.cpu_dai_name = "samsung-i2s.0", .cpu_dai_name = "samsung-i2s.0",
.codec_dai_name = "wm8996-aif1", .codec_dai_name = "wm0010-sdi1",
.platform_name = "samsung-audio", .platform_name = "samsung-audio",
.codec_name = "spi0.0",
.init = speyside_wm0010_init,
.dai_fmt = SND_SOC_DAIFMT_I2S | SND_SOC_DAIFMT_NB_NF
| SND_SOC_DAIFMT_CBM_CFM,
},
{
.name = "DSP-CODEC",
.stream_name = "DSP-CODEC",
.cpu_dai_name = "wm0010-sdi2",
.codec_dai_name = "wm8996-aif1",
.codec_name = "wm8996.1-001a", .codec_name = "wm8996.1-001a",
.init = speyside_wm8996_init, .init = speyside_wm8996_init,
.dai_fmt = SND_SOC_DAIFMT_I2S | SND_SOC_DAIFMT_NB_NF .dai_fmt = SND_SOC_DAIFMT_I2S | SND_SOC_DAIFMT_NB_NF
| SND_SOC_DAIFMT_CBM_CFM, | SND_SOC_DAIFMT_CBM_CFM,
.params = &dsp_codec_params,
.ignore_suspend = 1,
}, },
{ {
.name = "Baseband", .name = "Baseband",
......
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