diff options
author | Anton Khirnov <anton@khirnov.net> | 2013-11-14 12:19:04 +0100 |
---|---|---|
committer | Anton Khirnov <anton@khirnov.net> | 2014-03-10 10:27:17 +0100 |
commit | e854b8f9f4097a3c560b746895e9da6721aa4cdb (patch) | |
tree | 003241c26cefa79a5cbd2c27a462c42022ea9109 /configure | |
parent | 8cafeb8bca5d079041739dbd72ccec0ead138eaf (diff) | |
download | ffmpeg-e854b8f9f4097a3c560b746895e9da6721aa4cdb.tar.gz |
Work around broken floating point limits on some systems.
The values of {FLT,DBL}_{MAX,MIN} macros on some systems (older musl
libc, some BSD flavours) are not exactly representable, i.e.
(double)DBL_MAX == DBL_MAX is false
This violates (at least some interpretations of) the C99 standard and
breaks code (e.g. in vf_fps) like
double f = DBL_MAX;
[...]
if (f == DBL_MAX) { // f has not been changed yet
[....]
}
Diffstat (limited to 'configure')
-rwxr-xr-x | configure | 14 |
1 files changed, 14 insertions, 0 deletions
@@ -994,6 +994,16 @@ check_builtin(){ check_code ld "$headers" "$builtin" "$@" && enable "$name" } +check_compile_assert(){ + log check_compile_assert "$@" + name=$1 + headers=$2 + condition=$3 + shift 3 + disable "$name" + check_code cc "$headers" "char c[2 * !!($condition) - 1]" "$@" && enable "$name" +} + require(){ name="$1" header="$2" @@ -1360,6 +1370,7 @@ HAVE_LIST=" fast_clz fast_cmov fcntl + flt_lim fork getaddrinfo gethrtime @@ -3536,6 +3547,9 @@ if enabled_all ccc libc_glibc; then add_ldflags -Wl,-z,now # calls to libots crash without this fi +check_compile_assert flt_lim "float.h limits.h" "DBL_MAX == (double)DBL_MAX" || + add_cppflags '-I\$(SRC_PATH)/compat/float' + esc(){ echo "$*" | sed 's/%/%25/g;s/:/%3a/g' } |