diff options
author | Linus Torvalds <torvalds@linux-foundation.org> | 2011-07-26 20:42:18 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2011-07-26 20:42:18 -0400 |
commit | b0189cd087aa82bd23277cb5c8960ab030e13e5c (patch) | |
tree | 7b1a4c152cd62ce136fd5b0e4379d58eb2244e66 /sound/soc/omap | |
parent | 69f1d1a6acbaa7d83ef3f4ee26209c58cd000204 (diff) | |
parent | bc574e190d3fbed37d724e33a16aee326d6f2ac4 (diff) |
Merge branch 'next/devel2' of git://git.kernel.org/pub/scm/linux/kernel/git/arm/linux-arm-soc
* 'next/devel2' of git://git.kernel.org/pub/scm/linux/kernel/git/arm/linux-arm-soc: (47 commits)
OMAP: Add debugfs node to show the summary of all clocks
OMAP2+: hwmod: Follow the recommended PRCM module enable sequence
OMAP2+: clock: allow per-SoC clock init code to prevent clockdomain calls from clock code
OMAP2+: clockdomain: Add per clkdm lock to prevent concurrent state programming
OMAP2+: PM: idle clkdms only if already in idle
OMAP2+: clockdomain: add clkdm_in_hwsup()
OMAP2+: clockdomain: Add 2 APIs to control clockdomain from hwmod framework
OMAP: clockdomain: Remove redundant call to pwrdm_wait_transition()
OMAP4: hwmod: Introduce the module control in hwmod control
OMAP4: cm: Add two new APIs for modulemode control
OMAP4: hwmod data: Add modulemode entry in omap_hwmod structure
OMAP4: hwmod data: Add PRM context register offset
OMAP4: prm: Remove deprecated functions
OMAP4: prm: Replace warm reset API with the offset based version
OMAP4: hwmod: Replace RSTCTRL absolute address with offset macros
OMAP: hwmod: Wait the idle status to be disabled
OMAP4: hwmod: Replace CLKCTRL absolute address with offset macros
OMAP2+: hwmod: Init clkdm field at boot time
OMAP4: hwmod data: Add clock domain attribute
OMAP4: clock data: Add missing divider selection for auxclks
...
Diffstat (limited to 'sound/soc/omap')
-rw-r--r-- | sound/soc/omap/sdp3430.c | 2 | ||||
-rw-r--r-- | sound/soc/omap/sdp4430.c | 52 | ||||
-rw-r--r-- | sound/soc/omap/zoom2.c | 2 |
3 files changed, 9 insertions, 47 deletions
diff --git a/sound/soc/omap/sdp3430.c b/sound/soc/omap/sdp3430.c index 3f72d17d1ef0..9f6a758029d1 100644 --- a/sound/soc/omap/sdp3430.c +++ b/sound/soc/omap/sdp3430.c | |||
@@ -36,7 +36,7 @@ | |||
36 | #include <plat/mcbsp.h> | 36 | #include <plat/mcbsp.h> |
37 | 37 | ||
38 | /* Register descriptions for twl4030 codec part */ | 38 | /* Register descriptions for twl4030 codec part */ |
39 | #include <linux/mfd/twl4030-codec.h> | 39 | #include <linux/mfd/twl4030-audio.h> |
40 | 40 | ||
41 | #include "omap-mcbsp.h" | 41 | #include "omap-mcbsp.h" |
42 | #include "omap-pcm.h" | 42 | #include "omap-pcm.h" |
diff --git a/sound/soc/omap/sdp4430.c b/sound/soc/omap/sdp4430.c index 189e03900637..b80efb02bfca 100644 --- a/sound/soc/omap/sdp4430.c +++ b/sound/soc/omap/sdp4430.c | |||
@@ -21,6 +21,8 @@ | |||
21 | 21 | ||
22 | #include <linux/clk.h> | 22 | #include <linux/clk.h> |
23 | #include <linux/platform_device.h> | 23 | #include <linux/platform_device.h> |
24 | #include <linux/mfd/twl6040.h> | ||
25 | |||
24 | #include <sound/core.h> | 26 | #include <sound/core.h> |
25 | #include <sound/pcm.h> | 27 | #include <sound/pcm.h> |
26 | #include <sound/soc.h> | 28 | #include <sound/soc.h> |
@@ -34,8 +36,6 @@ | |||
34 | #include "omap-pcm.h" | 36 | #include "omap-pcm.h" |
35 | #include "../codecs/twl6040.h" | 37 | #include "../codecs/twl6040.h" |
36 | 38 | ||
37 | static int twl6040_power_mode; | ||
38 | |||
39 | static int sdp4430_hw_params(struct snd_pcm_substream *substream, | 39 | static int sdp4430_hw_params(struct snd_pcm_substream *substream, |
40 | struct snd_pcm_hw_params *params) | 40 | struct snd_pcm_hw_params *params) |
41 | { | 41 | { |
@@ -44,13 +44,13 @@ static int sdp4430_hw_params(struct snd_pcm_substream *substream, | |||
44 | int clk_id, freq; | 44 | int clk_id, freq; |
45 | int ret; | 45 | int ret; |
46 | 46 | ||
47 | if (twl6040_power_mode) { | 47 | clk_id = twl6040_get_clk_id(rtd->codec); |
48 | clk_id = TWL6040_SYSCLK_SEL_HPPLL; | 48 | if (clk_id == TWL6040_SYSCLK_SEL_HPPLL) |
49 | freq = 38400000; | 49 | freq = 38400000; |
50 | } else { | 50 | else if (clk_id == TWL6040_SYSCLK_SEL_LPPLL) |
51 | clk_id = TWL6040_SYSCLK_SEL_LPPLL; | ||
52 | freq = 32768; | 51 | freq = 32768; |
53 | } | 52 | else |
53 | return -EINVAL; | ||
54 | 54 | ||
55 | /* set the codec mclk */ | 55 | /* set the codec mclk */ |
56 | ret = snd_soc_dai_set_sysclk(codec_dai, clk_id, freq, | 56 | ret = snd_soc_dai_set_sysclk(codec_dai, clk_id, freq, |
@@ -81,35 +81,6 @@ static struct snd_soc_jack_pin hs_jack_pins[] = { | |||
81 | }, | 81 | }, |
82 | }; | 82 | }; |
83 | 83 | ||
84 | static int sdp4430_get_power_mode(struct snd_kcontrol *kcontrol, | ||
85 | struct snd_ctl_elem_value *ucontrol) | ||
86 | { | ||
87 | ucontrol->value.integer.value[0] = twl6040_power_mode; | ||
88 | return 0; | ||
89 | } | ||
90 | |||
91 | static int sdp4430_set_power_mode(struct snd_kcontrol *kcontrol, | ||
92 | struct snd_ctl_elem_value *ucontrol) | ||
93 | { | ||
94 | if (twl6040_power_mode == ucontrol->value.integer.value[0]) | ||
95 | return 0; | ||
96 | |||
97 | twl6040_power_mode = ucontrol->value.integer.value[0]; | ||
98 | |||
99 | return 1; | ||
100 | } | ||
101 | |||
102 | static const char *power_texts[] = {"Low-Power", "High-Performance"}; | ||
103 | |||
104 | static const struct soc_enum sdp4430_enum[] = { | ||
105 | SOC_ENUM_SINGLE_EXT(2, power_texts), | ||
106 | }; | ||
107 | |||
108 | static const struct snd_kcontrol_new sdp4430_controls[] = { | ||
109 | SOC_ENUM_EXT("TWL6040 Power Mode", sdp4430_enum[0], | ||
110 | sdp4430_get_power_mode, sdp4430_set_power_mode), | ||
111 | }; | ||
112 | |||
113 | /* SDP4430 machine DAPM */ | 84 | /* SDP4430 machine DAPM */ |
114 | static const struct snd_soc_dapm_widget sdp4430_twl6040_dapm_widgets[] = { | 85 | static const struct snd_soc_dapm_widget sdp4430_twl6040_dapm_widgets[] = { |
115 | SND_SOC_DAPM_MIC("Ext Mic", NULL), | 86 | SND_SOC_DAPM_MIC("Ext Mic", NULL), |
@@ -152,12 +123,6 @@ static int sdp4430_twl6040_init(struct snd_soc_pcm_runtime *rtd) | |||
152 | struct snd_soc_dapm_context *dapm = &codec->dapm; | 123 | struct snd_soc_dapm_context *dapm = &codec->dapm; |
153 | int ret; | 124 | int ret; |
154 | 125 | ||
155 | /* Add SDP4430 specific controls */ | ||
156 | ret = snd_soc_add_controls(codec, sdp4430_controls, | ||
157 | ARRAY_SIZE(sdp4430_controls)); | ||
158 | if (ret) | ||
159 | return ret; | ||
160 | |||
161 | /* Add SDP4430 specific widgets */ | 126 | /* Add SDP4430 specific widgets */ |
162 | ret = snd_soc_dapm_new_controls(dapm, sdp4430_twl6040_dapm_widgets, | 127 | ret = snd_soc_dapm_new_controls(dapm, sdp4430_twl6040_dapm_widgets, |
163 | ARRAY_SIZE(sdp4430_twl6040_dapm_widgets)); | 128 | ARRAY_SIZE(sdp4430_twl6040_dapm_widgets)); |
@@ -237,9 +202,6 @@ static int __init sdp4430_soc_init(void) | |||
237 | if (ret) | 202 | if (ret) |
238 | goto err; | 203 | goto err; |
239 | 204 | ||
240 | /* Codec starts in HP mode */ | ||
241 | twl6040_power_mode = 1; | ||
242 | |||
243 | return 0; | 205 | return 0; |
244 | 206 | ||
245 | err: | 207 | err: |
diff --git a/sound/soc/omap/zoom2.c b/sound/soc/omap/zoom2.c index 01709940a43c..9a2666ffc16c 100644 --- a/sound/soc/omap/zoom2.c +++ b/sound/soc/omap/zoom2.c | |||
@@ -32,7 +32,7 @@ | |||
32 | #include <plat/mcbsp.h> | 32 | #include <plat/mcbsp.h> |
33 | 33 | ||
34 | /* Register descriptions for twl4030 codec part */ | 34 | /* Register descriptions for twl4030 codec part */ |
35 | #include <linux/mfd/twl4030-codec.h> | 35 | #include <linux/mfd/twl4030-audio.h> |
36 | 36 | ||
37 | #include "omap-mcbsp.h" | 37 | #include "omap-mcbsp.h" |
38 | #include "omap-pcm.h" | 38 | #include "omap-pcm.h" |