diff options
Diffstat (limited to 'sound/soc/omap/sdp4430.c')
-rw-r--r-- | sound/soc/omap/sdp4430.c | 84 |
1 files changed, 56 insertions, 28 deletions
diff --git a/sound/soc/omap/sdp4430.c b/sound/soc/omap/sdp4430.c index 4ebbde6b565f..189e03900637 100644 --- a/sound/soc/omap/sdp4430.c +++ b/sound/soc/omap/sdp4430.c | |||
@@ -24,14 +24,13 @@ | |||
24 | #include <sound/core.h> | 24 | #include <sound/core.h> |
25 | #include <sound/pcm.h> | 25 | #include <sound/pcm.h> |
26 | #include <sound/soc.h> | 26 | #include <sound/soc.h> |
27 | #include <sound/soc-dapm.h> | 27 | #include <sound/jack.h> |
28 | 28 | ||
29 | #include <asm/mach-types.h> | 29 | #include <asm/mach-types.h> |
30 | #include <plat/hardware.h> | 30 | #include <plat/hardware.h> |
31 | #include <plat/mux.h> | 31 | #include <plat/mux.h> |
32 | 32 | ||
33 | #include "mcpdm.h" | 33 | #include "mcpdm.h" |
34 | #include "omap-mcpdm.h" | ||
35 | #include "omap-pcm.h" | 34 | #include "omap-pcm.h" |
36 | #include "../codecs/twl6040.h" | 35 | #include "../codecs/twl6040.h" |
37 | 36 | ||
@@ -41,7 +40,7 @@ static int sdp4430_hw_params(struct snd_pcm_substream *substream, | |||
41 | struct snd_pcm_hw_params *params) | 40 | struct snd_pcm_hw_params *params) |
42 | { | 41 | { |
43 | struct snd_soc_pcm_runtime *rtd = substream->private_data; | 42 | struct snd_soc_pcm_runtime *rtd = substream->private_data; |
44 | struct snd_soc_dai *codec_dai = rtd->dai->codec_dai; | 43 | struct snd_soc_dai *codec_dai = rtd->codec_dai; |
45 | int clk_id, freq; | 44 | int clk_id, freq; |
46 | int ret; | 45 | int ret; |
47 | 46 | ||
@@ -60,12 +59,28 @@ static int sdp4430_hw_params(struct snd_pcm_substream *substream, | |||
60 | printk(KERN_ERR "can't set codec system clock\n"); | 59 | printk(KERN_ERR "can't set codec system clock\n"); |
61 | return ret; | 60 | return ret; |
62 | } | 61 | } |
62 | return ret; | ||
63 | } | 63 | } |
64 | 64 | ||
65 | static struct snd_soc_ops sdp4430_ops = { | 65 | static struct snd_soc_ops sdp4430_ops = { |
66 | .hw_params = sdp4430_hw_params, | 66 | .hw_params = sdp4430_hw_params, |
67 | }; | 67 | }; |
68 | 68 | ||
69 | /* Headset jack */ | ||
70 | static struct snd_soc_jack hs_jack; | ||
71 | |||
72 | /*Headset jack detection DAPM pins */ | ||
73 | static struct snd_soc_jack_pin hs_jack_pins[] = { | ||
74 | { | ||
75 | .pin = "Headset Mic", | ||
76 | .mask = SND_JACK_MICROPHONE, | ||
77 | }, | ||
78 | { | ||
79 | .pin = "Headset Stereophone", | ||
80 | .mask = SND_JACK_HEADPHONE, | ||
81 | }, | ||
82 | }; | ||
83 | |||
69 | static int sdp4430_get_power_mode(struct snd_kcontrol *kcontrol, | 84 | static int sdp4430_get_power_mode(struct snd_kcontrol *kcontrol, |
70 | struct snd_ctl_elem_value *ucontrol) | 85 | struct snd_ctl_elem_value *ucontrol) |
71 | { | 86 | { |
@@ -102,6 +117,7 @@ static const struct snd_soc_dapm_widget sdp4430_twl6040_dapm_widgets[] = { | |||
102 | SND_SOC_DAPM_MIC("Headset Mic", NULL), | 117 | SND_SOC_DAPM_MIC("Headset Mic", NULL), |
103 | SND_SOC_DAPM_HP("Headset Stereophone", NULL), | 118 | SND_SOC_DAPM_HP("Headset Stereophone", NULL), |
104 | SND_SOC_DAPM_SPK("Earphone Spk", NULL), | 119 | SND_SOC_DAPM_SPK("Earphone Spk", NULL), |
120 | SND_SOC_DAPM_INPUT("Aux/FM Stereo In"), | ||
105 | }; | 121 | }; |
106 | 122 | ||
107 | static const struct snd_soc_dapm_route audio_map[] = { | 123 | static const struct snd_soc_dapm_route audio_map[] = { |
@@ -124,10 +140,16 @@ static const struct snd_soc_dapm_route audio_map[] = { | |||
124 | 140 | ||
125 | /* Earphone speaker */ | 141 | /* Earphone speaker */ |
126 | {"Earphone Spk", NULL, "EP"}, | 142 | {"Earphone Spk", NULL, "EP"}, |
143 | |||
144 | /* Aux/FM Stereo In: AFML, AFMR */ | ||
145 | {"AFML", NULL, "Aux/FM Stereo In"}, | ||
146 | {"AFMR", NULL, "Aux/FM Stereo In"}, | ||
127 | }; | 147 | }; |
128 | 148 | ||
129 | static int sdp4430_twl6040_init(struct snd_soc_codec *codec) | 149 | static int sdp4430_twl6040_init(struct snd_soc_pcm_runtime *rtd) |
130 | { | 150 | { |
151 | struct snd_soc_codec *codec = rtd->codec; | ||
152 | struct snd_soc_dapm_context *dapm = &codec->dapm; | ||
131 | int ret; | 153 | int ret; |
132 | 154 | ||
133 | /* Add SDP4430 specific controls */ | 155 | /* Add SDP4430 specific controls */ |
@@ -137,25 +159,39 @@ static int sdp4430_twl6040_init(struct snd_soc_codec *codec) | |||
137 | return ret; | 159 | return ret; |
138 | 160 | ||
139 | /* Add SDP4430 specific widgets */ | 161 | /* Add SDP4430 specific widgets */ |
140 | ret = snd_soc_dapm_new_controls(codec, sdp4430_twl6040_dapm_widgets, | 162 | ret = snd_soc_dapm_new_controls(dapm, sdp4430_twl6040_dapm_widgets, |
141 | ARRAY_SIZE(sdp4430_twl6040_dapm_widgets)); | 163 | ARRAY_SIZE(sdp4430_twl6040_dapm_widgets)); |
142 | if (ret) | 164 | if (ret) |
143 | return ret; | 165 | return ret; |
144 | 166 | ||
145 | /* Set up SDP4430 specific audio path audio_map */ | 167 | /* Set up SDP4430 specific audio path audio_map */ |
146 | snd_soc_dapm_add_routes(codec, audio_map, ARRAY_SIZE(audio_map)); | 168 | snd_soc_dapm_add_routes(dapm, audio_map, ARRAY_SIZE(audio_map)); |
147 | 169 | ||
148 | /* SDP4430 connected pins */ | 170 | /* SDP4430 connected pins */ |
149 | snd_soc_dapm_enable_pin(codec, "Ext Mic"); | 171 | snd_soc_dapm_enable_pin(dapm, "Ext Mic"); |
150 | snd_soc_dapm_enable_pin(codec, "Ext Spk"); | 172 | snd_soc_dapm_enable_pin(dapm, "Ext Spk"); |
151 | snd_soc_dapm_enable_pin(codec, "Headset Mic"); | 173 | snd_soc_dapm_enable_pin(dapm, "AFML"); |
152 | snd_soc_dapm_enable_pin(codec, "Headset Stereophone"); | 174 | snd_soc_dapm_enable_pin(dapm, "AFMR"); |
175 | snd_soc_dapm_enable_pin(dapm, "Headset Mic"); | ||
176 | snd_soc_dapm_enable_pin(dapm, "Headset Stereophone"); | ||
177 | |||
178 | ret = snd_soc_dapm_sync(dapm); | ||
179 | if (ret) | ||
180 | return ret; | ||
153 | 181 | ||
154 | /* TWL6040 not connected pins */ | 182 | /* Headset jack detection */ |
155 | snd_soc_dapm_nc_pin(codec, "AFML"); | 183 | ret = snd_soc_jack_new(codec, "Headset Jack", |
156 | snd_soc_dapm_nc_pin(codec, "AFMR"); | 184 | SND_JACK_HEADSET, &hs_jack); |
185 | if (ret) | ||
186 | return ret; | ||
187 | |||
188 | ret = snd_soc_jack_add_pins(&hs_jack, ARRAY_SIZE(hs_jack_pins), | ||
189 | hs_jack_pins); | ||
157 | 190 | ||
158 | ret = snd_soc_dapm_sync(codec); | 191 | if (machine_is_omap_4430sdp()) |
192 | twl6040_hs_jack_detect(codec, &hs_jack, SND_JACK_HEADSET); | ||
193 | else | ||
194 | snd_soc_jack_report(&hs_jack, SND_JACK_HEADSET, SND_JACK_HEADSET); | ||
159 | 195 | ||
160 | return ret; | 196 | return ret; |
161 | } | 197 | } |
@@ -164,8 +200,10 @@ static int sdp4430_twl6040_init(struct snd_soc_codec *codec) | |||
164 | static struct snd_soc_dai_link sdp4430_dai = { | 200 | static struct snd_soc_dai_link sdp4430_dai = { |
165 | .name = "TWL6040", | 201 | .name = "TWL6040", |
166 | .stream_name = "TWL6040", | 202 | .stream_name = "TWL6040", |
167 | .cpu_dai = &omap_mcpdm_dai, | 203 | .cpu_dai_name ="omap-mcpdm-dai", |
168 | .codec_dai = &twl6040_dai, | 204 | .codec_dai_name = "twl6040-hifi", |
205 | .platform_name = "omap-pcm-audio", | ||
206 | .codec_name = "twl6040-codec", | ||
169 | .init = sdp4430_twl6040_init, | 207 | .init = sdp4430_twl6040_init, |
170 | .ops = &sdp4430_ops, | 208 | .ops = &sdp4430_ops, |
171 | }; | 209 | }; |
@@ -173,27 +211,18 @@ static struct snd_soc_dai_link sdp4430_dai = { | |||
173 | /* Audio machine driver */ | 211 | /* Audio machine driver */ |
174 | static struct snd_soc_card snd_soc_sdp4430 = { | 212 | static struct snd_soc_card snd_soc_sdp4430 = { |
175 | .name = "SDP4430", | 213 | .name = "SDP4430", |
176 | .platform = &omap_soc_platform, | ||
177 | .dai_link = &sdp4430_dai, | 214 | .dai_link = &sdp4430_dai, |
178 | .num_links = 1, | 215 | .num_links = 1, |
179 | }; | 216 | }; |
180 | 217 | ||
181 | /* Audio subsystem */ | ||
182 | static struct snd_soc_device sdp4430_snd_devdata = { | ||
183 | .card = &snd_soc_sdp4430, | ||
184 | .codec_dev = &soc_codec_dev_twl6040, | ||
185 | }; | ||
186 | |||
187 | static struct platform_device *sdp4430_snd_device; | 218 | static struct platform_device *sdp4430_snd_device; |
188 | 219 | ||
189 | static int __init sdp4430_soc_init(void) | 220 | static int __init sdp4430_soc_init(void) |
190 | { | 221 | { |
191 | int ret; | 222 | int ret; |
192 | 223 | ||
193 | if (!machine_is_omap_4430sdp()) { | 224 | if (!machine_is_omap_4430sdp()) |
194 | pr_debug("Not SDP4430!\n"); | ||
195 | return -ENODEV; | 225 | return -ENODEV; |
196 | } | ||
197 | printk(KERN_INFO "SDP4430 SoC init\n"); | 226 | printk(KERN_INFO "SDP4430 SoC init\n"); |
198 | 227 | ||
199 | sdp4430_snd_device = platform_device_alloc("soc-audio", -1); | 228 | sdp4430_snd_device = platform_device_alloc("soc-audio", -1); |
@@ -202,8 +231,7 @@ static int __init sdp4430_soc_init(void) | |||
202 | return -ENOMEM; | 231 | return -ENOMEM; |
203 | } | 232 | } |
204 | 233 | ||
205 | platform_set_drvdata(sdp4430_snd_device, &sdp4430_snd_devdata); | 234 | platform_set_drvdata(sdp4430_snd_device, &snd_soc_sdp4430); |
206 | sdp4430_snd_devdata.dev = &sdp4430_snd_device->dev; | ||
207 | 235 | ||
208 | ret = platform_device_add(sdp4430_snd_device); | 236 | ret = platform_device_add(sdp4430_snd_device); |
209 | if (ret) | 237 | if (ret) |