blob: dc905aec6294b511693693376960f586547ef087 [file] [log] [blame]
Jonathan Camerona195b512009-05-04 14:54:11 +00001
2#include <linux/module.h>
3#include <sound/soc.h>
4
5#include <asm/mach-types.h>
6
7#include "../codecs/wm8940.h"
8#include "pxa2xx-i2s.h"
Jonathan Camerona195b512009-05-04 14:54:11 +00009
10static int imote2_asoc_hw_params(struct snd_pcm_substream *substream,
11 struct snd_pcm_hw_params *params)
12{
13 struct snd_soc_pcm_runtime *rtd = substream->private_data;
Liam Girdwoodf0fba2a2010-03-17 20:15:21 +000014 struct snd_soc_dai *codec_dai = rtd->codec_dai;
15 struct snd_soc_dai *cpu_dai = rtd->cpu_dai;
Jonathan Camerona195b512009-05-04 14:54:11 +000016 unsigned int clk = 0;
17 int ret;
18
19 switch (params_rate(params)) {
20 case 8000:
21 case 16000:
22 case 48000:
23 case 96000:
24 clk = 12288000;
25 break;
26 case 11025:
27 case 22050:
28 case 44100:
29 clk = 11289600;
30 break;
31 }
32
Jonathan Camerona195b512009-05-04 14:54:11 +000033 ret = snd_soc_dai_set_sysclk(codec_dai, 0, clk,
34 SND_SOC_CLOCK_IN);
35 if (ret < 0)
36 return ret;
37
38 /* set the I2S system clock as input (unused) */
39 ret = snd_soc_dai_set_sysclk(cpu_dai, PXA2XX_I2S_SYSCLK, clk,
40 SND_SOC_CLOCK_OUT);
41
42 return ret;
43}
44
45static struct snd_soc_ops imote2_asoc_ops = {
46 .hw_params = imote2_asoc_hw_params,
47};
48
49static struct snd_soc_dai_link imote2_dai = {
50 .name = "WM8940",
51 .stream_name = "WM8940",
Ian Larteya2a00862010-08-20 17:18:43 +010052 .cpu_dai_name = "pxa2xx-i2s",
Liam Girdwoodf0fba2a2010-03-17 20:15:21 +000053 .codec_dai_name = "wm8940-hifi",
54 .platform_name = "pxa-pcm-audio",
55 .codec_name = "wm8940-codec.0-0034",
Axel Lin52ec35f2011-12-20 16:27:28 +080056 .dai_fmt = SND_SOC_DAIFMT_I2S | SND_SOC_DAIFMT_NB_NF |
57 SND_SOC_DAIFMT_CBS_CFS,
Jonathan Camerona195b512009-05-04 14:54:11 +000058 .ops = &imote2_asoc_ops,
59};
60
Axel Linac1e8982011-12-15 10:55:24 +080061static struct snd_soc_card imote2 = {
Jonathan Camerona195b512009-05-04 14:54:11 +000062 .name = "Imote2",
Jonathan Camerona195b512009-05-04 14:54:11 +000063 .dai_link = &imote2_dai,
64 .num_links = 1,
65};
66
Axel Linac1e8982011-12-15 10:55:24 +080067static int __devinit imote2_probe(struct platform_device *pdev)
Jonathan Camerona195b512009-05-04 14:54:11 +000068{
Axel Linac1e8982011-12-15 10:55:24 +080069 struct snd_soc_card *card = &imote2;
Jonathan Camerona195b512009-05-04 14:54:11 +000070 int ret;
71
Axel Linac1e8982011-12-15 10:55:24 +080072 card->dev = &pdev->dev;
Jonathan Camerona195b512009-05-04 14:54:11 +000073
Axel Linac1e8982011-12-15 10:55:24 +080074 ret = snd_soc_register_card(card);
Jonathan Camerona195b512009-05-04 14:54:11 +000075 if (ret)
Axel Linac1e8982011-12-15 10:55:24 +080076 dev_err(&pdev->dev, "snd_soc_register_card() failed: %d\n",
77 ret);
Jonathan Camerona195b512009-05-04 14:54:11 +000078 return ret;
79}
Jonathan Camerona195b512009-05-04 14:54:11 +000080
Axel Linac1e8982011-12-15 10:55:24 +080081static int __devexit imote2_remove(struct platform_device *pdev)
Jonathan Camerona195b512009-05-04 14:54:11 +000082{
Axel Linac1e8982011-12-15 10:55:24 +080083 struct snd_soc_card *card = platform_get_drvdata(pdev);
84
85 snd_soc_unregister_card(card);
86 return 0;
Jonathan Camerona195b512009-05-04 14:54:11 +000087}
Axel Linac1e8982011-12-15 10:55:24 +080088
89static struct platform_driver imote2_driver = {
90 .driver = {
91 .name = "imote2-audio",
92 .owner = THIS_MODULE,
93 },
94 .probe = imote2_probe,
95 .remove = __devexit_p(imote2_remove),
96};
97
98module_platform_driver(imote2_driver);
Jonathan Camerona195b512009-05-04 14:54:11 +000099
100MODULE_AUTHOR("Jonathan Cameron");
101MODULE_DESCRIPTION("ALSA SoC Imote 2");
102MODULE_LICENSE("GPL");
Axel Linac1e8982011-12-15 10:55:24 +0800103MODULE_ALIAS("platform:imote2-audio");