# HG changeset patch # User michael # Date 1187650979 0 # Node ID d2d3b185c8c89647aa3c6152021aef578ad11ab0 # Parent 0790af6d00280423a727826ad4ed35f765666408 slightly change horizontal lift3 so it needs 1 bit less headroom diff -r 0790af6d0028 -r d2d3b185c8c8 i386/snowdsp_mmx.c --- a/i386/snowdsp_mmx.c Mon Aug 20 22:41:47 2007 +0000 +++ b/i386/snowdsp_mmx.c Mon Aug 20 23:02:59 2007 +0000 @@ -333,18 +333,18 @@ "movq 12(%1), %%mm6 \n\t" "paddd (%1), %%mm2 \n\t" "paddd 8(%1), %%mm6 \n\t" - "movq %%mm2, %%mm0 \n\t" - "movq %%mm6, %%mm4 \n\t" - "pslld $2, %%mm2 \n\t" - "pslld $2, %%mm6 \n\t" + "pxor %%mm0, %%mm0 \n\t" //note: the 2 xor could be avoided if we would flip the rounding direction + "pxor %%mm4, %%mm4 \n\t" "psubd %%mm2, %%mm0 \n\t" "psubd %%mm6, %%mm4 \n\t" "psrad $1, %%mm0 \n\t" "psrad $1, %%mm4 \n\t" - "movq (%0), %%mm2 \n\t" - "movq 8(%0), %%mm6 \n\t" "psubd %%mm0, %%mm2 \n\t" "psubd %%mm4, %%mm6 \n\t" + "movq (%0), %%mm0 \n\t" + "movq 8(%0), %%mm4 \n\t" + "paddd %%mm0, %%mm2 \n\t" + "paddd %%mm4, %%mm6 \n\t" "movq %%mm2, (%2) \n\t" "movq %%mm6, 8(%2) \n\t" :: "r"(&src[i]), "r"(&b[i]), "r"(&temp[i])