ASoC: SMDK_WM8580: Enable for SMDKC100
authorJassi Brar <jassi.brar@samsung.com>
Mon, 22 Nov 2010 06:37:19 +0000 (15:37 +0900)
committerMark Brown <broonie@opensource.wolfsonmicro.com>
Tue, 23 Nov 2010 14:08:15 +0000 (14:08 +0000)
Enable the ASoC Machine driver to run on SMDKC100 as well.

Signed-off-by: Jassi Brar <jassi.brar@samsung.com>
Acked-by: Kukjin Kim <kgene.kim@samsung.com>
Acked-by: Liam Girdwood <lrg@slimlogic.co.uk>
Signed-off-by: Mark Brown <broonie@opensource.wolfsonmicro.com>
arch/arm/mach-s5pc100/mach-smdkc100.c
sound/soc/s3c24xx/Kconfig
sound/soc/s3c24xx/smdk_wm8580.c

index 18b405d514d63fe34d61bd7290ac82c96ca9798a..dd192a27524d1eec316d9465e263d3f2c7a3c154 100644 (file)
@@ -96,6 +96,7 @@ static struct s3c2410_uartcfg smdkc100_uartcfgs[] __initdata = {
 
 /* I2C0 */
 static struct i2c_board_info i2c_devs0[] __initdata = {
+       {I2C_BOARD_INFO("wm8580", 0x1b),},
 };
 
 /* I2C1 */
@@ -190,6 +191,7 @@ static struct platform_device *smdkc100_devices[] __initdata = {
        &s3c_device_ts,
        &s3c_device_wdt,
        &smdkc100_lcd_powerdev,
+       &samsung_asoc_dma,
        &s5pc100_device_iis0,
        &samsung_device_keypad,
        &s5pc100_device_ac97,
index 396f678d1af5fa6334a93e0c40c8fefc0a3d0382..4989fad83563c5667fe49a17af064404cb3a6382 100644 (file)
@@ -62,7 +62,7 @@ config SND_S3C24XX_SOC_JIVE_WM8750
 
 config SND_SOC_SMDK_WM8580
        tristate "SoC I2S Audio support for WM8580 on SMDK"
-       depends on SND_S3C24XX_SOC && MACH_SMDK6410
+       depends on SND_S3C24XX_SOC && (MACH_SMDK6410 || MACH_SMDKC100)
        select SND_SOC_WM8580
        select SND_SAMSUNG_I2S
        help
index b1b3d12abcb9c014c673bfc4442397e0239a06d2..0ae3d57d79e650064973c38c3ba3f65ef6f1c3ab 100644 (file)
@@ -17,6 +17,8 @@
 #include <sound/pcm_params.h>
 #include <sound/soc.h>
 
+#include <asm/mach-types.h>
+
 #include "../codecs/wm8580.h"
 #include "dma.h"
 #include "i2s.h"
@@ -200,33 +202,49 @@ static int smdk_wm8580_init_paifrx(struct snd_soc_pcm_runtime *rtd)
        return 0;
 }
 
+enum {
+       PRI_PLAYBACK = 0,
+       PRI_CAPTURE,
+       SEC_PLAYBACK,
+};
+
 static struct snd_soc_dai_link smdk_dai[] = {
-{ /* Primary Playback i/f */
-       .name = "WM8580 PAIF RX",
-       .stream_name = "Playback",
-       .cpu_dai_name = "samsung-i2s.2",
-       .codec_dai_name = "wm8580-hifi-playback",
-       .platform_name = "samsung-audio",
-       .codec_name = "wm8580-codec.0-001b",
-       .init = smdk_wm8580_init_paifrx,
-       .ops = &smdk_ops,
-},
-{ /* Primary Capture i/f */
-       .name = "WM8580 PAIF TX",
-       .stream_name = "Capture",
-       .cpu_dai_name = "samsung-i2s.2",
-       .codec_dai_name = "wm8580-hifi-capture",
-       .platform_name = "samsung-audio",
-       .codec_name = "wm8580-codec.0-001b",
-       .init = smdk_wm8580_init_paiftx,
-       .ops = &smdk_ops,
-},
+       [PRI_PLAYBACK] = { /* Primary Playback i/f */
+               .name = "WM8580 PAIF RX",
+               .stream_name = "Playback",
+               .cpu_dai_name = "samsung-i2s.2",
+               .codec_dai_name = "wm8580-hifi-playback",
+               .platform_name = "samsung-audio",
+               .codec_name = "wm8580-codec.0-001b",
+               .init = smdk_wm8580_init_paifrx,
+               .ops = &smdk_ops,
+       },
+       [PRI_CAPTURE] = { /* Primary Capture i/f */
+               .name = "WM8580 PAIF TX",
+               .stream_name = "Capture",
+               .cpu_dai_name = "samsung-i2s.2",
+               .codec_dai_name = "wm8580-hifi-capture",
+               .platform_name = "samsung-audio",
+               .codec_name = "wm8580-codec.0-001b",
+               .init = smdk_wm8580_init_paiftx,
+               .ops = &smdk_ops,
+       },
+       [SEC_PLAYBACK] = { /* Sec_Fifo Playback i/f */
+               .name = "Sec_FIFO TX",
+               .stream_name = "Playback",
+               .cpu_dai_name = "samsung-i2s.x",
+               .codec_dai_name = "wm8580-hifi-playback",
+               .platform_name = "samsung-audio",
+               .codec_name = "wm8580-codec.0-001b",
+               .init = smdk_wm8580_init_paifrx,
+               .ops = &smdk_ops,
+       },
 };
 
 static struct snd_soc_card smdk = {
        .name = "SMDK-I2S",
        .dai_link = smdk_dai,
-       .num_links = ARRAY_SIZE(smdk_dai),
+       .num_links = 2,
 };
 
 static struct platform_device *smdk_snd_device;
@@ -234,6 +252,19 @@ static struct platform_device *smdk_snd_device;
 static int __init smdk_audio_init(void)
 {
        int ret;
+       char *str;
+
+       if (machine_is_smdkc100()) {
+               smdk.num_links = 3;
+               /* S5PC100 has I2S0 as v5 */
+               str = (char *)smdk_dai[PRI_PLAYBACK].cpu_dai_name;
+               str[strlen(str) - 1] = '0';
+               str = (char *)smdk_dai[PRI_CAPTURE].cpu_dai_name;
+               str[strlen(str) - 1] = '0';
+               /* Secondary is at offset SAMSUNG_I2S_SECOFF from Primary */
+               str = (char *)smdk_dai[SEC_PLAYBACK].cpu_dai_name;
+               str[strlen(str) - 1] = '0' + SAMSUNG_I2S_SECOFF;
+       }
 
        smdk_snd_device = platform_device_alloc("soc-audio", -1);
        if (!smdk_snd_device)