diff options
author | Daniel Mack <zonque@gmail.com> | 2012-03-19 09:12:53 +0100 |
---|---|---|
committer | Mark Brown <broonie@opensource.wolfsonmicro.com> | 2012-03-19 12:47:25 +0000 |
commit | 273b72c8ce6b28df6b49423d775c3e59072c73c5 (patch) | |
tree | b96da830969b5c433ad672cb5f87a350fb9ff447 /mm/bootmem.c | |
parent | 70ac07bb633dee75ac554195b9a4d69adfa7803c (diff) | |
download | lwn-273b72c8ce6b28df6b49423d775c3e59072c73c5.tar.gz lwn-273b72c8ce6b28df6b49423d775c3e59072c73c5.zip |
ASoC: pxa-ssp: atomically set stream active masks
PXA's SSP engine fails to take its current channel phase into account
when enabling a stream while the engine is already running. This
results in randomly swapped left/right channels on either the record
or the playback side, depending on which one was enabled first.
The following patch fixes this by factoring out the bit field
modifications in question to a separate function that pauses the
engine temporarily, modifies the bits and kicks it off again
afterwards. Appearantly, a transition of SSCR0_SSE syncs both
directions properly.
The patch has been rolled out to quite a number of devices over the
last weeks and seems to fix the issue reliably.
Signed-off-by: Daniel Mack <zonque@gmail.com>
Reported-and-tested-by: Sven Neumann <s.neumann@raumfeld.com>
Signed-off-by: Mark Brown <broonie@opensource.wolfsonmicro.com>
Cc: stable@vger.kernel.org
Diffstat (limited to 'mm/bootmem.c')
0 files changed, 0 insertions, 0 deletions