diff options
Diffstat (limited to 'sound/soc/kirkwood')
-rw-r--r-- | sound/soc/kirkwood/Kconfig | 11 | ||||
-rw-r--r-- | sound/soc/kirkwood/Makefile | 2 | ||||
-rw-r--r-- | sound/soc/kirkwood/kirkwood-openrd.c | 2 | ||||
-rw-r--r-- | sound/soc/kirkwood/kirkwood-t5325.c | 141 |
4 files changed, 154 insertions, 2 deletions
diff --git a/sound/soc/kirkwood/Kconfig b/sound/soc/kirkwood/Kconfig index 16ec2a2dba4d..8f49e165f4d1 100644 --- a/sound/soc/kirkwood/Kconfig +++ b/sound/soc/kirkwood/Kconfig | |||
@@ -11,10 +11,19 @@ config SND_KIRKWOOD_SOC_I2S | |||
11 | 11 | ||
12 | config SND_KIRKWOOD_SOC_OPENRD | 12 | config SND_KIRKWOOD_SOC_OPENRD |
13 | tristate "SoC Audio support for Kirkwood Openrd Client" | 13 | tristate "SoC Audio support for Kirkwood Openrd Client" |
14 | depends on SND_KIRKWOOD_SOC && MACH_OPENRD_CLIENT | 14 | depends on SND_KIRKWOOD_SOC && (MACH_OPENRD_CLIENT || MACH_OPENRD_ULTIMATE) |
15 | select SND_KIRKWOOD_SOC_I2S | 15 | select SND_KIRKWOOD_SOC_I2S |
16 | select SND_SOC_CS42L51 | 16 | select SND_SOC_CS42L51 |
17 | help | 17 | help |
18 | Say Y if you want to add support for SoC audio on | 18 | Say Y if you want to add support for SoC audio on |
19 | Openrd Client. | 19 | Openrd Client. |
20 | 20 | ||
21 | config SND_KIRKWOOD_SOC_T5325 | ||
22 | tristate "SoC Audio support for HP t5325" | ||
23 | depends on SND_KIRKWOOD_SOC && MACH_T5325 | ||
24 | select SND_KIRKWOOD_SOC_I2S | ||
25 | select SND_SOC_ALC5623 | ||
26 | help | ||
27 | Say Y if you want to add support for SoC audio on | ||
28 | the HP t5325 thin client. | ||
29 | |||
diff --git a/sound/soc/kirkwood/Makefile b/sound/soc/kirkwood/Makefile index 33a16dcab5b5..3e62ae9e7bbe 100644 --- a/sound/soc/kirkwood/Makefile +++ b/sound/soc/kirkwood/Makefile | |||
@@ -5,5 +5,7 @@ obj-$(CONFIG_SND_KIRKWOOD_SOC) += snd-soc-kirkwood.o | |||
5 | obj-$(CONFIG_SND_KIRKWOOD_SOC_I2S) += snd-soc-kirkwood-i2s.o | 5 | obj-$(CONFIG_SND_KIRKWOOD_SOC_I2S) += snd-soc-kirkwood-i2s.o |
6 | 6 | ||
7 | snd-soc-openrd-objs := kirkwood-openrd.o | 7 | snd-soc-openrd-objs := kirkwood-openrd.o |
8 | snd-soc-t5325-objs := kirkwood-t5325.o | ||
8 | 9 | ||
9 | obj-$(CONFIG_SND_KIRKWOOD_SOC_OPENRD) += snd-soc-openrd.o | 10 | obj-$(CONFIG_SND_KIRKWOOD_SOC_OPENRD) += snd-soc-openrd.o |
11 | obj-$(CONFIG_SND_KIRKWOOD_SOC_T5325) += snd-soc-t5325.o | ||
diff --git a/sound/soc/kirkwood/kirkwood-openrd.c b/sound/soc/kirkwood/kirkwood-openrd.c index 9d7c81e921f1..d863afb3ee52 100644 --- a/sound/soc/kirkwood/kirkwood-openrd.c +++ b/sound/soc/kirkwood/kirkwood-openrd.c | |||
@@ -86,7 +86,7 @@ static int __init openrd_client_init(void) | |||
86 | { | 86 | { |
87 | int ret; | 87 | int ret; |
88 | 88 | ||
89 | if (!machine_is_openrd_client()) | 89 | if (!machine_is_openrd_client() && !machine_is_openrd_ultimate()) |
90 | return 0; | 90 | return 0; |
91 | 91 | ||
92 | openrd_client_snd_device = platform_device_alloc("soc-audio", -1); | 92 | openrd_client_snd_device = platform_device_alloc("soc-audio", -1); |
diff --git a/sound/soc/kirkwood/kirkwood-t5325.c b/sound/soc/kirkwood/kirkwood-t5325.c new file mode 100644 index 000000000000..c8d21956ab52 --- /dev/null +++ b/sound/soc/kirkwood/kirkwood-t5325.c | |||
@@ -0,0 +1,141 @@ | |||
1 | /* | ||
2 | * kirkwood-t5325.c | ||
3 | * | ||
4 | * (c) 2010 Arnaud Patard <arnaud.patard@rtp-net.org> | ||
5 | * | ||
6 | * This program is free software; you can redistribute it and/or modify it | ||
7 | * under the terms of the GNU General Public License as published by the | ||
8 | * Free Software Foundation; either version 2 of the License, or (at your | ||
9 | * option) any later version. | ||
10 | */ | ||
11 | |||
12 | #include <linux/module.h> | ||
13 | #include <linux/moduleparam.h> | ||
14 | #include <linux/interrupt.h> | ||
15 | #include <linux/platform_device.h> | ||
16 | #include <linux/slab.h> | ||
17 | #include <sound/soc.h> | ||
18 | #include <mach/kirkwood.h> | ||
19 | #include <plat/audio.h> | ||
20 | #include <asm/mach-types.h> | ||
21 | #include "../codecs/alc5623.h" | ||
22 | |||
23 | static int t5325_hw_params(struct snd_pcm_substream *substream, | ||
24 | struct snd_pcm_hw_params *params) | ||
25 | { | ||
26 | struct snd_soc_pcm_runtime *rtd = substream->private_data; | ||
27 | struct snd_soc_dai *codec_dai = rtd->codec_dai; | ||
28 | struct snd_soc_dai *cpu_dai = rtd->cpu_dai; | ||
29 | int ret; | ||
30 | unsigned int freq, fmt; | ||
31 | |||
32 | fmt = SND_SOC_DAIFMT_I2S | SND_SOC_DAIFMT_CBS_CFS; | ||
33 | ret = snd_soc_dai_set_fmt(cpu_dai, fmt); | ||
34 | if (ret < 0) | ||
35 | return ret; | ||
36 | |||
37 | ret = snd_soc_dai_set_fmt(codec_dai, fmt); | ||
38 | if (ret < 0) | ||
39 | return ret; | ||
40 | |||
41 | freq = params_rate(params) * 256; | ||
42 | |||
43 | return snd_soc_dai_set_sysclk(codec_dai, 0, freq, SND_SOC_CLOCK_IN); | ||
44 | |||
45 | } | ||
46 | |||
47 | static struct snd_soc_ops t5325_ops = { | ||
48 | .hw_params = t5325_hw_params, | ||
49 | }; | ||
50 | |||
51 | static const struct snd_soc_dapm_widget t5325_dapm_widgets[] = { | ||
52 | SND_SOC_DAPM_HP("Headphone Jack", NULL), | ||
53 | SND_SOC_DAPM_SPK("Speaker", NULL), | ||
54 | SND_SOC_DAPM_MIC("Mic Jack", NULL), | ||
55 | }; | ||
56 | |||
57 | static const struct snd_soc_dapm_route t5325_route[] = { | ||
58 | { "Headphone Jack", NULL, "HPL" }, | ||
59 | { "Headphone Jack", NULL, "HPR" }, | ||
60 | |||
61 | {"Speaker", NULL, "SPKOUT"}, | ||
62 | {"Speaker", NULL, "SPKOUTN"}, | ||
63 | |||
64 | { "MIC1", NULL, "Mic Jack" }, | ||
65 | { "MIC2", NULL, "Mic Jack" }, | ||
66 | }; | ||
67 | |||
68 | static int t5325_dai_init(struct snd_soc_pcm_runtime *rtd) | ||
69 | { | ||
70 | struct snd_soc_codec *codec = rtd->codec; | ||
71 | struct snd_soc_dapm_context *dapm = &codec->dapm; | ||
72 | |||
73 | snd_soc_dapm_new_controls(dapm, t5325_dapm_widgets, | ||
74 | ARRAY_SIZE(t5325_dapm_widgets)); | ||
75 | |||
76 | snd_soc_dapm_add_routes(dapm, t5325_route, ARRAY_SIZE(t5325_route)); | ||
77 | |||
78 | snd_soc_dapm_enable_pin(dapm, "Mic Jack"); | ||
79 | snd_soc_dapm_enable_pin(dapm, "Headphone Jack"); | ||
80 | snd_soc_dapm_enable_pin(dapm, "Speaker"); | ||
81 | |||
82 | snd_soc_dapm_sync(dapm); | ||
83 | |||
84 | return 0; | ||
85 | } | ||
86 | |||
87 | static struct snd_soc_dai_link t5325_dai[] = { | ||
88 | { | ||
89 | .name = "ALC5621", | ||
90 | .stream_name = "ALC5621 HiFi", | ||
91 | .cpu_dai_name = "kirkwood-i2s", | ||
92 | .platform_name = "kirkwood-pcm-audio", | ||
93 | .codec_dai_name = "alc5621-hifi", | ||
94 | .codec_name = "alc562x-codec.0-001a", | ||
95 | .ops = &t5325_ops, | ||
96 | .init = t5325_dai_init, | ||
97 | }, | ||
98 | }; | ||
99 | |||
100 | |||
101 | static struct snd_soc_card t5325 = { | ||
102 | .name = "t5325", | ||
103 | .dai_link = t5325_dai, | ||
104 | .num_links = ARRAY_SIZE(t5325_dai), | ||
105 | }; | ||
106 | |||
107 | static struct platform_device *t5325_snd_device; | ||
108 | |||
109 | static int __init t5325_init(void) | ||
110 | { | ||
111 | int ret; | ||
112 | |||
113 | if (!machine_is_t5325()) | ||
114 | return 0; | ||
115 | |||
116 | t5325_snd_device = platform_device_alloc("soc-audio", -1); | ||
117 | if (!t5325_snd_device) | ||
118 | return -ENOMEM; | ||
119 | |||
120 | platform_set_drvdata(t5325_snd_device, | ||
121 | &t5325); | ||
122 | |||
123 | ret = platform_device_add(t5325_snd_device); | ||
124 | if (ret) { | ||
125 | printk(KERN_ERR "%s: platform_device_add failed\n", __func__); | ||
126 | platform_device_put(t5325_snd_device); | ||
127 | } | ||
128 | |||
129 | return ret; | ||
130 | } | ||
131 | module_init(t5325_init); | ||
132 | |||
133 | static void __exit t5325_exit(void) | ||
134 | { | ||
135 | platform_device_unregister(t5325_snd_device); | ||
136 | } | ||
137 | module_exit(t5325_exit); | ||
138 | |||
139 | MODULE_AUTHOR("Arnaud Patard <arnaud.patard@rtp-net.org>"); | ||
140 | MODULE_DESCRIPTION("ALSA SoC t5325 audio client"); | ||
141 | MODULE_LICENSE("GPL"); | ||