diff options
author | Filippos Karapetis | 2008-04-21 16:52:09 +0000 |
---|---|---|
committer | Filippos Karapetis | 2008-04-21 16:52:09 +0000 |
commit | 4e62a13a67dc499ed0b73c7b19f6f2bb3257b865 (patch) | |
tree | b1bd86e1d0695e590bc3cebd3eb39b4ee3219559 /engines/made/sound.cpp | |
parent | fb76c3eeedc48a89501590bd2b642896ae6462e0 (diff) | |
download | scummvm-rg350-4e62a13a67dc499ed0b73c7b19f6f2bb3257b865.tar.gz scummvm-rg350-4e62a13a67dc499ed0b73c7b19f6f2bb3257b865.tar.bz2 scummvm-rg350-4e62a13a67dc499ed0b73c7b19f6f2bb3257b865.zip |
Performed some optimizations to the PMV player
svn-id: r31644
Diffstat (limited to 'engines/made/sound.cpp')
-rw-r--r-- | engines/made/sound.cpp | 59 |
1 files changed, 29 insertions, 30 deletions
diff --git a/engines/made/sound.cpp b/engines/made/sound.cpp index 55b6584003..3cb2ea69fd 100644 --- a/engines/made/sound.cpp +++ b/engines/made/sound.cpp @@ -32,24 +32,35 @@ namespace Made { void decompressSound(byte *source, byte *dest, uint16 chunkSize, uint16 chunkCount) { - int16 prevSample = 0; + int16 prevSample = 0, workSample = 0; byte soundBuffer[1025]; byte soundBuffer3[1024]; int16 soundBuffer2[16]; + byte deltaType, type; + uint16 workChunkSize, byteCount, bitCount; + byte bitMask, bitShift; + uint16 ofs = 0; + uint16 i = 0, l = 0; + byte val; + + const int modeValues[3][4] = { + { 2, 8, 0x01, 1}, + { 4, 4, 0x03, 2}, + {16, 2, 0x0F, 4} + }; while (chunkCount--) { + deltaType = (*source) >> 6; + workChunkSize = chunkSize; - byte deltaType = (*source) >> 6; - - uint16 workChunkSize = chunkSize; if (deltaType == 1) workChunkSize /= 2; else if (deltaType == 2) workChunkSize /= 4; - byte type = (*source++) & 0x0F; + type = (*source++) & 0x0F; - int16 workSample = prevSample; + workSample = prevSample; switch (type) { @@ -64,27 +75,18 @@ void decompressSound(byte *source, byte *dest, uint16 chunkSize, uint16 chunkCou case 2: case 3: case 4: - { - - const int modeValues[3][4] = { - { 2, 8, 0x01, 1}, - { 4, 4, 0x03, 2}, - {16, 2, 0x0F, 4} - }; - - uint16 byteCount = modeValues[type - 2][0]; - uint16 bitCount = modeValues[type - 2][1]; - byte bitMask = modeValues[type - 2][2]; - byte bitShift = modeValues[type - 2][3]; + byteCount = modeValues[type - 2][0]; + bitCount = modeValues[type - 2][1]; + bitMask = modeValues[type - 2][2]; + bitShift = modeValues[type - 2][3]; + ofs = 0; - uint16 ofs = 0; - - for (uint16 i = 0; i < byteCount; i++) + for (i = 0; i < byteCount; i++) soundBuffer2[i] = (*source++) * 2 - 128; while (ofs < workChunkSize) { - byte val = *source++; - for (uint i = 0; i < bitCount; i++) { + val = *source++; + for (i = 0; i < bitCount; i++) { workSample = CLIP<int16>(workSample + soundBuffer2[val & bitMask], -127, 127); val >>= bitShift; soundBuffer[ofs++] = workSample + 128; @@ -92,15 +94,12 @@ void decompressSound(byte *source, byte *dest, uint16 chunkSize, uint16 chunkCou } break; - } case 5: - { - for (uint16 i = 0; i < workChunkSize; i++) + for (i = 0; i < workChunkSize; i++) soundBuffer[i] = *source++; workSample = soundBuffer[workChunkSize - 1] - 128; break; - } default: return; @@ -108,12 +107,12 @@ void decompressSound(byte *source, byte *dest, uint16 chunkSize, uint16 chunkCou } if (deltaType == 1) { - for (uint16 i = 0; i < chunkSize - 1; i += 2) { - uint16 l = i / 2; + for (i = 0; i < chunkSize - 1; i += 2) { + l = i / 2; soundBuffer3[i] = soundBuffer[l]; soundBuffer3[i + 1] = (soundBuffer[l + 1] + soundBuffer[l]) / 2; } - for (uint16 i = 0; i < chunkSize; i++) { + for (i = 0; i < chunkSize; i++) { soundBuffer[i] = soundBuffer3[i]; } } else if (deltaType == 2) { |