Commit 158a80cc authored by Matt Oliver's avatar Matt Oliver Committed by Michael Niedermayer

Remove leal op to fix icl inline asm.

Signed-off-by: 's avatarMichael Niedermayer <michaelni@gmx.at>
parent 02497a5d
...@@ -29,24 +29,21 @@ ...@@ -29,24 +29,21 @@
static av_always_inline int vp56_rac_get_prob(VP56RangeCoder *c, uint8_t prob) static av_always_inline int vp56_rac_get_prob(VP56RangeCoder *c, uint8_t prob)
{ {
unsigned int code_word = vp56_rac_renorm(c); unsigned int code_word = vp56_rac_renorm(c);
unsigned int high = c->high; unsigned int low = 1 + (((c->high - 1) * prob) >> 8);
unsigned int low = 1 + (((high - 1) * prob) >> 8);
unsigned int low_shift = low << 16; unsigned int low_shift = low << 16;
int bit = 0; int bit = 0;
c->code_word = code_word;
__asm__( __asm__(
"subl %4, %1 \n\t" "subl %4, %1 \n\t"
"subl %3, %2 \n\t" "subl %3, %2 \n\t"
"leal (%2, %3), %3 \n\t"
"setae %b0 \n\t" "setae %b0 \n\t"
"cmovb %4, %1 \n\t" "cmovb %4, %1 \n\t"
"cmovb %3, %2 \n\t" "cmovb %5, %2 \n\t"
: "+q"(bit), "+r"(high), "+r"(code_word), "+r"(low_shift) : "+q"(bit), "+&r"(c->high), "+&r"(c->code_word)
: "r"(low) : "r"(low_shift), "r"(low), "r"(code_word)
); );
c->high = high;
c->code_word = code_word;
return bit; return bit;
} }
#endif #endif
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment