Commit 0632d428 authored by mru's avatar mru

Fix build on configurations without fast av_log2()

This is a bit hackish.  I will try to think of something nicer, but
this will do for now.

git-svn-id: file:///var/local/repositories/ffmpeg/trunk@22366 9553f0bf-9b14-0410-a0b8-cfaf0461ba5b
parent 1daf3513
...@@ -36,11 +36,6 @@ ...@@ -36,11 +36,6 @@
#include <string.h> #include <string.h>
#include "attributes.h" #include "attributes.h"
#ifdef HAVE_AV_CONFIG_H
# include "config.h"
# include "intmath.h"
#endif
//rounded division & shift //rounded division & shift
#define RSHIFT(a,b) ((a) > 0 ? ((a) + ((1<<(b))>>1))>>(b) : ((a) + ((1<<(b))>>1)-1)>>(b)) #define RSHIFT(a,b) ((a) > 0 ? ((a) + ((1<<(b))>>1))>>(b) : ((a) + ((1<<(b))>>1)-1)>>(b))
/* assume b>0 */ /* assume b>0 */
...@@ -62,8 +57,7 @@ extern const uint8_t ff_log2_tab[256]; ...@@ -62,8 +57,7 @@ extern const uint8_t ff_log2_tab[256];
extern const uint8_t av_reverse[256]; extern const uint8_t av_reverse[256];
#ifndef av_log2 static inline av_const int av_log2_c(unsigned int v)
static inline av_const int av_log2(unsigned int v)
{ {
int n = 0; int n = 0;
if (v & 0xffff0000) { if (v & 0xffff0000) {
...@@ -78,10 +72,8 @@ static inline av_const int av_log2(unsigned int v) ...@@ -78,10 +72,8 @@ static inline av_const int av_log2(unsigned int v)
return n; return n;
} }
#endif
#ifndef av_log2_16bit static inline av_const int av_log2_16bit_c(unsigned int v)
static inline av_const int av_log2_16bit(unsigned int v)
{ {
int n = 0; int n = 0;
if (v & 0xff00) { if (v & 0xff00) {
...@@ -92,6 +84,17 @@ static inline av_const int av_log2_16bit(unsigned int v) ...@@ -92,6 +84,17 @@ static inline av_const int av_log2_16bit(unsigned int v)
return n; return n;
} }
#ifdef HAVE_AV_CONFIG_H
# include "config.h"
# include "intmath.h"
#endif
#ifndef av_log2
# define av_log2 av_log2_c
#endif
#ifndef av_log2_16bit
# define av_log2_16bit av_log2_16bit_c
#endif #endif
/** /**
......
...@@ -21,8 +21,9 @@ ...@@ -21,8 +21,9 @@
#ifndef AVUTIL_INTMATH_H #ifndef AVUTIL_INTMATH_H
#define AVUTIL_INTMATH_H #define AVUTIL_INTMATH_H
#include <stdint.h>
#include "config.h" #include "config.h"
#include "common.h" #include "attributes.h"
extern const uint32_t ff_inverse[257]; extern const uint32_t ff_inverse[257];
...@@ -56,6 +57,22 @@ extern const uint32_t ff_inverse[257]; ...@@ -56,6 +57,22 @@ extern const uint32_t ff_inverse[257];
#endif /* FASTDIV */ #endif /* FASTDIV */
/*
* Get definition of av_log2_c from common.h. In the event we got
* here through common.h including this file, including it again will
* be a no-op due to multi-inclusion guards, so we must duplicate the
* fallback defines here.
*/
#include "common.h"
#ifndef av_log2
# define av_log2 av_log2_c
#endif
#ifndef av_log2_16bit
# define av_log2_16bit av_log2_16bit_c
#endif
extern const uint8_t ff_sqrt_tab[256]; extern const uint8_t ff_sqrt_tab[256];
static inline av_const unsigned int ff_sqrt(unsigned int a) static inline av_const unsigned int ff_sqrt(unsigned int a)
......
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