15 Dec, 2010
13 commits
-
Enable plug detection interrupt mask in order to get headset
PLUGINT/UNPLUGINT interrupts.Signed-off-by: Misael Lopez Cruz
Signed-off-by: Margarita Olaya Cabrera
Acked-by: Mark Brown
Signed-off-by: Liam Girdwood -
On Phoenix 1.1, the INTID register default value is an invalid
one, causing the interrupt handler to think the phoenix power on
sequence is ready before it actually finishes.This causes some i2c errors when trying to configure twl.
Signed-off-by: Jorge Eduardo Candelaria
Signed-off-by: Margarita Olaya Cabrera
Acked-by: Mark Brown
Signed-off-by: Liam Girdwood -
Phoenix 1.1 supports automatic power on sequence, a
verification is added to use it with new revision of
the chip.Signed-off-by: Margarita Olaya Cabrera
Acked-by: Mark Brown
Signed-off-by: Liam Girdwood -
The mux control has 4 elements not 3
Signed-off-by: Margarita Olaya Cabrera
Acked-by: Mark Brown
Signed-off-by: Liam Girdwood -
The twl6040 can support more sample rates other than 88.2 and 96k.
Signed-off-by: Margarita Olaya Cabrera
Acked-by: Mark Brown
Signed-off-by: Liam Girdwood -
This patch moves all the PCM error handling for clock config
out of trigger() and startup() and into prepare().Signed-off-by: Margarita Olaya Cabrera
Acked-by: Mark Brown
Signed-off-by: Liam Girdwood -
This patch restores the CODEC bias level at resume().
Signed-off-by: Margarita Olaya Cabrera
Acked-by: Mark Brown
Signed-off-by: Liam Girdwood -
This patch adds support for the twl6040 headset and handset
MUX controls.Signed-off-by: Jorge Eduardo Candelaria
Signed-off-by: Margarita Olaya Cabrera
Acked-by: Mark Brown
Signed-off-by: Liam Girdwood -
Multiples interrupts can be received. The irq handler is modified
to attend all of them.Signed-off-by: Margarita Olaya Cabrera
Acked-by: Mark Brown
Signed-off-by: Liam Girdwood -
Update the codec to use the new twl core register macros
Signed-off-by: Margarita Olaya Cabrera
Acked-by: Mark Brown
Signed-off-by: Liam Girdwood -
Use jack framework to enable detection for the headset microphone
and stereo output in the sdp4430.Signed-off-by: Jorge Eduardo Candelaria
Signed-off-by: David Anders
Signed-off-by: Margarita Olaya Cabrera
Acked-by: Mark Brown
Signed-off-by: Liam Girdwood -
This patch adds support for reporting twl6040 headset and
handset jack events.The machine driver retrieves and report the status through
twl6040_hs_jack_detect.A workq is used to debounce of the irq.
Signed-off-by: Jorge Eduardo Candelaria
Signed-off-by: Misael Lopez Cruz
Signed-off-by: Margarita Olaya Cabrera
Signed-off-by: Liam Girdwood -
twl4030 series of codecs supports S32_LE with msbits=24.
Replace the S24_LE with S32_LE format, and add constraint
for 24msbit in case of 32 S32_LE format.Signed-off-by: Peter Ujfalusi
Acked-by: Mark Brown
Signed-off-by: Liam Girdwood
11 Dec, 2010
1 commit
-
If the following scenario has been followed:
1. Enable analog bypass
amixer sset 'Analog Left Bypass' on
amixer sset 'Analog Right Bypass' on2. Start playback
aplay -fdat -d3 /dev/zeroAfter the playback stopped (3 sec), and the soc timeout (5 sec),
the digital parts of the codec will remain powered up.
This means that the DAI clocks are continue to run, the
oscillator remain operational, etc.Use the SND_SOC_DAPM_POST_PMD widget to get notification
about the stopped stream, and power down the digital
part of the codec.
If the analog bypass is enabled, than the codec will remain in
BIAS_ON level, and things will work correctly.
In case, if the bypass is disabled, than the codec will
fall to BIAS_STANDBY than to BIAS_OFF level, as it used
to.The digital part of DAC33 is initialized at every stream start
(DAPM_PRE:PRE_PMU event), so subsequent streams (within 5 sec)
will have working DAI.
When the codec is coming out from BIAS_OFF, the full power-up
sequence followed by the same DAPM_PRE widget event will power up
the digital part.Signed-off-by: Peter Ujfalusi
Acked-by: Mark Brown
Signed-off-by: Liam Girdwood
09 Dec, 2010
4 commits
-
Add FM stereo pins to the machine driver and add them as a
dapm widget.Signed-off-by: Jorge Eduardo Candelaria
Signed-off-by: Margarita Olaya Cabrera
Acked-by: Mark Brown
Signed-off-by: Liam Girdwood -
Fix the compilation error introduced by patch:
ASoC: tlv320dac33: Avoid multiple soft power upSigned-off-by: Peter Ujfalusi
Acked-by: Mark Brown
Signed-off-by: Liam Girdwood -
The power for the DACs need to be enabled, even when only
the analog bypass is in use with the codec, otherwise
the audio is going to be distorted.
Make sure that the DACs are powered all the time, when
there is audio activity.Signed-off-by: Peter Ujfalusi
Acked-by: Mark Brown
Signed-off-by: Liam Girdwood -
Use better name for the widget, and remove the 'Power'
from it's name.Signed-off-by: Peter Ujfalusi
Acked-by: Mark Brown
Signed-off-by: Liam Girdwood
02 Dec, 2010
2 commits
-
Signed-off-by: Axel Lin
Acked-by: Mark Brown
Acked-by: Jarkko Nikula
Signed-off-by: Liam Girdwood -
The use of DAPM widgets, and extra routing can cause ordering
problems in the system.
Machine drivers should use the exported direct interface with
SND_SOC_DAPM_HP's event callback to manage the state of the
amplifier.Signed-off-by: Peter Ujfalusi
Acked-by: Mark Brown
Signed-off-by: Liam Girdwood
30 Nov, 2010
13 commits
-
New DAPM widgets, and paths to enable both channels at the
same time (for stereo output).
With this path the switch time difference can be avoided
between left and right channels.
The original DAPM paths can be still used, if only one of
TPA's output has been connected to a speaker, but for most of
the cases, switching to the stereo path is better.Signed-off-by: Peter Ujfalusi
Acked-by: Mark Brown
Signed-off-by: Liam Girdwood -
Reduce the amount of duplicated code by using single
event handler for PGA_E to enable the needed channel.
Use the w->shift to pass the channel information to
the handler function.Signed-off-by: Peter Ujfalusi
Acked-by: Mark Brown
Signed-off-by: Liam Girdwood -
Do not enable the amplifier right after the power has been
restored to the amplifier.
The DAPM_SUPPLY widget turns on the amp early in the DAPM
power walk, and the unmuting of channel happens quite late.
Keeping the amp in SW reset state ensures better muting.
In this way the pop noise coming from other components (codec)
can be filtered out.Signed-off-by: Peter Ujfalusi
Acked-by: Mark Brown
Signed-off-by: Liam Girdwood -
Use simpler way to avoid setting the same power state
for the amplifier.
Simplifies the check introduced by patch:
ASoC: tpa6130a2: Fix unbalanced regulator disablesSigned-off-by: Peter Ujfalusi
Cc: Jarkko Nikula
Signed-off-by: Liam Girdwood -
During playback start the codec has been already powered at
BIAS_ON event time, so there's no need to enable the codec again.Signed-off-by: Peter Ujfalusi
Acked-by: Mark Brown
Signed-off-by: Liam Girdwood -
No need to enable the codec at this time.
The codec will be enabled later by other eventsSigned-off-by: Peter Ujfalusi
Acked-by: Mark Brown
Signed-off-by: Liam Girdwood -
Otherwise, calling dev_get_drvdata in p1022_ds_remove returns NULL.
Signed-off-by: Axel Lin
Acked-by: Timur Tabi
Acked-by: Liam Girdwood
Signed-off-by: Mark Brown -
Otherwise, calling dev_get_drvdata in mpc8610_hpcd_remove returns NULL.
Signed-off-by: Axel Lin
Acked-by: Timur Tabi
Acked-by: Liam Girdwood
Signed-off-by: Mark Brown -
I think this unneededd !! operations just reduce the readability.
Signed-off-by: Axel Lin
Acked-by: Liam Girdwood
Signed-off-by: Mark Brown -
This patch fixes below error:
CC sound/soc/nuc900/nuc900-pcm.o
sound/soc/nuc900/nuc900-pcm.c: In function 'nuc900_dma_open':
sound/soc/nuc900/nuc900-pcm.c:267: error: 'nuc900_ac97_data' undeclared (first use in this function)
sound/soc/nuc900/nuc900-pcm.c:267: error: (Each undeclared identifier is reported only once
sound/soc/nuc900/nuc900-pcm.c:267: error: for each function it appears in.)
sound/soc/nuc900/nuc900-pcm.c: At top level:
sound/soc/nuc900/nuc900-pcm.c:337: error: expected ',' or ';' before 'static'
sound/soc/nuc900/nuc900-pcm.c:354: error: 'nuc900_soc_platform_probe' undeclared here (not in a function)
make[3]: *** [sound/soc/nuc900/nuc900-pcm.o] Error 1
make[2]: *** [sound/soc/nuc900] Error 2
make[1]: *** [sound/soc] Error 2
make: *** [sound] Error 2Signed-off-by: Axel Lin
Acked-by: Liam Girdwood
Signed-off-by: Mark Brown -
This patch fixes below compile warning:
CC sound/soc/nuc900/nuc900-ac97.o
sound/soc/nuc900/nuc900-ac97.c:300: warning: initialization from incompatible pointer type
sound/soc/nuc900/nuc900-ac97.c:301: warning: initialization from incompatible pointer typeSigned-off-by: Axel Lin
Acked-by: Liam Girdwood
Signed-off-by: Mark Brown -
Fix below compile error by add a missing ';'.
CC sound/soc/nuc900/nuc900-ac97.o
sound/soc/nuc900/nuc900-ac97.c:300: warning: initialization from incompatible pointer type
sound/soc/nuc900/nuc900-ac97.c:301: warning: initialization from incompatible pointer type
sound/soc/nuc900/nuc900-ac97.c:318: error: expected ',' or ';' before 'static'
sound/soc/nuc900/nuc900-ac97.c:405: error: 'nuc900_ac97_drvprobe' undeclared here (not in a function)
make[3]: *** [sound/soc/nuc900/nuc900-ac97.o] Error 1
make[2]: *** [sound/soc/nuc900] Error 2
make[1]: *** [sound/soc] Error 2
make: *** [sound] Error 2Signed-off-by: Axel Lin
Acked-by: Liam Girdwood
Signed-off-by: Mark Brown
29 Nov, 2010
6 commits
-
Signed-off-by: Dimitris Papastamos
Acked-by: Liam Girdwood
Signed-off-by: Mark Brown -
Ensure that we report any errors encountered during reads/writes
in the cache syncing functions.Remove redundant newline in the source code.
Signed-off-by: Dimitris Papastamos
Acked-by: Liam Girdwood
Signed-off-by: Mark Brown -
Properly free allocated resources in smdk_init() error path.
Add missing platform_device_unregister() in smdk_exit().Signed-off-by: Axel Lin
Acked-by: Jassi Brar
Acked-by: Liam Girdwood
Signed-off-by: Mark Brown -
Signed-off-by: Axel Lin
Acked-by: Jassi Brar
Acked-by: Liam Girdwood
Signed-off-by: Mark Brown -
Properly free allocated resources in neo1973_gta02_init() error path.
Signed-off-by: Axel Lin
Acked-by: Jassi Brar
Acked-by: Liam Girdwood
Signed-off-by: Mark Brown -
Properly free allocated resources in goni_init() error path.
Add missing snd_soc_unregister_dai() in goni_exit().Signed-off-by: Axel Lin
Acked-by: Jassi Brar
Acked-by: Liam Girdwood
Signed-off-by: Mark Brown
27 Nov, 2010
1 commit
-
This allows us to communicate our power management state back to the
parent device, allowing it to do a full power down when the device is
idle.Signed-off-by: Mark Brown
Acked-by: Liam Girdwood