diff options
| author | 2016-09-03 14:01:31 +0100 | |
|---|---|---|
| committer | 2016-09-03 14:06:25 +0100 | |
| commit | 0bbda3bab45f37fc888b8a8ac3ca9392a667c342 (patch) | |
| tree | 227a21382fb51833a20d858273b98f342662feba /src | |
| parent | Merge pull request #2032 from bunnei/qt-graphics (diff) | |
| download | yuzu-0bbda3bab45f37fc888b8a8ac3ca9392a667c342.tar.gz yuzu-0bbda3bab45f37fc888b8a8ac3ca9392a667c342.tar.xz yuzu-0bbda3bab45f37fc888b8a8ac3ca9392a667c342.zip | |
codec: Fix ADPCM distortion caused by incorrect nibble order
Closes #2049.
Signed-off-by: MerryMage <MerryMage@users.noreply.github.com>
Diffstat (limited to 'src')
| -rw-r--r-- | src/audio_core/codec.cpp | 4 |
1 files changed, 2 insertions, 2 deletions
diff --git a/src/audio_core/codec.cpp b/src/audio_core/codec.cpp index ab65514b7..3e23323f1 100644 --- a/src/audio_core/codec.cpp +++ b/src/audio_core/codec.cpp | |||
| @@ -58,11 +58,11 @@ StereoBuffer16 DecodeADPCM(const u8* const data, const size_t sample_count, cons | |||
| 58 | size_t outputi = framei * SAMPLES_PER_FRAME; | 58 | size_t outputi = framei * SAMPLES_PER_FRAME; |
| 59 | size_t datai = framei * FRAME_LEN + 1; | 59 | size_t datai = framei * FRAME_LEN + 1; |
| 60 | for (size_t i = 0; i < SAMPLES_PER_FRAME && outputi < sample_count; i += 2) { | 60 | for (size_t i = 0; i < SAMPLES_PER_FRAME && outputi < sample_count; i += 2) { |
| 61 | const s16 sample1 = decode_sample(SIGNED_NIBBLES[data[datai] & 0xF]); | 61 | const s16 sample1 = decode_sample(SIGNED_NIBBLES[data[datai] >> 4]); |
| 62 | ret[outputi].fill(sample1); | 62 | ret[outputi].fill(sample1); |
| 63 | outputi++; | 63 | outputi++; |
| 64 | 64 | ||
| 65 | const s16 sample2 = decode_sample(SIGNED_NIBBLES[data[datai] >> 4]); | 65 | const s16 sample2 = decode_sample(SIGNED_NIBBLES[data[datai] & 0xF]); |
| 66 | ret[outputi].fill(sample2); | 66 | ret[outputi].fill(sample2); |
| 67 | outputi++; | 67 | outputi++; |
| 68 | 68 | ||