# HG changeset patch # User conrad # Date 1263947650 0 # Node ID 3a723e8dcd26afe8d771b67c7b11b2a67bc6e6de # Parent ee944149442f95ee8bec7fd5c3dfb87940fea80f Use constant offsets for memory operands since gcc is unable to This fixes gcc failing to fit 6 memory locations into 7 registers on x86-32 diff -r ee944149442f -r 3a723e8dcd26 x86/h264dsp_mmx.c --- a/x86/h264dsp_mmx.c Wed Jan 20 00:17:16 2010 +0000 +++ b/x86/h264dsp_mmx.c Wed Jan 20 00:34:10 2010 +0000 @@ -834,9 +834,9 @@ "por %%mm1, %%mm0 \n\t" "movq %2, %%mm1 \n\t" - "movq %3, %%mm2 \n\t" - "psubw %4, %%mm1 \n\t" - "psubw %5, %%mm2 \n\t" + "movq 8+1*%2, %%mm2 \n\t" + "psubw %3, %%mm1 \n\t" + "psubw 8+1*%3, %%mm2 \n\t" "packsswb %%mm2, %%mm1 \n\t" "paddb %%mm5, %%mm1 \n\t" "pminub %%mm4, %%mm1 \n\t" @@ -845,9 +845,7 @@ ::"m"(ref[l][b_idx]), "m"(ref[l][b_idx+d_idx]), "m"(mv[l][b_idx][0]), - "m"(mv[l][b_idx+2][0]), - "m"(mv[l][b_idx+d_idx][0]), - "m"(mv[l][b_idx+d_idx+2][0]) + "m"(mv[l][b_idx+d_idx][0]) ); } if(bidir==1){ @@ -863,9 +861,9 @@ "por %%mm1, %%mm3 \n\t" "movq %2, %%mm1 \n\t" - "movq %3, %%mm2 \n\t" - "psubw %4, %%mm1 \n\t" - "psubw %5, %%mm2 \n\t" + "movq 8+1*%2, %%mm2 \n\t" + "psubw %3, %%mm1 \n\t" + "psubw 8+1*%3, %%mm2 \n\t" "packsswb %%mm2, %%mm1 \n\t" "paddb %%mm5, %%mm1 \n\t" "pminub %%mm4, %%mm1 \n\t" @@ -874,9 +872,7 @@ ::"m"(ref[l][b_idx]), "m"(ref[1-l][b_idx+d_idx]), "m"(mv[l][b_idx][0]), - "m"(mv[l][b_idx+2][0]), - "m"(mv[1-l][b_idx+d_idx][0]), - "m"(mv[1-l][b_idx+d_idx+2][0]) + "m"(mv[1-l][b_idx+d_idx][0]) ); } __asm__ volatile(