Commit 2ccddc02 authored by Vladimir Voroshilov's avatar Vladimir Voroshilov

Add explicit (int) cast to i386 optimized MUL* macros.

Wrong result is returned when 16-bit value is passed as value.
Also fixes "Warning: using `%edx' instead of `%dx' due to `l' suffix".

Originally committed as revision 14981 to svn://svn.ffmpeg.org/ffmpeg/trunk
parent 51f2a119
...@@ -28,18 +28,18 @@ ...@@ -28,18 +28,18 @@
"imull %3 \n\t"\ "imull %3 \n\t"\
"shrdl %4, %%edx, %%eax \n\t"\ "shrdl %4, %%edx, %%eax \n\t"\
: "=a"(rt), "=d"(dummy)\ : "=a"(rt), "=d"(dummy)\
: "a" (ra), "rm" (rb), "i"(FRAC_BITS));\ : "a" ((int)ra), "rm" ((int)rb), "i"(FRAC_BITS));\
rt; }) rt; })
#endif #endif
#define MULH(ra, rb) \ #define MULH(ra, rb) \
({ int rt, dummy;\ ({ int rt, dummy;\
asm ("imull %3\n\t" : "=d"(rt), "=a"(dummy): "a" (ra), "rm" (rb));\ asm ("imull %3\n\t" : "=d"(rt), "=a"(dummy): "a" ((int)ra), "rm" ((int)rb));\
rt; }) rt; })
#define MUL64(ra, rb) \ #define MUL64(ra, rb) \
({ int64_t rt;\ ({ int64_t rt;\
asm ("imull %2\n\t" : "=A"(rt) : "a" (ra), "g" (rb));\ asm ("imull %2\n\t" : "=A"(rt) : "a" ((int)ra), "g" ((int)rb));\
rt; }) rt; })
#endif /* FFMPEG_I386_MATHOPS_H */ #endif /* FFMPEG_I386_MATHOPS_H */
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