summaryrefslogtreecommitdiff
path: root/libavcodec/common.h
diff options
context:
space:
mode:
authorMichael Niedermayer <michaelni@gmx.at>2002-06-02 12:11:44 +0000
committerMichael Niedermayer <michaelni@gmx.at>2002-06-02 12:11:44 +0000
commit7fd08ac1d1043b2d6c39eac11d00703b8fd42e40 (patch)
tree54dda3b072a2a71ad510a937f048deceb8e76ec8 /libavcodec/common.h
parentab00685a75c44c7ce3210e1a32c18fca0b6e2bb4 (diff)
sqrt
MAX, MIN Originally committed as revision 637 to svn://svn.ffmpeg.org/ffmpeg/trunk
Diffstat (limited to 'libavcodec/common.h')
-rw-r--r--libavcodec/common.h37
1 files changed, 36 insertions, 1 deletions
diff --git a/libavcodec/common.h b/libavcodec/common.h
index 3f38901b00..5b320b2d82 100644
--- a/libavcodec/common.h
+++ b/libavcodec/common.h
@@ -151,6 +151,8 @@ inline void dprintf(const char* fmt,...) {}
/* assume b>0 */
#define ROUNDED_DIV(a,b) (((a)>0 ? (a) + ((b)>>1) : (a) - ((b)>>1))/(b))
#define ABS(a) ((a) >= 0 ? (a) : (-(a)))
+#define MAX(a,b) ((a) > (b) ? (a) : (b))
+#define MIN(a,b) ((a) > (b) ? (b) : (a))
/* bit output */
@@ -420,7 +422,6 @@ static inline void jput_bits(PutBitContext *s, int n, int value)
}
#endif
-
static inline uint8_t* pbBufPtr(PutBitContext *s)
{
#ifdef ALT_BITSTREAM_WRITER
@@ -897,6 +898,40 @@ void __av_freep(void **ptr);
/* math */
int ff_gcd(int a, int b);
+static inline int ff_sqrt(int a)
+{
+ int ret=0;
+ int s;
+ int ret_sq=0;
+
+ for(s=15; s>=0; s--){
+ int b= ret_sq + (1<<(s*2)) + (ret<<s)*2;
+ if(b<=a){
+ ret_sq=b;
+ ret+= 1<<s;
+ }
+ }
+ return ret;
+}
+#if __CPU__ >= 686 && !defined(RUNTIME_CPUDETECT)
+#define COPY3_IF_LT(x,y,a,b,c,d)\
+asm volatile (\
+ "cmpl %0, %3 \n\t"\
+ "cmovl %3, %0 \n\t"\
+ "cmovl %4, %1 \n\t"\
+ "cmovl %5, %2 \n\t"\
+ : "+r" (x), "+r" (a), "+r" (c)\
+ : "r" (y), "r" (b), "r" (d)\
+);
+#else
+#define COPY3_IF_LT(x,y,a,b,c,d)\
+if((y)<(x)){\
+ (x)=(y);\
+ (a)=(b);\
+ (c)=(d);\
+}
+#endif
+
#define CLAMP_TO_8BIT(d) ((d > 0xff) ? 0xff : (d < 0) ? 0 : d)
#endif