diff options
author | Ramiro Polla <ramiro.polla@gmail.com> | 2009-06-03 23:48:28 +0000 |
---|---|---|
committer | Ramiro Polla <ramiro.polla@gmail.com> | 2009-06-03 23:48:28 +0000 |
commit | 989b7181acbaa5ed3d731dc479a204874fee9141 (patch) | |
tree | 72f0642cadecfb3daa428c0dc8017946833a772b /libavcodec | |
parent | 007c47e8b9ae5f7da4802b28d141eb55b380a411 (diff) | |
download | ffmpeg-989b7181acbaa5ed3d731dc479a204874fee9141.tar.gz |
Use fewer macros in x86-optimized mlpdsp.
Fixes compilation on 32-bit llvm which didn't allow a cast in an m operand.
Originally committed as revision 19086 to svn://svn.ffmpeg.org/ffmpeg/trunk
Diffstat (limited to 'libavcodec')
-rw-r--r-- | libavcodec/x86/mlpdsp.c | 29 |
1 files changed, 10 insertions, 19 deletions
diff --git a/libavcodec/x86/mlpdsp.c b/libavcodec/x86/mlpdsp.c index a44760bc07..486a927ad7 100644 --- a/libavcodec/x86/mlpdsp.c +++ b/libavcodec/x86/mlpdsp.c @@ -75,11 +75,6 @@ static const void *iirtable[5] = { &ff_mlp_iirorder_0, &ff_mlp_iirorder_1, #define RESULT "%%rsi" #define RESULT32 "%%esi" -#define READVAL "r" -#define RDWRVAL "+r" -#define COUNTER "c" -#define ECXUSED - #else /* if ARCH_X86_32 */ #define MLPMUL(label, offset, offs, offc) \ @@ -106,11 +101,6 @@ static const void *iirtable[5] = { &ff_mlp_iirorder_0, &ff_mlp_iirorder_1, #define RESULT "%%eax" #define RESULT32 "%%eax" -#define READVAL "m" -#define RDWRVAL "+m" -#define COUNTER "m" -#define ECXUSED , "ecx" - #endif /* !ARCH_X86_64 */ #define BINC AV_STRINGIFY(4* MAX_CHANNELS) @@ -164,19 +154,20 @@ static void mlp_filter_channel_x86(int32_t *state, const int32_t *coeff, : /* 0*/"+r"(state), /* 1*/"+r"(coeff), /* 2*/"+r"(sample_buffer), - /* 3*/RDWRVAL(blocksize) - : - /* 4*/READVAL((x86_reg)mask), - /* 5*/READVAL(firjump), - /* 6*/READVAL(iirjump), - /* 7*/COUNTER(filter_shift) #if ARCH_X86_64 + /* 3*/"+r"(blocksize) + : /* 4*/"r"((x86_reg)mask), /* 5*/"r"(firjump), + /* 6*/"r"(iirjump) , /* 7*/"c"(filter_shift) , /* 8*/"r"((int64_t)coeff[0]) , /* 9*/"r"((int64_t)coeff[1]) , /*10*/"r"((int64_t)coeff[2]) -#endif /* ARCH_X86_64 */ - : REG_a, REG_d, REG_S - ECXUSED + : "rax", "rdx", "rsi" +#else /* ARCH_X86_32 */ + /* 3*/"+m"(blocksize) + : /* 4*/"m"( mask), /* 5*/"m"(firjump), + /* 6*/"m"(iirjump) , /* 7*/"m"(filter_shift) + : "eax", "edx", "esi", "ecx" +#endif /* !ARCH_X86_64 */ ); } |