summaryrefslogtreecommitdiff
path: root/indra/media_plugins/winmmshim
diff options
context:
space:
mode:
authorYuri Chebotarev <ychebotarev@productengine.com>2010-04-30 17:59:53 +0300
committerYuri Chebotarev <ychebotarev@productengine.com>2010-04-30 17:59:53 +0300
commit67c95d6d9238615232fd581aaedf53adfe166e5c (patch)
tree4332afc70cd8a46ce2c390ccc0a7d583d9ea6165 /indra/media_plugins/winmmshim
parent2479959dd9be78a74c10484c65094bd56d1c3d9e (diff)
parent23bd34a78163c31bc2a661acd15db63ed248af53 (diff)
merge
--HG-- branch : product-engine
Diffstat (limited to 'indra/media_plugins/winmmshim')
-rw-r--r--indra/media_plugins/winmmshim/winmm_shim.cpp5
1 files changed, 3 insertions, 2 deletions
diff --git a/indra/media_plugins/winmmshim/winmm_shim.cpp b/indra/media_plugins/winmmshim/winmm_shim.cpp
index f7df3b19a0..54bfa652e9 100644
--- a/indra/media_plugins/winmmshim/winmm_shim.cpp
+++ b/indra/media_plugins/winmmshim/winmm_shim.cpp
@@ -144,10 +144,11 @@ extern "C"
// copy volume level 4 times into 64 bit MMX register
__m64 volume_64 = _mm_set_pi16(volume_16, volume_16, volume_16, volume_16);
- __m64 *sample_64;
+ __m64* sample_64;
+ __m64* last_sample_64 = (__m64*)(pwh->lpData + pwh->dwBufferLength - sizeof(__m64));
// for everything that can be addressed in 64 bit multiples...
for (sample_64 = (__m64*)pwh->lpData;
- sample_64 < (__m64*)(pwh->lpData + pwh->dwBufferLength);
+ sample_64 <= last_sample_64;
++sample_64)
{
//...multiply the samples by the volume...