1
0
mirror of https://github.com/FFmpeg/FFmpeg.git synced 2025-01-24 13:56:33 +02:00

swscale: Allow the max filter size to be set at compile time

This can help "extreme" resizes, e.g with some 4k stuff.

Signed-off-by: Derek Buitenhuis <derek.buitenhuis@gmail.com>
This commit is contained in:
Derek Buitenhuis 2014-06-11 17:51:49 +01:00
parent 681868cbbe
commit a4bd4733c0
3 changed files with 8 additions and 2 deletions

6
configure vendored
View File

@ -314,6 +314,7 @@ Advanced options (experts only):
(faster, but may crash)
--enable-memalign-hack emulate memalign, interferes with memory debuggers
--enable-sram allow use of on-chip SRAM
--sws-max-filter-size=N the max filter size swscale uses [$sws_max_filter_size_default]
Optimization options (experts only):
--disable-asm disable all assembler optimizations
@ -1892,6 +1893,7 @@ CMDLINE_SET="
ranlib
samples
strip
sws_max_filter_size
sysinclude
sysroot
target_exec
@ -2646,6 +2648,9 @@ enable safe_bitstream_reader
enable static
enable swscale_alpha
sws_max_filter_size_default=256
set_default sws_max_filter_size
# Enable hwaccels by default.
enable dxva2 vaapi vda vdpau xvmc
enable xlib
@ -5451,6 +5456,7 @@ cat > $TMPH <<EOF
#define BUILDSUF "$build_suffix"
#define SLIBSUF "$SLIBSUF"
#define HAVE_MMX2 HAVE_MMXEXT
#define SWS_MAX_FILTER_SIZE $sws_max_filter_size
EOF
test -n "$assert_level" &&

View File

@ -39,7 +39,7 @@
#define YUVRGB_TABLE_HEADROOM 128
#define MAX_FILTER_SIZE 256
#define MAX_FILTER_SIZE SWS_MAX_FILTER_SIZE
#define DITHER1XBPP

View File

@ -582,7 +582,7 @@ static av_cold int initFilter(int16_t **outFilter, int32_t **filterPos,
goto fail;
if (filterSize >= MAX_FILTER_SIZE * 16 /
((flags & SWS_ACCURATE_RND) ? APCK_SIZE : 16)) {
av_log(NULL, AV_LOG_ERROR, "sws: filterSize %d is too large, try less extreme scaling or increase MAX_FILTER_SIZE and recompile\n",
av_log(NULL, AV_LOG_ERROR, "sws: filterSize %d is too large, try less extreme scaling or set --sws-max-filter-size and recompile\n",
FF_CEIL_RSHIFT((filterSize+1) * ((flags & SWS_ACCURATE_RND) ? APCK_SIZE : 16), 4));
goto fail;
}