Skip to content

Commit

Permalink
BlitRGBtoRGBPixelAlphaMMX() is putting the wrong value into a register.
Browse files Browse the repository at this point in the history
 Thanks to Alex Volkov for following up on this.

   Fixes Bugzilla #390.
  • Loading branch information
icculus committed Apr 4, 2007
1 parent bb31832 commit 34bc26e
Showing 1 changed file with 4 additions and 3 deletions.
7 changes: 4 additions & 3 deletions src/video/SDL_blit_A.c
Expand Up @@ -369,7 +369,9 @@ static void BlitRGBtoRGBPixelAlphaMMX(SDL_BlitInfo *info)
packsswb_r2r(mm6, mm3); /* 0000FFFF -> mm3 */
pxor_r2r(mm0, mm3); /* 0000F000 -> mm3 (~channel mask) */
/* get alpha channel shift */
movd_m2r(sf->Ashift, mm5); /* Ashift -> mm5 */
__asm__ __volatile__ (
"movd %0, %%mm5"
: : "rm" ((Uint32) sf->Ashift) ); /* Ashift -> mm5 */

while(height--) {
DUFFS_LOOP4({
Expand Down Expand Up @@ -1566,7 +1568,6 @@ static void BlitRGBtoRGBPixelAlphaMMX3DNOW(SDL_BlitInfo *info)
int dstskip = info->d_skip >> 2;
SDL_PixelFormat* sf = info->src;
Uint32 amask = sf->Amask;
Uint32 ashift = sf->Ashift;

__asm__ (
/* make mm6 all zeros. */
Expand All @@ -1588,7 +1589,7 @@ static void BlitRGBtoRGBPixelAlphaMMX3DNOW(SDL_BlitInfo *info)
/* get alpha channel shift */
"movd %1, %%mm5\n\t" /* Ashift -> mm5 */

: /* nothing */ : "m" (amask), "m" (ashift) );
: /* nothing */ : "rm" (amask), "rm" ((Uint32) sf->Ashift) );

while(height--) {

Expand Down

0 comments on commit 34bc26e

Please sign in to comment.