# HG changeset patch # User michael # Date 1160431030 0 # Node ID ce16f66a48adbb7138ab99d9e9a4f082657582c6 # Parent db01070401c708eee6e10a8fba179b3fbcb71485 reading 8bit mem into a 8bit register needs 2 uops on P4, 8bit->32bit with zero extension needs just 1 diff -r db01070401c7 -r ce16f66a48ad cabac.h --- a/cabac.h Mon Oct 09 21:39:07 2006 +0000 +++ b/cabac.h Mon Oct 09 21:57:10 2006 +0000 @@ -393,7 +393,7 @@ "setb %%cl \n\t" "shl %%cl, %%edx \n\t" "shl %%cl, %%ebx \n\t" - "movb "MPS_STATE"(%2, %%eax), %%cl \n\t" + "movzbl "MPS_STATE"(%2, %%eax), %%ecx \n\t" "movb %%cl, (%1) \n\t" //eax:state ebx:low, edx:range, esi:RangeLPS "test %%bx, %%bx \n\t" @@ -412,10 +412,10 @@ "subl %%edx, %%ebx \n\t" "movl %%esi, %%edx \n\t" "shr $19, %%esi \n\t" - "movb " MANGLE(ff_h264_norm_shift) "(%%esi), %%cl \n\t" + "movzbl " MANGLE(ff_h264_norm_shift) "(%%esi), %%ecx \n\t" "shll %%cl, %%ebx \n\t" "shll %%cl, %%edx \n\t" - "movb "LPS_STATE"(%2, %%eax), %%cl \n\t" + "movzbl "LPS_STATE"(%2, %%eax), %%ecx \n\t" "movb %%cl, (%1) \n\t" "addl $1, %%eax \n\t" "test %%bx, %%bx \n\t" @@ -432,7 +432,7 @@ "leal -1(%%ebx), %%ecx \n\t" "xorl %%ebx, %%ecx \n\t" "shrl $17, %%ecx \n\t" - "movb " MANGLE(ff_h264_norm_shift) "(%%ecx), %%cl \n\t" + "movzbl " MANGLE(ff_h264_norm_shift) "(%%ecx), %%ecx \n\t" "neg %%cl \n\t" "add $7, %%cl \n\t" @@ -470,14 +470,14 @@ //eax:state ebx:low edx:mask esi:range "xorl %%edx, %%eax \n\t" - "movb "MPS_STATE"(%2, %%eax), %%cl \n\t" + "movzbl "MPS_STATE"(%2, %%eax), %%ecx \n\t" "movb %%cl, (%1) \n\t" "movl %%esi, %%edx \n\t" //eax:bit ebx:low edx:range esi:range "shr $19, %%esi \n\t" - "movb " MANGLE(ff_h264_norm_shift) "(%%esi), %%cl \n\t" + "movzbl " MANGLE(ff_h264_norm_shift) "(%%esi), %%ecx \n\t" "shll %%cl, %%ebx \n\t" "shll %%cl, %%edx \n\t" "test %%bx, %%bx \n\t" @@ -494,7 +494,7 @@ "leal -1(%%ebx), %%ecx \n\t" "xorl %%ebx, %%ecx \n\t" "shrl $17, %%ecx \n\t" - "movb " MANGLE(ff_h264_norm_shift) "(%%ecx), %%cl \n\t" + "movzbl " MANGLE(ff_h264_norm_shift) "(%%ecx), %%ecx \n\t" "neg %%cl \n\t" "add $7, %%cl \n\t"