File 021_kodi_ffmpeg8.patch of Package kodi

From 8a1855e6b6a531582d1ee0928ed48b5dc5e9d84c Mon Sep 17 00:00:00 2001
From: Stephan Sundermann <stephansundermann@gmail.com>
Date: Sat, 9 Aug 2025 19:10:10 +0200
Subject: [PATCH 1/6] [depends][target] Update to FFmpeg 8.0

libpostproc is a plugin now but can be merged in before build
---
 cmake/modules/FindFFMPEG.cmake                |    6 +-
 tools/buildsteps/windows/download-msys2.bat   |    2 +-
 tools/buildsteps/windows/ffmpeg_options.txt   |    2 +-
 ...peg-windows-configure-detect-openssl.patch |   10 +-
 ...-windows-configure-fix-zlib-conflict.patch |    2 +-
 ...dows-configure-allow-building-static.patch |    4 +-
 ...eg-windows-configure-detect-libdav1d.patch |    2 +-
 .../0006-ffmpeg-libpostproc-plugin.patch      | 9759 +++++++++++++++++
 .../ffmpeg/0001-libpostproc-plugin.patch      | 9759 +++++++++++++++++
 tools/depends/target/ffmpeg/CMakeLists.txt    |    2 +-
 tools/depends/target/ffmpeg/FFMPEG-VERSION    |    7 +-
 tools/depends/target/ffmpeg/Makefile          |    1 +
 12 files changed, 19540 insertions(+), 16 deletions(-)
 create mode 100644 tools/buildsteps/windows/patches/0006-ffmpeg-libpostproc-plugin.patch
 create mode 100644 tools/depends/target/ffmpeg/0001-libpostproc-plugin.patch

diff --git a/cmake/modules/FindFFMPEG.cmake b/cmake/modules/FindFFMPEG.cmake
index 2a6d565e95d33..973b86f345955 100644
--- a/cmake/modules/FindFFMPEG.cmake
+++ b/cmake/modules/FindFFMPEG.cmake
@@ -85,7 +85,11 @@ macro(buildFFMPEG)
                  -DPKG_CONFIG_PATH=${CMAKE_BINARY_DIR}/${CORE_BUILD_DIR}/lib/pkgconfig)
   set(PATCH_COMMAND ${CMAKE_COMMAND} -E copy
                     ${CMAKE_SOURCE_DIR}/tools/depends/target/ffmpeg/CMakeLists.txt
-                    <SOURCE_DIR>)
+                    <SOURCE_DIR>
+                    COMMAND ${CMAKE_COMMAND} -E copy
+                    ${CMAKE_SOURCE_DIR}/tools/depends/target/ffmpeg/0001-libpostproc-plugin.patch
+                    <SOURCE_DIR>
+  )
 
   if(CMAKE_GENERATOR STREQUAL Xcode)
     set(${${CMAKE_FIND_PACKAGE_NAME}_MODULE}_GENERATOR CMAKE_GENERATOR "Unix Makefiles")
diff --git a/tools/buildsteps/windows/download-msys2.bat b/tools/buildsteps/windows/download-msys2.bat
index fa3493f2dfb3c..ca5e037834b56 100644
--- a/tools/buildsteps/windows/download-msys2.bat
+++ b/tools/buildsteps/windows/download-msys2.bat
@@ -32,7 +32,7 @@ set msysver=20231026
 set msys2=msys64
 set arch=x86_64
 set instdir=%WORKSPACE%\project\BuildDependencies
-set msyspackages=diffutils gcc make patch perl tar yasm
+set msyspackages=diffutils gcc make nasm patch perl tar yasm
 set gaspreprocurl=https://github.com/FFmpeg/gas-preprocessor/archive/master.tar.gz
 set usemirror=yes
 set opt=mintty
diff --git a/tools/buildsteps/windows/ffmpeg_options.txt b/tools/buildsteps/windows/ffmpeg_options.txt
index 776c0b4b35ac0..189ce658b8603 100644
--- a/tools/buildsteps/windows/ffmpeg_options.txt
+++ b/tools/buildsteps/windows/ffmpeg_options.txt
@@ -4,13 +4,13 @@
 --disable-devices
 --disable-dxva2
 --disable-gnutls
+--disable-muxer=whip
 --disable-nvenc
 --disable-openssl
 --disable-programs
 --disable-shared
 --enable-encoder=ac3,aac,wmav2,png,mjpeg
 --enable-muxer=spdif,adts,asf,ipod
---enable-postproc
 --enable-protocol=http
 --enable-runtime-cpudetect
 --enable-static
diff --git a/tools/buildsteps/windows/patches/0001-ffmpeg-windows-configure-detect-openssl.patch b/tools/buildsteps/windows/patches/0001-ffmpeg-windows-configure-detect-openssl.patch
index 3795fef7a7f59..26953e1f29ddb 100644
--- a/tools/buildsteps/windows/patches/0001-ffmpeg-windows-configure-detect-openssl.patch
+++ b/tools/buildsteps/windows/patches/0001-ffmpeg-windows-configure-detect-openssl.patch
@@ -11,13 +11,13 @@ diff --git a/configure b/configure
 index ffa407d53d..c4fe14568a 100755
 --- a/configure
 +++ b/configure
-@@ -7106,6 +7106,8 @@ enabled openssl           && { { check_pkg_config openssl "openssl >= 3.0.0" ope
-                                check_lib openssl openssl/ssl.h SSL_library_init -lssl -lcrypto ||
-                                check_lib openssl openssl/ssl.h SSL_library_init -lssl32 -leay32 ||
-                                check_lib openssl openssl/ssl.h SSL_library_init -lssl -lcrypto -lws2_32 -lgdi32 ||
+@@ -7264,6 +7264,8 @@ enabled openssl           && { { check_pkg_config openssl "openssl >= 3.0.0" ope
+                                check_pkg_config openssl "openssl >= 1.1.0" openssl/ssl.h OPENSSL_init_ssl ||
+                                check_lib openssl openssl/ssl.h OPENSSL_init_ssl -lssl -lcrypto ||
+                                check_lib openssl openssl/ssl.h OPENSSL_init_ssl -lssl -lcrypto -lws2_32 -lgdi32 ||
 +                               check_lib openssl openssl/ssl.h OPENSSL_init_ssl -llibssl -llibcrypto -lws2_32 -lgdi32 -ladvapi32 -luser32 ||
 +                               check_lib openssl openssl/ssl.h SSL_library_init -llibeay32 -lssleay32 ||
-                                die "ERROR: openssl not found"; }
+                                die "ERROR: openssl (>= 1.1.0) not found"; }
  enabled pocketsphinx      && require_pkg_config pocketsphinx pocketsphinx pocketsphinx/pocketsphinx.h ps_init
  enabled rkmpp             && { require_pkg_config rkmpp rockchip_mpp  rockchip/rk_mpi.h mpp_create &&
 -- 
diff --git a/tools/buildsteps/windows/patches/0002-ffmpeg-windows-configure-fix-zlib-conflict.patch b/tools/buildsteps/windows/patches/0002-ffmpeg-windows-configure-fix-zlib-conflict.patch
index 8522020e5d29b..f13632983f4de 100644
--- a/tools/buildsteps/windows/patches/0002-ffmpeg-windows-configure-fix-zlib-conflict.patch
+++ b/tools/buildsteps/windows/patches/0002-ffmpeg-windows-configure-fix-zlib-conflict.patch
@@ -11,7 +11,7 @@ diff --git a/configure b/configure
 index c4fe14568a..9bebb75093 100755
 --- a/configure
 +++ b/configure
-@@ -8234,6 +8234,9 @@ print_config HAVE_   "$config_files" $HAVE_LIST
+@@ -8432,6 +8434,9 @@ print_config HAVE_   "$config_files" $HAVE_LIST
  print_config CONFIG_ "$config_files" $CONFIG_LIST       \
                                       $CONFIG_EXTRA      \
  
diff --git a/tools/buildsteps/windows/patches/0003-ffmpeg-windows-configure-allow-building-static.patch b/tools/buildsteps/windows/patches/0003-ffmpeg-windows-configure-allow-building-static.patch
index 423aec6591b2a..7352e09e67f83 100644
--- a/tools/buildsteps/windows/patches/0003-ffmpeg-windows-configure-allow-building-static.patch
+++ b/tools/buildsteps/windows/patches/0003-ffmpeg-windows-configure-allow-building-static.patch
@@ -11,7 +11,7 @@ diff --git a/configure b/configure
 index 9bebb75093..28dcf462dd 100755
 --- a/configure
 +++ b/configure
-@@ -5827,6 +5827,8 @@ case $target_os in
+@@ -5951,6 +5951,8 @@ case $target_os in
          enabled x86_32 && check_ldflags -Wl,--large-address-aware
          add_cppflags -DWIN32_LEAN_AND_MEAN
          shlibdir_default="$bindir_default"
@@ -20,7 +20,7 @@ index 9bebb75093..28dcf462dd 100755
          SLIBPREF=""
          SLIBSUF=".dll"
          SLIBNAME_WITH_VERSION='$(SLIBPREF)$(FULLNAME)-$(LIBVERSION)$(SLIBSUF)'
-@@ -5878,6 +5880,8 @@ case $target_os in
+@@ -6002,6 +6004,8 @@ case $target_os in
          enabled x86_32 && check_ldflags -LARGEADDRESSAWARE
          add_cppflags -DWIN32_LEAN_AND_MEAN
          shlibdir_default="$bindir_default"
diff --git a/tools/buildsteps/windows/patches/0004-ffmpeg-windows-configure-detect-libdav1d.patch b/tools/buildsteps/windows/patches/0004-ffmpeg-windows-configure-detect-libdav1d.patch
index 25eaf6bfb2889..2e9960fed8711 100644
--- a/tools/buildsteps/windows/patches/0004-ffmpeg-windows-configure-detect-libdav1d.patch
+++ b/tools/buildsteps/windows/patches/0004-ffmpeg-windows-configure-detect-libdav1d.patch
@@ -11,7 +11,7 @@ diff --git a/configure b/configure
 index 28dcf462dd..ffa96e283d 100755
 --- a/configure
 +++ b/configure
-@@ -6884,7 +6884,7 @@ enabled libcelt           && require libcelt celt/celt.h celt_decode -lcelt0 &&
+@@ -7037,7 +7041,7 @@ enabled libcelt           && require libcelt celt/celt.h celt_decode -lcelt0 &&
                                 die "ERROR: libcelt must be installed and version must be >= 0.11.0."; }
  enabled libcaca           && require_pkg_config libcaca caca caca.h caca_create_canvas
  enabled libcodec2         && require libcodec2 codec2/codec2.h codec2_create -lcodec2
diff --git a/tools/buildsteps/windows/patches/0006-ffmpeg-libpostproc-plugin.patch b/tools/buildsteps/windows/patches/0006-ffmpeg-libpostproc-plugin.patch
new file mode 100644
index 0000000000000..5d8c1eb84a1c2
--- /dev/null
+++ b/tools/buildsteps/windows/patches/0006-ffmpeg-libpostproc-plugin.patch
@@ -0,0 +1,9759 @@
+diff --git a/LICENSE.md b/LICENSE.md
+index 371b0913ce7c1..613070e1b631a 100644
+--- a/LICENSE.md
++++ b/LICENSE.md
+@@ -12,6 +12,7 @@ configure to activate them. In this case, FFmpeg's license changes to GPL v2+.
+ 
+ Specifically, the GPL parts of FFmpeg are:
+ 
++- libpostproc
+ - optional x86 optimization in the files
+     - `libavcodec/x86/flac_dsp_gpl.asm`
+     - `libavcodec/x86/idct_mmx.c`
+@@ -44,6 +45,7 @@ Specifically, the GPL parts of FFmpeg are:
+     - `vf_owdenoise.c`
+     - `vf_perspective.c`
+     - `vf_phase.c`
++    - `vf_pp.c`
+     - `vf_pp7.c`
+     - `vf_pullup.c`
+     - `vf_repeatfields.c`
+diff --git a/MAINTAINERS b/MAINTAINERS
+index d1d87752b9193..c410293c323c9 100644
+--- a/MAINTAINERS
++++ b/MAINTAINERS
+@@ -135,6 +135,8 @@ Generic Parts:
+     ratecontrol.c                   [2] Michael Niedermayer
+   simple IDCT:
+     simple_idct.c, simple_idct.h    [2] Michael Niedermayer
++  postprocessing:
++    libpostproc/*                   [2] Michael Niedermayer
+   table generation:
+     tableprint.c, tableprint.h          Reimar Doeffinger
+   fixed point FFT:
+diff --git a/Makefile b/Makefile
+index 877b0071f6cc7..d7b5a360a4d94 100644
+--- a/Makefile
++++ b/Makefile
+@@ -25,6 +25,7 @@ ALLFFLIBS =            \
+     avfilter           \
+     avformat           \
+     avutil             \
++    postproc           \
+     swscale            \
+     swresample         \
+ 
+@@ -33,6 +34,7 @@ FFLIBS-$(CONFIG_AVDEVICE)   += avdevice
+ FFLIBS-$(CONFIG_AVFILTER)   += avfilter
+ FFLIBS-$(CONFIG_AVFORMAT)   += avformat
+ FFLIBS-$(CONFIG_AVCODEC)    += avcodec
++FFLIBS-$(CONFIG_POSTPROC)   += postproc
+ FFLIBS-$(CONFIG_SWRESAMPLE) += swresample
+ FFLIBS-$(CONFIG_SWSCALE)    += swscale
+ 
+diff --git a/configure b/configure
+index ae74efc09f412..625a09ad385b5 100755
+--- a/configure
++++ b/configure
+@@ -130,6 +130,7 @@ Component options:
+   --disable-avformat       disable libavformat build
+   --disable-swresample     disable libswresample build
+   --disable-swscale        disable libswscale build
++  --disable-postproc       disable libpostproc build
+   --disable-avfilter       disable libavfilter build
+   --disable-pthreads       disable pthreads [autodetect]
+   --disable-w32threads     disable Win32 threads [autodetect]
+@@ -2072,6 +2073,7 @@ LIBRARY_LIST="
+     avdevice
+     avfilter
+     swscale
++    postproc
+     avformat
+     avcodec
+     swresample
+@@ -3969,6 +3971,7 @@ pan_filter_deps="swresample"
+ perspective_filter_deps="gpl"
+ phase_filter_deps="gpl"
+ pp7_filter_deps="gpl"
++pp_filter_deps="gpl postproc"
+ prewitt_opencl_filter_deps="opencl"
+ procamp_vaapi_filter_deps="vaapi"
+ program_opencl_filter_deps="opencl"
+@@ -4085,6 +4088,8 @@ avfilter_suggest="libm stdatomic spirv_compiler"
+ avformat_deps="avcodec avutil"
+ avformat_suggest="libm network zlib stdatomic"
+ avutil_suggest="clock_gettime ffnvcodec gcrypt libm libdrm libmfx opencl openssl user32 vaapi vulkan videotoolbox corefoundation corevideo coremedia bcrypt stdatomic"
++postproc_deps="avutil gpl"
++postproc_suggest="libm stdatomic"
+ swresample_deps="avutil"
+ swresample_suggest="libm libsoxr stdatomic"
+ swscale_deps="avutil"
+@@ -7535,7 +7540,7 @@ void (^block)(void);
+ EOF
+ 
+ # add some linker flags
+-check_ldflags -Wl,-rpath-link=:libswresample:libswscale:libavfilter:libavdevice:libavformat:libavcodec:libavutil
++check_ldflags -Wl,-rpath-link=:libpostproc:libswresample:libswscale:libavfilter:libavdevice:libavformat:libavcodec:libavutil
+ enabled rpath && add_ldexeflags -Wl,-rpath,$libdir && add_ldsoflags -Wl,-rpath,$libdir
+ test_ldflags -Wl,-Bsymbolic && append SHFLAGS -Wl,-Bsymbolic
+ 
+@@ -7900,6 +7905,7 @@ enabled fsync_filter        && prepend avfilter_deps "avformat"
+ enabled mcdeint_filter      && prepend avfilter_deps "avcodec"
+ enabled movie_filter        && prepend avfilter_deps "avformat avcodec"
+ enabled pan_filter          && prepend avfilter_deps "swresample"
++enabled pp_filter           && prepend avfilter_deps "postproc"
+ enabled qrencode_filter     && prepend avfilter_deps "swscale"
+ enabled qrencodesrc_filter  && prepend avfilter_deps "swscale"
+ enabled removelogo_filter   && prepend avfilter_deps "avformat avcodec swscale"
+@@ -7951,6 +7957,9 @@ expand_deps(){
+     reorder_by ${1}_deps LIBRARY_LIST  # linking order is expected later
+ }
+ 
++#we have to remove gpl from the deps here as some code assumes all lib deps are libs
++postproc_deps="$(filter_out 'gpl' $postproc_deps)"
++
+ map 'expand_deps $v' $LIBRARY_LIST
+ 
+ if test "$quiet" != "yes"; then
+@@ -8041,6 +8050,7 @@ echo "optimize for size         ${small-no}"
+ echo "optimizations             ${optimizations-no}"
+ echo "static                    ${static-no}"
+ echo "shared                    ${shared-no}"
++echo "postprocessing support    ${postproc-no}"
+ echo "network support           ${network-no}"
+ echo "threading support         ${thread_type-no}"
+ echo "safe bitstream reader     ${safe_bitstream_reader-no}"
+@@ -8417,6 +8427,7 @@ extralibs_avcodec="$avcodec_extralibs"
+ extralibs_avformat="$avformat_extralibs"
+ extralibs_avdevice="$avdevice_extralibs"
+ extralibs_avfilter="$avfilter_extralibs"
++extralibs_postproc="$postproc_extralibs"
+ extralibs_swscale="$swscale_extralibs"
+ extralibs_swresample="$swresample_extralibs"
+ EOF
+diff --git a/doc/filters.texi b/doc/filters.texi
+index 6d2df075083c3..47ca7000ca374 100644
+--- a/doc/filters.texi
++++ b/doc/filters.texi
+@@ -19409,6 +19409,181 @@ Set window Y position, relative offset on Y axis.
+ 
+ This filter supports same @ref{commands} as options.
+ 
++@section pp
++
++Enable the specified chain of postprocessing subfilters using libpostproc. This
++library should be automatically selected with a GPL build (@code{--enable-gpl}).
++Subfilters must be separated by '/' and can be disabled by prepending a '-'.
++Each subfilter and some options have a short and a long name that can be used
++interchangeably, i.e. dr/dering are the same.
++
++The filters accept the following options:
++
++@table @option
++@item subfilters
++Set postprocessing subfilters string.
++@end table
++
++All subfilters share common options to determine their scope:
++
++@table @option
++@item a/autoq
++Honor the quality commands for this subfilter.
++
++@item c/chrom
++Do chrominance filtering, too (default).
++
++@item y/nochrom
++Do luma filtering only (no chrominance).
++
++@item n/noluma
++Do chrominance filtering only (no luma).
++@end table
++
++These options can be appended after the subfilter name, separated by a '|'.
++
++Available subfilters are:
++
++@table @option
++@item hb/hdeblock[|difference[|flatness]]
++Horizontal deblocking filter
++@table @option
++@item difference
++Difference factor where higher values mean more deblocking (default: @code{32}).
++@item flatness
++Flatness threshold where lower values mean more deblocking (default: @code{39}).
++@end table
++
++@item vb/vdeblock[|difference[|flatness]]
++Vertical deblocking filter
++@table @option
++@item difference
++Difference factor where higher values mean more deblocking (default: @code{32}).
++@item flatness
++Flatness threshold where lower values mean more deblocking (default: @code{39}).
++@end table
++
++@item ha/hadeblock[|difference[|flatness]]
++Accurate horizontal deblocking filter
++@table @option
++@item difference
++Difference factor where higher values mean more deblocking (default: @code{32}).
++@item flatness
++Flatness threshold where lower values mean more deblocking (default: @code{39}).
++@end table
++
++@item va/vadeblock[|difference[|flatness]]
++Accurate vertical deblocking filter
++@table @option
++@item difference
++Difference factor where higher values mean more deblocking (default: @code{32}).
++@item flatness
++Flatness threshold where lower values mean more deblocking (default: @code{39}).
++@end table
++@end table
++
++The horizontal and vertical deblocking filters share the difference and
++flatness values so you cannot set different horizontal and vertical
++thresholds.
++
++@table @option
++@item h1/x1hdeblock
++Experimental horizontal deblocking filter
++
++@item v1/x1vdeblock
++Experimental vertical deblocking filter
++
++@item dr/dering
++Deringing filter
++
++@item tn/tmpnoise[|threshold1[|threshold2[|threshold3]]], temporal noise reducer
++@table @option
++@item threshold1
++larger -> stronger filtering
++@item threshold2
++larger -> stronger filtering
++@item threshold3
++larger -> stronger filtering
++@end table
++
++@item al/autolevels[:f/fullyrange], automatic brightness / contrast correction
++@table @option
++@item f/fullyrange
++Stretch luma to @code{0-255}.
++@end table
++
++@item lb/linblenddeint
++Linear blend deinterlacing filter that deinterlaces the given block by
++filtering all lines with a @code{(1 2 1)} filter.
++
++@item li/linipoldeint
++Linear interpolating deinterlacing filter that deinterlaces the given block by
++linearly interpolating every second line.
++
++@item ci/cubicipoldeint
++Cubic interpolating deinterlacing filter deinterlaces the given block by
++cubically interpolating every second line.
++
++@item md/mediandeint
++Median deinterlacing filter that deinterlaces the given block by applying a
++median filter to every second line.
++
++@item fd/ffmpegdeint
++FFmpeg deinterlacing filter that deinterlaces the given block by filtering every
++second line with a @code{(-1 4 2 4 -1)} filter.
++
++@item l5/lowpass5
++Vertically applied FIR lowpass deinterlacing filter that deinterlaces the given
++block by filtering all lines with a @code{(-1 2 6 2 -1)} filter.
++
++@item fq/forceQuant[|quantizer]
++Overrides the quantizer table from the input with the constant quantizer you
++specify.
++@table @option
++@item quantizer
++Quantizer to use
++@end table
++
++@item de/default
++Default pp filter combination (@code{hb|a,vb|a,dr|a})
++
++@item fa/fast
++Fast pp filter combination (@code{h1|a,v1|a,dr|a})
++
++@item ac
++High quality pp filter combination (@code{ha|a|128|7,va|a,dr|a})
++@end table
++
++@subsection Examples
++
++@itemize
++@item
++Apply horizontal and vertical deblocking, deringing and automatic
++brightness/contrast:
++@example
++pp=hb/vb/dr/al
++@end example
++
++@item
++Apply default filters without brightness/contrast correction:
++@example
++pp=de/-al
++@end example
++
++@item
++Apply default filters and temporal denoiser:
++@example
++pp=default/tmpnoise|1|2|3
++@end example
++
++@item
++Apply deblocking on luma only, and switch vertical deblocking on or off
++automatically depending on available CPU time:
++@example
++pp=hb|y/vb|a
++@end example
++@end itemize
++
+ @section pp7
+ Apply Postprocessing filter 7. It is variant of the @ref{spp} filter,
+ similar to spp = 6 with 7 point DCT, where only the center sample is
+diff --git a/fftools/ffprobe.c b/fftools/ffprobe.c
+index 80ce38e73bd2e..e6f8b16e1eaaa 100644
+--- a/fftools/ffprobe.c
++++ b/fftools/ffprobe.c
+@@ -62,6 +62,8 @@
+ #include "libswscale/version.h"
+ #include "libswresample/swresample.h"
+ #include "libswresample/version.h"
++#include "libpostproc/postprocess.h"
++#include "libpostproc/version.h"
+ #include "libavfilter/version.h"
+ #include "textformat/avtextformat.h"
+ #include "cmdutils.h"
+@@ -2571,6 +2573,7 @@ static void ffprobe_show_library_versions(AVTextFormatContext *tfc)
+     SHOW_LIB_VERSION(avfilter,   AVFILTER);
+     SHOW_LIB_VERSION(swscale,    SWSCALE);
+     SHOW_LIB_VERSION(swresample, SWRESAMPLE);
++    SHOW_LIB_VERSION(postproc,   POSTPROC);
+     avtext_print_section_footer(tfc);
+ }
+ 
+diff --git a/fftools/opt_common.c b/fftools/opt_common.c
+index c2f6b9de2a75d..2ac3fd4fb364c 100644
+--- a/fftools/opt_common.c
++++ b/fftools/opt_common.c
+@@ -60,6 +60,8 @@
+ #include "libswresample/swresample.h"
+ #include "libswresample/version.h"
+ 
++#include "libpostproc/postprocess.h"
++#include "libpostproc/version.h"
+ 
+ enum show_muxdemuxers {
+     SHOW_DEFAULT,
+@@ -189,6 +191,7 @@ static void print_all_libs_info(int flags, int level)
+     PRINT_LIB_INFO(avfilter,   AVFILTER,   flags, level);
+     PRINT_LIB_INFO(swscale,    SWSCALE,    flags, level);
+     PRINT_LIB_INFO(swresample, SWRESAMPLE, flags, level);
++    PRINT_LIB_INFO(postproc,   POSTPROC,   flags, level);
+ }
+ 
+ static void print_program_info(int flags, int level)
+diff --git a/libavfilter/Makefile b/libavfilter/Makefile
+index 0effe4127ffd3..7c0d879ec9c4e 100644
+--- a/libavfilter/Makefile
++++ b/libavfilter/Makefile
+@@ -431,6 +431,7 @@ OBJS-$(CONFIG_PHOTOSENSITIVITY_FILTER)       += vf_photosensitivity.o
+ OBJS-$(CONFIG_PIXDESCTEST_FILTER)            += vf_pixdesctest.o
+ OBJS-$(CONFIG_PIXELIZE_FILTER)               += vf_pixelize.o
+ OBJS-$(CONFIG_PIXSCOPE_FILTER)               += vf_datascope.o
++OBJS-$(CONFIG_PP_FILTER)                     += vf_pp.o qp_table.o
+ OBJS-$(CONFIG_PP7_FILTER)                    += vf_pp7.o qp_table.o
+ OBJS-$(CONFIG_PREMULTIPLY_FILTER)            += vf_premultiply.o framesync.o
+ OBJS-$(CONFIG_PREWITT_FILTER)                += vf_convolution.o
+diff --git a/libavfilter/allfilters.c b/libavfilter/allfilters.c
+index 5ea33cdf01b91..740d9ab265cc5 100644
+--- a/libavfilter/allfilters.c
++++ b/libavfilter/allfilters.c
+@@ -404,6 +404,7 @@ extern const FFFilter ff_vf_photosensitivity;
+ extern const FFFilter ff_vf_pixdesctest;
+ extern const FFFilter ff_vf_pixelize;
+ extern const FFFilter ff_vf_pixscope;
++extern const FFFilter ff_vf_pp;
+ extern const FFFilter ff_vf_pp7;
+ extern const FFFilter ff_vf_premultiply;
+ extern const FFFilter ff_vf_prewitt;
+diff --git a/libavfilter/vf_pp.c b/libavfilter/vf_pp.c
+new file mode 100644
+index 0000000000000..9e9903eb97461
+--- /dev/null
++++ b/libavfilter/vf_pp.c
+@@ -0,0 +1,191 @@
++/*
++ * Copyright (c) 2002 A'rpi
++ * Copyright (C) 2012 Clément Bœsch
++ *
++ * This file is part of FFmpeg.
++ *
++ * FFmpeg is free software; you can redistribute it and/or modify
++ * it under the terms of the GNU General Public License as published by
++ * the Free Software Foundation; either version 2 of the License, or
++ * (at your option) any later version.
++ *
++ * FFmpeg is distributed in the hope that it will be useful,
++ * but WITHOUT ANY WARRANTY; without even the implied warranty of
++ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
++ * GNU General Public License for more details.
++ *
++ * You should have received a copy of the GNU General Public License along
++ * with FFmpeg; if not, write to the Free Software Foundation, Inc.,
++ * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
++ */
++
++/**
++ * @file
++ * libpostproc filter, ported from MPlayer.
++ */
++
++#include "libavutil/avassert.h"
++#include "libavutil/mem.h"
++#include "libavutil/opt.h"
++
++#include "filters.h"
++#include "qp_table.h"
++#include "video.h"
++
++#include "libpostproc/postprocess.h"
++
++typedef struct PPFilterContext {
++    const AVClass *class;
++    char *subfilters;
++    int mode_id;
++    pp_mode *modes[PP_QUALITY_MAX + 1];
++    void *pp_ctx;
++} PPFilterContext;
++
++#define OFFSET(x) offsetof(PPFilterContext, x)
++#define FLAGS AV_OPT_FLAG_FILTERING_PARAM|AV_OPT_FLAG_VIDEO_PARAM
++static const AVOption pp_options[] = {
++    { "subfilters", "set postprocess subfilters", OFFSET(subfilters), AV_OPT_TYPE_STRING, {.str="de"}, .flags = FLAGS },
++    { NULL }
++};
++
++AVFILTER_DEFINE_CLASS(pp);
++
++static av_cold int pp_init(AVFilterContext *ctx)
++{
++    int i;
++    PPFilterContext *pp = ctx->priv;
++
++    for (i = 0; i <= PP_QUALITY_MAX; i++) {
++        pp->modes[i] = pp_get_mode_by_name_and_quality(pp->subfilters, i);
++        if (!pp->modes[i])
++            return AVERROR_EXTERNAL;
++    }
++    pp->mode_id = PP_QUALITY_MAX;
++    return 0;
++}
++
++static int pp_process_command(AVFilterContext *ctx, const char *cmd, const char *args,
++                              char *res, int res_len, int flags)
++{
++    PPFilterContext *pp = ctx->priv;
++
++    if (!strcmp(cmd, "quality")) {
++        pp->mode_id = av_clip(strtol(args, NULL, 10), 0, PP_QUALITY_MAX);
++        return 0;
++    }
++    return AVERROR(ENOSYS);
++}
++
++static const enum AVPixelFormat pix_fmts[] = {
++    AV_PIX_FMT_YUV420P, AV_PIX_FMT_YUVJ420P,
++    AV_PIX_FMT_YUV422P, AV_PIX_FMT_YUVJ422P,
++    AV_PIX_FMT_YUV411P,
++    AV_PIX_FMT_GBRP,
++    AV_PIX_FMT_YUV444P, AV_PIX_FMT_YUVJ444P,
++    AV_PIX_FMT_YUV440P, AV_PIX_FMT_YUVJ440P,
++    AV_PIX_FMT_GRAY8,
++    AV_PIX_FMT_NONE
++};
++
++static int pp_config_props(AVFilterLink *inlink)
++{
++    int flags = PP_CPU_CAPS_AUTO;
++    PPFilterContext *pp = inlink->dst->priv;
++
++    switch (inlink->format) {
++    case AV_PIX_FMT_GRAY8:
++    case AV_PIX_FMT_YUVJ420P:
++    case AV_PIX_FMT_YUV420P: flags |= PP_FORMAT_420; break;
++    case AV_PIX_FMT_YUVJ422P:
++    case AV_PIX_FMT_YUV422P: flags |= PP_FORMAT_422; break;
++    case AV_PIX_FMT_YUV411P: flags |= PP_FORMAT_411; break;
++    case AV_PIX_FMT_GBRP:
++    case AV_PIX_FMT_YUVJ444P:
++    case AV_PIX_FMT_YUV444P: flags |= PP_FORMAT_444; break;
++    case AV_PIX_FMT_YUVJ440P:
++    case AV_PIX_FMT_YUV440P: flags |= PP_FORMAT_440; break;
++    default: av_assert0(0);
++    }
++
++    pp->pp_ctx = pp_get_context(inlink->w, inlink->h, flags);
++    if (!pp->pp_ctx)
++        return AVERROR(ENOMEM);
++    return 0;
++}
++
++static int pp_filter_frame(AVFilterLink *inlink, AVFrame *inbuf)
++{
++    AVFilterContext *ctx = inlink->dst;
++    PPFilterContext *pp = ctx->priv;
++    AVFilterLink *outlink = ctx->outputs[0];
++    const int aligned_w = FFALIGN(outlink->w, 8);
++    const int aligned_h = FFALIGN(outlink->h, 8);
++    AVFrame *outbuf;
++    int qstride = 0;
++    int8_t *qp_table = NULL;
++    int ret;
++
++    outbuf = ff_get_video_buffer(outlink, aligned_w, aligned_h);
++    if (!outbuf) {
++        av_frame_free(&inbuf);
++        return AVERROR(ENOMEM);
++    }
++    av_frame_copy_props(outbuf, inbuf);
++    outbuf->width  = inbuf->width;
++    outbuf->height = inbuf->height;
++
++    ret = ff_qp_table_extract(inbuf, &qp_table, &qstride, NULL, NULL);
++    if (ret < 0) {
++        av_frame_free(&inbuf);
++        av_frame_free(&outbuf);
++        return ret;
++    }
++
++    pp_postprocess((const uint8_t **)inbuf->data, inbuf->linesize,
++                   outbuf->data,                 outbuf->linesize,
++                   aligned_w, outlink->h,
++                   qp_table,
++                   qstride,
++                   pp->modes[pp->mode_id],
++                   pp->pp_ctx,
++                   outbuf->pict_type | (qp_table ? PP_PICT_TYPE_QP2 : 0));
++
++    av_frame_free(&inbuf);
++    av_freep(&qp_table);
++    return ff_filter_frame(outlink, outbuf);
++}
++
++static av_cold void pp_uninit(AVFilterContext *ctx)
++{
++    int i;
++    PPFilterContext *pp = ctx->priv;
++
++    for (i = 0; i <= PP_QUALITY_MAX; i++)
++        pp_free_mode(pp->modes[i]);
++    if (pp->pp_ctx)
++        pp_free_context(pp->pp_ctx);
++}
++
++static const AVFilterPad pp_inputs[] = {
++    {
++        .name         = "default",
++        .type         = AVMEDIA_TYPE_VIDEO,
++        .config_props = pp_config_props,
++        .filter_frame = pp_filter_frame,
++    },
++};
++
++const FFFilter ff_vf_pp = {
++    .p.name          = "pp",
++    .p.description   = NULL_IF_CONFIG_SMALL("Filter video using libpostproc."),
++    .p.priv_class    = &pp_class,
++    .p.flags         = AVFILTER_FLAG_SUPPORT_TIMELINE_GENERIC,
++    .priv_size       = sizeof(PPFilterContext),
++    .init            = pp_init,
++    .uninit          = pp_uninit,
++    FILTER_INPUTS(pp_inputs),
++    FILTER_OUTPUTS(ff_video_default_filterpad),
++    FILTER_PIXFMTS_ARRAY(pix_fmts),
++    .process_command = pp_process_command,
++};
+diff --git a/libavutil/avutil.h b/libavutil/avutil.h
+index c8ae114ab6f37..ee709fbb2abe7 100644
+--- a/libavutil/avutil.h
++++ b/libavutil/avutil.h
+@@ -41,6 +41,7 @@
+  * @li @ref lavd "libavdevice" special devices muxing/demuxing library
+  * @li @ref lavu "libavutil" common utility library
+  * @li @ref lswr "libswresample" audio resampling, format conversion and mixing
++ * @li @ref lpp  "libpostproc" post processing library
+  * @li @ref libsws "libswscale" color conversion and scaling library
+  *
+  * @section ffmpeg_versioning Versioning and compatibility
+diff --git a/libpostproc/Makefile b/libpostproc/Makefile
+new file mode 100644
+index 0000000000000..d78fc0277f413
+--- /dev/null
++++ b/libpostproc/Makefile
+@@ -0,0 +1,23 @@
++NAME = postproc
++DESC = FFmpeg postprocessing library
++FFLIBS = avutil
++
++HEADERS = postprocess.h        \
++          version.h            \
++          version_major.h      \
++
++OBJS = postprocess.o           \
++       version.o               \
++
++TESTOBJS = tests/test_utils.o        \
++
++# Windows resource file
++SHLIBOBJS-$(HAVE_GNU_WINDRES) += postprocres.o
++
++TESTPROGS = blocktest          \
++            stripetest         \
++            temptest	       \
++
++$(SUBDIR)tests/blocktest$(EXESUF):  $(SUBDIR)tests/test_utils.o
++$(SUBDIR)tests/stripetest$(EXESUF): $(SUBDIR)tests/test_utils.o
++$(SUBDIR)tests/temptest$(EXESUF):  $(SUBDIR)tests/test_utils.o
+diff --git a/libpostproc/libpostproc.v b/libpostproc/libpostproc.v
+new file mode 100644
+index 0000000000000..27381c6aca3ca
+--- /dev/null
++++ b/libpostproc/libpostproc.v
+@@ -0,0 +1,7 @@
++LIBPOSTPROC_MAJOR {
++    global:
++        postproc_*;
++        pp_*;
++    local:
++        *;
++};
+diff --git a/libpostproc/postprocess.c b/libpostproc/postprocess.c
+new file mode 100644
+index 0000000000000..eab2228919265
+--- /dev/null
++++ b/libpostproc/postprocess.c
+@@ -0,0 +1,992 @@
++/*
++ * Copyright (C) 2001-2003 Michael Niedermayer (michaelni@gmx.at)
++ *
++ * AltiVec optimizations (C) 2004 Romain Dolbeau <romain@dolbeau.org>
++ *
++ * This file is part of FFmpeg.
++ *
++ * FFmpeg is free software; you can redistribute it and/or modify
++ * it under the terms of the GNU General Public License as published by
++ * the Free Software Foundation; either version 2 of the License, or
++ * (at your option) any later version.
++ *
++ * FFmpeg is distributed in the hope that it will be useful,
++ * but WITHOUT ANY WARRANTY; without even the implied warranty of
++ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
++ * GNU General Public License for more details.
++ *
++ * You should have received a copy of the GNU General Public License
++ * along with FFmpeg; if not, write to the Free Software
++ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
++ */
++
++/**
++ * @file
++ * postprocessing.
++ */
++
++/*
++                        C       MMX     MMX2    AltiVec
++isVertDC                Ec      Ec              Ec
++isVertMinMaxOk          Ec      Ec              Ec
++doVertLowPass           E               e       Ec
++doVertDefFilter         Ec      Ec      e       Ec
++isHorizDC               Ec      Ec              Ec
++isHorizMinMaxOk         a       E               Ec
++doHorizLowPass          E               e       Ec
++doHorizDefFilter        Ec      Ec      e       Ec
++do_a_deblock            Ec      E       Ec
++deRing                  E               e       Ecp
++Vertical RKAlgo1        E               a
++Horizontal RKAlgo1                      a
++Vertical X1#            a               E
++Horizontal X1#          a               E
++LinIpolDeinterlace      e               E
++CubicIpolDeinterlace    a               e
++LinBlendDeinterlace     e               E
++MedianDeinterlace#      E       Ec      Ec
++TempDeNoiser#           E               e       Ec
++
++# more or less selfinvented filters so the exactness is not too meaningful
++E = Exact implementation
++e = almost exact implementation (slightly different rounding,...)
++a = alternative / approximate impl
++c = checked against the other implementations (-vo md5)
++p = partially optimized, still some work to do
++*/
++
++/*
++TODO:
++reduce the time wasted on the mem transfer
++unroll stuff if instructions depend too much on the prior one
++move YScale thing to the end instead of fixing QP
++write a faster and higher quality deblocking filter :)
++make the mainloop more flexible (variable number of blocks at once
++        (the if/else stuff per block is slowing things down)
++compare the quality & speed of all filters
++split this huge file
++optimize c versions
++try to unroll inner for(x=0 ... loop to avoid these damn if(x ... checks
++...
++*/
++
++//Changelog: use git log
++
++#include <stddef.h>
++#include <stdlib.h>
++#include <string.h>
++
++#include "config.h"
++#include "libavutil/common.h"
++#include "libavutil/cpu.h"
++#include "libavutil/intreadwrite.h"
++#include "libavutil/mem.h"
++//#undef HAVE_MMXEXT_INLINE
++//#undef HAVE_MMX_INLINE
++//#undef ARCH_X86
++//#define DEBUG_BRIGHTNESS
++#include "postprocess.h"
++#include "postprocess_internal.h"
++#include "libavutil/avstring.h"
++
++#define GET_MODE_BUFFER_SIZE 500
++#define OPTIONS_ARRAY_SIZE 10
++#define BLOCK_SIZE 8
++#define TEMP_STRIDE 8
++//#define NUM_BLOCKS_AT_ONCE 16 //not used yet
++
++#define DERING_THRESHOLD 20
++
++#if ARCH_X86 && HAVE_INLINE_ASM
++DECLARE_ASM_CONST(8, uint64_t, w05)= 0x0005000500050005LL;
++DECLARE_ASM_CONST(8, uint64_t, w04)= 0x0004000400040004LL;
++DECLARE_ASM_CONST(8, uint64_t, w20)= 0x0020002000200020LL;
++DECLARE_ASM_CONST(8, uint64_t, b00)= 0x0000000000000000LL;
++DECLARE_ASM_CONST(8, uint64_t, b01)= 0x0101010101010101LL;
++DECLARE_ASM_CONST(8, uint64_t, b08)= 0x0808080808080808LL;
++DECLARE_ASM_CONST(8, uint64_t, b80)= 0x8080808080808080LL;
++#endif
++
++static const struct PPFilter filters[]=
++{
++    {"hb", "hdeblock",              1, 1, 3, H_DEBLOCK},
++    {"vb", "vdeblock",              1, 2, 4, V_DEBLOCK},
++/*  {"hr", "rkhdeblock",            1, 1, 3, H_RK1_FILTER},
++    {"vr", "rkvdeblock",            1, 2, 4, V_RK1_FILTER},*/
++    {"h1", "x1hdeblock",            1, 1, 3, H_X1_FILTER},
++    {"v1", "x1vdeblock",            1, 2, 4, V_X1_FILTER},
++    {"ha", "ahdeblock",             1, 1, 3, H_A_DEBLOCK},
++    {"va", "avdeblock",             1, 2, 4, V_A_DEBLOCK},
++    {"dr", "dering",                1, 5, 6, DERING},
++    {"al", "autolevels",            0, 1, 2, LEVEL_FIX},
++    {"lb", "linblenddeint",         1, 1, 4, LINEAR_BLEND_DEINT_FILTER},
++    {"li", "linipoldeint",          1, 1, 4, LINEAR_IPOL_DEINT_FILTER},
++    {"ci", "cubicipoldeint",        1, 1, 4, CUBIC_IPOL_DEINT_FILTER},
++    {"md", "mediandeint",           1, 1, 4, MEDIAN_DEINT_FILTER},
++    {"fd", "ffmpegdeint",           1, 1, 4, FFMPEG_DEINT_FILTER},
++    {"l5", "lowpass5",              1, 1, 4, LOWPASS5_DEINT_FILTER},
++    {"tn", "tmpnoise",              1, 7, 8, TEMP_NOISE_FILTER},
++    {"fq", "forcequant",            1, 0, 0, FORCE_QUANT},
++    {"be", "bitexact",              1, 0, 0, BITEXACT},
++    {"vi", "visualize",             1, 0, 0, VISUALIZE},
++    {NULL, NULL,0,0,0,0} //End Marker
++};
++
++static const char * const replaceTable[]=
++{
++    "default",      "hb:a,vb:a,dr:a",
++    "de",           "hb:a,vb:a,dr:a",
++    "fast",         "h1:a,v1:a,dr:a",
++    "fa",           "h1:a,v1:a,dr:a",
++    "ac",           "ha:a:128:7,va:a,dr:a",
++    NULL //End Marker
++};
++
++/* The horizontal functions exist only in C because the MMX
++ * code is faster with vertical filters and transposing. */
++
++/**
++ * Check if the given 8x8 Block is mostly "flat"
++ */
++static inline int isHorizDC_C(const uint8_t src[], int stride, const PPContext *c)
++{
++    int numEq= 0;
++    int y;
++    const int dcOffset= ((c->nonBQP*c->ppMode.baseDcDiff)>>8) + 1;
++    const int dcThreshold= dcOffset*2 + 1;
++
++    for(y=0; y<BLOCK_SIZE; y++){
++        numEq += ((unsigned)(src[0] - src[1] + dcOffset)) < dcThreshold;
++        numEq += ((unsigned)(src[1] - src[2] + dcOffset)) < dcThreshold;
++        numEq += ((unsigned)(src[2] - src[3] + dcOffset)) < dcThreshold;
++        numEq += ((unsigned)(src[3] - src[4] + dcOffset)) < dcThreshold;
++        numEq += ((unsigned)(src[4] - src[5] + dcOffset)) < dcThreshold;
++        numEq += ((unsigned)(src[5] - src[6] + dcOffset)) < dcThreshold;
++        numEq += ((unsigned)(src[6] - src[7] + dcOffset)) < dcThreshold;
++        src+= stride;
++    }
++    return numEq > c->ppMode.flatnessThreshold;
++}
++
++/**
++ * Check if the middle 8x8 Block in the given 8x16 block is flat
++ */
++static inline int isVertDC_C(const uint8_t src[], int stride, const PPContext *c)
++{
++    int numEq= 0;
++    int y;
++    const int dcOffset= ((c->nonBQP*c->ppMode.baseDcDiff)>>8) + 1;
++    const int dcThreshold= dcOffset*2 + 1;
++
++    src+= stride*4; // src points to begin of the 8x8 Block
++    for(y=0; y<BLOCK_SIZE-1; y++){
++        numEq += ((unsigned)(src[0] - src[0+stride] + dcOffset)) < dcThreshold;
++        numEq += ((unsigned)(src[1] - src[1+stride] + dcOffset)) < dcThreshold;
++        numEq += ((unsigned)(src[2] - src[2+stride] + dcOffset)) < dcThreshold;
++        numEq += ((unsigned)(src[3] - src[3+stride] + dcOffset)) < dcThreshold;
++        numEq += ((unsigned)(src[4] - src[4+stride] + dcOffset)) < dcThreshold;
++        numEq += ((unsigned)(src[5] - src[5+stride] + dcOffset)) < dcThreshold;
++        numEq += ((unsigned)(src[6] - src[6+stride] + dcOffset)) < dcThreshold;
++        numEq += ((unsigned)(src[7] - src[7+stride] + dcOffset)) < dcThreshold;
++        src+= stride;
++    }
++    return numEq > c->ppMode.flatnessThreshold;
++}
++
++static inline int isHorizMinMaxOk_C(const uint8_t src[], int stride, int QP)
++{
++    int i;
++    for(i=0; i<2; i++){
++        if((unsigned)(src[0] - src[5] + 2*QP) > 4*QP) return 0;
++        src += stride;
++        if((unsigned)(src[2] - src[7] + 2*QP) > 4*QP) return 0;
++        src += stride;
++        if((unsigned)(src[4] - src[1] + 2*QP) > 4*QP) return 0;
++        src += stride;
++        if((unsigned)(src[6] - src[3] + 2*QP) > 4*QP) return 0;
++        src += stride;
++    }
++    return 1;
++}
++
++static inline int isVertMinMaxOk_C(const uint8_t src[], int stride, int QP)
++{
++    int x;
++    src+= stride*4;
++    for(x=0; x<BLOCK_SIZE; x+=4){
++        if((unsigned)(src[  x + 0*stride] - src[  x + 5*stride] + 2*QP) > 4*QP) return 0;
++        if((unsigned)(src[1+x + 2*stride] - src[1+x + 7*stride] + 2*QP) > 4*QP) return 0;
++        if((unsigned)(src[2+x + 4*stride] - src[2+x + 1*stride] + 2*QP) > 4*QP) return 0;
++        if((unsigned)(src[3+x + 6*stride] - src[3+x + 3*stride] + 2*QP) > 4*QP) return 0;
++    }
++    return 1;
++}
++
++static inline int horizClassify_C(const uint8_t src[], int stride, const PPContext *c)
++{
++    if( isHorizDC_C(src, stride, c) ){
++        return isHorizMinMaxOk_C(src, stride, c->QP);
++    }else{
++        return 2;
++    }
++}
++
++static inline int vertClassify_C(const uint8_t src[], int stride, const PPContext *c)
++{
++    if( isVertDC_C(src, stride, c) ){
++        return isVertMinMaxOk_C(src, stride, c->QP);
++    }else{
++        return 2;
++    }
++}
++
++static inline void doHorizDefFilter_C(uint8_t dst[], int stride, const PPContext *c)
++{
++    int y;
++    for(y=0; y<BLOCK_SIZE; y++){
++        const int middleEnergy= 5*(dst[4] - dst[3]) + 2*(dst[2] - dst[5]);
++
++        if(FFABS(middleEnergy) < 8*c->QP){
++            const int q=(dst[3] - dst[4])/2;
++            const int leftEnergy=  5*(dst[2] - dst[1]) + 2*(dst[0] - dst[3]);
++            const int rightEnergy= 5*(dst[6] - dst[5]) + 2*(dst[4] - dst[7]);
++
++            int d= FFABS(middleEnergy) - FFMIN( FFABS(leftEnergy), FFABS(rightEnergy) );
++            d= FFMAX(d, 0);
++
++            d= (5*d + 32) >> 6;
++            d*= FFSIGN(-middleEnergy);
++
++            if(q>0)
++            {
++                d = FFMAX(d, 0);
++                d = FFMIN(d, q);
++            }
++            else
++            {
++                d = FFMIN(d, 0);
++                d = FFMAX(d, q);
++            }
++
++            dst[3]-= d;
++            dst[4]+= d;
++        }
++        dst+= stride;
++    }
++}
++
++/**
++ * Do a horizontal low pass filter on the 10x8 block (dst points to middle 8x8 Block)
++ * using the 9-Tap Filter (1,1,2,2,4,2,2,1,1)/16 (C version)
++ */
++static inline void doHorizLowPass_C(uint8_t dst[], int stride, const PPContext *c)
++{
++    int y;
++    for(y=0; y<BLOCK_SIZE; y++){
++        const int first= FFABS(dst[-1] - dst[0]) < c->QP ? dst[-1] : dst[0];
++        const int last= FFABS(dst[8] - dst[7]) < c->QP ? dst[8] : dst[7];
++
++        int sums[10];
++        sums[0] = 4*first + dst[0] + dst[1] + dst[2] + 4;
++        sums[1] = sums[0] - first  + dst[3];
++        sums[2] = sums[1] - first  + dst[4];
++        sums[3] = sums[2] - first  + dst[5];
++        sums[4] = sums[3] - first  + dst[6];
++        sums[5] = sums[4] - dst[0] + dst[7];
++        sums[6] = sums[5] - dst[1] + last;
++        sums[7] = sums[6] - dst[2] + last;
++        sums[8] = sums[7] - dst[3] + last;
++        sums[9] = sums[8] - dst[4] + last;
++
++        dst[0]= (sums[0] + sums[2] + 2*dst[0])>>4;
++        dst[1]= (sums[1] + sums[3] + 2*dst[1])>>4;
++        dst[2]= (sums[2] + sums[4] + 2*dst[2])>>4;
++        dst[3]= (sums[3] + sums[5] + 2*dst[3])>>4;
++        dst[4]= (sums[4] + sums[6] + 2*dst[4])>>4;
++        dst[5]= (sums[5] + sums[7] + 2*dst[5])>>4;
++        dst[6]= (sums[6] + sums[8] + 2*dst[6])>>4;
++        dst[7]= (sums[7] + sums[9] + 2*dst[7])>>4;
++
++        dst+= stride;
++    }
++}
++
++/**
++ * Experimental Filter 1 (Horizontal)
++ * will not damage linear gradients
++ * Flat blocks should look like they were passed through the (1,1,2,2,4,2,2,1,1) 9-Tap filter
++ * can only smooth blocks at the expected locations (it cannot smooth them if they did move)
++ * MMX2 version does correct clipping C version does not
++ * not identical with the vertical one
++ */
++static inline void horizX1Filter(uint8_t *src, int stride, int QP)
++{
++    int y;
++    static uint64_t lut[256];
++    if(!lut[255])
++    {
++        int i;
++        for(i=0; i<256; i++)
++        {
++            int v= i < 128 ? 2*i : 2*(i-256);
++/*
++//Simulate 112242211 9-Tap filter
++            uint64_t a= (v/16)  & 0xFF;
++            uint64_t b= (v/8)   & 0xFF;
++            uint64_t c= (v/4)   & 0xFF;
++            uint64_t d= (3*v/8) & 0xFF;
++*/
++//Simulate piecewise linear interpolation
++            uint64_t a= (v/16)   & 0xFF;
++            uint64_t b= (v*3/16) & 0xFF;
++            uint64_t c= (v*5/16) & 0xFF;
++            uint64_t d= (7*v/16) & 0xFF;
++            uint64_t A= (0x100 - a)&0xFF;
++            uint64_t B= (0x100 - b)&0xFF;
++            uint64_t C= (0x100 - c)&0xFF;
++            uint64_t D= (0x100 - c)&0xFF;
++
++            lut[i]   = (a<<56) | (b<<48) | (c<<40) | (d<<32) |
++                       (D<<24) | (C<<16) | (B<<8)  | (A);
++            //lut[i] = (v<<32) | (v<<24);
++        }
++    }
++
++    for(y=0; y<BLOCK_SIZE; y++){
++        int a= src[1] - src[2];
++        int b= src[3] - src[4];
++        int c= src[5] - src[6];
++
++        int d= FFMAX(FFABS(b) - (FFABS(a) + FFABS(c))/2, 0);
++
++        if(d < QP){
++            int v = d * FFSIGN(-b);
++
++            src[1] +=v/8;
++            src[2] +=v/4;
++            src[3] +=3*v/8;
++            src[4] -=3*v/8;
++            src[5] -=v/4;
++            src[6] -=v/8;
++        }
++        src+=stride;
++    }
++}
++
++/**
++ * accurate deblock filter
++ */
++static av_always_inline void do_a_deblock_C(uint8_t *src, int step,
++                                            int stride, const PPContext *c, int mode)
++{
++    int y;
++    const int QP= c->QP;
++    const int dcOffset= ((c->nonBQP*c->ppMode.baseDcDiff)>>8) + 1;
++    const int dcThreshold= dcOffset*2 + 1;
++
++    src+= step*4; // src points to begin of the 8x8 Block
++    for(y=0; y<8; y++){
++        int numEq= 0;
++
++        numEq += ((unsigned)(src[-1*step] - src[0*step] + dcOffset)) < dcThreshold;
++        numEq += ((unsigned)(src[ 0*step] - src[1*step] + dcOffset)) < dcThreshold;
++        numEq += ((unsigned)(src[ 1*step] - src[2*step] + dcOffset)) < dcThreshold;
++        numEq += ((unsigned)(src[ 2*step] - src[3*step] + dcOffset)) < dcThreshold;
++        numEq += ((unsigned)(src[ 3*step] - src[4*step] + dcOffset)) < dcThreshold;
++        numEq += ((unsigned)(src[ 4*step] - src[5*step] + dcOffset)) < dcThreshold;
++        numEq += ((unsigned)(src[ 5*step] - src[6*step] + dcOffset)) < dcThreshold;
++        numEq += ((unsigned)(src[ 6*step] - src[7*step] + dcOffset)) < dcThreshold;
++        numEq += ((unsigned)(src[ 7*step] - src[8*step] + dcOffset)) < dcThreshold;
++        if(numEq > c->ppMode.flatnessThreshold){
++            int min, max, x;
++
++            if(src[0] > src[step]){
++                max= src[0];
++                min= src[step];
++            }else{
++                max= src[step];
++                min= src[0];
++            }
++            for(x=2; x<8; x+=2){
++                if(src[x*step] > src[(x+1)*step]){
++                        if(src[x    *step] > max) max= src[ x   *step];
++                        if(src[(x+1)*step] < min) min= src[(x+1)*step];
++                }else{
++                        if(src[(x+1)*step] > max) max= src[(x+1)*step];
++                        if(src[ x   *step] < min) min= src[ x   *step];
++                }
++            }
++            if(max-min < 2*QP){
++                const int first= FFABS(src[-1*step] - src[0]) < QP ? src[-1*step] : src[0];
++                const int last= FFABS(src[8*step] - src[7*step]) < QP ? src[8*step] : src[7*step];
++
++                int sums[10];
++                sums[0] = 4*first + src[0*step] + src[1*step] + src[2*step] + 4;
++                sums[1] = sums[0] - first       + src[3*step];
++                sums[2] = sums[1] - first       + src[4*step];
++                sums[3] = sums[2] - first       + src[5*step];
++                sums[4] = sums[3] - first       + src[6*step];
++                sums[5] = sums[4] - src[0*step] + src[7*step];
++                sums[6] = sums[5] - src[1*step] + last;
++                sums[7] = sums[6] - src[2*step] + last;
++                sums[8] = sums[7] - src[3*step] + last;
++                sums[9] = sums[8] - src[4*step] + last;
++
++                if (mode & VISUALIZE) {
++                    src[0*step] =
++                    src[1*step] =
++                    src[2*step] =
++                    src[3*step] =
++                    src[4*step] =
++                    src[5*step] =
++                    src[6*step] =
++                    src[7*step] = 128;
++                }
++                src[0*step]= (sums[0] + sums[2] + 2*src[0*step])>>4;
++                src[1*step]= (sums[1] + sums[3] + 2*src[1*step])>>4;
++                src[2*step]= (sums[2] + sums[4] + 2*src[2*step])>>4;
++                src[3*step]= (sums[3] + sums[5] + 2*src[3*step])>>4;
++                src[4*step]= (sums[4] + sums[6] + 2*src[4*step])>>4;
++                src[5*step]= (sums[5] + sums[7] + 2*src[5*step])>>4;
++                src[6*step]= (sums[6] + sums[8] + 2*src[6*step])>>4;
++                src[7*step]= (sums[7] + sums[9] + 2*src[7*step])>>4;
++            }
++        }else{
++            const int middleEnergy= 5*(src[4*step] - src[3*step]) + 2*(src[2*step] - src[5*step]);
++
++            if(FFABS(middleEnergy) < 8*QP){
++                const int q=(src[3*step] - src[4*step])/2;
++                const int leftEnergy=  5*(src[2*step] - src[1*step]) + 2*(src[0*step] - src[3*step]);
++                const int rightEnergy= 5*(src[6*step] - src[5*step]) + 2*(src[4*step] - src[7*step]);
++
++                int d= FFABS(middleEnergy) - FFMIN( FFABS(leftEnergy), FFABS(rightEnergy) );
++                d= FFMAX(d, 0);
++
++                d= (5*d + 32) >> 6;
++                d*= FFSIGN(-middleEnergy);
++
++                if(q>0){
++                    d = FFMAX(d, 0);
++                    d = FFMIN(d, q);
++                }else{
++                    d = FFMIN(d, 0);
++                    d = FFMAX(d, q);
++                }
++
++                if ((mode & VISUALIZE) && d) {
++                    d= (d < 0) ? 32 : -32;
++                    src[3*step]= av_clip_uint8(src[3*step] - d);
++                    src[4*step]= av_clip_uint8(src[4*step] + d);
++                    d = 0;
++                }
++
++                src[3*step]-= d;
++                src[4*step]+= d;
++            }
++        }
++
++        src += stride;
++    }
++}
++
++//Note: we have C and SSE2 version (which uses MMX(EXT) when advantageous)
++//Plain C versions
++//we always compile C for testing which needs bitexactness
++#define TEMPLATE_PP_C 1
++#include "postprocess_template.c"
++
++#if HAVE_ALTIVEC
++#include "libavutil/ppc/util_altivec.h"
++
++#   define TEMPLATE_PP_ALTIVEC 1
++#   include "postprocess_altivec_template.c"
++#   include "postprocess_template.c"
++#endif
++
++#if ARCH_X86 && HAVE_INLINE_ASM
++#    if CONFIG_RUNTIME_CPUDETECT
++#        define TEMPLATE_PP_SSE2 1
++#        include "postprocess_template.c"
++#    else
++#        if HAVE_SSE2_INLINE
++#            define TEMPLATE_PP_SSE2 1
++#            include "postprocess_template.c"
++#        endif
++#    endif
++#endif
++
++typedef void (*pp_fn)(const uint8_t src[], int srcStride, uint8_t dst[], int dstStride, int width, int height,
++                      const int8_t QPs[], int QPStride, int isColor, PPContext *c2);
++
++static inline void postProcess(const uint8_t src[], int srcStride, uint8_t dst[], int dstStride, int width, int height,
++        const int8_t QPs[], int QPStride, int isColor, pp_mode *vm, pp_context *vc)
++{
++    pp_fn pp = postProcess_C;
++    PPContext *c= (PPContext *)vc;
++    PPMode *ppMode= (PPMode *)vm;
++    c->ppMode= *ppMode; //FIXME
++
++    if (!(ppMode->lumMode & BITEXACT)) {
++#if CONFIG_RUNTIME_CPUDETECT
++#if ARCH_X86 && HAVE_INLINE_ASM
++        // ordered per speed fastest first
++        if      (c->cpuCaps & AV_CPU_FLAG_SSE2)     pp = postProcess_SSE2;
++#elif HAVE_ALTIVEC
++        if      (c->cpuCaps & AV_CPU_FLAG_ALTIVEC)  pp = postProcess_altivec;
++#endif
++#else /* CONFIG_RUNTIME_CPUDETECT */
++#if     HAVE_SSE2_INLINE
++        pp = postProcess_SSE2;
++#elif HAVE_ALTIVEC
++        pp = postProcess_altivec;
++#endif
++#endif /* !CONFIG_RUNTIME_CPUDETECT */
++    }
++
++    pp(src, srcStride, dst, dstStride, width, height, QPs, QPStride, isColor, c);
++}
++
++/* -pp Command line Help
++*/
++const char pp_help[] =
++"Available postprocessing filters:\n"
++"Filters                        Options\n"
++"short  long name       short   long option     Description\n"
++"*      *               a       autoq           CPU power dependent enabler\n"
++"                       c       chrom           chrominance filtering enabled\n"
++"                       y       nochrom         chrominance filtering disabled\n"
++"                       n       noluma          luma filtering disabled\n"
++"hb     hdeblock        (2 threshold)           horizontal deblocking filter\n"
++"       1. difference factor: default=32, higher -> more deblocking\n"
++"       2. flatness threshold: default=39, lower -> more deblocking\n"
++"                       the h & v deblocking filters share these\n"
++"                       so you can't set different thresholds for h / v\n"
++"vb     vdeblock        (2 threshold)           vertical deblocking filter\n"
++"ha     hadeblock       (2 threshold)           horizontal deblocking filter\n"
++"va     vadeblock       (2 threshold)           vertical deblocking filter\n"
++"h1     x1hdeblock                              experimental h deblock filter 1\n"
++"v1     x1vdeblock                              experimental v deblock filter 1\n"
++"dr     dering                                  deringing filter\n"
++"al     autolevels                              automatic brightness / contrast\n"
++"                       f        fullyrange     stretch luminance to (0..255)\n"
++"lb     linblenddeint                           linear blend deinterlacer\n"
++"li     linipoldeint                            linear interpolating deinterlace\n"
++"ci     cubicipoldeint                          cubic interpolating deinterlacer\n"
++"md     mediandeint                             median deinterlacer\n"
++"fd     ffmpegdeint                             ffmpeg deinterlacer\n"
++"l5     lowpass5                                FIR lowpass deinterlacer\n"
++"de     default                                 hb:a,vb:a,dr:a\n"
++"fa     fast                                    h1:a,v1:a,dr:a\n"
++"ac                                             ha:a:128:7,va:a,dr:a\n"
++"tn     tmpnoise        (3 threshold)           temporal noise reducer\n"
++"                     1. <= 2. <= 3.            larger -> stronger filtering\n"
++"fq     forceQuant      <quantizer>             force quantizer\n"
++"Usage:\n"
++"<filterName>[:<option>[:<option>...]][[,|/][-]<filterName>[:<option>...]]...\n"
++"long form example:\n"
++"vdeblock:autoq/hdeblock:autoq/linblenddeint    default,-vdeblock\n"
++"short form example:\n"
++"vb:a/hb:a/lb                                   de,-vb\n"
++"more examples:\n"
++"tn:64:128:256\n"
++"\n"
++;
++
++pp_mode *pp_get_mode_by_name_and_quality(const char *name, int quality)
++{
++    char temp[GET_MODE_BUFFER_SIZE];
++    char *p= temp;
++    static const char filterDelimiters[] = ",/";
++    static const char optionDelimiters[] = ":|";
++    struct PPMode *ppMode;
++    char *filterToken;
++
++    if (!name)  {
++        av_log(NULL, AV_LOG_ERROR, "pp: Missing argument\n");
++        return NULL;
++    }
++
++    if (!strcmp(name, "help")) {
++        const char *p;
++        for (p = pp_help; strchr(p, '\n'); p = strchr(p, '\n') + 1) {
++            av_strlcpy(temp, p, FFMIN(sizeof(temp), strchr(p, '\n') - p + 2));
++            av_log(NULL, AV_LOG_INFO, "%s", temp);
++        }
++        return NULL;
++    }
++
++    ppMode= av_malloc(sizeof(PPMode));
++    if (!ppMode)
++        return NULL;
++
++    ppMode->lumMode= 0;
++    ppMode->chromMode= 0;
++    ppMode->maxTmpNoise[0]= 700;
++    ppMode->maxTmpNoise[1]= 1500;
++    ppMode->maxTmpNoise[2]= 3000;
++    ppMode->maxAllowedY= 234;
++    ppMode->minAllowedY= 16;
++    ppMode->baseDcDiff= 256/8;
++    ppMode->flatnessThreshold= 56-16-1;
++    ppMode->maxClippedThreshold= (AVRational){1,100};
++    ppMode->error=0;
++
++    memset(temp, 0, GET_MODE_BUFFER_SIZE);
++    av_strlcpy(temp, name, GET_MODE_BUFFER_SIZE - 1);
++
++    av_log(NULL, AV_LOG_DEBUG, "pp: %s\n", name);
++
++    for(;;){
++        const char *filterName;
++        int q= 1000000; //PP_QUALITY_MAX;
++        int chrom=-1;
++        int luma=-1;
++        const char *option;
++        const char *options[OPTIONS_ARRAY_SIZE];
++        int i;
++        int filterNameOk=0;
++        int numOfUnknownOptions=0;
++        int enable=1; //does the user want us to enabled or disabled the filter
++        char *tokstate;
++
++        filterToken= av_strtok(p, filterDelimiters, &tokstate);
++        if(!filterToken) break;
++        p+= strlen(filterToken) + 1; // p points to next filterToken
++        filterName= av_strtok(filterToken, optionDelimiters, &tokstate);
++        if (!filterName) {
++            ppMode->error++;
++            break;
++        }
++        av_log(NULL, AV_LOG_DEBUG, "pp: %s::%s\n", filterToken, filterName);
++
++        if(*filterName == '-'){
++            enable=0;
++            filterName++;
++        }
++
++        for(;;){ //for all options
++            option= av_strtok(NULL, optionDelimiters, &tokstate);
++            if(!option) break;
++
++            av_log(NULL, AV_LOG_DEBUG, "pp: option: %s\n", option);
++            if(!strcmp("autoq", option) || !strcmp("a", option)) q= quality;
++            else if(!strcmp("nochrom", option) || !strcmp("y", option)) chrom=0;
++            else if(!strcmp("chrom", option) || !strcmp("c", option)) chrom=1;
++            else if(!strcmp("noluma", option) || !strcmp("n", option)) luma=0;
++            else{
++                options[numOfUnknownOptions] = option;
++                numOfUnknownOptions++;
++            }
++            if(numOfUnknownOptions >= OPTIONS_ARRAY_SIZE-1) break;
++        }
++        options[numOfUnknownOptions] = NULL;
++
++        /* replace stuff from the replace Table */
++        for(i=0; replaceTable[2*i]; i++){
++            if(!strcmp(replaceTable[2*i], filterName)){
++                size_t newlen = strlen(replaceTable[2*i + 1]);
++                int plen;
++                int spaceLeft;
++
++                p--, *p=',';
++
++                plen= strlen(p);
++                spaceLeft= p - temp + plen;
++                if(spaceLeft + newlen  >= GET_MODE_BUFFER_SIZE - 1){
++                    ppMode->error++;
++                    break;
++                }
++                memmove(p + newlen, p, plen+1);
++                memcpy(p, replaceTable[2*i + 1], newlen);
++                filterNameOk=1;
++            }
++        }
++
++        for(i=0; filters[i].shortName; i++){
++            if(   !strcmp(filters[i].longName, filterName)
++               || !strcmp(filters[i].shortName, filterName)){
++                ppMode->lumMode &= ~filters[i].mask;
++                ppMode->chromMode &= ~filters[i].mask;
++
++                filterNameOk=1;
++                if(!enable) break; // user wants to disable it
++
++                if(q >= filters[i].minLumQuality && luma)
++                    ppMode->lumMode|= filters[i].mask;
++                if(chrom==1 || (chrom==-1 && filters[i].chromDefault))
++                    if(q >= filters[i].minChromQuality)
++                            ppMode->chromMode|= filters[i].mask;
++
++                if(filters[i].mask == LEVEL_FIX){
++                    int o;
++                    ppMode->minAllowedY= 16;
++                    ppMode->maxAllowedY= 234;
++                    for(o=0; options[o]; o++){
++                        if(  !strcmp(options[o],"fullyrange")
++                           ||!strcmp(options[o],"f")){
++                            ppMode->minAllowedY= 0;
++                            ppMode->maxAllowedY= 255;
++                            numOfUnknownOptions--;
++                        }
++                    }
++                }
++                else if(filters[i].mask == TEMP_NOISE_FILTER)
++                {
++                    int o;
++                    int numOfNoises=0;
++
++                    for(o=0; options[o]; o++){
++                        char *tail;
++                        ppMode->maxTmpNoise[numOfNoises]=
++                            strtol(options[o], &tail, 0);
++                        if(tail!=options[o]){
++                            numOfNoises++;
++                            numOfUnknownOptions--;
++                            if(numOfNoises >= 3) break;
++                        }
++                    }
++                }
++                else if(filters[i].mask == V_DEBLOCK   || filters[i].mask == H_DEBLOCK
++                     || filters[i].mask == V_A_DEBLOCK || filters[i].mask == H_A_DEBLOCK){
++                    int o;
++
++                    for(o=0; options[o] && o<2; o++){
++                        char *tail;
++                        int val= strtol(options[o], &tail, 0);
++                        if(tail==options[o]) break;
++
++                        numOfUnknownOptions--;
++                        if(o==0) ppMode->baseDcDiff= val;
++                        else ppMode->flatnessThreshold= val;
++                    }
++                }
++                else if(filters[i].mask == FORCE_QUANT){
++                    int o;
++                    ppMode->forcedQuant= 15;
++
++                    for(o=0; options[o] && o<1; o++){
++                        char *tail;
++                        int val= strtol(options[o], &tail, 0);
++                        if(tail==options[o]) break;
++
++                        numOfUnknownOptions--;
++                        ppMode->forcedQuant= val;
++                    }
++                }
++            }
++        }
++        if(!filterNameOk) ppMode->error++;
++        ppMode->error += numOfUnknownOptions;
++    }
++
++    av_log(NULL, AV_LOG_DEBUG, "pp: lumMode=%X, chromMode=%X\n", ppMode->lumMode, ppMode->chromMode);
++    if(ppMode->error){
++        av_log(NULL, AV_LOG_ERROR, "%d errors in postprocess string \"%s\"\n", ppMode->error, name);
++        av_free(ppMode);
++        return NULL;
++    }
++    return ppMode;
++}
++
++void pp_free_mode(pp_mode *mode){
++    av_free(mode);
++}
++
++static void reallocAlign(void **p, int size){
++    av_free(*p);
++    *p= av_mallocz(size);
++}
++
++static void reallocBuffers(PPContext *c, int width, int height, int stride, int qpStride){
++    int mbWidth = (width+15)>>4;
++    int mbHeight= (height+15)>>4;
++    int i;
++
++    c->stride= stride;
++    c->qpStride= qpStride;
++
++    reallocAlign((void **)&c->tempDst, stride*24+32);
++    reallocAlign((void **)&c->tempSrc, stride*24);
++    reallocAlign((void **)&c->tempBlocks, 2*16*8);
++    reallocAlign((void **)&c->yHistogram, 256*sizeof(uint64_t));
++    for(i=0; i<256; i++)
++            c->yHistogram[i]= width*height/64*15/256;
++
++    for(i=0; i<3; i++){
++        //Note: The +17*1024 is just there so I do not have to worry about r/w over the end.
++        reallocAlign((void **)&c->tempBlurred[i], stride*mbHeight*16 + 17*1024);
++        reallocAlign((void **)&c->tempBlurredPast[i], 256*((height+7)&(~7))/2 + 17*1024);//FIXME size
++    }
++
++    reallocAlign((void **)&c->deintTemp, 2*width+32);
++    reallocAlign((void **)&c->nonBQPTable, qpStride*mbHeight*sizeof(int8_t));
++    reallocAlign((void **)&c->stdQPTable, qpStride*mbHeight*sizeof(int8_t));
++    reallocAlign((void **)&c->forcedQPTable, mbWidth*sizeof(int8_t));
++}
++
++static const char * context_to_name(void * ptr) {
++    return "postproc";
++}
++
++static const AVClass av_codec_context_class = { "Postproc", context_to_name, NULL };
++
++av_cold pp_context *pp_get_context(int width, int height, int cpuCaps){
++    PPContext *c= av_mallocz(sizeof(PPContext));
++    int stride= FFALIGN(width, 16);  //assumed / will realloc if needed
++    int qpStride= (width+15)/16 + 2; //assumed / will realloc if needed
++
++    if (!c)
++        return NULL;
++
++    c->av_class = &av_codec_context_class;
++    if(cpuCaps&PP_FORMAT){
++        c->hChromaSubSample= cpuCaps&0x3;
++        c->vChromaSubSample= (cpuCaps>>4)&0x3;
++    }else{
++        c->hChromaSubSample= 1;
++        c->vChromaSubSample= 1;
++    }
++    if (cpuCaps & PP_CPU_CAPS_AUTO) {
++        c->cpuCaps = av_get_cpu_flags();
++    } else {
++        c->cpuCaps = 0;
++        if (cpuCaps & PP_CPU_CAPS_ALTIVEC)  c->cpuCaps |= AV_CPU_FLAG_ALTIVEC;
++    }
++
++    reallocBuffers(c, width, height, stride, qpStride);
++
++    c->frameNum=-1;
++
++    return c;
++}
++
++av_cold void pp_free_context(void *vc){
++    PPContext *c = (PPContext*)vc;
++    int i;
++
++    for(i=0; i<FF_ARRAY_ELEMS(c->tempBlurred); i++)
++        av_free(c->tempBlurred[i]);
++    for(i=0; i<FF_ARRAY_ELEMS(c->tempBlurredPast); i++)
++        av_free(c->tempBlurredPast[i]);
++
++    av_free(c->tempBlocks);
++    av_free(c->yHistogram);
++    av_free(c->tempDst);
++    av_free(c->tempSrc);
++    av_free(c->deintTemp);
++    av_free(c->stdQPTable);
++    av_free(c->nonBQPTable);
++    av_free(c->forcedQPTable);
++
++    memset(c, 0, sizeof(PPContext));
++
++    av_free(c);
++}
++
++void  pp_postprocess(const uint8_t * src[3], const int srcStride[3],
++                     uint8_t * dst[3], const int dstStride[3],
++                     int width, int height,
++                     const int8_t *QP_store,  int QPStride,
++                     pp_mode *vm,  void *vc, int pict_type)
++{
++    int mbWidth = (width+15)>>4;
++    int mbHeight= (height+15)>>4;
++    PPMode *mode = vm;
++    PPContext *c = vc;
++    int minStride= FFMAX(FFABS(srcStride[0]), FFABS(dstStride[0]));
++    int absQPStride = FFABS(QPStride);
++
++    if (width < 16 || height < 16) {
++        av_log(c, AV_LOG_ERROR, "Postproc is designed to filter 16x16 macroblock based formats, the minimum size is 1 macroblock\n");
++        return;
++    }
++
++    // c->stride and c->QPStride are always positive
++    if(c->stride < minStride || c->qpStride < absQPStride)
++        reallocBuffers(c, width, height,
++                       FFMAX(minStride, c->stride),
++                       FFMAX(c->qpStride, absQPStride));
++
++    if(!QP_store || (mode->lumMode & FORCE_QUANT)){
++        int i;
++        QP_store= c->forcedQPTable;
++        absQPStride = QPStride = 0;
++        if(mode->lumMode & FORCE_QUANT)
++            for(i=0; i<mbWidth; i++) c->forcedQPTable[i]= mode->forcedQuant;
++        else
++            for(i=0; i<mbWidth; i++) c->forcedQPTable[i]= 1;
++    }
++
++    if(pict_type & PP_PICT_TYPE_QP2){
++        int i;
++        const int count= FFMAX(mbHeight * absQPStride, mbWidth);
++        for(i=0; i<(count>>2); i++){
++            AV_WN32(c->stdQPTable + (i<<2), AV_RN32(QP_store + (i<<2)) >> 1 & 0x7F7F7F7F);
++        }
++        for(i<<=2; i<count; i++){
++            c->stdQPTable[i] = QP_store[i]>>1;
++        }
++        QP_store= c->stdQPTable;
++        QPStride= absQPStride;
++    }
++
++    if(0){
++        int x,y;
++        for(y=0; y<mbHeight; y++){
++            for(x=0; x<mbWidth; x++){
++                av_log(c, AV_LOG_INFO, "%2d ", QP_store[x + y*QPStride]);
++            }
++            av_log(c, AV_LOG_INFO, "\n");
++        }
++        av_log(c, AV_LOG_INFO, "\n");
++    }
++
++    if((pict_type&7)!=3){
++        if (QPStride >= 0){
++            int i;
++            const int count= FFMAX(mbHeight * QPStride, mbWidth);
++            for(i=0; i<(count>>2); i++){
++                AV_WN32(c->nonBQPTable + (i<<2), AV_RN32(QP_store + (i<<2)) & 0x3F3F3F3F);
++            }
++            for(i<<=2; i<count; i++){
++                c->nonBQPTable[i] = QP_store[i] & 0x3F;
++            }
++        } else {
++            int i,j;
++            for(i=0; i<mbHeight; i++) {
++                for(j=0; j<absQPStride; j++) {
++                    c->nonBQPTable[i*absQPStride+j] = QP_store[i*QPStride+j] & 0x3F;
++                }
++            }
++        }
++    }
++
++    av_log(c, AV_LOG_DEBUG, "using npp filters 0x%X/0x%X\n",
++           mode->lumMode, mode->chromMode);
++
++    postProcess(src[0], srcStride[0], dst[0], dstStride[0],
++                width, height, QP_store, QPStride, 0, mode, c);
++
++    if (!(src[1] && src[2] && dst[1] && dst[2]))
++        return;
++
++    width  = (width )>>c->hChromaSubSample;
++    height = (height)>>c->vChromaSubSample;
++
++    if(mode->chromMode){
++        postProcess(src[1], srcStride[1], dst[1], dstStride[1],
++                    width, height, QP_store, QPStride, 1, mode, c);
++        postProcess(src[2], srcStride[2], dst[2], dstStride[2],
++                    width, height, QP_store, QPStride, 2, mode, c);
++    }
++    else if(srcStride[1] == dstStride[1] && srcStride[2] == dstStride[2]){
++        linecpy(dst[1], src[1], height, srcStride[1]);
++        linecpy(dst[2], src[2], height, srcStride[2]);
++    }else{
++        int y;
++        for(y=0; y<height; y++){
++            memcpy(&(dst[1][y*dstStride[1]]), &(src[1][y*srcStride[1]]), width);
++            memcpy(&(dst[2][y*dstStride[2]]), &(src[2][y*srcStride[2]]), width);
++        }
++    }
++}
+diff --git a/libpostproc/postprocess.h b/libpostproc/postprocess.h
+new file mode 100644
+index 0000000000000..d2adb6ccad754
+--- /dev/null
++++ b/libpostproc/postprocess.h
+@@ -0,0 +1,109 @@
++/*
++ * Copyright (C) 2001-2003 Michael Niedermayer (michaelni@gmx.at)
++ *
++ * This file is part of FFmpeg.
++ *
++ * FFmpeg is free software; you can redistribute it and/or modify
++ * it under the terms of the GNU General Public License as published by
++ * the Free Software Foundation; either version 2 of the License, or
++ * (at your option) any later version.
++ *
++ * FFmpeg is distributed in the hope that it will be useful,
++ * but WITHOUT ANY WARRANTY; without even the implied warranty of
++ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
++ * GNU General Public License for more details.
++ *
++ * You should have received a copy of the GNU General Public License
++ * along with FFmpeg; if not, write to the Free Software
++ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
++ */
++
++#ifndef POSTPROC_POSTPROCESS_H
++#define POSTPROC_POSTPROCESS_H
++
++/**
++ * @file
++ * @ingroup lpp
++ * external API header
++ */
++
++/**
++ * @defgroup lpp libpostproc
++ * Video postprocessing library.
++ *
++ * @{
++ */
++
++#include "libpostproc/version_major.h"
++#ifndef HAVE_AV_CONFIG_H
++/* When included as part of the ffmpeg build, only include the major version
++ * to avoid unnecessary rebuilds. When included externally, keep including
++ * the full version information. */
++#include "libpostproc/version.h"
++#endif
++
++/**
++ * Return the LIBPOSTPROC_VERSION_INT constant.
++ */
++unsigned postproc_version(void);
++
++/**
++ * Return the libpostproc build-time configuration.
++ */
++const char *postproc_configuration(void);
++
++/**
++ * Return the libpostproc license.
++ */
++const char *postproc_license(void);
++
++#define PP_QUALITY_MAX 6
++
++#include <inttypes.h>
++
++typedef void pp_context;
++typedef void pp_mode;
++
++extern const char pp_help[]; ///< a simple help text
++
++void  pp_postprocess(const uint8_t * src[3], const int srcStride[3],
++                     uint8_t * dst[3], const int dstStride[3],
++                     int horizontalSize, int verticalSize,
++                     const int8_t *QP_store,  int QP_stride,
++                     pp_mode *mode, pp_context *ppContext, int pict_type);
++
++
++/**
++ * Return a pp_mode or NULL if an error occurred.
++ *
++ * @param name    the string after "-pp" on the command line
++ * @param quality a number from 0 to PP_QUALITY_MAX
++ */
++pp_mode *pp_get_mode_by_name_and_quality(const char *name, int quality);
++void pp_free_mode(pp_mode *mode);
++
++pp_context *pp_get_context(int width, int height, int flags);
++void pp_free_context(pp_context *ppContext);
++
++#define PP_CPU_CAPS_MMX   0x80000000
++#define PP_CPU_CAPS_MMX2  0x20000000
++#if FF_API_PP_AMD_3DNOW
++#define PP_CPU_CAPS_3DNOW 0x40000000
++#endif
++#define PP_CPU_CAPS_ALTIVEC 0x10000000
++#define PP_CPU_CAPS_AUTO  0x00080000
++
++#define PP_FORMAT         0x00000008
++#define PP_FORMAT_420    (0x00000011|PP_FORMAT)
++#define PP_FORMAT_422    (0x00000001|PP_FORMAT)
++#define PP_FORMAT_411    (0x00000002|PP_FORMAT)
++#define PP_FORMAT_444    (0x00000000|PP_FORMAT)
++#define PP_FORMAT_440    (0x00000010|PP_FORMAT)
++
++#define PP_PICT_TYPE_QP2  0x00000010 ///< MPEG2 style QScale
++
++/**
++ * @}
++ */
++
++#endif /* POSTPROC_POSTPROCESS_H */
+diff --git a/libpostproc/postprocess_altivec_template.c b/libpostproc/postprocess_altivec_template.c
+new file mode 100644
+index 0000000000000..feddab50356b9
+--- /dev/null
++++ b/libpostproc/postprocess_altivec_template.c
+@@ -0,0 +1,1214 @@
++/*
++ * AltiVec optimizations (C) 2004 Romain Dolbeau <romain@dolbeau.org>
++ *
++ * based on code by Copyright (C) 2001-2003 Michael Niedermayer (michaelni@gmx.at)
++ *
++ * This file is part of FFmpeg.
++ *
++ * FFmpeg is free software; you can redistribute it and/or modify
++ * it under the terms of the GNU General Public License as published by
++ * the Free Software Foundation; either version 2 of the License, or
++ * (at your option) any later version.
++ *
++ * FFmpeg is distributed in the hope that it will be useful,
++ * but WITHOUT ANY WARRANTY; without even the implied warranty of
++ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
++ * GNU General Public License for more details.
++ *
++ * You should have received a copy of the GNU General Public License
++ * along with FFmpeg; if not, write to the Free Software
++ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
++ */
++
++#include "libavutil/avutil.h"
++#include "libavutil/mem_internal.h"
++
++#define ALTIVEC_TRANSPOSE_8x8_SHORT(src_a,src_b,src_c,src_d,src_e,src_f,src_g,src_h) \
++    do {                                                          \
++        __typeof__(src_a) tempA1, tempB1, tempC1, tempD1;         \
++        __typeof__(src_a) tempE1, tempF1, tempG1, tempH1;         \
++        __typeof__(src_a) tempA2, tempB2, tempC2, tempD2;         \
++        __typeof__(src_a) tempE2, tempF2, tempG2, tempH2;         \
++        tempA1 = vec_mergeh (src_a, src_e);                       \
++        tempB1 = vec_mergel (src_a, src_e);                       \
++        tempC1 = vec_mergeh (src_b, src_f);                       \
++        tempD1 = vec_mergel (src_b, src_f);                       \
++        tempE1 = vec_mergeh (src_c, src_g);                       \
++        tempF1 = vec_mergel (src_c, src_g);                       \
++        tempG1 = vec_mergeh (src_d, src_h);                       \
++        tempH1 = vec_mergel (src_d, src_h);                       \
++        tempA2 = vec_mergeh (tempA1, tempE1);                     \
++        tempB2 = vec_mergel (tempA1, tempE1);                     \
++        tempC2 = vec_mergeh (tempB1, tempF1);                     \
++        tempD2 = vec_mergel (tempB1, tempF1);                     \
++        tempE2 = vec_mergeh (tempC1, tempG1);                     \
++        tempF2 = vec_mergel (tempC1, tempG1);                     \
++        tempG2 = vec_mergeh (tempD1, tempH1);                     \
++        tempH2 = vec_mergel (tempD1, tempH1);                     \
++        src_a = vec_mergeh (tempA2, tempE2);                      \
++        src_b = vec_mergel (tempA2, tempE2);                      \
++        src_c = vec_mergeh (tempB2, tempF2);                      \
++        src_d = vec_mergel (tempB2, tempF2);                      \
++        src_e = vec_mergeh (tempC2, tempG2);                      \
++        src_f = vec_mergel (tempC2, tempG2);                      \
++        src_g = vec_mergeh (tempD2, tempH2);                      \
++        src_h = vec_mergel (tempD2, tempH2);                      \
++    } while (0)
++
++
++static inline int vertClassify_altivec(uint8_t src[], int stride, PPContext *c) {
++    /*
++    this code makes no assumption on src or stride.
++    One could remove the recomputation of the perm
++    vector by assuming (stride % 16) == 0, unfortunately
++    this is not always true.
++    */
++    short data_0 = ((c->nonBQP*c->ppMode.baseDcDiff)>>8) + 1;
++    DECLARE_ALIGNED(16, short, data)[8] =
++                    {
++                        data_0,
++                        data_0 * 2 + 1,
++                        c->QP * 2,
++                        c->QP * 4
++                    };
++    int numEq;
++    uint8_t *src2 = src;
++    vector signed short v_dcOffset;
++    vector signed short v2QP;
++    vector unsigned short v4QP;
++    vector unsigned short v_dcThreshold;
++    const int properStride = (stride % 16);
++    const int srcAlign = ((unsigned long)src2 % 16);
++    const int two_vectors = ((srcAlign > 8) || properStride) ? 1 : 0;
++    const vector signed int zero = vec_splat_s32(0);
++    const vector signed short mask = vec_splat_s16(1);
++    vector signed int v_numEq = vec_splat_s32(0);
++    vector signed short v_data = vec_ld(0, data);
++    vector signed short v_srcAss0, v_srcAss1, v_srcAss2, v_srcAss3,
++                        v_srcAss4, v_srcAss5, v_srcAss6, v_srcAss7;
++//FIXME avoid this mess if possible
++    register int j0 = 0,
++                 j1 = stride,
++                 j2 = 2 * stride,
++                 j3 = 3 * stride,
++                 j4 = 4 * stride,
++                 j5 = 5 * stride,
++                 j6 = 6 * stride,
++                 j7 = 7 * stride;
++    vector unsigned char v_srcA0, v_srcA1, v_srcA2, v_srcA3,
++                         v_srcA4, v_srcA5, v_srcA6, v_srcA7;
++
++    v_dcOffset = vec_splat(v_data, 0);
++    v_dcThreshold = (vector unsigned short)vec_splat(v_data, 1);
++    v2QP = vec_splat(v_data, 2);
++    v4QP = (vector unsigned short)vec_splat(v_data, 3);
++
++    src2 += stride * 4;
++
++#define LOAD_LINE(i)                                                    \
++    {                                                                   \
++    vector unsigned char perm##i = vec_lvsl(j##i, src2);                \
++    vector unsigned char v_srcA2##i;                                    \
++    vector unsigned char v_srcA1##i = vec_ld(j##i, src2);               \
++    if (two_vectors)                                                    \
++        v_srcA2##i = vec_ld(j##i + 16, src2);                           \
++    v_srcA##i =                                                         \
++        vec_perm(v_srcA1##i, v_srcA2##i, perm##i);                      \
++    v_srcAss##i =                                                       \
++        (vector signed short)vec_mergeh((vector signed char)zero,       \
++                                        (vector signed char)v_srcA##i); }
++
++#define LOAD_LINE_ALIGNED(i)                                            \
++    v_srcA##i = vec_ld(j##i, src2);                                     \
++    v_srcAss##i =                                                       \
++        (vector signed short)vec_mergeh((vector signed char)zero,       \
++                                        (vector signed char)v_srcA##i)
++
++    /* Special-casing the aligned case is worthwhile, as all calls from
++     * the (transposed) horizontable deblocks will be aligned, in addition
++     * to the naturally aligned vertical deblocks. */
++    if (properStride && srcAlign) {
++        LOAD_LINE_ALIGNED(0);
++        LOAD_LINE_ALIGNED(1);
++        LOAD_LINE_ALIGNED(2);
++        LOAD_LINE_ALIGNED(3);
++        LOAD_LINE_ALIGNED(4);
++        LOAD_LINE_ALIGNED(5);
++        LOAD_LINE_ALIGNED(6);
++        LOAD_LINE_ALIGNED(7);
++    } else {
++        LOAD_LINE(0);
++        LOAD_LINE(1);
++        LOAD_LINE(2);
++        LOAD_LINE(3);
++        LOAD_LINE(4);
++        LOAD_LINE(5);
++        LOAD_LINE(6);
++        LOAD_LINE(7);
++    }
++#undef LOAD_LINE
++#undef LOAD_LINE_ALIGNED
++
++#define ITER(i, j)                                                      \
++    const vector signed short v_diff##i =                               \
++        vec_sub(v_srcAss##i, v_srcAss##j);                              \
++    const vector signed short v_sum##i =                                \
++        vec_add(v_diff##i, v_dcOffset);                                 \
++    const vector signed short v_comp##i =                               \
++        (vector signed short)vec_cmplt((vector unsigned short)v_sum##i, \
++                                       v_dcThreshold);                  \
++    const vector signed short v_part##i = vec_and(mask, v_comp##i);
++
++    {
++        ITER(0, 1)
++        ITER(1, 2)
++        ITER(2, 3)
++        ITER(3, 4)
++        ITER(4, 5)
++        ITER(5, 6)
++        ITER(6, 7)
++
++        v_numEq = vec_sum4s(v_part0, v_numEq);
++        v_numEq = vec_sum4s(v_part1, v_numEq);
++        v_numEq = vec_sum4s(v_part2, v_numEq);
++        v_numEq = vec_sum4s(v_part3, v_numEq);
++        v_numEq = vec_sum4s(v_part4, v_numEq);
++        v_numEq = vec_sum4s(v_part5, v_numEq);
++        v_numEq = vec_sum4s(v_part6, v_numEq);
++    }
++
++#undef ITER
++
++    v_numEq = vec_sums(v_numEq, zero);
++
++    v_numEq = vec_splat(v_numEq, 3);
++    vec_ste(v_numEq, 0, &numEq);
++
++    if (numEq > c->ppMode.flatnessThreshold){
++        const vector unsigned char mmoP1 = (const vector unsigned char)
++            {0x1f, 0x1f, 0x1f, 0x1f, 0x1f, 0x1f, 0x1f, 0x1f,
++             0x00, 0x01, 0x12, 0x13, 0x08, 0x09, 0x1A, 0x1B};
++        const vector unsigned char mmoP2 = (const vector unsigned char)
++            {0x04, 0x05, 0x16, 0x17, 0x0C, 0x0D, 0x1E, 0x1F,
++             0x1f, 0x1f, 0x1f, 0x1f, 0x1f, 0x1f, 0x1f, 0x1f};
++        const vector unsigned char mmoP = (const vector unsigned char)
++            vec_lvsl(8, (unsigned char*)0);
++
++        vector signed short mmoL1 = vec_perm(v_srcAss0, v_srcAss2, mmoP1);
++        vector signed short mmoL2 = vec_perm(v_srcAss4, v_srcAss6, mmoP2);
++        vector signed short mmoL = vec_perm(mmoL1, mmoL2, mmoP);
++        vector signed short mmoR1 = vec_perm(v_srcAss5, v_srcAss7, mmoP1);
++        vector signed short mmoR2 = vec_perm(v_srcAss1, v_srcAss3, mmoP2);
++        vector signed short mmoR = vec_perm(mmoR1, mmoR2, mmoP);
++        vector signed short mmoDiff = vec_sub(mmoL, mmoR);
++        vector unsigned short mmoSum = (vector unsigned short)vec_add(mmoDiff, v2QP);
++
++        if (vec_any_gt(mmoSum, v4QP))
++            return 0;
++        else
++            return 1;
++    }
++    else return 2;
++}
++
++static inline void doVertLowPass_altivec(uint8_t *src, int stride, PPContext *c) {
++    /*
++    this code makes no assumption on src or stride.
++    One could remove the recomputation of the perm
++    vector by assuming (stride % 16) == 0, unfortunately
++    this is not always true. Quite a lot of load/stores
++    can be removed by assuming proper alignment of
++    src & stride :-(
++    */
++    uint8_t *src2 = src;
++    const vector signed int zero = vec_splat_s32(0);
++    const int properStride = (stride % 16);
++    const int srcAlign = ((unsigned long)src2 % 16);
++    DECLARE_ALIGNED(16, short, qp)[8] = {c->QP};
++    vector signed short vqp = vec_ld(0, qp);
++    vector signed short vb0, vb1, vb2, vb3, vb4, vb5, vb6, vb7, vb8, vb9;
++    vector unsigned char vbA0, av_uninit(vbA1), av_uninit(vbA2), av_uninit(vbA3), av_uninit(vbA4), av_uninit(vbA5), av_uninit(vbA6), av_uninit(vbA7), av_uninit(vbA8), vbA9;
++    vector unsigned char vbB0, av_uninit(vbB1), av_uninit(vbB2), av_uninit(vbB3), av_uninit(vbB4), av_uninit(vbB5), av_uninit(vbB6), av_uninit(vbB7), av_uninit(vbB8), vbB9;
++    vector unsigned char vbT0, vbT1, vbT2, vbT3, vbT4, vbT5, vbT6, vbT7, vbT8, vbT9;
++    vector unsigned char perml0, perml1, perml2, perml3, perml4,
++                         perml5, perml6, perml7, perml8, perml9;
++    register int j0 = 0,
++                 j1 = stride,
++                 j2 = 2 * stride,
++                 j3 = 3 * stride,
++                 j4 = 4 * stride,
++                 j5 = 5 * stride,
++                 j6 = 6 * stride,
++                 j7 = 7 * stride,
++                 j8 = 8 * stride,
++                 j9 = 9 * stride;
++
++    vqp = vec_splat(vqp, 0);
++
++    src2 += stride*3;
++
++#define LOAD_LINE(i)                                                    \
++    perml##i = vec_lvsl(i * stride, src2);                              \
++    vbA##i = vec_ld(i * stride, src2);                                  \
++    vbB##i = vec_ld(i * stride + 16, src2);                             \
++    vbT##i = vec_perm(vbA##i, vbB##i, perml##i);                        \
++    vb##i =                                                             \
++        (vector signed short)vec_mergeh((vector unsigned char)zero,     \
++                                        (vector unsigned char)vbT##i)
++
++#define LOAD_LINE_ALIGNED(i)                                            \
++    vbT##i = vec_ld(j##i, src2);                                        \
++    vb##i =                                                             \
++        (vector signed short)vec_mergeh((vector signed char)zero,       \
++                                        (vector signed char)vbT##i)
++
++      /* Special-casing the aligned case is worthwhile, as all calls from
++       * the (transposed) horizontable deblocks will be aligned, in addition
++       * to the naturally aligned vertical deblocks. */
++    if (properStride && srcAlign) {
++          LOAD_LINE_ALIGNED(0);
++          LOAD_LINE_ALIGNED(1);
++          LOAD_LINE_ALIGNED(2);
++          LOAD_LINE_ALIGNED(3);
++          LOAD_LINE_ALIGNED(4);
++          LOAD_LINE_ALIGNED(5);
++          LOAD_LINE_ALIGNED(6);
++          LOAD_LINE_ALIGNED(7);
++          LOAD_LINE_ALIGNED(8);
++          LOAD_LINE_ALIGNED(9);
++    } else {
++          LOAD_LINE(0);
++          LOAD_LINE(1);
++          LOAD_LINE(2);
++          LOAD_LINE(3);
++          LOAD_LINE(4);
++          LOAD_LINE(5);
++          LOAD_LINE(6);
++          LOAD_LINE(7);
++          LOAD_LINE(8);
++          LOAD_LINE(9);
++    }
++#undef LOAD_LINE
++#undef LOAD_LINE_ALIGNED
++    {
++        const vector unsigned short v_2 = vec_splat_u16(2);
++        const vector unsigned short v_4 = vec_splat_u16(4);
++
++        const vector signed short v_diff01 = vec_sub(vb0, vb1);
++        const vector unsigned short v_cmp01 =
++            (const vector unsigned short) vec_cmplt(vec_abs(v_diff01), vqp);
++        const vector signed short v_first = vec_sel(vb1, vb0, v_cmp01);
++        const vector signed short v_diff89 = vec_sub(vb8, vb9);
++        const vector unsigned short v_cmp89 =
++            (const vector unsigned short) vec_cmplt(vec_abs(v_diff89), vqp);
++        const vector signed short v_last = vec_sel(vb8, vb9, v_cmp89);
++
++        const vector signed short temp01 = vec_mladd(v_first, (vector signed short)v_4, vb1);
++        const vector signed short temp02 = vec_add(vb2, vb3);
++        const vector signed short temp03 = vec_add(temp01, (vector signed short)v_4);
++        const vector signed short v_sumsB0 = vec_add(temp02, temp03);
++
++        const vector signed short temp11 = vec_sub(v_sumsB0, v_first);
++        const vector signed short v_sumsB1 = vec_add(temp11, vb4);
++
++        const vector signed short temp21 = vec_sub(v_sumsB1, v_first);
++        const vector signed short v_sumsB2 = vec_add(temp21, vb5);
++
++        const vector signed short temp31 = vec_sub(v_sumsB2, v_first);
++        const vector signed short v_sumsB3 = vec_add(temp31, vb6);
++
++        const vector signed short temp41 = vec_sub(v_sumsB3, v_first);
++        const vector signed short v_sumsB4 = vec_add(temp41, vb7);
++
++        const vector signed short temp51 = vec_sub(v_sumsB4, vb1);
++        const vector signed short v_sumsB5 = vec_add(temp51, vb8);
++
++        const vector signed short temp61 = vec_sub(v_sumsB5, vb2);
++        const vector signed short v_sumsB6 = vec_add(temp61, v_last);
++
++        const vector signed short temp71 = vec_sub(v_sumsB6, vb3);
++        const vector signed short v_sumsB7 = vec_add(temp71, v_last);
++
++        const vector signed short temp81 = vec_sub(v_sumsB7, vb4);
++        const vector signed short v_sumsB8 = vec_add(temp81, v_last);
++
++        const vector signed short temp91 = vec_sub(v_sumsB8, vb5);
++        const vector signed short v_sumsB9 = vec_add(temp91, v_last);
++
++    #define COMPUTE_VR(i, j, k)                                             \
++        const vector signed short temps1##i =                               \
++            vec_add(v_sumsB##i, v_sumsB##k);                                \
++        const vector signed short temps2##i =                               \
++            vec_mladd(vb##j, (vector signed short)v_2, temps1##i);          \
++        const vector signed short  vr##j = vec_sra(temps2##i, v_4)
++
++        COMPUTE_VR(0, 1, 2);
++        COMPUTE_VR(1, 2, 3);
++        COMPUTE_VR(2, 3, 4);
++        COMPUTE_VR(3, 4, 5);
++        COMPUTE_VR(4, 5, 6);
++        COMPUTE_VR(5, 6, 7);
++        COMPUTE_VR(6, 7, 8);
++        COMPUTE_VR(7, 8, 9);
++
++        const vector signed char neg1 = vec_splat_s8(-1);
++        const vector unsigned char permHH = (const vector unsigned char){0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07,
++                                                                         0x18, 0x19, 0x1A, 0x1B, 0x1C, 0x1D, 0x1E, 0x1F};
++
++#define PACK_AND_STORE(i)                                       \
++{   const vector unsigned char perms##i =                       \
++        vec_lvsr(i * stride, src2);                             \
++    const vector unsigned char vf##i =                          \
++        vec_packsu(vr##i, (vector signed short)zero);           \
++    const vector unsigned char vg##i =                          \
++        vec_perm(vf##i, vbT##i, permHH);                        \
++    const vector unsigned char mask##i =                        \
++        vec_perm((vector unsigned char)zero, (vector unsigned char)neg1, perms##i); \
++    const vector unsigned char vg2##i =                         \
++        vec_perm(vg##i, vg##i, perms##i);                       \
++    const vector unsigned char svA##i =                         \
++        vec_sel(vbA##i, vg2##i, mask##i);                       \
++    const vector unsigned char svB##i =                         \
++        vec_sel(vg2##i, vbB##i, mask##i);                       \
++    vec_st(svA##i, i * stride, src2);                           \
++    vec_st(svB##i, i * stride + 16, src2);}
++
++#define PACK_AND_STORE_ALIGNED(i)                               \
++{   const vector unsigned char vf##i =                          \
++        vec_packsu(vr##i, (vector signed short)zero);           \
++    const vector unsigned char vg##i =                          \
++        vec_perm(vf##i, vbT##i, permHH);                        \
++    vec_st(vg##i, i * stride, src2);}
++
++        /* Special-casing the aligned case is worthwhile, as all calls from
++         * the (transposed) horizontable deblocks will be aligned, in addition
++         * to the naturally aligned vertical deblocks. */
++        if (properStride && srcAlign) {
++            PACK_AND_STORE_ALIGNED(1)
++            PACK_AND_STORE_ALIGNED(2)
++            PACK_AND_STORE_ALIGNED(3)
++            PACK_AND_STORE_ALIGNED(4)
++            PACK_AND_STORE_ALIGNED(5)
++            PACK_AND_STORE_ALIGNED(6)
++            PACK_AND_STORE_ALIGNED(7)
++            PACK_AND_STORE_ALIGNED(8)
++        } else {
++            PACK_AND_STORE(1)
++            PACK_AND_STORE(2)
++            PACK_AND_STORE(3)
++            PACK_AND_STORE(4)
++            PACK_AND_STORE(5)
++            PACK_AND_STORE(6)
++            PACK_AND_STORE(7)
++            PACK_AND_STORE(8)
++        }
++    #undef PACK_AND_STORE
++    #undef PACK_AND_STORE_ALIGNED
++    }
++}
++
++
++
++static inline void doVertDefFilter_altivec(uint8_t src[], int stride, PPContext *c) {
++    /*
++    this code makes no assumption on src or stride.
++    One could remove the recomputation of the perm
++    vector by assuming (stride % 16) == 0, unfortunately
++    this is not always true. Quite a lot of load/stores
++    can be removed by assuming proper alignment of
++    src & stride :-(
++    */
++    uint8_t *src2 = src + stride*3;
++    const vector signed int zero = vec_splat_s32(0);
++    DECLARE_ALIGNED(16, short, qp)[8] = {8*c->QP};
++    vector signed short vqp = vec_splat(
++                                (vector signed short)vec_ld(0, qp), 0);
++
++#define LOAD_LINE(i)                                                    \
++    const vector unsigned char perm##i =                                \
++        vec_lvsl(i * stride, src2);                                     \
++    const vector unsigned char vbA##i =                                 \
++        vec_ld(i * stride, src2);                                       \
++    const vector unsigned char vbB##i =                                 \
++        vec_ld(i * stride + 16, src2);                                  \
++    const vector unsigned char vbT##i =                                 \
++        vec_perm(vbA##i, vbB##i, perm##i);                              \
++    const vector signed short vb##i =                                   \
++        (vector signed short)vec_mergeh((vector unsigned char)zero,     \
++                                        (vector unsigned char)vbT##i)
++
++     LOAD_LINE(1);
++     LOAD_LINE(2);
++     LOAD_LINE(3);
++     LOAD_LINE(4);
++     LOAD_LINE(5);
++     LOAD_LINE(6);
++     LOAD_LINE(7);
++     LOAD_LINE(8);
++#undef LOAD_LINE
++
++     const vector signed short v_1 = vec_splat_s16(1);
++     const vector signed short v_2 = vec_splat_s16(2);
++     const vector signed short v_5 = vec_splat_s16(5);
++     const vector signed short v_32 = vec_sl(v_1,
++                                             (vector unsigned short)v_5);
++     /* middle energy */
++     const vector signed short l3minusl6 = vec_sub(vb3, vb6);
++     const vector signed short l5minusl4 = vec_sub(vb5, vb4);
++     const vector signed short twotimes_l3minusl6 = vec_mladd(v_2, l3minusl6, (vector signed short)zero);
++     const vector signed short mE = vec_mladd(v_5, l5minusl4, twotimes_l3minusl6);
++     const vector signed short absmE = vec_abs(mE);
++     /* left & right energy */
++     const vector signed short l1minusl4 = vec_sub(vb1, vb4);
++     const vector signed short l3minusl2 = vec_sub(vb3, vb2);
++     const vector signed short l5minusl8 = vec_sub(vb5, vb8);
++     const vector signed short l7minusl6 = vec_sub(vb7, vb6);
++     const vector signed short twotimes_l1minusl4 = vec_mladd(v_2, l1minusl4, (vector signed short)zero);
++     const vector signed short twotimes_l5minusl8 = vec_mladd(v_2, l5minusl8, (vector signed short)zero);
++     const vector signed short lE = vec_mladd(v_5, l3minusl2, twotimes_l1minusl4);
++     const vector signed short rE = vec_mladd(v_5, l7minusl6, twotimes_l5minusl8);
++     /* d */
++     const vector signed short ddiff = vec_sub(absmE,
++                                               vec_min(vec_abs(lE),
++                                                       vec_abs(rE)));
++     const vector signed short ddiffclamp = vec_max(ddiff, (vector signed short)zero);
++     const vector signed short dtimes64 = vec_mladd(v_5, ddiffclamp, v_32);
++     const vector signed short d = vec_sra(dtimes64, vec_splat_u16(6));
++     const vector signed short minusd = vec_sub((vector signed short)zero, d);
++     const vector signed short finald = vec_sel(minusd,
++                                                d,
++                                                vec_cmpgt(vec_sub((vector signed short)zero, mE),
++                                                          (vector signed short)zero));
++     /* q */
++     const vector signed short qtimes2 = vec_sub(vb4, vb5);
++     /* for a shift right to behave like /2, we need to add one
++        to all negative integer */
++     const vector signed short rounddown = vec_sel((vector signed short)zero,
++                                                   v_1,
++                                                   vec_cmplt(qtimes2, (vector signed short)zero));
++     const vector signed short q = vec_sra(vec_add(qtimes2, rounddown), vec_splat_u16(1));
++     /* clamp */
++     const vector signed short dclamp_P1 = vec_max((vector signed short)zero, finald);
++     const vector signed short dclamp_P = vec_min(dclamp_P1, q);
++     const vector signed short dclamp_N1 = vec_min((vector signed short)zero, finald);
++     const vector signed short dclamp_N = vec_max(dclamp_N1, q);
++
++     const vector signed short dclampedfinal = vec_sel(dclamp_N,
++                                                       dclamp_P,
++                                                       vec_cmpgt(q, (vector signed short)zero));
++     const vector signed short dornotd = vec_sel((vector signed short)zero,
++                                                 dclampedfinal,
++                                                 vec_cmplt(absmE, vqp));
++     /* add/subtract to l4 and l5 */
++     const vector signed short vb4minusd = vec_sub(vb4, dornotd);
++     const vector signed short vb5plusd  = vec_add(vb5, dornotd);
++     /* finally, stores */
++     const vector unsigned char st4 = vec_packsu(vb4minusd, (vector signed short)zero);
++     const vector unsigned char st5 = vec_packsu(vb5plusd,  (vector signed short)zero);
++
++     const vector signed char neg1 = vec_splat_s8(-1);
++     const vector unsigned char permHH = (const vector unsigned char){0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07,
++                                                                      0x18, 0x19, 0x1A, 0x1B, 0x1C, 0x1D, 0x1E, 0x1F};
++
++#define STORE(i)                                                \
++{    const vector unsigned char perms##i =                      \
++         vec_lvsr(i * stride, src2);                            \
++     const vector unsigned char vg##i =                         \
++         vec_perm(st##i, vbT##i, permHH);                       \
++     const vector unsigned char mask##i =                       \
++         vec_perm((vector unsigned char)zero, (vector unsigned char)neg1, perms##i); \
++     const vector unsigned char vg2##i =                        \
++         vec_perm(vg##i, vg##i, perms##i);                      \
++     const vector unsigned char svA##i =                        \
++         vec_sel(vbA##i, vg2##i, mask##i);                      \
++     const vector unsigned char svB##i =                        \
++         vec_sel(vg2##i, vbB##i, mask##i);                      \
++     vec_st(svA##i, i * stride, src2);                          \
++     vec_st(svB##i, i * stride + 16, src2);}
++
++     STORE(4)
++     STORE(5)
++}
++
++static inline void dering_altivec(uint8_t src[], int stride, PPContext *c, int leftborder, int rightborder, int topborder) {
++    const vector signed int vsint32_8 = vec_splat_s32(8);
++    const vector unsigned int vuint32_4 = vec_splat_u32(4);
++    const vector signed char neg1 = vec_splat_s8(-1);
++
++    const vector unsigned char permA1 = (vector unsigned char)
++        {0x00, 0x01, 0x02, 0x10, 0x11, 0x12, 0x1F, 0x1F,
++         0x1F, 0x1F, 0x1F, 0x1F, 0x1F, 0x1F, 0x1F, 0x1F};
++    const vector unsigned char permA2 = (vector unsigned char)
++        {0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x10, 0x11,
++         0x12, 0x1F, 0x1F, 0x1F, 0x1F, 0x1F, 0x1F, 0x1F};
++    const vector unsigned char permA1inc = (vector unsigned char)
++        {0x01, 0x01, 0x01, 0x01, 0x01, 0x01, 0x00, 0x00,
++         0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00};
++    const vector unsigned char permA2inc = (vector unsigned char)
++        {0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x01, 0x01,
++         0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00};
++    const vector unsigned char magic = (vector unsigned char)
++        {0x01, 0x02, 0x01, 0x02, 0x04, 0x02, 0x01, 0x02,
++         0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00};
++    const vector unsigned char extractPerm = (vector unsigned char)
++        {0x10, 0x10, 0x10, 0x01, 0x10, 0x10, 0x10, 0x01,
++         0x10, 0x10, 0x10, 0x01, 0x10, 0x10, 0x10, 0x01};
++    const vector unsigned char extractPermInc = (vector unsigned char)
++        {0x00, 0x00, 0x00, 0x01, 0x00, 0x00, 0x00, 0x01,
++         0x00, 0x00, 0x00, 0x01, 0x00, 0x00, 0x00, 0x01};
++    const vector unsigned char identity = vec_lvsl(0,(unsigned char *)0);
++    const vector unsigned char tenRight = (vector unsigned char)
++        {0x00, 0x10, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
++         0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00};
++    const vector unsigned char eightLeft = (vector unsigned char)
++        {0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
++         0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x08};
++
++    /*
++    this code makes no assumption on src or stride.
++    One could remove the recomputation of the perm
++    vector by assuming (stride % 16) == 0, unfortunately
++    this is not always true. Quite a lot of load/stores
++    can be removed by assuming proper alignment of
++    src & stride :-(
++    */
++    uint8_t *srcCopy = src;
++    DECLARE_ALIGNED(16, uint8_t, dt)[16] = { DERING_THRESHOLD };
++    const vector signed int zero = vec_splat_s32(0);
++    vector unsigned char v_dt = vec_splat(vec_ld(0, dt), 0);
++
++    if (topborder)
++        return;
++
++#define LOAD_LINE(i)                                                  \
++    const vector unsigned char perm##i =                              \
++        vec_lvsl(i * stride, srcCopy);                                \
++    vector unsigned char sA##i = vec_ld(i * stride, srcCopy);         \
++    vector unsigned char sB##i = vec_ld(i * stride + 16, srcCopy);    \
++    vector unsigned char src##i = vec_perm(sA##i, sB##i, perm##i)
++
++    LOAD_LINE(0);
++    LOAD_LINE(1);
++    LOAD_LINE(2);
++    LOAD_LINE(3);
++    LOAD_LINE(4);
++    LOAD_LINE(5);
++    LOAD_LINE(6);
++    LOAD_LINE(7);
++    LOAD_LINE(8);
++    LOAD_LINE(9);
++#undef LOAD_LINE
++
++    vector unsigned char v_avg;
++    DECLARE_ALIGNED(16, signed int, S)[8];
++    DECLARE_ALIGNED(16, int, tQP2)[4] = { c->QP/2 + 1 };
++    vector signed int vQP2 = vec_ld(0, tQP2);
++    vQP2 = vec_splat(vQP2, 0);
++
++    {
++    const vector unsigned char trunc_perm = (vector unsigned char)
++        {0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08,
++         0x11, 0x12, 0x13, 0x14, 0x15, 0x16, 0x17, 0x18};
++    const vector unsigned char trunc_src12 = vec_perm(src1, src2, trunc_perm);
++    const vector unsigned char trunc_src34 = vec_perm(src3, src4, trunc_perm);
++    const vector unsigned char trunc_src56 = vec_perm(src5, src6, trunc_perm);
++    const vector unsigned char trunc_src78 = vec_perm(src7, src8, trunc_perm);
++
++#define EXTRACT(op) do {                                                \
++    const vector unsigned char s_1   = vec_##op(trunc_src12, trunc_src34); \
++    const vector unsigned char s_2   = vec_##op(trunc_src56, trunc_src78); \
++    const vector unsigned char s_6   = vec_##op(s_1, s_2);     \
++    const vector unsigned char s_8h  = vec_mergeh(s_6, s_6);   \
++    const vector unsigned char s_8l  = vec_mergel(s_6, s_6);   \
++    const vector unsigned char s_9   = vec_##op(s_8h, s_8l);   \
++    const vector unsigned char s_9h  = vec_mergeh(s_9, s_9);   \
++    const vector unsigned char s_9l  = vec_mergel(s_9, s_9);   \
++    const vector unsigned char s_10  = vec_##op(s_9h, s_9l);   \
++    const vector unsigned char s_10h = vec_mergeh(s_10, s_10); \
++    const vector unsigned char s_10l = vec_mergel(s_10, s_10); \
++    const vector unsigned char s_11  = vec_##op(s_10h, s_10l); \
++    const vector unsigned char s_11h = vec_mergeh(s_11, s_11); \
++    const vector unsigned char s_11l = vec_mergel(s_11, s_11); \
++    v_##op = vec_##op(s_11h, s_11l);                           \
++} while (0)
++
++    vector unsigned char v_min;
++    vector unsigned char v_max;
++    EXTRACT(min);
++    EXTRACT(max);
++#undef EXTRACT
++
++    if (vec_all_lt(vec_sub(v_max, v_min), v_dt))
++        return;
++
++    v_avg = vec_avg(v_min, v_max);
++    }
++
++    {
++    const vector unsigned short mask1 = (vector unsigned short)
++                                        {0x0001, 0x0002, 0x0004, 0x0008,
++                                         0x0010, 0x0020, 0x0040, 0x0080};
++    const vector unsigned short mask2 = (vector unsigned short)
++                                        {0x0100, 0x0200, 0x0000, 0x0000,
++                                         0x0000, 0x0000, 0x0000, 0x0000};
++
++    const vector unsigned int vuint32_16 = vec_sl(vec_splat_u32(1), vec_splat_u32(4));
++    const vector unsigned int vuint32_1 = vec_splat_u32(1);
++
++    vector signed int sumA2;
++    vector signed int sumB2;
++    vector signed int sum0, sum1, sum2, sum3, sum4;
++    vector signed int sum5, sum6, sum7, sum8, sum9;
++
++#define COMPARE(i)                                                      \
++    do {                                                                \
++        const vector unsigned char cmp =                                \
++            (vector unsigned char)vec_cmpgt(src##i, v_avg);             \
++        const vector unsigned short cmpHi =                             \
++            (vector unsigned short)vec_mergeh(cmp, cmp);                \
++        const vector unsigned short cmpLi =                             \
++            (vector unsigned short)vec_mergel(cmp, cmp);                \
++        const vector signed short cmpHf =                               \
++            (vector signed short)vec_and(cmpHi, mask1);                 \
++        const vector signed short cmpLf =                               \
++            (vector signed short)vec_and(cmpLi, mask2);                 \
++        const vector signed int sump = vec_sum4s(cmpHf, zero);          \
++        const vector signed int sumq = vec_sum4s(cmpLf, sump);          \
++        sum##i  = vec_sums(sumq, zero);                                 \
++    } while (0)
++
++    COMPARE(0);
++    COMPARE(1);
++    COMPARE(2);
++    COMPARE(3);
++    COMPARE(4);
++    COMPARE(5);
++    COMPARE(6);
++    COMPARE(7);
++    COMPARE(8);
++    COMPARE(9);
++#undef COMPARE
++
++    {
++    const vector signed int sump02 = vec_mergel(sum0, sum2);
++    const vector signed int sump13 = vec_mergel(sum1, sum3);
++    const vector signed int sumA = vec_mergel(sump02, sump13);
++
++    const vector signed int sump46 = vec_mergel(sum4, sum6);
++    const vector signed int sump57 = vec_mergel(sum5, sum7);
++    const vector signed int sumB = vec_mergel(sump46, sump57);
++
++    const vector signed int sump8A = vec_mergel(sum8, zero);
++    const vector signed int sump9B = vec_mergel(sum9, zero);
++    const vector signed int sumC = vec_mergel(sump8A, sump9B);
++
++    const vector signed int tA = vec_sl(vec_nor(zero, sumA), vuint32_16);
++    const vector signed int tB = vec_sl(vec_nor(zero, sumB), vuint32_16);
++    const vector signed int tC = vec_sl(vec_nor(zero, sumC), vuint32_16);
++    const vector signed int t2A = vec_or(sumA, tA);
++    const vector signed int t2B = vec_or(sumB, tB);
++    const vector signed int t2C = vec_or(sumC, tC);
++    const vector signed int t3A = vec_and(vec_sra(t2A, vuint32_1),
++                                          vec_sl(t2A, vuint32_1));
++    const vector signed int t3B = vec_and(vec_sra(t2B, vuint32_1),
++                                          vec_sl(t2B, vuint32_1));
++    const vector signed int t3C = vec_and(vec_sra(t2C, vuint32_1),
++                                          vec_sl(t2C, vuint32_1));
++    const vector signed int yA = vec_and(t2A, t3A);
++    const vector signed int yB = vec_and(t2B, t3B);
++    const vector signed int yC = vec_and(t2C, t3C);
++
++    const vector unsigned char strangeperm1 = vec_lvsl(4, (unsigned char*)0);
++    const vector unsigned char strangeperm2 = vec_lvsl(8, (unsigned char*)0);
++    const vector signed int sumAd4 = vec_perm(yA, yB, strangeperm1);
++    const vector signed int sumAd8 = vec_perm(yA, yB, strangeperm2);
++    const vector signed int sumBd4 = vec_perm(yB, yC, strangeperm1);
++    const vector signed int sumBd8 = vec_perm(yB, yC, strangeperm2);
++    const vector signed int sumAp = vec_and(yA,
++                                            vec_and(sumAd4,sumAd8));
++    const vector signed int sumBp = vec_and(yB,
++                                            vec_and(sumBd4,sumBd8));
++    sumA2 = vec_or(sumAp,
++                   vec_sra(sumAp,
++                           vuint32_16));
++    sumB2  = vec_or(sumBp,
++                    vec_sra(sumBp,
++                            vuint32_16));
++    }
++    vec_st(sumA2, 0, S);
++    vec_st(sumB2, 16, S);
++    }
++
++    /* I'm not sure the following is actually faster
++       than straight, unvectorized C code :-( */
++
++#define F_INIT()                                       \
++    vector unsigned char tenRightM = tenRight;         \
++    vector unsigned char permA1M = permA1;             \
++    vector unsigned char permA2M = permA2;             \
++    vector unsigned char extractPermM = extractPerm
++
++#define F2(i, j, k, l)                                                  \
++    if (S[i] & (1 << (l+1))) {                                          \
++        const vector unsigned char a_A = vec_perm(src##i, src##j, permA1M); \
++        const vector unsigned char a_B = vec_perm(a_A, src##k, permA2M); \
++        const vector signed int a_sump =                                \
++            (vector signed int)vec_msum(a_B, magic, (vector unsigned int)zero);\
++        vector signed int F = vec_sr(vec_sums(a_sump, vsint32_8), vuint32_4); \
++        const vector signed int p =                                     \
++            (vector signed int)vec_perm(src##j, (vector unsigned char)zero, \
++                                        extractPermM);                  \
++        const vector signed int sum  = vec_add(p, vQP2);                \
++        const vector signed int diff = vec_sub(p, vQP2);                \
++        vector signed int newpm;                                        \
++        vector unsigned char newpm2, mask;                              \
++        F = vec_splat(F, 3);                                            \
++        if (vec_all_lt(sum, F))                                         \
++            newpm = sum;                                                \
++        else if (vec_all_gt(diff, F))                                   \
++            newpm = diff;                                               \
++        else newpm = F;                                                 \
++        newpm2 = vec_splat((vector unsigned char)newpm, 15);            \
++        mask = vec_add(identity, tenRightM);                            \
++        src##j = vec_perm(src##j, newpm2, mask);                        \
++    }                                                                   \
++    permA1M = vec_add(permA1M, permA1inc);                              \
++    permA2M = vec_add(permA2M, permA2inc);                              \
++    tenRightM = vec_sro(tenRightM, eightLeft);                          \
++    extractPermM = vec_add(extractPermM, extractPermInc)
++
++#define ITER(i, j, k) do {                      \
++    F_INIT();                                   \
++    F2(i, j, k, 0);                             \
++    F2(i, j, k, 1);                             \
++    F2(i, j, k, 2);                             \
++    F2(i, j, k, 3);                             \
++    F2(i, j, k, 4);                             \
++    F2(i, j, k, 5);                             \
++    F2(i, j, k, 6);                             \
++    F2(i, j, k, 7);                             \
++} while (0)
++
++    ITER(0, 1, 2);
++    ITER(1, 2, 3);
++    ITER(2, 3, 4);
++    ITER(3, 4, 5);
++    ITER(4, 5, 6);
++    ITER(5, 6, 7);
++    ITER(6, 7, 8);
++    ITER(7, 8, 9);
++
++#define STORE_LINE(i) do {                              \
++    const vector unsigned char permST =                 \
++        vec_lvsr(i * stride, srcCopy);                  \
++    const vector unsigned char maskST =                 \
++        vec_perm((vector unsigned char)zero,            \
++                 (vector unsigned char)neg1, permST);   \
++    src##i = vec_perm(src##i ,src##i, permST);          \
++    sA##i= vec_sel(sA##i, src##i, maskST);              \
++    sB##i= vec_sel(src##i, sB##i, maskST);              \
++    vec_st(sA##i, i * stride, srcCopy);                 \
++    vec_st(sB##i, i * stride + 16, srcCopy);            \
++} while (0)
++
++    STORE_LINE(1);
++    STORE_LINE(2);
++    STORE_LINE(3);
++    STORE_LINE(4);
++    STORE_LINE(5);
++    STORE_LINE(6);
++    STORE_LINE(7);
++    STORE_LINE(8);
++
++#undef STORE_LINE
++#undef ITER
++#undef F2
++}
++
++#define doHorizLowPass_altivec(a...) doHorizLowPass_C(a)
++#define doHorizDefFilter_altivec(a...) doHorizDefFilter_C(a)
++#define do_a_deblock_altivec(a...) do_a_deblock_C(a)
++
++static inline void tempNoiseReducer_altivec(uint8_t *src, int stride,
++                                            uint8_t *tempBlurred, uint32_t *tempBlurredPast, int *maxNoise)
++{
++    const vector signed char neg1 = vec_splat_s8(-1);
++    const vector unsigned char permHH = (const vector unsigned char){0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07,
++                                                                     0x18, 0x19, 0x1A, 0x1B, 0x1C, 0x1D, 0x1E, 0x1F};
++
++    const vector signed int zero = vec_splat_s32(0);
++    const vector signed short vsint16_1 = vec_splat_s16(1);
++    vector signed int v_dp = zero;
++    vector signed int v_sysdp = zero;
++    int d, sysd, i;
++
++#define LOAD_LINE(src, i)                                               \
++    register int j##src##i = i * stride;                                \
++    vector unsigned char perm##src##i = vec_lvsl(j##src##i, src);       \
++    const vector unsigned char v_##src##A1##i = vec_ld(j##src##i, src); \
++    const vector unsigned char v_##src##A2##i = vec_ld(j##src##i + 16, src); \
++    const vector unsigned char v_##src##A##i =                          \
++        vec_perm(v_##src##A1##i, v_##src##A2##i, perm##src##i);         \
++    vector signed short v_##src##Ass##i =                               \
++        (vector signed short)vec_mergeh((vector signed char)zero,       \
++                                        (vector signed char)v_##src##A##i)
++
++    LOAD_LINE(src, 0);
++    LOAD_LINE(src, 1);
++    LOAD_LINE(src, 2);
++    LOAD_LINE(src, 3);
++    LOAD_LINE(src, 4);
++    LOAD_LINE(src, 5);
++    LOAD_LINE(src, 6);
++    LOAD_LINE(src, 7);
++
++    LOAD_LINE(tempBlurred, 0);
++    LOAD_LINE(tempBlurred, 1);
++    LOAD_LINE(tempBlurred, 2);
++    LOAD_LINE(tempBlurred, 3);
++    LOAD_LINE(tempBlurred, 4);
++    LOAD_LINE(tempBlurred, 5);
++    LOAD_LINE(tempBlurred, 6);
++    LOAD_LINE(tempBlurred, 7);
++#undef LOAD_LINE
++
++#define ACCUMULATE_DIFFS(i) do {                                \
++        vector signed short v_d = vec_sub(v_tempBlurredAss##i,  \
++                                          v_srcAss##i);         \
++        v_dp = vec_msums(v_d, v_d, v_dp);                       \
++        v_sysdp = vec_msums(v_d, vsint16_1, v_sysdp);           \
++    } while (0)
++
++    ACCUMULATE_DIFFS(0);
++    ACCUMULATE_DIFFS(1);
++    ACCUMULATE_DIFFS(2);
++    ACCUMULATE_DIFFS(3);
++    ACCUMULATE_DIFFS(4);
++    ACCUMULATE_DIFFS(5);
++    ACCUMULATE_DIFFS(6);
++    ACCUMULATE_DIFFS(7);
++#undef ACCUMULATE_DIFFS
++
++    tempBlurredPast[127]= maxNoise[0];
++    tempBlurredPast[128]= maxNoise[1];
++    tempBlurredPast[129]= maxNoise[2];
++
++    v_dp = vec_sums(v_dp, zero);
++    v_sysdp = vec_sums(v_sysdp, zero);
++
++    v_dp = vec_splat(v_dp, 3);
++    v_sysdp = vec_splat(v_sysdp, 3);
++
++    vec_ste(v_dp, 0, &d);
++    vec_ste(v_sysdp, 0, &sysd);
++
++    i = d;
++    d = (4*d
++         +(*(tempBlurredPast-256))
++         +(*(tempBlurredPast-1))+ (*(tempBlurredPast+1))
++         +(*(tempBlurredPast+256))
++         +4)>>3;
++
++    *tempBlurredPast=i;
++
++    if (d > maxNoise[1]) {
++        if (d < maxNoise[2]) {
++#define OP(i) v_tempBlurredAss##i = vec_avg(v_tempBlurredAss##i, v_srcAss##i);
++
++            OP(0);
++            OP(1);
++            OP(2);
++            OP(3);
++            OP(4);
++            OP(5);
++            OP(6);
++            OP(7);
++#undef OP
++        } else {
++#define OP(i) v_tempBlurredAss##i = v_srcAss##i;
++
++            OP(0);
++            OP(1);
++            OP(2);
++            OP(3);
++            OP(4);
++            OP(5);
++            OP(6);
++            OP(7);
++#undef OP
++        }
++    } else {
++        if (d < maxNoise[0]) {
++            const vector signed short vsint16_7 = vec_splat_s16(7);
++            const vector signed short vsint16_4 = vec_splat_s16(4);
++            const vector unsigned short vuint16_3 = vec_splat_u16(3);
++
++#define OP(i) do {                                                      \
++            const vector signed short v_temp =                          \
++                vec_mladd(v_tempBlurredAss##i, vsint16_7, v_srcAss##i); \
++            const vector signed short v_temp2 = vec_add(v_temp, vsint16_4); \
++            v_tempBlurredAss##i = vec_sr(v_temp2, vuint16_3);           \
++        } while (0)
++
++            OP(0);
++            OP(1);
++            OP(2);
++            OP(3);
++            OP(4);
++            OP(5);
++            OP(6);
++            OP(7);
++#undef OP
++        } else {
++            const vector signed short vsint16_3 = vec_splat_s16(3);
++            const vector signed short vsint16_2 = vec_splat_s16(2);
++
++#define OP(i) do {                                              \
++            const vector signed short v_temp =                  \
++                vec_mladd(v_tempBlurredAss##i, vsint16_3, v_srcAss##i); \
++            const vector signed short v_temp2 = vec_add(v_temp, vsint16_2); \
++            v_tempBlurredAss##i =                                       \
++                vec_sr(v_temp2, (vector unsigned short)vsint16_2);      \
++        } while (0)
++
++            OP(0);
++            OP(1);
++            OP(2);
++            OP(3);
++            OP(4);
++            OP(5);
++            OP(6);
++            OP(7);
++#undef OP
++        }
++    }
++
++#define PACK_AND_STORE(src, i) do {                                      \
++    const vector unsigned char perms = vec_lvsr(i * stride, src);        \
++    const vector unsigned char vf =                                      \
++        vec_packsu(v_tempBlurredAss##1, (vector signed short)zero);     \
++    const vector unsigned char vg = vec_perm(vf, v_##src##A##i, permHH); \
++    const vector unsigned char mask =                                    \
++        vec_perm((vector unsigned char)zero, (vector unsigned char)neg1, perms); \
++    const vector unsigned char vg2 = vec_perm(vg, vg, perms);            \
++    const vector unsigned char svA = vec_sel(v_##src##A1##i, vg2, mask); \
++    const vector unsigned char svB = vec_sel(vg2, v_##src##A2##i, mask); \
++    vec_st(svA, i * stride, src);                                        \
++    vec_st(svB, i * stride + 16, src);                                   \
++} while (0)
++
++    PACK_AND_STORE(src, 0);
++    PACK_AND_STORE(src, 1);
++    PACK_AND_STORE(src, 2);
++    PACK_AND_STORE(src, 3);
++    PACK_AND_STORE(src, 4);
++    PACK_AND_STORE(src, 5);
++    PACK_AND_STORE(src, 6);
++    PACK_AND_STORE(src, 7);
++    PACK_AND_STORE(tempBlurred, 0);
++    PACK_AND_STORE(tempBlurred, 1);
++    PACK_AND_STORE(tempBlurred, 2);
++    PACK_AND_STORE(tempBlurred, 3);
++    PACK_AND_STORE(tempBlurred, 4);
++    PACK_AND_STORE(tempBlurred, 5);
++    PACK_AND_STORE(tempBlurred, 6);
++    PACK_AND_STORE(tempBlurred, 7);
++#undef PACK_AND_STORE
++}
++
++static inline void transpose_16x8_char_toPackedAlign_altivec(unsigned char* dst, unsigned char* src, int stride) {
++    const vector unsigned char zero = vec_splat_u8(0);
++
++#define LOAD_DOUBLE_LINE(i, j)                                          \
++    vector unsigned char perm1##i = vec_lvsl(i * stride, src);          \
++    vector unsigned char perm2##i = vec_lvsl(j * stride, src);          \
++    vector unsigned char srcA##i = vec_ld(i * stride, src);             \
++    vector unsigned char srcB##i = vec_ld(i * stride + 16, src);        \
++    vector unsigned char srcC##i = vec_ld(j * stride, src);             \
++    vector unsigned char srcD##i = vec_ld(j * stride+ 16, src);         \
++    vector unsigned char src##i = vec_perm(srcA##i, srcB##i, perm1##i); \
++    vector unsigned char src##j = vec_perm(srcC##i, srcD##i, perm2##i)
++
++    LOAD_DOUBLE_LINE(0, 1);
++    LOAD_DOUBLE_LINE(2, 3);
++    LOAD_DOUBLE_LINE(4, 5);
++    LOAD_DOUBLE_LINE(6, 7);
++#undef LOAD_DOUBLE_LINE
++
++    vector unsigned char tempA = vec_mergeh(src0, zero);
++    vector unsigned char tempB = vec_mergel(src0, zero);
++    vector unsigned char tempC = vec_mergeh(src1, zero);
++    vector unsigned char tempD = vec_mergel(src1, zero);
++    vector unsigned char tempE = vec_mergeh(src2, zero);
++    vector unsigned char tempF = vec_mergel(src2, zero);
++    vector unsigned char tempG = vec_mergeh(src3, zero);
++    vector unsigned char tempH = vec_mergel(src3, zero);
++    vector unsigned char tempI = vec_mergeh(src4, zero);
++    vector unsigned char tempJ = vec_mergel(src4, zero);
++    vector unsigned char tempK = vec_mergeh(src5, zero);
++    vector unsigned char tempL = vec_mergel(src5, zero);
++    vector unsigned char tempM = vec_mergeh(src6, zero);
++    vector unsigned char tempN = vec_mergel(src6, zero);
++    vector unsigned char tempO = vec_mergeh(src7, zero);
++    vector unsigned char tempP = vec_mergel(src7, zero);
++
++    vector unsigned char temp0  = vec_mergeh(tempA, tempI);
++    vector unsigned char temp1  = vec_mergel(tempA, tempI);
++    vector unsigned char temp2  = vec_mergeh(tempB, tempJ);
++    vector unsigned char temp3  = vec_mergel(tempB, tempJ);
++    vector unsigned char temp4  = vec_mergeh(tempC, tempK);
++    vector unsigned char temp5  = vec_mergel(tempC, tempK);
++    vector unsigned char temp6  = vec_mergeh(tempD, tempL);
++    vector unsigned char temp7  = vec_mergel(tempD, tempL);
++    vector unsigned char temp8  = vec_mergeh(tempE, tempM);
++    vector unsigned char temp9  = vec_mergel(tempE, tempM);
++    vector unsigned char temp10 = vec_mergeh(tempF, tempN);
++    vector unsigned char temp11 = vec_mergel(tempF, tempN);
++    vector unsigned char temp12 = vec_mergeh(tempG, tempO);
++    vector unsigned char temp13 = vec_mergel(tempG, tempO);
++    vector unsigned char temp14 = vec_mergeh(tempH, tempP);
++    vector unsigned char temp15 = vec_mergel(tempH, tempP);
++
++    tempA = vec_mergeh(temp0, temp8);
++    tempB = vec_mergel(temp0, temp8);
++    tempC = vec_mergeh(temp1, temp9);
++    tempD = vec_mergel(temp1, temp9);
++    tempE = vec_mergeh(temp2, temp10);
++    tempF = vec_mergel(temp2, temp10);
++    tempG = vec_mergeh(temp3, temp11);
++    tempH = vec_mergel(temp3, temp11);
++    tempI = vec_mergeh(temp4, temp12);
++    tempJ = vec_mergel(temp4, temp12);
++    tempK = vec_mergeh(temp5, temp13);
++    tempL = vec_mergel(temp5, temp13);
++    tempM = vec_mergeh(temp6, temp14);
++    tempN = vec_mergel(temp6, temp14);
++    tempO = vec_mergeh(temp7, temp15);
++    tempP = vec_mergel(temp7, temp15);
++
++    temp0  = vec_mergeh(tempA, tempI);
++    temp1  = vec_mergel(tempA, tempI);
++    temp2  = vec_mergeh(tempB, tempJ);
++    temp3  = vec_mergel(tempB, tempJ);
++    temp4  = vec_mergeh(tempC, tempK);
++    temp5  = vec_mergel(tempC, tempK);
++    temp6  = vec_mergeh(tempD, tempL);
++    temp7  = vec_mergel(tempD, tempL);
++    temp8  = vec_mergeh(tempE, tempM);
++    temp9  = vec_mergel(tempE, tempM);
++    temp10 = vec_mergeh(tempF, tempN);
++    temp11 = vec_mergel(tempF, tempN);
++    temp12 = vec_mergeh(tempG, tempO);
++    temp13 = vec_mergel(tempG, tempO);
++    temp14 = vec_mergeh(tempH, tempP);
++    temp15 = vec_mergel(tempH, tempP);
++
++    vec_st(temp0,    0, dst);
++    vec_st(temp1,   16, dst);
++    vec_st(temp2,   32, dst);
++    vec_st(temp3,   48, dst);
++    vec_st(temp4,   64, dst);
++    vec_st(temp5,   80, dst);
++    vec_st(temp6,   96, dst);
++    vec_st(temp7,  112, dst);
++    vec_st(temp8,  128, dst);
++    vec_st(temp9,  144, dst);
++    vec_st(temp10, 160, dst);
++    vec_st(temp11, 176, dst);
++    vec_st(temp12, 192, dst);
++    vec_st(temp13, 208, dst);
++    vec_st(temp14, 224, dst);
++    vec_st(temp15, 240, dst);
++}
++
++static inline void transpose_8x16_char_fromPackedAlign_altivec(unsigned char* dst, unsigned char* src, int stride) {
++    const vector unsigned char zero = vec_splat_u8(0);
++    const vector signed   char neg1 = vec_splat_s8(-1);
++
++#define LOAD_DOUBLE_LINE(i, j)                                  \
++    vector unsigned char src##i = vec_ld(i * 16, src);            \
++    vector unsigned char src##j = vec_ld(j * 16, src)
++
++    LOAD_DOUBLE_LINE(0, 1);
++    LOAD_DOUBLE_LINE(2, 3);
++    LOAD_DOUBLE_LINE(4, 5);
++    LOAD_DOUBLE_LINE(6, 7);
++    LOAD_DOUBLE_LINE(8, 9);
++    LOAD_DOUBLE_LINE(10, 11);
++    LOAD_DOUBLE_LINE(12, 13);
++    LOAD_DOUBLE_LINE(14, 15);
++#undef LOAD_DOUBLE_LINE
++
++    vector unsigned char tempA = vec_mergeh(src0, src8);
++    vector unsigned char tempB;
++    vector unsigned char tempC = vec_mergeh(src1, src9);
++    vector unsigned char tempD;
++    vector unsigned char tempE = vec_mergeh(src2, src10);
++    vector unsigned char tempG = vec_mergeh(src3, src11);
++    vector unsigned char tempI = vec_mergeh(src4, src12);
++    vector unsigned char tempJ;
++    vector unsigned char tempK = vec_mergeh(src5, src13);
++    vector unsigned char tempL;
++    vector unsigned char tempM = vec_mergeh(src6, src14);
++    vector unsigned char tempO = vec_mergeh(src7, src15);
++
++    vector unsigned char temp0 = vec_mergeh(tempA, tempI);
++    vector unsigned char temp1 = vec_mergel(tempA, tempI);
++    vector unsigned char temp2;
++    vector unsigned char temp3;
++    vector unsigned char temp4 = vec_mergeh(tempC, tempK);
++    vector unsigned char temp5 = vec_mergel(tempC, tempK);
++    vector unsigned char temp6;
++    vector unsigned char temp7;
++    vector unsigned char temp8 = vec_mergeh(tempE, tempM);
++    vector unsigned char temp9 = vec_mergel(tempE, tempM);
++    vector unsigned char temp12 = vec_mergeh(tempG, tempO);
++    vector unsigned char temp13 = vec_mergel(tempG, tempO);
++
++    tempA = vec_mergeh(temp0, temp8);
++    tempB = vec_mergel(temp0, temp8);
++    tempC = vec_mergeh(temp1, temp9);
++    tempD = vec_mergel(temp1, temp9);
++    tempI = vec_mergeh(temp4, temp12);
++    tempJ = vec_mergel(temp4, temp12);
++    tempK = vec_mergeh(temp5, temp13);
++    tempL = vec_mergel(temp5, temp13);
++
++    temp0 = vec_mergeh(tempA, tempI);
++    temp1 = vec_mergel(tempA, tempI);
++    temp2 = vec_mergeh(tempB, tempJ);
++    temp3 = vec_mergel(tempB, tempJ);
++    temp4 = vec_mergeh(tempC, tempK);
++    temp5 = vec_mergel(tempC, tempK);
++    temp6 = vec_mergeh(tempD, tempL);
++    temp7 = vec_mergel(tempD, tempL);
++
++
++#define STORE_DOUBLE_LINE(i, j) do {                                    \
++    vector unsigned char dstAi = vec_ld(i * stride, dst);               \
++    vector unsigned char dstBi = vec_ld(i * stride + 16, dst);          \
++    vector unsigned char dstAj = vec_ld(j * stride, dst);               \
++    vector unsigned char dstBj = vec_ld(j * stride+ 16, dst);           \
++    vector unsigned char aligni = vec_lvsr(i * stride, dst);            \
++    vector unsigned char alignj = vec_lvsr(j * stride, dst);            \
++    vector unsigned char maski =                                        \
++        vec_perm(zero, (vector unsigned char)neg1, aligni);             \
++    vector unsigned char maskj =                                        \
++        vec_perm(zero, (vector unsigned char)neg1, alignj);             \
++    vector unsigned char dstRi = vec_perm(temp##i, temp##i, aligni);    \
++    vector unsigned char dstRj = vec_perm(temp##j, temp##j, alignj);    \
++    vector unsigned char dstAFi = vec_sel(dstAi, dstRi, maski);         \
++    vector unsigned char dstBFi = vec_sel(dstRi, dstBi, maski);         \
++    vector unsigned char dstAFj = vec_sel(dstAj, dstRj, maskj);         \
++    vector unsigned char dstBFj = vec_sel(dstRj, dstBj, maskj);         \
++    vec_st(dstAFi, i * stride, dst);                                    \
++    vec_st(dstBFi, i * stride + 16, dst);                               \
++    vec_st(dstAFj, j * stride, dst);                                    \
++    vec_st(dstBFj, j * stride + 16, dst);                               \
++} while (0)
++
++    STORE_DOUBLE_LINE(0,1);
++    STORE_DOUBLE_LINE(2,3);
++    STORE_DOUBLE_LINE(4,5);
++    STORE_DOUBLE_LINE(6,7);
++}
+diff --git a/libpostproc/postprocess_internal.h b/libpostproc/postprocess_internal.h
+new file mode 100644
+index 0000000000000..5d1aee362ea60
+--- /dev/null
++++ b/libpostproc/postprocess_internal.h
+@@ -0,0 +1,185 @@
++/*
++ * Copyright (C) 2001-2002 Michael Niedermayer (michaelni@gmx.at)
++ *
++ * This file is part of FFmpeg.
++ *
++ * FFmpeg is free software; you can redistribute it and/or modify
++ * it under the terms of the GNU General Public License as published by
++ * the Free Software Foundation; either version 2 of the License, or
++ * (at your option) any later version.
++ *
++ * FFmpeg is distributed in the hope that it will be useful,
++ * but WITHOUT ANY WARRANTY; without even the implied warranty of
++ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
++ * GNU General Public License for more details.
++ *
++ * You should have received a copy of the GNU General Public License
++ * along with FFmpeg; if not, write to the Free Software
++ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
++ */
++
++/**
++ * @file
++ * internal API header.
++ */
++
++#ifndef POSTPROC_POSTPROCESS_INTERNAL_H
++#define POSTPROC_POSTPROCESS_INTERNAL_H
++
++#include <string.h>
++#include "libavutil/avutil.h"
++#include "libavutil/intmath.h"
++#include "libavutil/log.h"
++#include "libavutil/mem_internal.h"
++#include "postprocess.h"
++
++#define V_DEBLOCK       0x01
++#define H_DEBLOCK       0x02
++#define DERING          0x04
++#define LEVEL_FIX       0x08 ///< Brightness & Contrast
++
++#define LUM_V_DEBLOCK   V_DEBLOCK               //   1
++#define LUM_H_DEBLOCK   H_DEBLOCK               //   2
++#define CHROM_V_DEBLOCK (V_DEBLOCK<<4)          //  16
++#define CHROM_H_DEBLOCK (H_DEBLOCK<<4)          //  32
++#define LUM_DERING      DERING                  //   4
++#define CHROM_DERING    (DERING<<4)             //  64
++#define LUM_LEVEL_FIX   LEVEL_FIX               //   8
++#define CHROM_LEVEL_FIX (LEVEL_FIX<<4)          // 128 (not implemented yet)
++
++// Experimental vertical filters
++#define V_X1_FILTER     0x0200                  // 512
++#define V_A_DEBLOCK     0x0400
++
++// Experimental horizontal filters
++#define H_X1_FILTER     0x2000                  // 8192
++#define H_A_DEBLOCK     0x4000
++
++/// select between full y range (255-0) or standard one (234-16)
++#define FULL_Y_RANGE    0x8000                  // 32768
++
++//Deinterlacing Filters
++#define LINEAR_IPOL_DEINT_FILTER        0x10000 // 65536
++#define LINEAR_BLEND_DEINT_FILTER       0x20000 // 131072
++#define CUBIC_BLEND_DEINT_FILTER        0x8000  // (not implemented yet)
++#define CUBIC_IPOL_DEINT_FILTER         0x40000 // 262144
++#define MEDIAN_DEINT_FILTER             0x80000 // 524288
++#define FFMPEG_DEINT_FILTER             0x400000
++#define LOWPASS5_DEINT_FILTER           0x800000
++
++#define TEMP_NOISE_FILTER               0x100000
++#define FORCE_QUANT                     0x200000
++#define BITEXACT                        0x1000000
++#define VISUALIZE                       0x2000000
++
++//use if you want a faster postprocessing code
++//cannot differentiate between chroma & luma filters (both on or both off)
++//obviously the -pp option on the command line has no effect except turning the here selected
++//filters on
++//#define COMPILE_TIME_MODE 0x77
++
++/**
++ * Postprocessing filter.
++ */
++struct PPFilter{
++    const char *shortName;
++    const char *longName;
++    int chromDefault;       ///< is chrominance filtering on by default if this filter is manually activated
++    int minLumQuality;      ///< minimum quality to turn luminance filtering on
++    int minChromQuality;    ///< minimum quality to turn chrominance filtering on
++    int mask;               ///< Bitmask to turn this filter on
++};
++
++/**
++ * Postprocessing mode.
++ */
++typedef struct PPMode{
++    int lumMode;                    ///< activates filters for luminance
++    int chromMode;                  ///< activates filters for chrominance
++    int error;                      ///< non zero on error
++
++    int minAllowedY;                ///< for brightness correction
++    int maxAllowedY;                ///< for brightness correction
++    AVRational maxClippedThreshold; ///< amount of "black" you are willing to lose to get a brightness-corrected picture
++
++    int maxTmpNoise[3];             ///< for Temporal Noise Reducing filter (Maximal sum of abs differences)
++
++    int baseDcDiff;
++    int flatnessThreshold;
++
++    int forcedQuant;                ///< quantizer if FORCE_QUANT is used
++} PPMode;
++
++/**
++ * postprocess context.
++ */
++typedef struct PPContext{
++    /**
++     * info on struct for av_log
++     */
++    const AVClass *av_class;
++
++    uint8_t *tempBlocks; ///<used for the horizontal code
++
++    /**
++     * luma histogram.
++     * we need 64bit here otherwise we'll going to have a problem
++     * after watching a black picture for 5 hours
++     */
++    uint64_t *yHistogram;
++
++    DECLARE_ALIGNED(8, uint64_t, packedYOffset);
++    DECLARE_ALIGNED(8, uint64_t, packedYScale);
++
++    /** Temporal noise reducing buffers */
++    uint8_t *tempBlurred[3];
++    int32_t *tempBlurredPast[3];
++
++    /** Temporary buffers for handling the last row(s) */
++    uint8_t *tempDst;
++    uint8_t *tempSrc;
++
++    uint8_t *deintTemp;
++
++    DECLARE_ALIGNED(8, uint64_t, pQPb);
++    DECLARE_ALIGNED(8, uint64_t, pQPb2);
++
++    DECLARE_ALIGNED(32, uint64_t, pQPb_block)[4];
++    DECLARE_ALIGNED(32, uint64_t, pQPb2_block)[4];
++
++    DECLARE_ALIGNED(32, uint64_t, mmxDcOffset)[64];
++    DECLARE_ALIGNED(32, uint64_t, mmxDcThreshold)[64];
++
++    int8_t *stdQPTable;       ///< used to fix MPEG2 style qscale
++    int8_t *nonBQPTable;
++    int8_t *forcedQPTable;
++
++    int QP;
++    int nonBQP;
++
++    DECLARE_ALIGNED(32, int, QP_block)[4];
++    DECLARE_ALIGNED(32, int, nonBQP_block)[4];
++
++    int frameNum;
++
++    int cpuCaps;
++
++    int qpStride; ///<size of qp buffers (needed to realloc them if needed)
++    int stride;   ///<size of some buffers (needed to realloc them if needed)
++
++    int hChromaSubSample;
++    int vChromaSubSample;
++
++    PPMode ppMode;
++} PPContext;
++
++
++static inline void linecpy(void *dest, const void *src, int lines, int stride) {
++    if (stride > 0) {
++        memcpy(dest, src, lines*stride);
++    } else {
++        memcpy((uint8_t*)dest+(lines-1)*stride, (const uint8_t*)src+(lines-1)*stride, -lines*stride);
++    }
++}
++
++#endif /* POSTPROC_POSTPROCESS_INTERNAL_H */
+diff --git a/libpostproc/postprocess_template.c b/libpostproc/postprocess_template.c
+new file mode 100644
+index 0000000000000..3dfe701b5dce5
+--- /dev/null
++++ b/libpostproc/postprocess_template.c
+@@ -0,0 +1,3293 @@
++/*
++ * Copyright (C) 2001-2002 Michael Niedermayer (michaelni@gmx.at)
++ *
++ * This file is part of FFmpeg.
++ *
++ * FFmpeg is free software; you can redistribute it and/or modify
++ * it under the terms of the GNU General Public License as published by
++ * the Free Software Foundation; either version 2 of the License, or
++ * (at your option) any later version.
++ *
++ * FFmpeg is distributed in the hope that it will be useful,
++ * but WITHOUT ANY WARRANTY; without even the implied warranty of
++ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
++ * GNU General Public License for more details.
++ *
++ * You should have received a copy of the GNU General Public License
++ * along with FFmpeg; if not, write to the Free Software
++ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
++ */
++
++/**
++ * @file
++ * mmx/mmx2/sse2 postprocess code.
++ */
++#include "config.h"
++
++#include "libavutil/mem_internal.h"
++#if ARCH_X86
++#include "libavutil/x86/asm.h"
++#endif
++
++/* A single TEMPLATE_PP_* should be defined (to 1) when this template is
++ * included. The following macros will define its dependencies to 1 as well
++ * (like MMX2 depending on MMX), and will define to 0 all the others. Every
++ * TEMPLATE_PP_* need to be undef at the end. */
++
++#ifdef TEMPLATE_PP_C
++#   define RENAME(a) a ## _C
++#else
++#   define TEMPLATE_PP_C 0
++#endif
++
++#ifdef TEMPLATE_PP_ALTIVEC
++#   define RENAME(a) a ## _altivec
++#else
++#   define TEMPLATE_PP_ALTIVEC 0
++#endif
++
++#ifdef TEMPLATE_PP_MMX
++#   define RENAME(a) a ## _MMX
++#else
++#   define TEMPLATE_PP_MMX 0
++#endif
++
++#ifdef TEMPLATE_PP_MMXEXT
++#   undef  TEMPLATE_PP_MMX
++#   define TEMPLATE_PP_MMX 1
++#   define RENAME(a) a ## _MMX2
++#else
++#   define TEMPLATE_PP_MMXEXT 0
++#endif
++
++#ifdef TEMPLATE_PP_SSE2
++#   undef  TEMPLATE_PP_MMX
++#   define TEMPLATE_PP_MMX 1
++#   undef  TEMPLATE_PP_MMXEXT
++#   define TEMPLATE_PP_MMXEXT 1
++#   define RENAME(a) a ## _SSE2
++#else
++#   define TEMPLATE_PP_SSE2 0
++#endif
++
++#undef REAL_PAVGB
++#undef PAVGB
++#undef PMINUB
++#undef PMAXUB
++
++#if   TEMPLATE_PP_MMXEXT
++#define REAL_PAVGB(a,b) "pavgb " #a ", " #b " \n\t"
++#endif
++#define PAVGB(a,b)  REAL_PAVGB(a,b)
++
++#if   TEMPLATE_PP_MMXEXT
++#define PMINUB(a,b,t) "pminub " #a ", " #b " \n\t"
++#endif
++
++#if   TEMPLATE_PP_MMXEXT
++#define PMAXUB(a,b) "pmaxub " #a ", " #b " \n\t"
++#endif
++
++//FIXME? |255-0| = 1 (should not be a problem ...)
++#if TEMPLATE_PP_MMXEXT
++/**
++ * Check if the middle 8x8 Block in the given 8x16 block is flat
++ */
++static inline int RENAME(vertClassify)(const uint8_t src[], int stride, PPContext *c){
++    int numEq= 0, dcOk;
++    src+= stride*4; // src points to begin of the 8x8 Block
++    __asm__ volatile(
++        "movq %0, %%mm7                         \n\t"
++        "movq %1, %%mm6                         \n\t"
++        : : "m" (c->mmxDcOffset[c->nonBQP]),  "m" (c->mmxDcThreshold[c->nonBQP])
++        );
++
++    __asm__ volatile(
++        "lea (%2, %3), %%"FF_REG_a"             \n\t"
++//      0       1       2       3       4       5       6       7       8       9
++//      %1      eax     eax+%2  eax+2%2 %1+4%2  ecx     ecx+%2  ecx+2%2 %1+8%2  ecx+4%2
++
++        "movq (%2), %%mm0                       \n\t"
++        "movq (%%"FF_REG_a"), %%mm1             \n\t"
++        "movq %%mm0, %%mm3                      \n\t"
++        "movq %%mm0, %%mm4                      \n\t"
++        PMAXUB(%%mm1, %%mm4)
++        PMINUB(%%mm1, %%mm3, %%mm5)
++        "psubb %%mm1, %%mm0                     \n\t" // mm0 = difference
++        "paddb %%mm7, %%mm0                     \n\t"
++        "pcmpgtb %%mm6, %%mm0                   \n\t"
++
++        "movq (%%"FF_REG_a",%3), %%mm2          \n\t"
++        PMAXUB(%%mm2, %%mm4)
++        PMINUB(%%mm2, %%mm3, %%mm5)
++        "psubb %%mm2, %%mm1                     \n\t"
++        "paddb %%mm7, %%mm1                     \n\t"
++        "pcmpgtb %%mm6, %%mm1                   \n\t"
++        "paddb %%mm1, %%mm0                     \n\t"
++
++        "movq (%%"FF_REG_a", %3, 2), %%mm1      \n\t"
++        PMAXUB(%%mm1, %%mm4)
++        PMINUB(%%mm1, %%mm3, %%mm5)
++        "psubb %%mm1, %%mm2                     \n\t"
++        "paddb %%mm7, %%mm2                     \n\t"
++        "pcmpgtb %%mm6, %%mm2                   \n\t"
++        "paddb %%mm2, %%mm0                     \n\t"
++
++        "lea (%%"FF_REG_a", %3, 4), %%"FF_REG_a"\n\t"
++
++        "movq (%2, %3, 4), %%mm2                \n\t"
++        PMAXUB(%%mm2, %%mm4)
++        PMINUB(%%mm2, %%mm3, %%mm5)
++        "psubb %%mm2, %%mm1                     \n\t"
++        "paddb %%mm7, %%mm1                     \n\t"
++        "pcmpgtb %%mm6, %%mm1                   \n\t"
++        "paddb %%mm1, %%mm0                     \n\t"
++
++        "movq (%%"FF_REG_a"), %%mm1             \n\t"
++        PMAXUB(%%mm1, %%mm4)
++        PMINUB(%%mm1, %%mm3, %%mm5)
++        "psubb %%mm1, %%mm2                     \n\t"
++        "paddb %%mm7, %%mm2                     \n\t"
++        "pcmpgtb %%mm6, %%mm2                   \n\t"
++        "paddb %%mm2, %%mm0                     \n\t"
++
++        "movq (%%"FF_REG_a", %3), %%mm2         \n\t"
++        PMAXUB(%%mm2, %%mm4)
++        PMINUB(%%mm2, %%mm3, %%mm5)
++        "psubb %%mm2, %%mm1                     \n\t"
++        "paddb %%mm7, %%mm1                     \n\t"
++        "pcmpgtb %%mm6, %%mm1                   \n\t"
++        "paddb %%mm1, %%mm0                     \n\t"
++
++        "movq (%%"FF_REG_a", %3, 2), %%mm1      \n\t"
++        PMAXUB(%%mm1, %%mm4)
++        PMINUB(%%mm1, %%mm3, %%mm5)
++        "psubb %%mm1, %%mm2                     \n\t"
++        "paddb %%mm7, %%mm2                     \n\t"
++        "pcmpgtb %%mm6, %%mm2                   \n\t"
++        "paddb %%mm2, %%mm0                     \n\t"
++        "psubusb %%mm3, %%mm4                   \n\t"
++
++        "                                       \n\t"
++        "pxor %%mm7, %%mm7                      \n\t"
++        "psadbw %%mm7, %%mm0                    \n\t"
++        "movq %4, %%mm7                         \n\t" // QP,..., QP
++        "paddusb %%mm7, %%mm7                   \n\t" // 2QP ... 2QP
++        "psubusb %%mm7, %%mm4                   \n\t" // Diff <= 2QP -> 0
++        "packssdw %%mm4, %%mm4                  \n\t"
++        "movd %%mm0, %0                         \n\t"
++        "movd %%mm4, %1                         \n\t"
++
++        : "=r" (numEq), "=r" (dcOk)
++        : "r" (src), "r" ((x86_reg)stride), "m" (c->pQPb)
++        : "%"FF_REG_a
++        );
++
++    numEq= (-numEq) &0xFF;
++    if(numEq > c->ppMode.flatnessThreshold){
++        if(dcOk) return 0;
++        else     return 1;
++    }else{
++        return 2;
++    }
++}
++#endif //TEMPLATE_PP_MMXEXT
++
++/**
++ * Do a vertical low pass filter on the 8x16 block (only write to the 8x8 block in the middle)
++ * using the 9-Tap Filter (1,1,2,2,4,2,2,1,1)/16
++ */
++#if !TEMPLATE_PP_ALTIVEC
++static inline void RENAME(doVertLowPass)(uint8_t *src, int stride, PPContext *c)
++{
++#if TEMPLATE_PP_MMXEXT
++    src+= stride*3;
++    __asm__ volatile(        //"movv %0 %1 %2\n\t"
++        "movq %2, %%mm0                         \n\t"  // QP,..., QP
++        "pxor %%mm4, %%mm4                      \n\t"
++
++        "movq (%0), %%mm6                       \n\t"
++        "movq (%0, %1), %%mm5                   \n\t"
++        "movq %%mm5, %%mm1                      \n\t"
++        "movq %%mm6, %%mm2                      \n\t"
++        "psubusb %%mm6, %%mm5                   \n\t"
++        "psubusb %%mm1, %%mm2                   \n\t"
++        "por %%mm5, %%mm2                       \n\t" // ABS Diff of lines
++        "psubusb %%mm0, %%mm2                   \n\t" // diff <= QP -> 0
++        "pcmpeqb %%mm4, %%mm2                   \n\t" // diff <= QP -> FF
++
++        "pand %%mm2, %%mm6                      \n\t"
++        "pandn %%mm1, %%mm2                     \n\t"
++        "por %%mm2, %%mm6                       \n\t"// First Line to Filter
++
++        "movq (%0, %1, 8), %%mm5                \n\t"
++        "lea (%0, %1, 4), %%"FF_REG_a"          \n\t"
++        "lea (%0, %1, 8), %%"FF_REG_c"          \n\t"
++        "sub %1, %%"FF_REG_c"                   \n\t"
++        "add %1, %0                             \n\t" // %0 points to line 1 not 0
++        "movq (%0, %1, 8), %%mm7                \n\t"
++        "movq %%mm5, %%mm1                      \n\t"
++        "movq %%mm7, %%mm2                      \n\t"
++        "psubusb %%mm7, %%mm5                   \n\t"
++        "psubusb %%mm1, %%mm2                   \n\t"
++        "por %%mm5, %%mm2                       \n\t" // ABS Diff of lines
++        "psubusb %%mm0, %%mm2                   \n\t" // diff <= QP -> 0
++        "pcmpeqb %%mm4, %%mm2                   \n\t" // diff <= QP -> FF
++
++        "pand %%mm2, %%mm7                      \n\t"
++        "pandn %%mm1, %%mm2                     \n\t"
++        "por %%mm2, %%mm7                       \n\t" // First Line to Filter
++
++
++        //      1       2       3       4       5       6       7       8
++        //      %0      %0+%1   %0+2%1  eax     %0+4%1  eax+2%1 ecx     eax+4%1
++        // 6 4 2 2 1 1
++        // 6 4 4 2
++        // 6 8 2
++
++        "movq (%0, %1), %%mm0                   \n\t" //  1
++        "movq %%mm0, %%mm1                      \n\t" //  1
++        PAVGB(%%mm6, %%mm0)                           //1 1        /2
++        PAVGB(%%mm6, %%mm0)                           //3 1        /4
++
++        "movq (%0, %1, 4), %%mm2                \n\t" //     1
++        "movq %%mm2, %%mm5                      \n\t" //     1
++        PAVGB((%%FF_REGa), %%mm2)                     //    11        /2
++        PAVGB((%0, %1, 2), %%mm2)                     //   211        /4
++        "movq %%mm2, %%mm3                      \n\t" //   211        /4
++        "movq (%0), %%mm4                       \n\t" // 1
++        PAVGB(%%mm4, %%mm3)                           // 4 211        /8
++        PAVGB(%%mm0, %%mm3)                           //642211        /16
++        "movq %%mm3, (%0)                       \n\t" // X
++        // mm1=2 mm2=3(211) mm4=1 mm5=5 mm6=0 mm7=9
++        "movq %%mm1, %%mm0                      \n\t" //  1
++        PAVGB(%%mm6, %%mm0)                           //1 1        /2
++        "movq %%mm4, %%mm3                      \n\t" // 1
++        PAVGB((%0,%1,2), %%mm3)                       // 1 1        /2
++        PAVGB((%%FF_REGa,%1,2), %%mm5)                //     11        /2
++        PAVGB((%%FF_REGa), %%mm5)                     //    211 /4
++        PAVGB(%%mm5, %%mm3)                           // 2 2211 /8
++        PAVGB(%%mm0, %%mm3)                           //4242211 /16
++        "movq %%mm3, (%0,%1)                    \n\t" //  X
++        // mm1=2 mm2=3(211) mm4=1 mm5=4(211) mm6=0 mm7=9
++        PAVGB(%%mm4, %%mm6)                                   //11        /2
++        "movq (%%"FF_REG_c"), %%mm0             \n\t" //       1
++        PAVGB((%%FF_REGa, %1, 2), %%mm0)              //      11/2
++        "movq %%mm0, %%mm3                      \n\t" //      11/2
++        PAVGB(%%mm1, %%mm0)                           //  2   11/4
++        PAVGB(%%mm6, %%mm0)                           //222   11/8
++        PAVGB(%%mm2, %%mm0)                           //22242211/16
++        "movq (%0, %1, 2), %%mm2                \n\t" //   1
++        "movq %%mm0, (%0, %1, 2)                \n\t" //   X
++        // mm1=2 mm2=3 mm3=6(11) mm4=1 mm5=4(211) mm6=0(11) mm7=9
++        "movq (%%"FF_REG_a", %1, 4), %%mm0      \n\t" //        1
++        PAVGB((%%FF_REGc), %%mm0)                     //       11        /2
++        PAVGB(%%mm0, %%mm6)                           //11     11        /4
++        PAVGB(%%mm1, %%mm4)                           // 11                /2
++        PAVGB(%%mm2, %%mm1)                           //  11                /2
++        PAVGB(%%mm1, %%mm6)                           //1122   11        /8
++        PAVGB(%%mm5, %%mm6)                           //112242211        /16
++        "movq (%%"FF_REG_a"), %%mm5             \n\t" //    1
++        "movq %%mm6, (%%"FF_REG_a")             \n\t" //    X
++        // mm0=7(11) mm1=2(11) mm2=3 mm3=6(11) mm4=1(11) mm5=4 mm7=9
++        "movq (%%"FF_REG_a", %1, 4), %%mm6      \n\t" //        1
++        PAVGB(%%mm7, %%mm6)                           //        11        /2
++        PAVGB(%%mm4, %%mm6)                           // 11     11        /4
++        PAVGB(%%mm3, %%mm6)                           // 11   2211        /8
++        PAVGB(%%mm5, %%mm2)                           //   11                /2
++        "movq (%0, %1, 4), %%mm4                \n\t" //     1
++        PAVGB(%%mm4, %%mm2)                           //   112                /4
++        PAVGB(%%mm2, %%mm6)                           // 112242211        /16
++        "movq %%mm6, (%0, %1, 4)                \n\t" //     X
++        // mm0=7(11) mm1=2(11) mm2=3(112) mm3=6(11) mm4=5 mm5=4 mm7=9
++        PAVGB(%%mm7, %%mm1)                           //  11     2        /4
++        PAVGB(%%mm4, %%mm5)                           //    11                /2
++        PAVGB(%%mm5, %%mm0)                           //    11 11        /4
++        "movq (%%"FF_REG_a", %1, 2), %%mm6      \n\t" //      1
++        PAVGB(%%mm6, %%mm1)                           //  11  4  2        /8
++        PAVGB(%%mm0, %%mm1)                           //  11224222        /16
++        "movq %%mm1, (%%"FF_REG_a", %1, 2)      \n\t" //      X
++        // mm2=3(112) mm3=6(11) mm4=5 mm5=4(11) mm6=6 mm7=9
++        PAVGB((%%FF_REGc), %%mm2)                     //   112 4        /8
++        "movq (%%"FF_REG_a", %1, 4), %%mm0      \n\t" //        1
++        PAVGB(%%mm0, %%mm6)                           //      1 1        /2
++        PAVGB(%%mm7, %%mm6)                           //      1 12        /4
++        PAVGB(%%mm2, %%mm6)                           //   1122424        /4
++        "movq %%mm6, (%%"FF_REG_c")             \n\t" //       X
++        // mm0=8 mm3=6(11) mm4=5 mm5=4(11) mm7=9
++        PAVGB(%%mm7, %%mm5)                           //    11   2        /4
++        PAVGB(%%mm7, %%mm5)                           //    11   6        /8
++
++        PAVGB(%%mm3, %%mm0)                           //      112        /4
++        PAVGB(%%mm0, %%mm5)                           //    112246        /16
++        "movq %%mm5, (%%"FF_REG_a", %1, 4)      \n\t" //        X
++        "sub %1, %0                             \n\t"
++
++        :
++        : "r" (src), "r" ((x86_reg)stride), "m" (c->pQPb)
++        : "%"FF_REG_a, "%"FF_REG_c
++    );
++#else //TEMPLATE_PP_MMXEXT
++    const int l1= stride;
++    const int l2= stride + l1;
++    const int l3= stride + l2;
++    const int l4= stride + l3;
++    const int l5= stride + l4;
++    const int l6= stride + l5;
++    const int l7= stride + l6;
++    const int l8= stride + l7;
++    const int l9= stride + l8;
++    int x;
++    src+= stride*3;
++    for(x=0; x<BLOCK_SIZE; x++){
++        const int first= FFABS(src[0] - src[l1]) < c->QP ? src[0] : src[l1];
++        const int last= FFABS(src[l8] - src[l9]) < c->QP ? src[l9] : src[l8];
++
++        int sums[10];
++        sums[0] = 4*first + src[l1] + src[l2] + src[l3] + 4;
++        sums[1] = sums[0] - first  + src[l4];
++        sums[2] = sums[1] - first  + src[l5];
++        sums[3] = sums[2] - first  + src[l6];
++        sums[4] = sums[3] - first  + src[l7];
++        sums[5] = sums[4] - src[l1] + src[l8];
++        sums[6] = sums[5] - src[l2] + last;
++        sums[7] = sums[6] - src[l3] + last;
++        sums[8] = sums[7] - src[l4] + last;
++        sums[9] = sums[8] - src[l5] + last;
++
++        src[l1]= (sums[0] + sums[2] + 2*src[l1])>>4;
++        src[l2]= (sums[1] + sums[3] + 2*src[l2])>>4;
++        src[l3]= (sums[2] + sums[4] + 2*src[l3])>>4;
++        src[l4]= (sums[3] + sums[5] + 2*src[l4])>>4;
++        src[l5]= (sums[4] + sums[6] + 2*src[l5])>>4;
++        src[l6]= (sums[5] + sums[7] + 2*src[l6])>>4;
++        src[l7]= (sums[6] + sums[8] + 2*src[l7])>>4;
++        src[l8]= (sums[7] + sums[9] + 2*src[l8])>>4;
++
++        src++;
++    }
++#endif //TEMPLATE_PP_MMXEXT
++}
++#endif //TEMPLATE_PP_ALTIVEC
++
++/**
++ * Experimental Filter 1
++ * will not damage linear gradients
++ * Flat blocks should look like they were passed through the (1,1,2,2,4,2,2,1,1) 9-Tap filter
++ * can only smooth blocks at the expected locations (it cannot smooth them if they did move)
++ * MMX2 version does correct clipping C version does not
++ */
++static inline void RENAME(vertX1Filter)(uint8_t *src, int stride, PPContext *co)
++{
++#if TEMPLATE_PP_MMXEXT
++    src+= stride*3;
++
++    __asm__ volatile(
++        "pxor %%mm7, %%mm7                      \n\t" // 0
++        "lea (%0, %1), %%"FF_REG_a"             \n\t"
++        "lea (%%"FF_REG_a", %1, 4), %%"FF_REG_c"\n\t"
++//      0       1       2       3       4       5       6       7       8       9
++//      %0      eax     eax+%1  eax+2%1 %0+4%1  ecx     ecx+%1  ecx+2%1 %0+8%1  ecx+4%1
++        "movq (%%"FF_REG_a", %1, 2), %%mm0      \n\t" // line 3
++        "movq (%0, %1, 4), %%mm1                \n\t" // line 4
++        "movq %%mm1, %%mm2                      \n\t" // line 4
++        "psubusb %%mm0, %%mm1                   \n\t"
++        "psubusb %%mm2, %%mm0                   \n\t"
++        "por %%mm1, %%mm0                       \n\t" // |l2 - l3|
++        "movq (%%"FF_REG_c"), %%mm3             \n\t" // line 5
++        "movq (%%"FF_REG_c", %1), %%mm4         \n\t" // line 6
++        "movq %%mm3, %%mm5                      \n\t" // line 5
++        "psubusb %%mm4, %%mm3                   \n\t"
++        "psubusb %%mm5, %%mm4                   \n\t"
++        "por %%mm4, %%mm3                       \n\t" // |l5 - l6|
++        PAVGB(%%mm3, %%mm0)                           // (|l2 - l3| + |l5 - l6|)/2
++        "movq %%mm2, %%mm1                      \n\t" // line 4
++        "psubusb %%mm5, %%mm2                   \n\t"
++        "movq %%mm2, %%mm4                      \n\t"
++        "pcmpeqb %%mm7, %%mm2                   \n\t" // (l4 - l5) <= 0 ? -1 : 0
++        "psubusb %%mm1, %%mm5                   \n\t"
++        "por %%mm5, %%mm4                       \n\t" // |l4 - l5|
++        "psubusb %%mm0, %%mm4                   \n\t" //d = MAX(0, |l4-l5| - (|l2-l3| + |l5-l6|)/2)
++        "movq %%mm4, %%mm3                      \n\t" // d
++        "movq %2, %%mm0                         \n\t"
++        "paddusb %%mm0, %%mm0                   \n\t"
++        "psubusb %%mm0, %%mm4                   \n\t"
++        "pcmpeqb %%mm7, %%mm4                   \n\t" // d <= QP ? -1 : 0
++        "psubusb "MANGLE(b01)", %%mm3           \n\t"
++        "pand %%mm4, %%mm3                      \n\t" // d <= QP ? d : 0
++
++        PAVGB(%%mm7, %%mm3)                           // d/2
++        "movq %%mm3, %%mm1                      \n\t" // d/2
++        PAVGB(%%mm7, %%mm3)                           // d/4
++        PAVGB(%%mm1, %%mm3)                           // 3*d/8
++
++        "movq (%0, %1, 4), %%mm0                \n\t" // line 4
++        "pxor %%mm2, %%mm0                      \n\t" //(l4 - l5) <= 0 ? -l4-1 : l4
++        "psubusb %%mm3, %%mm0                   \n\t"
++        "pxor %%mm2, %%mm0                      \n\t"
++        "movq %%mm0, (%0, %1, 4)                \n\t" // line 4
++
++        "movq (%%"FF_REG_c"), %%mm0             \n\t" // line 5
++        "pxor %%mm2, %%mm0                      \n\t" //(l4 - l5) <= 0 ? -l5-1 : l5
++        "paddusb %%mm3, %%mm0                   \n\t"
++        "pxor %%mm2, %%mm0                      \n\t"
++        "movq %%mm0, (%%"FF_REG_c")             \n\t" // line 5
++
++        PAVGB(%%mm7, %%mm1)                           // d/4
++
++        "movq (%%"FF_REG_a", %1, 2), %%mm0      \n\t" // line 3
++        "pxor %%mm2, %%mm0                      \n\t" //(l4 - l5) <= 0 ? -l4-1 : l4
++        "psubusb %%mm1, %%mm0                   \n\t"
++        "pxor %%mm2, %%mm0                      \n\t"
++        "movq %%mm0, (%%"FF_REG_a", %1, 2)      \n\t" // line 3
++
++        "movq (%%"FF_REG_c", %1), %%mm0         \n\t" // line 6
++        "pxor %%mm2, %%mm0                      \n\t" //(l4 - l5) <= 0 ? -l5-1 : l5
++        "paddusb %%mm1, %%mm0                   \n\t"
++        "pxor %%mm2, %%mm0                      \n\t"
++        "movq %%mm0, (%%"FF_REG_c", %1)         \n\t" // line 6
++
++        PAVGB(%%mm7, %%mm1)                           // d/8
++
++        "movq (%%"FF_REG_a", %1), %%mm0         \n\t" // line 2
++        "pxor %%mm2, %%mm0                      \n\t" //(l4 - l5) <= 0 ? -l2-1 : l2
++        "psubusb %%mm1, %%mm0                   \n\t"
++        "pxor %%mm2, %%mm0                      \n\t"
++        "movq %%mm0, (%%"FF_REG_a", %1)         \n\t" // line 2
++
++        "movq (%%"FF_REG_c", %1, 2), %%mm0      \n\t" // line 7
++        "pxor %%mm2, %%mm0                      \n\t" //(l4 - l5) <= 0 ? -l7-1 : l7
++        "paddusb %%mm1, %%mm0                   \n\t"
++        "pxor %%mm2, %%mm0                      \n\t"
++        "movq %%mm0, (%%"FF_REG_c", %1, 2)      \n\t" // line 7
++
++        :
++        : "r" (src), "r" ((x86_reg)stride), "m" (co->pQPb)
++          NAMED_CONSTRAINTS_ADD(b01)
++        : "%"FF_REG_a, "%"FF_REG_c
++    );
++#else //TEMPLATE_PP_MMXEXT
++
++    const int l1= stride;
++    const int l2= stride + l1;
++    const int l3= stride + l2;
++    const int l4= stride + l3;
++    const int l5= stride + l4;
++    const int l6= stride + l5;
++    const int l7= stride + l6;
++//    const int l8= stride + l7;
++//    const int l9= stride + l8;
++    int x;
++
++    src+= stride*3;
++    for(x=0; x<BLOCK_SIZE; x++){
++        int a= src[l3] - src[l4];
++        int b= src[l4] - src[l5];
++        int c= src[l5] - src[l6];
++
++        int d= FFABS(b) - ((FFABS(a) + FFABS(c))>>1);
++        d= FFMAX(d, 0);
++
++        if(d < co->QP*2){
++            int v = d * FFSIGN(-b);
++
++            src[l2] +=v>>3;
++            src[l3] +=v>>2;
++            src[l4] +=(3*v)>>3;
++            src[l5] -=(3*v)>>3;
++            src[l6] -=v>>2;
++            src[l7] -=v>>3;
++        }
++        src++;
++    }
++#endif //TEMPLATE_PP_MMXEXT
++}
++
++#if !TEMPLATE_PP_ALTIVEC
++static inline void RENAME(doVertDefFilter)(uint8_t src[], int stride, PPContext *c)
++{
++#if TEMPLATE_PP_MMXEXT
++/*
++    uint8_t tmp[16];
++    const int l1= stride;
++    const int l2= stride + l1;
++    const int l3= stride + l2;
++    const int l4= (int)tmp - (int)src - stride*3;
++    const int l5= (int)tmp - (int)src - stride*3 + 8;
++    const int l6= stride*3 + l3;
++    const int l7= stride + l6;
++    const int l8= stride + l7;
++
++    memcpy(tmp, src+stride*7, 8);
++    memcpy(tmp+8, src+stride*8, 8);
++*/
++    src+= stride*4;
++    __asm__ volatile(
++
++#if 0 //slightly more accurate and slightly slower
++        "pxor %%mm7, %%mm7                      \n\t" // 0
++        "lea (%0, %1), %%"FF_REG_a"             \n\t"
++        "lea (%%"FF_REG_a", %1, 4), %%"FF_REG_c"\n\t"
++//      0       1       2       3       4       5       6       7
++//      %0      %0+%1   %0+2%1  eax+2%1 %0+4%1  eax+4%1 ecx+%1  ecx+2%1
++//      %0      eax     eax+%1  eax+2%1 %0+4%1  ecx     ecx+%1  ecx+2%1
++
++
++        "movq (%0, %1, 2), %%mm0                \n\t" // l2
++        "movq (%0), %%mm1                       \n\t" // l0
++        "movq %%mm0, %%mm2                      \n\t" // l2
++        PAVGB(%%mm7, %%mm0)                           // ~l2/2
++        PAVGB(%%mm1, %%mm0)                           // ~(l2 + 2l0)/4
++        PAVGB(%%mm2, %%mm0)                           // ~(5l2 + 2l0)/8
++
++        "movq (%%"FF_REG_a"), %%mm1             \n\t" // l1
++        "movq (%%"FF_REG_a", %1, 2), %%mm3      \n\t" // l3
++        "movq %%mm1, %%mm4                      \n\t" // l1
++        PAVGB(%%mm7, %%mm1)                           // ~l1/2
++        PAVGB(%%mm3, %%mm1)                           // ~(l1 + 2l3)/4
++        PAVGB(%%mm4, %%mm1)                           // ~(5l1 + 2l3)/8
++
++        "movq %%mm0, %%mm4                      \n\t" // ~(5l2 + 2l0)/8
++        "psubusb %%mm1, %%mm0                   \n\t"
++        "psubusb %%mm4, %%mm1                   \n\t"
++        "por %%mm0, %%mm1                       \n\t" // ~|2l0 - 5l1 + 5l2 - 2l3|/8
++// mm1= |lenergy|, mm2= l2, mm3= l3, mm7=0
++
++        "movq (%0, %1, 4), %%mm0                \n\t" // l4
++        "movq %%mm0, %%mm4                      \n\t" // l4
++        PAVGB(%%mm7, %%mm0)                           // ~l4/2
++        PAVGB(%%mm2, %%mm0)                           // ~(l4 + 2l2)/4
++        PAVGB(%%mm4, %%mm0)                           // ~(5l4 + 2l2)/8
++
++        "movq (%%"FF_REG_c"), %%mm2             \n\t" // l5
++        "movq %%mm3, %%mm5                      \n\t" // l3
++        PAVGB(%%mm7, %%mm3)                           // ~l3/2
++        PAVGB(%%mm2, %%mm3)                           // ~(l3 + 2l5)/4
++        PAVGB(%%mm5, %%mm3)                           // ~(5l3 + 2l5)/8
++
++        "movq %%mm0, %%mm6                      \n\t" // ~(5l4 + 2l2)/8
++        "psubusb %%mm3, %%mm0                   \n\t"
++        "psubusb %%mm6, %%mm3                   \n\t"
++        "por %%mm0, %%mm3                       \n\t" // ~|2l2 - 5l3 + 5l4 - 2l5|/8
++        "pcmpeqb %%mm7, %%mm0                   \n\t" // SIGN(2l2 - 5l3 + 5l4 - 2l5)
++// mm0= SIGN(menergy), mm1= |lenergy|, mm2= l5, mm3= |menergy|, mm4=l4, mm5= l3, mm7=0
++
++        "movq (%%"FF_REG_c", %1), %%mm6         \n\t" // l6
++        "movq %%mm6, %%mm5                      \n\t" // l6
++        PAVGB(%%mm7, %%mm6)                           // ~l6/2
++        PAVGB(%%mm4, %%mm6)                           // ~(l6 + 2l4)/4
++        PAVGB(%%mm5, %%mm6)                           // ~(5l6 + 2l4)/8
++
++        "movq (%%"FF_REG_c", %1, 2), %%mm5      \n\t" // l7
++        "movq %%mm2, %%mm4                      \n\t" // l5
++        PAVGB(%%mm7, %%mm2)                           // ~l5/2
++        PAVGB(%%mm5, %%mm2)                           // ~(l5 + 2l7)/4
++        PAVGB(%%mm4, %%mm2)                           // ~(5l5 + 2l7)/8
++
++        "movq %%mm6, %%mm4                      \n\t" // ~(5l6 + 2l4)/8
++        "psubusb %%mm2, %%mm6                   \n\t"
++        "psubusb %%mm4, %%mm2                   \n\t"
++        "por %%mm6, %%mm2                       \n\t" // ~|2l4 - 5l5 + 5l6 - 2l7|/8
++// mm0= SIGN(menergy), mm1= |lenergy|/8, mm2= |renergy|/8, mm3= |menergy|/8, mm7=0
++
++
++        PMINUB(%%mm2, %%mm1, %%mm4)                   // MIN(|lenergy|,|renergy|)/8
++        "movq %2, %%mm4                         \n\t" // QP //FIXME QP+1 ?
++        "paddusb "MANGLE(b01)", %%mm4           \n\t"
++        "pcmpgtb %%mm3, %%mm4                   \n\t" // |menergy|/8 < QP
++        "psubusb %%mm1, %%mm3                   \n\t" // d=|menergy|/8-MIN(|lenergy|,|renergy|)/8
++        "pand %%mm4, %%mm3                      \n\t"
++
++        "movq %%mm3, %%mm1                      \n\t"
++//        "psubusb "MANGLE(b01)", %%mm3           \n\t"
++        PAVGB(%%mm7, %%mm3)
++        PAVGB(%%mm7, %%mm3)
++        "paddusb %%mm1, %%mm3                   \n\t"
++//        "paddusb "MANGLE(b01)", %%mm3           \n\t"
++
++        "movq (%%"FF_REG_a", %1, 2), %%mm6      \n\t" //l3
++        "movq (%0, %1, 4), %%mm5                \n\t" //l4
++        "movq (%0, %1, 4), %%mm4                \n\t" //l4
++        "psubusb %%mm6, %%mm5                   \n\t"
++        "psubusb %%mm4, %%mm6                   \n\t"
++        "por %%mm6, %%mm5                       \n\t" // |l3-l4|
++        "pcmpeqb %%mm7, %%mm6                   \n\t" // SIGN(l3-l4)
++        "pxor %%mm6, %%mm0                      \n\t"
++        "pand %%mm0, %%mm3                      \n\t"
++        PMINUB(%%mm5, %%mm3, %%mm0)
++
++        "psubusb "MANGLE(b01)", %%mm3           \n\t"
++        PAVGB(%%mm7, %%mm3)
++
++        "movq (%%"FF_REG_a", %1, 2), %%mm0      \n\t"
++        "movq (%0, %1, 4), %%mm2                \n\t"
++        "pxor %%mm6, %%mm0                      \n\t"
++        "pxor %%mm6, %%mm2                      \n\t"
++        "psubb %%mm3, %%mm0                     \n\t"
++        "paddb %%mm3, %%mm2                     \n\t"
++        "pxor %%mm6, %%mm0                      \n\t"
++        "pxor %%mm6, %%mm2                      \n\t"
++        "movq %%mm0, (%%"FF_REG_a", %1, 2)      \n\t"
++        "movq %%mm2, (%0, %1, 4)                \n\t"
++#endif //0
++
++        "lea (%0, %1), %%"FF_REG_a"             \n\t"
++        "pcmpeqb %%mm6, %%mm6                   \n\t" // -1
++//      0       1       2       3       4       5       6       7
++//      %0      %0+%1   %0+2%1  eax+2%1 %0+4%1  eax+4%1 ecx+%1  ecx+2%1
++//      %0      eax     eax+%1  eax+2%1 %0+4%1  ecx     ecx+%1  ecx+2%1
++
++
++        "movq (%%"FF_REG_a", %1, 2), %%mm1      \n\t" // l3
++        "movq (%0, %1, 4), %%mm0                \n\t" // l4
++        "pxor %%mm6, %%mm1                      \n\t" // -l3-1
++        PAVGB(%%mm1, %%mm0)                           // -q+128 = (l4-l3+256)/2
++// mm1=-l3-1, mm0=128-q
++
++        "movq (%%"FF_REG_a", %1, 4), %%mm2      \n\t" // l5
++        "movq (%%"FF_REG_a", %1), %%mm3         \n\t" // l2
++        "pxor %%mm6, %%mm2                      \n\t" // -l5-1
++        "movq %%mm2, %%mm5                      \n\t" // -l5-1
++        "movq "MANGLE(b80)", %%mm4              \n\t" // 128
++        "lea (%%"FF_REG_a", %1, 4), %%"FF_REG_c"\n\t"
++        PAVGB(%%mm3, %%mm2)                           // (l2-l5+256)/2
++        PAVGB(%%mm0, %%mm4)                           // ~(l4-l3)/4 + 128
++        PAVGB(%%mm2, %%mm4)                           // ~(l2-l5)/4 +(l4-l3)/8 + 128
++        PAVGB(%%mm0, %%mm4)                           // ~(l2-l5)/8 +5(l4-l3)/16 + 128
++// mm1=-l3-1, mm0=128-q, mm3=l2, mm4=menergy/16 + 128, mm5= -l5-1
++
++        "movq (%%"FF_REG_a"), %%mm2             \n\t" // l1
++        "pxor %%mm6, %%mm2                      \n\t" // -l1-1
++        PAVGB(%%mm3, %%mm2)                           // (l2-l1+256)/2
++        PAVGB((%0), %%mm1)                            // (l0-l3+256)/2
++        "movq "MANGLE(b80)", %%mm3              \n\t" // 128
++        PAVGB(%%mm2, %%mm3)                           // ~(l2-l1)/4 + 128
++        PAVGB(%%mm1, %%mm3)                           // ~(l0-l3)/4 +(l2-l1)/8 + 128
++        PAVGB(%%mm2, %%mm3)                           // ~(l0-l3)/8 +5(l2-l1)/16 + 128
++// mm0=128-q, mm3=lenergy/16 + 128, mm4= menergy/16 + 128, mm5= -l5-1
++
++        PAVGB((%%FF_REGc, %1), %%mm5)                 // (l6-l5+256)/2
++        "movq (%%"FF_REG_c", %1, 2), %%mm1      \n\t" // l7
++        "pxor %%mm6, %%mm1                      \n\t" // -l7-1
++        PAVGB((%0, %1, 4), %%mm1)                     // (l4-l7+256)/2
++        "movq "MANGLE(b80)", %%mm2              \n\t" // 128
++        PAVGB(%%mm5, %%mm2)                           // ~(l6-l5)/4 + 128
++        PAVGB(%%mm1, %%mm2)                           // ~(l4-l7)/4 +(l6-l5)/8 + 128
++        PAVGB(%%mm5, %%mm2)                           // ~(l4-l7)/8 +5(l6-l5)/16 + 128
++// mm0=128-q, mm2=renergy/16 + 128, mm3=lenergy/16 + 128, mm4= menergy/16 + 128
++
++        "movq "MANGLE(b00)", %%mm1              \n\t" // 0
++        "movq "MANGLE(b00)", %%mm5              \n\t" // 0
++        "psubb %%mm2, %%mm1                     \n\t" // 128 - renergy/16
++        "psubb %%mm3, %%mm5                     \n\t" // 128 - lenergy/16
++        PMAXUB(%%mm1, %%mm2)                          // 128 + |renergy/16|
++        PMAXUB(%%mm5, %%mm3)                          // 128 + |lenergy/16|
++        PMINUB(%%mm2, %%mm3, %%mm1)                   // 128 + MIN(|lenergy|,|renergy|)/16
++
++// mm0=128-q, mm3=128 + MIN(|lenergy|,|renergy|)/16, mm4= menergy/16 + 128
++
++        "movq "MANGLE(b00)", %%mm7              \n\t" // 0
++        "movq %2, %%mm2                         \n\t" // QP
++        PAVGB(%%mm6, %%mm2)                           // 128 + QP/2
++        "psubb %%mm6, %%mm2                     \n\t"
++
++        "movq %%mm4, %%mm1                      \n\t"
++        "pcmpgtb %%mm7, %%mm1                   \n\t" // SIGN(menergy)
++        "pxor %%mm1, %%mm4                      \n\t"
++        "psubb %%mm1, %%mm4                     \n\t" // 128 + |menergy|/16
++        "pcmpgtb %%mm4, %%mm2                   \n\t" // |menergy|/16 < QP/2
++        "psubusb %%mm3, %%mm4                   \n\t" //d=|menergy|/16 - MIN(|lenergy|,|renergy|)/16
++// mm0=128-q, mm1= SIGN(menergy), mm2= |menergy|/16 < QP/2, mm4= d/16
++
++        "movq %%mm4, %%mm3                      \n\t" // d
++        "psubusb "MANGLE(b01)", %%mm4           \n\t"
++        PAVGB(%%mm7, %%mm4)                           // d/32
++        PAVGB(%%mm7, %%mm4)                           // (d + 32)/64
++        "paddb %%mm3, %%mm4                     \n\t" // 5d/64
++        "pand %%mm2, %%mm4                      \n\t"
++
++        "movq "MANGLE(b80)", %%mm5              \n\t" // 128
++        "psubb %%mm0, %%mm5                     \n\t" // q
++        "paddsb %%mm6, %%mm5                    \n\t" // fix bad rounding
++        "pcmpgtb %%mm5, %%mm7                   \n\t" // SIGN(q)
++        "pxor %%mm7, %%mm5                      \n\t"
++
++        PMINUB(%%mm5, %%mm4, %%mm3)                   // MIN(|q|, 5d/64)
++        "pxor %%mm1, %%mm7                      \n\t" // SIGN(d*q)
++
++        "pand %%mm7, %%mm4                      \n\t"
++        "movq (%%"FF_REG_a", %1, 2), %%mm0      \n\t"
++        "movq (%0, %1, 4), %%mm2                \n\t"
++        "pxor %%mm1, %%mm0                      \n\t"
++        "pxor %%mm1, %%mm2                      \n\t"
++        "paddb %%mm4, %%mm0                     \n\t"
++        "psubb %%mm4, %%mm2                     \n\t"
++        "pxor %%mm1, %%mm0                      \n\t"
++        "pxor %%mm1, %%mm2                      \n\t"
++        "movq %%mm0, (%%"FF_REG_a", %1, 2)      \n\t"
++        "movq %%mm2, (%0, %1, 4)                \n\t"
++
++        :
++        : "r" (src), "r" ((x86_reg)stride), "m" (c->pQPb)
++          NAMED_CONSTRAINTS_ADD(b80,b00,b01)
++        : "%"FF_REG_a, "%"FF_REG_c
++    );
++
++/*
++    {
++    int x;
++    src-= stride;
++    for(x=0; x<BLOCK_SIZE; x++){
++        const int middleEnergy= 5*(src[l5] - src[l4]) + 2*(src[l3] - src[l6]);
++        if(FFABS(middleEnergy)< 8*QP){
++            const int q=(src[l4] - src[l5])/2;
++            const int leftEnergy=  5*(src[l3] - src[l2]) + 2*(src[l1] - src[l4]);
++            const int rightEnergy= 5*(src[l7] - src[l6]) + 2*(src[l5] - src[l8]);
++
++            int d= FFABS(middleEnergy) - FFMIN( FFABS(leftEnergy), FFABS(rightEnergy) );
++            d= FFMAX(d, 0);
++
++            d= (5*d + 32) >> 6;
++            d*= FFSIGN(-middleEnergy);
++
++            if(q>0){
++                d= d<0 ? 0 : d;
++                d= d>q ? q : d;
++            }else{
++                d= d>0 ? 0 : d;
++                d= d<q ? q : d;
++            }
++
++            src[l4]-= d;
++            src[l5]+= d;
++        }
++        src++;
++    }
++    src-=8;
++    for(x=0; x<8; x++){
++        int y;
++        for(y=4; y<6; y++){
++            int d= src[x+y*stride] - tmp[x+(y-4)*8];
++            int ad= FFABS(d);
++            static int max=0;
++            static int sum=0;
++            static int num=0;
++            static int bias=0;
++
++            if(max<ad) max=ad;
++            sum+= ad>3 ? 1 : 0;
++            if(ad>3){
++                src[0] = src[7] = src[stride*7] = src[(stride+1)*7]=255;
++            }
++            if(y==4) bias+=d;
++            num++;
++            if(num%1000000 == 0){
++                av_log(c, AV_LOG_INFO, " %d %d %d %d\n", num, sum, max, bias);
++            }
++        }
++    }
++}
++*/
++#else //TEMPLATE_PP_MMXEXT
++    const int l1= stride;
++    const int l2= stride + l1;
++    const int l3= stride + l2;
++    const int l4= stride + l3;
++    const int l5= stride + l4;
++    const int l6= stride + l5;
++    const int l7= stride + l6;
++    const int l8= stride + l7;
++//    const int l9= stride + l8;
++    int x;
++    src+= stride*3;
++    for(x=0; x<BLOCK_SIZE; x++){
++        const int middleEnergy= 5*(src[l5] - src[l4]) + 2*(src[l3] - src[l6]);
++        if(FFABS(middleEnergy) < 8*c->QP){
++            const int q=(src[l4] - src[l5])/2;
++            const int leftEnergy=  5*(src[l3] - src[l2]) + 2*(src[l1] - src[l4]);
++            const int rightEnergy= 5*(src[l7] - src[l6]) + 2*(src[l5] - src[l8]);
++
++            int d= FFABS(middleEnergy) - FFMIN( FFABS(leftEnergy), FFABS(rightEnergy) );
++            d= FFMAX(d, 0);
++
++            d= (5*d + 32) >> 6;
++            d*= FFSIGN(-middleEnergy);
++
++            if(q>0){
++                d = FFMAX(d, 0);
++                d = FFMIN(d, q);
++            }else{
++                d = FFMIN(d, 0);
++                d = FFMAX(d, q);
++            }
++
++            src[l4]-= d;
++            src[l5]+= d;
++        }
++        src++;
++    }
++#endif //TEMPLATE_PP_MMXEXT
++}
++#endif //TEMPLATE_PP_ALTIVEC
++
++#if !TEMPLATE_PP_ALTIVEC
++static inline void RENAME(dering)(uint8_t src[], int stride, PPContext *c, int leftborder, int rightborder, int topborder)
++{
++#if TEMPLATE_PP_MMXEXT && HAVE_7REGS
++    if (topborder)
++        return;
++    DECLARE_ALIGNED(8, uint64_t, tmp)[3];
++    __asm__ volatile(
++        "pxor %%mm6, %%mm6                      \n\t"
++        "pcmpeqb %%mm7, %%mm7                   \n\t"
++        "movq %2, %%mm0                         \n\t"
++        "punpcklbw %%mm6, %%mm0                 \n\t"
++        "psrlw $1, %%mm0                        \n\t"
++        "psubw %%mm7, %%mm0                     \n\t"
++        "packuswb %%mm0, %%mm0                  \n\t"
++        "movq %%mm0, %3                         \n\t"
++
++        "lea (%0, %1), %%"FF_REG_a"             \n\t"
++        "lea (%%"FF_REG_a", %1, 4), %%"FF_REG_d"\n\t"
++
++//        0        1        2        3        4        5        6        7        8        9
++//        %0        eax        eax+%1        eax+2%1        %0+4%1        edx        edx+%1        edx+2%1        %0+8%1        edx+4%1
++
++#undef REAL_FIND_MIN_MAX
++#undef FIND_MIN_MAX
++#define REAL_FIND_MIN_MAX(addr)\
++        "movq " #addr ", %%mm0                  \n\t"\
++        "pminub %%mm0, %%mm7                    \n\t"\
++        "pmaxub %%mm0, %%mm6                    \n\t"
++#define FIND_MIN_MAX(addr)  REAL_FIND_MIN_MAX(addr)
++
++FIND_MIN_MAX((%%FF_REGa))
++FIND_MIN_MAX((%%FF_REGa, %1))
++FIND_MIN_MAX((%%FF_REGa, %1, 2))
++FIND_MIN_MAX((%0, %1, 4))
++FIND_MIN_MAX((%%FF_REGd))
++FIND_MIN_MAX((%%FF_REGd, %1))
++FIND_MIN_MAX((%%FF_REGd, %1, 2))
++FIND_MIN_MAX((%0, %1, 8))
++
++        "movq %%mm7, %%mm4                      \n\t"
++        "psrlq $8, %%mm7                        \n\t"
++        "pminub %%mm4, %%mm7                    \n\t" // min of pixels
++        "pshufw $0xF9, %%mm7, %%mm4             \n\t"
++        "pminub %%mm4, %%mm7                    \n\t" // min of pixels
++        "pshufw $0xFE, %%mm7, %%mm4             \n\t"
++        "pminub %%mm4, %%mm7                    \n\t"
++
++
++        "movq %%mm6, %%mm4                      \n\t"
++        "psrlq $8, %%mm6                        \n\t"
++        "pmaxub %%mm4, %%mm6                    \n\t" // max of pixels
++        "pshufw $0xF9, %%mm6, %%mm4             \n\t"
++        "pmaxub %%mm4, %%mm6                    \n\t"
++        "pshufw $0xFE, %%mm6, %%mm4             \n\t"
++        "pmaxub %%mm4, %%mm6                    \n\t"
++        "movq %%mm6, %%mm0                      \n\t" // max
++        "psubb %%mm7, %%mm6                     \n\t" // max - min
++        "push %%"FF_REG_a"                      \n\t"
++        "movd %%mm6, %%eax                      \n\t"
++        "cmpb $"AV_STRINGIFY(DERING_THRESHOLD)", %%al   \n\t"
++        "pop %%"FF_REG_a"                       \n\t"
++        " jb 1f                                 \n\t"
++        PAVGB(%%mm0, %%mm7)                           // a=(max + min)/2
++        "punpcklbw %%mm7, %%mm7                 \n\t"
++        "punpcklbw %%mm7, %%mm7                 \n\t"
++        "punpcklbw %%mm7, %%mm7                 \n\t"
++        "movq %%mm7, (%4)                       \n\t"
++
++        "movq (%0), %%mm0                       \n\t" // L10
++        "movq %%mm0, %%mm1                      \n\t" // L10
++        "movq %%mm0, %%mm2                      \n\t" // L10
++        "psllq $8, %%mm1                        \n\t"
++        "psrlq $8, %%mm2                        \n\t"
++        "movd -4(%0), %%mm3                     \n\t"
++        "movd 8(%0), %%mm4                      \n\t"
++        "psrlq $24, %%mm3                       \n\t"
++        "psllq $56, %%mm4                       \n\t"
++        "por %%mm3, %%mm1                       \n\t" // L00
++        "por %%mm4, %%mm2                       \n\t" // L20
++        "movq %%mm1, %%mm3                      \n\t" // L00
++        PAVGB(%%mm2, %%mm1)                           // (L20 + L00)/2
++        PAVGB(%%mm0, %%mm1)                           // (L20 + L00 + 2L10)/4
++        "psubusb %%mm7, %%mm0                   \n\t"
++        "psubusb %%mm7, %%mm2                   \n\t"
++        "psubusb %%mm7, %%mm3                   \n\t"
++        "pcmpeqb "MANGLE(b00)", %%mm0           \n\t" // L10 > a ? 0 : -1
++        "pcmpeqb "MANGLE(b00)", %%mm2           \n\t" // L20 > a ? 0 : -1
++        "pcmpeqb "MANGLE(b00)", %%mm3           \n\t" // L00 > a ? 0 : -1
++        "paddb %%mm2, %%mm0                     \n\t"
++        "paddb %%mm3, %%mm0                     \n\t"
++
++        "movq (%%"FF_REG_a"), %%mm2             \n\t" // L11
++        "movq %%mm2, %%mm3                      \n\t" // L11
++        "movq %%mm2, %%mm4                      \n\t" // L11
++        "psllq $8, %%mm3                        \n\t"
++        "psrlq $8, %%mm4                        \n\t"
++        "movd -4(%%"FF_REG_a"), %%mm5           \n\t"
++        "movd 8(%%"FF_REG_a"), %%mm6            \n\t"
++        "psrlq $24, %%mm5                       \n\t"
++        "psllq $56, %%mm6                       \n\t"
++        "por %%mm5, %%mm3                       \n\t" // L01
++        "por %%mm6, %%mm4                       \n\t" // L21
++        "movq %%mm3, %%mm5                      \n\t" // L01
++        PAVGB(%%mm4, %%mm3)                           // (L21 + L01)/2
++        PAVGB(%%mm2, %%mm3)                           // (L21 + L01 + 2L11)/4
++        "psubusb %%mm7, %%mm2                   \n\t"
++        "psubusb %%mm7, %%mm4                   \n\t"
++        "psubusb %%mm7, %%mm5                   \n\t"
++        "pcmpeqb "MANGLE(b00)", %%mm2           \n\t" // L11 > a ? 0 : -1
++        "pcmpeqb "MANGLE(b00)", %%mm4           \n\t" // L21 > a ? 0 : -1
++        "pcmpeqb "MANGLE(b00)", %%mm5           \n\t" // L01 > a ? 0 : -1
++        "paddb %%mm4, %%mm2                     \n\t"
++        "paddb %%mm5, %%mm2                     \n\t"
++// 0, 2, 3, 1
++#define REAL_DERING_CORE(dst,src,ppsx,psx,sx,pplx,plx,lx,t0,t1) \
++        "movq " #src ", " #sx "                 \n\t" /* src[0] */\
++        "movq " #sx ", " #lx "                  \n\t" /* src[0] */\
++        "movq " #sx ", " #t0 "                  \n\t" /* src[0] */\
++        "psllq $8, " #lx "                      \n\t"\
++        "psrlq $8, " #t0 "                      \n\t"\
++        "movd -4" #src ", " #t1 "               \n\t"\
++        "psrlq $24, " #t1 "                     \n\t"\
++        "por " #t1 ", " #lx "                   \n\t" /* src[-1] */\
++        "movd 8" #src ", " #t1 "                \n\t"\
++        "psllq $56, " #t1 "                     \n\t"\
++        "por " #t1 ", " #t0 "                   \n\t" /* src[+1] */\
++        "movq " #lx ", " #t1 "                  \n\t" /* src[-1] */\
++        PAVGB(t0, lx)                                 /* (src[-1] + src[+1])/2 */\
++        PAVGB(sx, lx)                                 /* (src[-1] + 2src[0] + src[+1])/4 */\
++        PAVGB(lx, pplx)                                     \
++        "movq " #lx ", 8(%4)                    \n\t"\
++        "movq (%4), " #lx "                     \n\t"\
++        "psubusb " #lx ", " #t1 "               \n\t"\
++        "psubusb " #lx ", " #t0 "               \n\t"\
++        "psubusb " #lx ", " #sx "               \n\t"\
++        "movq "MANGLE(b00)", " #lx "            \n\t"\
++        "pcmpeqb " #lx ", " #t1 "               \n\t" /* src[-1] > a ? 0 : -1*/\
++        "pcmpeqb " #lx ", " #t0 "               \n\t" /* src[+1] > a ? 0 : -1*/\
++        "pcmpeqb " #lx ", " #sx "               \n\t" /* src[0]  > a ? 0 : -1*/\
++        "paddb " #t1 ", " #t0 "                 \n\t"\
++        "paddb " #t0 ", " #sx "                 \n\t"\
++\
++        PAVGB(plx, pplx)                              /* filtered */\
++        "movq " #dst ", " #t0 "                 \n\t" /* dst */\
++        "movq " #t0 ", " #t1 "                  \n\t" /* dst */\
++        "psubusb %3, " #t0 "                    \n\t"\
++        "paddusb %3, " #t1 "                    \n\t"\
++        PMAXUB(t0, pplx)\
++        PMINUB(t1, pplx, t0)\
++        "paddb " #sx ", " #ppsx "               \n\t"\
++        "paddb " #psx ", " #ppsx "              \n\t"\
++        "pand "MANGLE(b08)", " #ppsx "          \n\t"\
++        "pcmpeqb " #lx ", " #ppsx "             \n\t"\
++        "pand " #ppsx ", " #pplx "              \n\t"\
++        "pandn " #dst ", " #ppsx "              \n\t"\
++        "por " #pplx ", " #ppsx "               \n\t"\
++        "movq " #ppsx ", " #dst "               \n\t"\
++        "movq 8(%4), " #lx "                    \n\t"
++
++#define DERING_CORE(dst,src,ppsx,psx,sx,pplx,plx,lx,t0,t1) \
++   REAL_DERING_CORE(dst,src,ppsx,psx,sx,pplx,plx,lx,t0,t1)
++/*
++0000000
++1111111
++
++1111110
++1111101
++1111100
++1111011
++1111010
++1111001
++
++1111000
++1110111
++
++*/
++//DERING_CORE(dst             ,src               ,ppsx ,psx  ,sx   ,pplx ,plx  ,lx   ,t0   ,t1)
++DERING_CORE((%%FF_REGa)       ,(%%FF_REGa, %1)   ,%%mm0,%%mm2,%%mm4,%%mm1,%%mm3,%%mm5,%%mm6,%%mm7)
++DERING_CORE((%%FF_REGa, %1)   ,(%%FF_REGa, %1, 2),%%mm2,%%mm4,%%mm0,%%mm3,%%mm5,%%mm1,%%mm6,%%mm7)
++DERING_CORE((%%FF_REGa, %1, 2),(%0, %1, 4)       ,%%mm4,%%mm0,%%mm2,%%mm5,%%mm1,%%mm3,%%mm6,%%mm7)
++DERING_CORE((%0, %1, 4)       ,(%%FF_REGd)       ,%%mm0,%%mm2,%%mm4,%%mm1,%%mm3,%%mm5,%%mm6,%%mm7)
++DERING_CORE((%%FF_REGd)       ,(%%FF_REGd, %1)   ,%%mm2,%%mm4,%%mm0,%%mm3,%%mm5,%%mm1,%%mm6,%%mm7)
++DERING_CORE((%%FF_REGd, %1)   ,(%%FF_REGd, %1, 2),%%mm4,%%mm0,%%mm2,%%mm5,%%mm1,%%mm3,%%mm6,%%mm7)
++DERING_CORE((%%FF_REGd, %1, 2),(%0, %1, 8)       ,%%mm0,%%mm2,%%mm4,%%mm1,%%mm3,%%mm5,%%mm6,%%mm7)
++DERING_CORE((%0, %1, 8)       ,(%%FF_REGd, %1, 4),%%mm2,%%mm4,%%mm0,%%mm3,%%mm5,%%mm1,%%mm6,%%mm7)
++
++        "1:                        \n\t"
++        : : "r" (src), "r" ((x86_reg)stride), "m" (c->pQPb), "m"(c->pQPb2), "q"(tmp)
++          NAMED_CONSTRAINTS_ADD(b00,b08)
++        : "%"FF_REG_a, "%"FF_REG_d
++    );
++#else // HAVE_7REGS && TEMPLATE_PP_MMXEXT
++    int y;
++    int min=255;
++    int max=0;
++    int avg;
++    uint8_t *p;
++    int s[10];
++    const int QP2= c->QP/2 + 1;
++
++    src --;
++    for(y=1; y<9; y++){
++        int x;
++        p= src + stride*y;
++        for(x=1; x<9; x++){
++            p++;
++            if(*p > max) max= *p;
++            if(*p < min) min= *p;
++        }
++    }
++    avg= (min + max + 1)>>1;
++
++    if (max - min < DERING_THRESHOLD) return;
++
++    s[0] = 0;
++    for(y=topborder; y<10; y++){
++        int t = 0;
++
++        if(!leftborder && src[stride*y + 0] > avg) t+= 1;
++        if(src[stride*y + 1] > avg) t+= 2;
++        if(src[stride*y + 2] > avg) t+= 4;
++        if(src[stride*y + 3] > avg) t+= 8;
++        if(src[stride*y + 4] > avg) t+= 16;
++        if(src[stride*y + 5] > avg) t+= 32;
++        if(src[stride*y + 6] > avg) t+= 64;
++        if(src[stride*y + 7] > avg) t+= 128;
++        if(src[stride*y + 8] > avg) t+= 256;
++        if(!rightborder && src[stride*y + 9] > avg) t+= 512;
++
++        t |= (~t)<<16;
++        t &= (t<<1) & (t>>1);
++        s[y] = t;
++    }
++
++    for(y=1; y<9; y++){
++        int t = s[y-1] & s[y] & s[y+1];
++        t|= t>>16;
++        s[y-1]= t;
++    }
++
++    for(y=1; y<9; y++){
++        int x;
++        int t = s[y-1];
++
++        p= src + stride*y + leftborder;
++        for(x=1+leftborder; x<9-rightborder; x++){
++            p++;
++            if(t & (1<<x)){
++                int f= (*(p-stride-1)) + 2*(*(p-stride)) + (*(p-stride+1))
++                      +2*(*(p     -1)) + 4*(*p         ) + 2*(*(p     +1))
++                      +(*(p+stride-1)) + 2*(*(p+stride)) + (*(p+stride+1));
++                f= (f + 8)>>4;
++
++#ifdef DEBUG_DERING_THRESHOLD
++                    __asm__ volatile("emms\n\t":);
++                    {
++                    static uint64_t numPixels=0;
++                    if(x!=1 && x!=8 && y!=1 && y!=8) numPixels++;
++//                    if((max-min)<20 || (max-min)*QP<200)
++//                    if((max-min)*QP < 500)
++//                    if(max-min<QP/2)
++                    if(max-min < 20){
++                        static int numSkipped=0;
++                        static int errorSum=0;
++                        static int worstQP=0;
++                        static int worstRange=0;
++                        static int worstDiff=0;
++                        int diff= (f - *p);
++                        int absDiff= FFABS(diff);
++                        int error= diff*diff;
++
++                        if(x==1 || x==8 || y==1 || y==8) continue;
++
++                        numSkipped++;
++                        if(absDiff > worstDiff){
++                            worstDiff= absDiff;
++                            worstQP= QP;
++                            worstRange= max-min;
++                        }
++                        errorSum+= error;
++
++                        if(1024LL*1024LL*1024LL % numSkipped == 0){
++                            av_log(c, AV_LOG_INFO, "sum:%1.3f, skip:%d, wQP:%d, "
++                                   "wRange:%d, wDiff:%d, relSkip:%1.3f\n",
++                                   (float)errorSum/numSkipped, numSkipped, worstQP, worstRange,
++                                   worstDiff, (float)numSkipped/numPixels);
++                        }
++                    }
++                    }
++#endif
++                    if     (*p + QP2 < f) *p= *p + QP2;
++                    else if(*p - QP2 > f) *p= *p - QP2;
++                    else *p=f;
++            }
++        }
++    }
++#ifdef DEBUG_DERING_THRESHOLD
++    if(max-min < 20){
++        for(y=1; y<9; y++){
++            int x;
++            int t = 0;
++            p= src + stride*y;
++            for(x=1; x<9; x++){
++                p++;
++                *p = FFMIN(*p + 20, 255);
++            }
++        }
++//        src[0] = src[7]=src[stride*7]=src[stride*7 + 7]=255;
++    }
++#endif
++#endif //TEMPLATE_PP_MMXEXT
++}
++#endif //TEMPLATE_PP_ALTIVEC
++
++/**
++ * Deinterlace the given block by linearly interpolating every second line.
++ * will be called for every 8x8 block and can read & write from line 4-15
++ * lines 0-3 have been passed through the deblock / dering filters already, but can be read, too.
++ * lines 4-12 will be read into the deblocking filter and should be deinterlaced
++ */
++static inline void RENAME(deInterlaceInterpolateLinear)(uint8_t src[], int stride)
++{
++#if TEMPLATE_PP_MMXEXT
++    src+= 4*stride;
++    __asm__ volatile(
++        "lea (%0, %1), %%"FF_REG_a"             \n\t"
++        "lea (%%"FF_REG_a", %1, 4), %%"FF_REG_c"\n\t"
++//      0       1       2       3       4       5       6       7       8       9
++//      %0      eax     eax+%1  eax+2%1 %0+4%1  ecx     ecx+%1  ecx+2%1 %0+8%1  ecx+4%1
++
++        "movq (%0), %%mm0                       \n\t"
++        "movq (%%"FF_REG_a", %1), %%mm1         \n\t"
++        PAVGB(%%mm1, %%mm0)
++        "movq %%mm0, (%%"FF_REG_a")             \n\t"
++        "movq (%0, %1, 4), %%mm0                \n\t"
++        PAVGB(%%mm0, %%mm1)
++        "movq %%mm1, (%%"FF_REG_a", %1, 2)      \n\t"
++        "movq (%%"FF_REG_c", %1), %%mm1         \n\t"
++        PAVGB(%%mm1, %%mm0)
++        "movq %%mm0, (%%"FF_REG_c")             \n\t"
++        "movq (%0, %1, 8), %%mm0                \n\t"
++        PAVGB(%%mm0, %%mm1)
++        "movq %%mm1, (%%"FF_REG_c", %1, 2)      \n\t"
++
++        : : "r" (src), "r" ((x86_reg)stride)
++        : "%"FF_REG_a, "%"FF_REG_c
++    );
++#else
++    int a, b, x;
++    src+= 4*stride;
++
++    for(x=0; x<2; x++){
++        a= *(uint32_t*)&src[stride*0];
++        b= *(uint32_t*)&src[stride*2];
++        *(uint32_t*)&src[stride*1]= (a|b) - (((a^b)&0xFEFEFEFEUL)>>1);
++        a= *(uint32_t*)&src[stride*4];
++        *(uint32_t*)&src[stride*3]= (a|b) - (((a^b)&0xFEFEFEFEUL)>>1);
++        b= *(uint32_t*)&src[stride*6];
++        *(uint32_t*)&src[stride*5]= (a|b) - (((a^b)&0xFEFEFEFEUL)>>1);
++        a= *(uint32_t*)&src[stride*8];
++        *(uint32_t*)&src[stride*7]= (a|b) - (((a^b)&0xFEFEFEFEUL)>>1);
++        src += 4;
++    }
++#endif
++}
++
++/**
++ * Deinterlace the given block by cubic interpolating every second line.
++ * will be called for every 8x8 block and can read & write from line 4-15
++ * lines 0-3 have been passed through the deblock / dering filters already, but can be read, too.
++ * lines 4-12 will be read into the deblocking filter and should be deinterlaced
++ * this filter will read lines 3-15 and write 7-13
++ */
++static inline void RENAME(deInterlaceInterpolateCubic)(uint8_t src[], int stride)
++{
++#if TEMPLATE_PP_SSE2
++    src+= stride*3;
++    __asm__ volatile(
++        "lea (%0, %1), %%"FF_REG_a"             \n\t"
++        "lea (%%"FF_REG_a", %1, 4), %%"FF_REG_d"\n\t"
++        "lea (%%"FF_REG_d", %1, 4), %%"FF_REG_c"\n\t"
++        "add %1, %%"FF_REG_c"                   \n\t"
++        "pxor %%xmm7, %%xmm7                    \n\t"
++#define REAL_DEINT_CUBIC(a,b,c,d,e)\
++        "movq " #a ", %%xmm0                    \n\t"\
++        "movq " #b ", %%xmm1                    \n\t"\
++        "movq " #d ", %%xmm2                    \n\t"\
++        "movq " #e ", %%xmm3                    \n\t"\
++        "pavgb %%xmm2, %%xmm1                   \n\t"\
++        "pavgb %%xmm3, %%xmm0                   \n\t"\
++        "punpcklbw %%xmm7, %%xmm0               \n\t"\
++        "punpcklbw %%xmm7, %%xmm1               \n\t"\
++        "psubw %%xmm1, %%xmm0                   \n\t"\
++        "psraw $3, %%xmm0                       \n\t"\
++        "psubw %%xmm0, %%xmm1                   \n\t"\
++        "packuswb %%xmm1, %%xmm1                \n\t"\
++        "movlps %%xmm1, " #c "                  \n\t"
++#define DEINT_CUBIC(a,b,c,d,e)  REAL_DEINT_CUBIC(a,b,c,d,e)
++
++DEINT_CUBIC((%0)           , (%%FF_REGa, %1), (%%FF_REGa, %1, 2), (%0, %1, 4)    , (%%FF_REGd, %1))
++DEINT_CUBIC((%%FF_REGa, %1), (%0, %1, 4)    , (%%FF_REGd)       , (%%FF_REGd, %1), (%0, %1, 8))
++DEINT_CUBIC((%0, %1, 4)    , (%%FF_REGd, %1), (%%FF_REGd, %1, 2), (%0, %1, 8)    , (%%FF_REGc))
++DEINT_CUBIC((%%FF_REGd, %1), (%0, %1, 8)    , (%%FF_REGd, %1, 4), (%%FF_REGc)    , (%%FF_REGc, %1, 2))
++
++        : : "r" (src), "r" ((x86_reg)stride)
++        :
++        XMM_CLOBBERS("%xmm0", "%xmm1", "%xmm2", "%xmm3", "%xmm7",)
++        "%"FF_REG_a, "%"FF_REG_d, "%"FF_REG_c
++    );
++#undef REAL_DEINT_CUBIC
++#else //TEMPLATE_PP_SSE2
++    int x;
++    src+= stride*3;
++    for(x=0; x<8; x++){
++        src[stride*3] = av_clip_uint8((-src[0]        + 9*src[stride*2] + 9*src[stride*4] - src[stride*6])>>4);
++        src[stride*5] = av_clip_uint8((-src[stride*2] + 9*src[stride*4] + 9*src[stride*6] - src[stride*8])>>4);
++        src[stride*7] = av_clip_uint8((-src[stride*4] + 9*src[stride*6] + 9*src[stride*8] - src[stride*10])>>4);
++        src[stride*9] = av_clip_uint8((-src[stride*6] + 9*src[stride*8] + 9*src[stride*10] - src[stride*12])>>4);
++        src++;
++    }
++#endif //TEMPLATE_PP_SSE2
++}
++
++/**
++ * Deinterlace the given block by filtering every second line with a (-1 4 2 4 -1) filter.
++ * will be called for every 8x8 block and can read & write from line 4-15
++ * lines 0-3 have been passed through the deblock / dering filters already, but can be read, too.
++ * lines 4-12 will be read into the deblocking filter and should be deinterlaced
++ * this filter will read lines 4-13 and write 5-11
++ */
++static inline void RENAME(deInterlaceFF)(uint8_t src[], int stride, uint8_t *tmp)
++{
++#if TEMPLATE_PP_MMXEXT
++    src+= stride*4;
++    __asm__ volatile(
++        "lea (%0, %1), %%"FF_REG_a"             \n\t"
++        "lea (%%"FF_REG_a", %1, 4), %%"FF_REG_d"\n\t"
++        "pxor %%mm7, %%mm7                      \n\t"
++        "movq (%2), %%mm0                       \n\t"
++//      0       1       2       3       4       5       6       7       8       9       10
++//      %0      eax     eax+%1  eax+2%1 %0+4%1  edx     edx+%1  edx+2%1 %0+8%1  edx+4%1 ecx
++
++#define REAL_DEINT_FF(a,b,c,d)\
++        "movq " #a ", %%mm1                     \n\t"\
++        "movq " #b ", %%mm2                     \n\t"\
++        "movq " #c ", %%mm3                     \n\t"\
++        "movq " #d ", %%mm4                     \n\t"\
++        PAVGB(%%mm3, %%mm1)                          \
++        PAVGB(%%mm4, %%mm0)                          \
++        "movq %%mm0, %%mm3                      \n\t"\
++        "punpcklbw %%mm7, %%mm0                 \n\t"\
++        "punpckhbw %%mm7, %%mm3                 \n\t"\
++        "movq %%mm1, %%mm4                      \n\t"\
++        "punpcklbw %%mm7, %%mm1                 \n\t"\
++        "punpckhbw %%mm7, %%mm4                 \n\t"\
++        "psllw $2, %%mm1                        \n\t"\
++        "psllw $2, %%mm4                        \n\t"\
++        "psubw %%mm0, %%mm1                     \n\t"\
++        "psubw %%mm3, %%mm4                     \n\t"\
++        "movq %%mm2, %%mm5                      \n\t"\
++        "movq %%mm2, %%mm0                      \n\t"\
++        "punpcklbw %%mm7, %%mm2                 \n\t"\
++        "punpckhbw %%mm7, %%mm5                 \n\t"\
++        "paddw %%mm2, %%mm1                     \n\t"\
++        "paddw %%mm5, %%mm4                     \n\t"\
++        "psraw $2, %%mm1                        \n\t"\
++        "psraw $2, %%mm4                        \n\t"\
++        "packuswb %%mm4, %%mm1                  \n\t"\
++        "movq %%mm1, " #b "                     \n\t"\
++
++#define DEINT_FF(a,b,c,d)  REAL_DEINT_FF(a,b,c,d)
++
++DEINT_FF((%0)           , (%%FF_REGa)       , (%%FF_REGa, %1), (%%FF_REGa, %1, 2))
++DEINT_FF((%%FF_REGa, %1), (%%FF_REGa, %1, 2), (%0, %1, 4)    , (%%FF_REGd)       )
++DEINT_FF((%0, %1, 4)    , (%%FF_REGd)       , (%%FF_REGd, %1), (%%FF_REGd, %1, 2))
++DEINT_FF((%%FF_REGd, %1), (%%FF_REGd, %1, 2), (%0, %1, 8)    , (%%FF_REGd, %1, 4))
++
++        "movq %%mm0, (%2)                       \n\t"
++        : : "r" (src), "r" ((x86_reg)stride), "r"(tmp)
++        : "%"FF_REG_a, "%"FF_REG_d
++    );
++#else //TEMPLATE_PP_MMXEXT
++    int x;
++    src+= stride*4;
++    for(x=0; x<8; x++){
++        int t1= tmp[x];
++        int t2= src[stride*1];
++
++        src[stride*1]= av_clip_uint8((-t1 + 4*src[stride*0] + 2*t2 + 4*src[stride*2] - src[stride*3] + 4)>>3);
++        t1= src[stride*4];
++        src[stride*3]= av_clip_uint8((-t2 + 4*src[stride*2] + 2*t1 + 4*src[stride*4] - src[stride*5] + 4)>>3);
++        t2= src[stride*6];
++        src[stride*5]= av_clip_uint8((-t1 + 4*src[stride*4] + 2*t2 + 4*src[stride*6] - src[stride*7] + 4)>>3);
++        t1= src[stride*8];
++        src[stride*7]= av_clip_uint8((-t2 + 4*src[stride*6] + 2*t1 + 4*src[stride*8] - src[stride*9] + 4)>>3);
++        tmp[x]= t1;
++
++        src++;
++    }
++#endif //TEMPLATE_PP_MMXEXT
++}
++
++/**
++ * Deinterlace the given block by filtering every line with a (-1 2 6 2 -1) filter.
++ * will be called for every 8x8 block and can read & write from line 4-15
++ * lines 0-3 have been passed through the deblock / dering filters already, but can be read, too.
++ * lines 4-12 will be read into the deblocking filter and should be deinterlaced
++ * this filter will read lines 4-13 and write 4-11
++ */
++static inline void RENAME(deInterlaceL5)(uint8_t src[], int stride, uint8_t *tmp, uint8_t *tmp2)
++{
++#if TEMPLATE_PP_MMXEXT && HAVE_6REGS
++    src+= stride*4;
++    __asm__ volatile(
++        "lea (%0, %1), %%"FF_REG_a"             \n\t"
++        "lea (%%"FF_REG_a", %1, 4), %%"FF_REG_d"\n\t"
++        "pxor %%mm7, %%mm7                      \n\t"
++        "movq (%2), %%mm0                       \n\t"
++        "movq (%3), %%mm1                       \n\t"
++//      0       1       2       3       4       5       6       7       8       9       10
++//      %0      eax     eax+%1  eax+2%1 %0+4%1  edx     edx+%1  edx+2%1 %0+8%1  edx+4%1 ecx
++
++#define REAL_DEINT_L5(t1,t2,a,b,c)\
++        "movq " #a ", %%mm2                     \n\t"\
++        "movq " #b ", %%mm3                     \n\t"\
++        "movq " #c ", %%mm4                     \n\t"\
++        PAVGB(t2, %%mm3)                             \
++        PAVGB(t1, %%mm4)                             \
++        "movq %%mm2, %%mm5                      \n\t"\
++        "movq %%mm2, " #t1 "                    \n\t"\
++        "punpcklbw %%mm7, %%mm2                 \n\t"\
++        "punpckhbw %%mm7, %%mm5                 \n\t"\
++        "movq %%mm2, %%mm6                      \n\t"\
++        "paddw %%mm2, %%mm2                     \n\t"\
++        "paddw %%mm6, %%mm2                     \n\t"\
++        "movq %%mm5, %%mm6                      \n\t"\
++        "paddw %%mm5, %%mm5                     \n\t"\
++        "paddw %%mm6, %%mm5                     \n\t"\
++        "movq %%mm3, %%mm6                      \n\t"\
++        "punpcklbw %%mm7, %%mm3                 \n\t"\
++        "punpckhbw %%mm7, %%mm6                 \n\t"\
++        "paddw %%mm3, %%mm3                     \n\t"\
++        "paddw %%mm6, %%mm6                     \n\t"\
++        "paddw %%mm3, %%mm2                     \n\t"\
++        "paddw %%mm6, %%mm5                     \n\t"\
++        "movq %%mm4, %%mm6                      \n\t"\
++        "punpcklbw %%mm7, %%mm4                 \n\t"\
++        "punpckhbw %%mm7, %%mm6                 \n\t"\
++        "psubw %%mm4, %%mm2                     \n\t"\
++        "psubw %%mm6, %%mm5                     \n\t"\
++        "psraw $2, %%mm2                        \n\t"\
++        "psraw $2, %%mm5                        \n\t"\
++        "packuswb %%mm5, %%mm2                  \n\t"\
++        "movq %%mm2, " #a "                     \n\t"\
++
++#define DEINT_L5(t1,t2,a,b,c)  REAL_DEINT_L5(t1,t2,a,b,c)
++
++DEINT_L5(%%mm0, %%mm1, (%0)              , (%%FF_REGa)       , (%%FF_REGa, %1)   )
++DEINT_L5(%%mm1, %%mm0, (%%FF_REGa)       , (%%FF_REGa, %1)   , (%%FF_REGa, %1, 2))
++DEINT_L5(%%mm0, %%mm1, (%%FF_REGa, %1)   , (%%FF_REGa, %1, 2), (%0, %1, 4)   )
++DEINT_L5(%%mm1, %%mm0, (%%FF_REGa, %1, 2), (%0, %1, 4)       , (%%FF_REGd)       )
++DEINT_L5(%%mm0, %%mm1, (%0, %1, 4)       , (%%FF_REGd)       , (%%FF_REGd, %1)   )
++DEINT_L5(%%mm1, %%mm0, (%%FF_REGd)       , (%%FF_REGd, %1)   , (%%FF_REGd, %1, 2))
++DEINT_L5(%%mm0, %%mm1, (%%FF_REGd, %1)   , (%%FF_REGd, %1, 2), (%0, %1, 8)   )
++DEINT_L5(%%mm1, %%mm0, (%%FF_REGd, %1, 2), (%0, %1, 8)       , (%%FF_REGd, %1, 4))
++
++        "movq %%mm0, (%2)                       \n\t"
++        "movq %%mm1, (%3)                       \n\t"
++        : : "r" (src), "r" ((x86_reg)stride), "r"(tmp), "r"(tmp2)
++        : "%"FF_REG_a, "%"FF_REG_d
++    );
++#else //TEMPLATE_PP_MMXEXT && HAVE_6REGS
++    int x;
++    src+= stride*4;
++    for(x=0; x<8; x++){
++        int t1= tmp[x];
++        int t2= tmp2[x];
++        int t3= src[0];
++
++        src[stride*0]= av_clip_uint8((-(t1 + src[stride*2]) + 2*(t2 + src[stride*1]) + 6*t3 + 4)>>3);
++        t1= src[stride*1];
++        src[stride*1]= av_clip_uint8((-(t2 + src[stride*3]) + 2*(t3 + src[stride*2]) + 6*t1 + 4)>>3);
++        t2= src[stride*2];
++        src[stride*2]= av_clip_uint8((-(t3 + src[stride*4]) + 2*(t1 + src[stride*3]) + 6*t2 + 4)>>3);
++        t3= src[stride*3];
++        src[stride*3]= av_clip_uint8((-(t1 + src[stride*5]) + 2*(t2 + src[stride*4]) + 6*t3 + 4)>>3);
++        t1= src[stride*4];
++        src[stride*4]= av_clip_uint8((-(t2 + src[stride*6]) + 2*(t3 + src[stride*5]) + 6*t1 + 4)>>3);
++        t2= src[stride*5];
++        src[stride*5]= av_clip_uint8((-(t3 + src[stride*7]) + 2*(t1 + src[stride*6]) + 6*t2 + 4)>>3);
++        t3= src[stride*6];
++        src[stride*6]= av_clip_uint8((-(t1 + src[stride*8]) + 2*(t2 + src[stride*7]) + 6*t3 + 4)>>3);
++        t1= src[stride*7];
++        src[stride*7]= av_clip_uint8((-(t2 + src[stride*9]) + 2*(t3 + src[stride*8]) + 6*t1 + 4)>>3);
++
++        tmp[x]= t3;
++        tmp2[x]= t1;
++
++        src++;
++    }
++#endif // TEMPLATE_PP_MMXEXT && HAVE_6REGS
++}
++
++/**
++ * Deinterlace the given block by filtering all lines with a (1 2 1) filter.
++ * will be called for every 8x8 block and can read & write from line 4-15
++ * lines 0-3 have been passed through the deblock / dering filters already, but can be read, too.
++ * lines 4-12 will be read into the deblocking filter and should be deinterlaced
++ * this filter will read lines 4-13 and write 4-11
++ */
++static inline void RENAME(deInterlaceBlendLinear)(uint8_t src[], int stride, uint8_t *tmp)
++{
++#if TEMPLATE_PP_MMXEXT
++    src+= 4*stride;
++    __asm__ volatile(
++        "lea (%0, %1), %%"FF_REG_a"             \n\t"
++        "lea (%%"FF_REG_a", %1, 4), %%"FF_REG_d"\n\t"
++//      0       1       2       3       4       5       6       7       8       9
++//      %0      eax     eax+%1  eax+2%1 %0+4%1  edx     edx+%1  edx+2%1 %0+8%1  edx+4%1
++
++        "movq (%2), %%mm0                       \n\t" // L0
++        "movq (%%"FF_REG_a"), %%mm1             \n\t" // L2
++        PAVGB(%%mm1, %%mm0)                           // L0+L2
++        "movq (%0), %%mm2                       \n\t" // L1
++        PAVGB(%%mm2, %%mm0)
++        "movq %%mm0, (%0)                       \n\t"
++        "movq (%%"FF_REG_a", %1), %%mm0         \n\t" // L3
++        PAVGB(%%mm0, %%mm2)                           // L1+L3
++        PAVGB(%%mm1, %%mm2)                           // 2L2 + L1 + L3
++        "movq %%mm2, (%%"FF_REG_a")             \n\t"
++        "movq (%%"FF_REG_a", %1, 2), %%mm2      \n\t" // L4
++        PAVGB(%%mm2, %%mm1)                           // L2+L4
++        PAVGB(%%mm0, %%mm1)                           // 2L3 + L2 + L4
++        "movq %%mm1, (%%"FF_REG_a", %1)         \n\t"
++        "movq (%0, %1, 4), %%mm1                \n\t" // L5
++        PAVGB(%%mm1, %%mm0)                           // L3+L5
++        PAVGB(%%mm2, %%mm0)                           // 2L4 + L3 + L5
++        "movq %%mm0, (%%"FF_REG_a", %1, 2)      \n\t"
++        "movq (%%"FF_REG_d"), %%mm0             \n\t" // L6
++        PAVGB(%%mm0, %%mm2)                           // L4+L6
++        PAVGB(%%mm1, %%mm2)                           // 2L5 + L4 + L6
++        "movq %%mm2, (%0, %1, 4)                \n\t"
++        "movq (%%"FF_REG_d", %1), %%mm2         \n\t" // L7
++        PAVGB(%%mm2, %%mm1)                           // L5+L7
++        PAVGB(%%mm0, %%mm1)                           // 2L6 + L5 + L7
++        "movq %%mm1, (%%"FF_REG_d")             \n\t"
++        "movq (%%"FF_REG_d", %1, 2), %%mm1      \n\t" // L8
++        PAVGB(%%mm1, %%mm0)                           // L6+L8
++        PAVGB(%%mm2, %%mm0)                           // 2L7 + L6 + L8
++        "movq %%mm0, (%%"FF_REG_d", %1)         \n\t"
++        "movq (%0, %1, 8), %%mm0                \n\t" // L9
++        PAVGB(%%mm0, %%mm2)                           // L7+L9
++        PAVGB(%%mm1, %%mm2)                           // 2L8 + L7 + L9
++        "movq %%mm2, (%%"FF_REG_d", %1, 2)      \n\t"
++        "movq %%mm1, (%2)                       \n\t"
++
++        : : "r" (src), "r" ((x86_reg)stride), "r" (tmp)
++        : "%"FF_REG_a, "%"FF_REG_d
++    );
++#else //TEMPLATE_PP_MMXEXT
++    int a, b, c, x;
++    src+= 4*stride;
++
++    for(x=0; x<2; x++){
++        a= *(uint32_t*)&tmp[stride*0];
++        b= *(uint32_t*)&src[stride*0];
++        c= *(uint32_t*)&src[stride*1];
++        a= (a&c) + (((a^c)&0xFEFEFEFEUL)>>1);
++        *(uint32_t*)&src[stride*0]= (a|b) - (((a^b)&0xFEFEFEFEUL)>>1);
++
++        a= *(uint32_t*)&src[stride*2];
++        b= (a&b) + (((a^b)&0xFEFEFEFEUL)>>1);
++        *(uint32_t*)&src[stride*1]= (c|b) - (((c^b)&0xFEFEFEFEUL)>>1);
++
++        b= *(uint32_t*)&src[stride*3];
++        c= (b&c) + (((b^c)&0xFEFEFEFEUL)>>1);
++        *(uint32_t*)&src[stride*2]= (c|a) - (((c^a)&0xFEFEFEFEUL)>>1);
++
++        c= *(uint32_t*)&src[stride*4];
++        a= (a&c) + (((a^c)&0xFEFEFEFEUL)>>1);
++        *(uint32_t*)&src[stride*3]= (a|b) - (((a^b)&0xFEFEFEFEUL)>>1);
++
++        a= *(uint32_t*)&src[stride*5];
++        b= (a&b) + (((a^b)&0xFEFEFEFEUL)>>1);
++        *(uint32_t*)&src[stride*4]= (c|b) - (((c^b)&0xFEFEFEFEUL)>>1);
++
++        b= *(uint32_t*)&src[stride*6];
++        c= (b&c) + (((b^c)&0xFEFEFEFEUL)>>1);
++        *(uint32_t*)&src[stride*5]= (c|a) - (((c^a)&0xFEFEFEFEUL)>>1);
++
++        c= *(uint32_t*)&src[stride*7];
++        a= (a&c) + (((a^c)&0xFEFEFEFEUL)>>1);
++        *(uint32_t*)&src[stride*6]= (a|b) - (((a^b)&0xFEFEFEFEUL)>>1);
++
++        a= *(uint32_t*)&src[stride*8];
++        b= (a&b) + (((a^b)&0xFEFEFEFEUL)>>1);
++        *(uint32_t*)&src[stride*7]= (c|b) - (((c^b)&0xFEFEFEFEUL)>>1);
++
++        *(uint32_t*)&tmp[stride*0]= c;
++        src += 4;
++        tmp += 4;
++    }
++#endif //TEMPLATE_PP_MMXEXT
++}
++
++/**
++ * Deinterlace the given block by applying a median filter to every second line.
++ * will be called for every 8x8 block and can read & write from line 4-15,
++ * lines 0-3 have been passed through the deblock / dering filters already, but can be read, too.
++ * lines 4-12 will be read into the deblocking filter and should be deinterlaced
++ */
++static inline void RENAME(deInterlaceMedian)(uint8_t src[], int stride)
++{
++#if TEMPLATE_PP_MMXEXT
++    src+= 4*stride;
++    __asm__ volatile(
++        "lea (%0, %1), %%"FF_REG_a"             \n\t"
++        "lea (%%"FF_REG_a", %1, 4), %%"FF_REG_d"\n\t"
++//      0       1       2       3       4       5       6       7       8       9
++//      %0      eax     eax+%1  eax+2%1 %0+4%1  edx     edx+%1  edx+2%1 %0+8%1  edx+4%1
++
++        "movq (%0), %%mm0                       \n\t"
++        "movq (%%"FF_REG_a", %1), %%mm2         \n\t"
++        "movq (%%"FF_REG_a"), %%mm1             \n\t"
++        "movq %%mm0, %%mm3                      \n\t"
++        "pmaxub %%mm1, %%mm0                    \n\t"
++        "pminub %%mm3, %%mm1                    \n\t"
++        "pmaxub %%mm2, %%mm1                    \n\t"
++        "pminub %%mm1, %%mm0                    \n\t"
++        "movq %%mm0, (%%"FF_REG_a")             \n\t"
++
++        "movq (%0, %1, 4), %%mm0                \n\t"
++        "movq (%%"FF_REG_a", %1, 2), %%mm1      \n\t"
++        "movq %%mm2, %%mm3                      \n\t"
++        "pmaxub %%mm1, %%mm2                    \n\t"
++        "pminub %%mm3, %%mm1                    \n\t"
++        "pmaxub %%mm0, %%mm1                    \n\t"
++        "pminub %%mm1, %%mm2                    \n\t"
++        "movq %%mm2, (%%"FF_REG_a", %1, 2)      \n\t"
++
++        "movq (%%"FF_REG_d"), %%mm2             \n\t"
++        "movq (%%"FF_REG_d", %1), %%mm1         \n\t"
++        "movq %%mm2, %%mm3                      \n\t"
++        "pmaxub %%mm0, %%mm2                    \n\t"
++        "pminub %%mm3, %%mm0                    \n\t"
++        "pmaxub %%mm1, %%mm0                    \n\t"
++        "pminub %%mm0, %%mm2                    \n\t"
++        "movq %%mm2, (%%"FF_REG_d")             \n\t"
++
++        "movq (%%"FF_REG_d", %1, 2), %%mm2      \n\t"
++        "movq (%0, %1, 8), %%mm0                \n\t"
++        "movq %%mm2, %%mm3                      \n\t"
++        "pmaxub %%mm0, %%mm2                    \n\t"
++        "pminub %%mm3, %%mm0                    \n\t"
++        "pmaxub %%mm1, %%mm0                    \n\t"
++        "pminub %%mm0, %%mm2                    \n\t"
++        "movq %%mm2, (%%"FF_REG_d", %1, 2)      \n\t"
++
++
++        : : "r" (src), "r" ((x86_reg)stride)
++        : "%"FF_REG_a, "%"FF_REG_d
++    );
++
++#else //TEMPLATE_PP_MMX
++    int x, y;
++    src+= 4*stride;
++    // FIXME - there should be a way to do a few columns in parallel like w/mmx
++    for(x=0; x<8; x++){
++        uint8_t *colsrc = src;
++        for (y=0; y<4; y++){
++            int a, b, c, d, e, f;
++            a = colsrc[0       ];
++            b = colsrc[stride  ];
++            c = colsrc[stride*2];
++            d = (a-b)>>31;
++            e = (b-c)>>31;
++            f = (c-a)>>31;
++            colsrc[stride  ] = (a|(d^f)) & (b|(d^e)) & (c|(e^f));
++            colsrc += stride*2;
++        }
++        src++;
++    }
++#endif //TEMPLATE_PP_MMX
++}
++
++#if TEMPLATE_PP_MMX
++/**
++ * Transpose and shift the given 8x8 Block into dst1 and dst2.
++ */
++static inline void RENAME(transpose1)(uint8_t *dst1, uint8_t *dst2, const uint8_t *src, int srcStride)
++{
++    __asm__(
++        "lea (%0, %1), %%"FF_REG_a"             \n\t"
++//      0       1       2       3       4       5       6       7       8       9
++//      %0      eax     eax+%1  eax+2%1 %0+4%1  edx     edx+%1  edx+2%1 %0+8%1  edx+4%1
++        "movq (%0), %%mm0                       \n\t" // 12345678
++        "movq (%%"FF_REG_a"), %%mm1             \n\t" // abcdefgh
++        "movq %%mm0, %%mm2                      \n\t" // 12345678
++        "punpcklbw %%mm1, %%mm0                 \n\t" // 1a2b3c4d
++        "punpckhbw %%mm1, %%mm2                 \n\t" // 5e6f7g8h
++
++        "movq (%%"FF_REG_a", %1), %%mm1         \n\t"
++        "movq (%%"FF_REG_a", %1, 2), %%mm3      \n\t"
++        "movq %%mm1, %%mm4                      \n\t"
++        "punpcklbw %%mm3, %%mm1                 \n\t"
++        "punpckhbw %%mm3, %%mm4                 \n\t"
++
++        "movq %%mm0, %%mm3                      \n\t"
++        "punpcklwd %%mm1, %%mm0                 \n\t"
++        "punpckhwd %%mm1, %%mm3                 \n\t"
++        "movq %%mm2, %%mm1                      \n\t"
++        "punpcklwd %%mm4, %%mm2                 \n\t"
++        "punpckhwd %%mm4, %%mm1                 \n\t"
++
++        "movd %%mm0, 128(%2)                    \n\t"
++        "psrlq $32, %%mm0                       \n\t"
++        "movd %%mm0, 144(%2)                    \n\t"
++        "movd %%mm3, 160(%2)                    \n\t"
++        "psrlq $32, %%mm3                       \n\t"
++        "movd %%mm3, 176(%2)                    \n\t"
++        "movd %%mm3, 48(%3)                     \n\t"
++        "movd %%mm2, 192(%2)                    \n\t"
++        "movd %%mm2, 64(%3)                     \n\t"
++        "psrlq $32, %%mm2                       \n\t"
++        "movd %%mm2, 80(%3)                     \n\t"
++        "movd %%mm1, 96(%3)                     \n\t"
++        "psrlq $32, %%mm1                       \n\t"
++        "movd %%mm1, 112(%3)                    \n\t"
++
++        "lea (%%"FF_REG_a", %1, 4), %%"FF_REG_a"\n\t"
++
++        "movq (%0, %1, 4), %%mm0                \n\t" // 12345678
++        "movq (%%"FF_REG_a"), %%mm1             \n\t" // abcdefgh
++        "movq %%mm0, %%mm2                      \n\t" // 12345678
++        "punpcklbw %%mm1, %%mm0                 \n\t" // 1a2b3c4d
++        "punpckhbw %%mm1, %%mm2                 \n\t" // 5e6f7g8h
++
++        "movq (%%"FF_REG_a", %1), %%mm1         \n\t"
++        "movq (%%"FF_REG_a", %1, 2), %%mm3      \n\t"
++        "movq %%mm1, %%mm4                      \n\t"
++        "punpcklbw %%mm3, %%mm1                 \n\t"
++        "punpckhbw %%mm3, %%mm4                 \n\t"
++
++        "movq %%mm0, %%mm3                      \n\t"
++        "punpcklwd %%mm1, %%mm0                 \n\t"
++        "punpckhwd %%mm1, %%mm3                 \n\t"
++        "movq %%mm2, %%mm1                      \n\t"
++        "punpcklwd %%mm4, %%mm2                 \n\t"
++        "punpckhwd %%mm4, %%mm1                 \n\t"
++
++        "movd %%mm0, 132(%2)                    \n\t"
++        "psrlq $32, %%mm0                       \n\t"
++        "movd %%mm0, 148(%2)                    \n\t"
++        "movd %%mm3, 164(%2)                    \n\t"
++        "psrlq $32, %%mm3                       \n\t"
++        "movd %%mm3, 180(%2)                    \n\t"
++        "movd %%mm3, 52(%3)                     \n\t"
++        "movd %%mm2, 196(%2)                    \n\t"
++        "movd %%mm2, 68(%3)                     \n\t"
++        "psrlq $32, %%mm2                       \n\t"
++        "movd %%mm2, 84(%3)                     \n\t"
++        "movd %%mm1, 100(%3)                    \n\t"
++        "psrlq $32, %%mm1                       \n\t"
++        "movd %%mm1, 116(%3)                    \n\t"
++
++
++        :: "r" (src), "r" ((x86_reg)srcStride), "r" (dst1), "r" (dst2)
++        : "%"FF_REG_a
++    );
++}
++
++/**
++ * Transpose the given 8x8 block.
++ */
++static inline void RENAME(transpose2)(uint8_t *dst, int dstStride, const uint8_t *src)
++{
++    __asm__(
++        "lea (%0, %1), %%"FF_REG_a"             \n\t"
++        "lea (%%"FF_REG_a",%1,4), %%"FF_REG_d"  \n\t"
++//      0       1       2       3       4       5       6       7       8       9
++//      %0      eax     eax+%1  eax+2%1 %0+4%1  edx     edx+%1  edx+2%1 %0+8%1  edx+4%1
++        "movq (%2), %%mm0                       \n\t" // 12345678
++        "movq 16(%2), %%mm1                     \n\t" // abcdefgh
++        "movq %%mm0, %%mm2                      \n\t" // 12345678
++        "punpcklbw %%mm1, %%mm0                 \n\t" // 1a2b3c4d
++        "punpckhbw %%mm1, %%mm2                 \n\t" // 5e6f7g8h
++
++        "movq 32(%2), %%mm1                     \n\t"
++        "movq 48(%2), %%mm3                     \n\t"
++        "movq %%mm1, %%mm4                      \n\t"
++        "punpcklbw %%mm3, %%mm1                 \n\t"
++        "punpckhbw %%mm3, %%mm4                 \n\t"
++
++        "movq %%mm0, %%mm3                      \n\t"
++        "punpcklwd %%mm1, %%mm0                 \n\t"
++        "punpckhwd %%mm1, %%mm3                 \n\t"
++        "movq %%mm2, %%mm1                      \n\t"
++        "punpcklwd %%mm4, %%mm2                 \n\t"
++        "punpckhwd %%mm4, %%mm1                 \n\t"
++
++        "movd %%mm0, (%0)                       \n\t"
++        "psrlq $32, %%mm0                       \n\t"
++        "movd %%mm0, (%%"FF_REG_a")             \n\t"
++        "movd %%mm3, (%%"FF_REG_a", %1)         \n\t"
++        "psrlq $32, %%mm3                       \n\t"
++        "movd %%mm3, (%%"FF_REG_a", %1, 2)      \n\t"
++        "movd %%mm2, (%0, %1, 4)                \n\t"
++        "psrlq $32, %%mm2                       \n\t"
++        "movd %%mm2, (%%"FF_REG_d")             \n\t"
++        "movd %%mm1, (%%"FF_REG_d", %1)         \n\t"
++        "psrlq $32, %%mm1                       \n\t"
++        "movd %%mm1, (%%"FF_REG_d", %1, 2)      \n\t"
++
++
++        "movq 64(%2), %%mm0                     \n\t" // 12345678
++        "movq 80(%2), %%mm1                     \n\t" // abcdefgh
++        "movq %%mm0, %%mm2                      \n\t" // 12345678
++        "punpcklbw %%mm1, %%mm0                 \n\t" // 1a2b3c4d
++        "punpckhbw %%mm1, %%mm2                 \n\t" // 5e6f7g8h
++
++        "movq 96(%2), %%mm1                     \n\t"
++        "movq 112(%2), %%mm3                    \n\t"
++        "movq %%mm1, %%mm4                      \n\t"
++        "punpcklbw %%mm3, %%mm1                 \n\t"
++        "punpckhbw %%mm3, %%mm4                 \n\t"
++
++        "movq %%mm0, %%mm3                      \n\t"
++        "punpcklwd %%mm1, %%mm0                 \n\t"
++        "punpckhwd %%mm1, %%mm3                 \n\t"
++        "movq %%mm2, %%mm1                      \n\t"
++        "punpcklwd %%mm4, %%mm2                 \n\t"
++        "punpckhwd %%mm4, %%mm1                 \n\t"
++
++        "movd %%mm0, 4(%0)                      \n\t"
++        "psrlq $32, %%mm0                       \n\t"
++        "movd %%mm0, 4(%%"FF_REG_a")            \n\t"
++        "movd %%mm3, 4(%%"FF_REG_a", %1)        \n\t"
++        "psrlq $32, %%mm3                       \n\t"
++        "movd %%mm3, 4(%%"FF_REG_a", %1, 2)     \n\t"
++        "movd %%mm2, 4(%0, %1, 4)               \n\t"
++        "psrlq $32, %%mm2                       \n\t"
++        "movd %%mm2, 4(%%"FF_REG_d")            \n\t"
++        "movd %%mm1, 4(%%"FF_REG_d", %1)        \n\t"
++        "psrlq $32, %%mm1                       \n\t"
++        "movd %%mm1, 4(%%"FF_REG_d", %1, 2)     \n\t"
++
++        :: "r" (dst), "r" ((x86_reg)dstStride), "r" (src)
++        : "%"FF_REG_a, "%"FF_REG_d
++    );
++}
++#endif //TEMPLATE_PP_MMX
++//static long test=0;
++
++#if !TEMPLATE_PP_ALTIVEC
++static inline void RENAME(tempNoiseReducer)(uint8_t *src, int stride,
++                                    uint8_t *tempBlurred, uint32_t *tempBlurredPast, const int *maxNoise)
++{
++    // to save a register (FIXME do this outside of the loops)
++    tempBlurredPast[127]= maxNoise[0];
++    tempBlurredPast[128]= maxNoise[1];
++    tempBlurredPast[129]= maxNoise[2];
++
++#define FAST_L2_DIFF
++//#define L1_DIFF //u should change the thresholds too if u try that one
++#if TEMPLATE_PP_MMXEXT && HAVE_6REGS
++    __asm__ volatile(
++        "lea (%2, %2, 2), %%"FF_REG_a"          \n\t" // 3*stride
++        "lea (%2, %2, 4), %%"FF_REG_d"          \n\t" // 5*stride
++        "lea (%%"FF_REG_d", %2, 2), %%"FF_REG_c"\n\t" // 7*stride
++//      0       1       2       3       4       5       6       7       8       9
++//      %x      %x+%2   %x+2%2  %x+eax  %x+4%2  %x+edx  %x+2eax %x+ecx  %x+8%2
++//FIXME reorder?
++#ifdef L1_DIFF //needs mmx2
++        "movq (%0), %%mm0                       \n\t" // L0
++        "psadbw (%1), %%mm0                     \n\t" // |L0-R0|
++        "movq (%0, %2), %%mm1                   \n\t" // L1
++        "psadbw (%1, %2), %%mm1                 \n\t" // |L1-R1|
++        "movq (%0, %2, 2), %%mm2                \n\t" // L2
++        "psadbw (%1, %2, 2), %%mm2              \n\t" // |L2-R2|
++        "movq (%0, %%"FF_REG_a"), %%mm3         \n\t" // L3
++        "psadbw (%1, %%"FF_REG_a"), %%mm3       \n\t" // |L3-R3|
++
++        "movq (%0, %2, 4), %%mm4                \n\t" // L4
++        "paddw %%mm1, %%mm0                     \n\t"
++        "psadbw (%1, %2, 4), %%mm4              \n\t" // |L4-R4|
++        "movq (%0, %%"FF_REG_d"), %%mm5         \n\t" // L5
++        "paddw %%mm2, %%mm0                     \n\t"
++        "psadbw (%1, %%"FF_REG_d"), %%mm5       \n\t" // |L5-R5|
++        "movq (%0, %%"FF_REG_a", 2), %%mm6      \n\t" // L6
++        "paddw %%mm3, %%mm0                     \n\t"
++        "psadbw (%1, %%"FF_REG_a", 2), %%mm6    \n\t" // |L6-R6|
++        "movq (%0, %%"FF_REG_c"), %%mm7         \n\t" // L7
++        "paddw %%mm4, %%mm0                     \n\t"
++        "psadbw (%1, %%"FF_REG_c"), %%mm7       \n\t" // |L7-R7|
++        "paddw %%mm5, %%mm6                     \n\t"
++        "paddw %%mm7, %%mm6                     \n\t"
++        "paddw %%mm6, %%mm0                     \n\t"
++#else //L1_DIFF
++#if defined (FAST_L2_DIFF)
++        "pcmpeqb %%mm7, %%mm7                   \n\t"
++        "movq "MANGLE(b80)", %%mm6              \n\t"
++        "pxor %%mm0, %%mm0                      \n\t"
++#define REAL_L2_DIFF_CORE(a, b)\
++        "movq " #a ", %%mm5                     \n\t"\
++        "movq " #b ", %%mm2                     \n\t"\
++        "pxor %%mm7, %%mm2                      \n\t"\
++        PAVGB(%%mm2, %%mm5)\
++        "paddb %%mm6, %%mm5                     \n\t"\
++        "movq %%mm5, %%mm2                      \n\t"\
++        "psllw $8, %%mm5                        \n\t"\
++        "pmaddwd %%mm5, %%mm5                   \n\t"\
++        "pmaddwd %%mm2, %%mm2                   \n\t"\
++        "paddd %%mm2, %%mm5                     \n\t"\
++        "psrld $14, %%mm5                       \n\t"\
++        "paddd %%mm5, %%mm0                     \n\t"
++
++#else //defined (FAST_L2_DIFF)
++        "pxor %%mm7, %%mm7                      \n\t"
++        "pxor %%mm0, %%mm0                      \n\t"
++#define REAL_L2_DIFF_CORE(a, b)\
++        "movq " #a ", %%mm5                     \n\t"\
++        "movq " #b ", %%mm2                     \n\t"\
++        "movq %%mm5, %%mm1                      \n\t"\
++        "movq %%mm2, %%mm3                      \n\t"\
++        "punpcklbw %%mm7, %%mm5                 \n\t"\
++        "punpckhbw %%mm7, %%mm1                 \n\t"\
++        "punpcklbw %%mm7, %%mm2                 \n\t"\
++        "punpckhbw %%mm7, %%mm3                 \n\t"\
++        "psubw %%mm2, %%mm5                     \n\t"\
++        "psubw %%mm3, %%mm1                     \n\t"\
++        "pmaddwd %%mm5, %%mm5                   \n\t"\
++        "pmaddwd %%mm1, %%mm1                   \n\t"\
++        "paddd %%mm1, %%mm5                     \n\t"\
++        "paddd %%mm5, %%mm0                     \n\t"
++
++#endif //defined (FAST_L2_DIFF)
++
++#define L2_DIFF_CORE(a, b)  REAL_L2_DIFF_CORE(a, b)
++
++L2_DIFF_CORE((%0)             , (%1))
++L2_DIFF_CORE((%0, %2)         , (%1, %2))
++L2_DIFF_CORE((%0, %2, 2)      , (%1, %2, 2))
++L2_DIFF_CORE((%0, %%FF_REGa)  , (%1, %%FF_REGa))
++L2_DIFF_CORE((%0, %2, 4)      , (%1, %2, 4))
++L2_DIFF_CORE((%0, %%FF_REGd)  , (%1, %%FF_REGd))
++L2_DIFF_CORE((%0, %%FF_REGa,2), (%1, %%FF_REGa,2))
++L2_DIFF_CORE((%0, %%FF_REGc)  , (%1, %%FF_REGc))
++
++#endif //L1_DIFF
++
++        "movq %%mm0, %%mm4                      \n\t"
++        "psrlq $32, %%mm0                       \n\t"
++        "paddd %%mm0, %%mm4                     \n\t"
++        "movd %%mm4, %%ecx                      \n\t"
++        "shll $2, %%ecx                         \n\t"
++        "mov %3, %%"FF_REG_d"                   \n\t"
++        "addl -4(%%"FF_REG_d"), %%ecx           \n\t"
++        "addl 4(%%"FF_REG_d"), %%ecx            \n\t"
++        "addl -1024(%%"FF_REG_d"), %%ecx        \n\t"
++        "addl $4, %%ecx                         \n\t"
++        "addl 1024(%%"FF_REG_d"), %%ecx         \n\t"
++        "shrl $3, %%ecx                         \n\t"
++        "movl %%ecx, (%%"FF_REG_d")             \n\t"
++
++//        "mov %3, %%"FF_REG_c"                   \n\t"
++//        "mov %%"FF_REG_c", test                 \n\t"
++//        "jmp 4f                                 \n\t"
++        "cmpl 512(%%"FF_REG_d"), %%ecx          \n\t"
++        " jb 2f                                 \n\t"
++        "cmpl 516(%%"FF_REG_d"), %%ecx          \n\t"
++        " jb 1f                                 \n\t"
++
++        "lea (%%"FF_REG_a", %2, 2), %%"FF_REG_d"\n\t" // 5*stride
++        "lea (%%"FF_REG_d", %2, 2), %%"FF_REG_c"\n\t" // 7*stride
++        "movq (%0), %%mm0                       \n\t" // L0
++        "movq (%0, %2), %%mm1                   \n\t" // L1
++        "movq (%0, %2, 2), %%mm2                \n\t" // L2
++        "movq (%0, %%"FF_REG_a"), %%mm3         \n\t" // L3
++        "movq (%0, %2, 4), %%mm4                \n\t" // L4
++        "movq (%0, %%"FF_REG_d"), %%mm5         \n\t" // L5
++        "movq (%0, %%"FF_REG_a", 2), %%mm6      \n\t" // L6
++        "movq (%0, %%"FF_REG_c"), %%mm7         \n\t" // L7
++        "movq %%mm0, (%1)                       \n\t" // L0
++        "movq %%mm1, (%1, %2)                   \n\t" // L1
++        "movq %%mm2, (%1, %2, 2)                \n\t" // L2
++        "movq %%mm3, (%1, %%"FF_REG_a")         \n\t" // L3
++        "movq %%mm4, (%1, %2, 4)                \n\t" // L4
++        "movq %%mm5, (%1, %%"FF_REG_d")         \n\t" // L5
++        "movq %%mm6, (%1, %%"FF_REG_a", 2)      \n\t" // L6
++        "movq %%mm7, (%1, %%"FF_REG_c")         \n\t" // L7
++        "jmp 4f                                 \n\t"
++
++        "1:                                     \n\t"
++        "lea (%%"FF_REG_a", %2, 2), %%"FF_REG_d"\n\t" // 5*stride
++        "lea (%%"FF_REG_d", %2, 2), %%"FF_REG_c"\n\t" // 7*stride
++        "movq (%0), %%mm0                       \n\t" // L0
++        PAVGB((%1), %%mm0)                            // L0
++        "movq (%0, %2), %%mm1                   \n\t" // L1
++        PAVGB((%1, %2), %%mm1)                        // L1
++        "movq (%0, %2, 2), %%mm2                \n\t" // L2
++        PAVGB((%1, %2, 2), %%mm2)                     // L2
++        "movq (%0, %%"FF_REG_a"), %%mm3         \n\t" // L3
++        PAVGB((%1, %%FF_REGa), %%mm3)                 // L3
++        "movq (%0, %2, 4), %%mm4                \n\t" // L4
++        PAVGB((%1, %2, 4), %%mm4)                     // L4
++        "movq (%0, %%"FF_REG_d"), %%mm5         \n\t" // L5
++        PAVGB((%1, %%FF_REGd), %%mm5)                 // L5
++        "movq (%0, %%"FF_REG_a", 2), %%mm6      \n\t" // L6
++        PAVGB((%1, %%FF_REGa, 2), %%mm6)              // L6
++        "movq (%0, %%"FF_REG_c"), %%mm7         \n\t" // L7
++        PAVGB((%1, %%FF_REGc), %%mm7)                 // L7
++        "movq %%mm0, (%1)                       \n\t" // R0
++        "movq %%mm1, (%1, %2)                   \n\t" // R1
++        "movq %%mm2, (%1, %2, 2)                \n\t" // R2
++        "movq %%mm3, (%1, %%"FF_REG_a")         \n\t" // R3
++        "movq %%mm4, (%1, %2, 4)                \n\t" // R4
++        "movq %%mm5, (%1, %%"FF_REG_d")         \n\t" // R5
++        "movq %%mm6, (%1, %%"FF_REG_a", 2)      \n\t" // R6
++        "movq %%mm7, (%1, %%"FF_REG_c")         \n\t" // R7
++        "movq %%mm0, (%0)                       \n\t" // L0
++        "movq %%mm1, (%0, %2)                   \n\t" // L1
++        "movq %%mm2, (%0, %2, 2)                \n\t" // L2
++        "movq %%mm3, (%0, %%"FF_REG_a")         \n\t" // L3
++        "movq %%mm4, (%0, %2, 4)                \n\t" // L4
++        "movq %%mm5, (%0, %%"FF_REG_d")         \n\t" // L5
++        "movq %%mm6, (%0, %%"FF_REG_a", 2)      \n\t" // L6
++        "movq %%mm7, (%0, %%"FF_REG_c")         \n\t" // L7
++        "jmp 4f                                 \n\t"
++
++        "2:                                     \n\t"
++        "cmpl 508(%%"FF_REG_d"), %%ecx          \n\t"
++        " jb 3f                                 \n\t"
++
++        "lea (%%"FF_REG_a", %2, 2), %%"FF_REG_d"\n\t" // 5*stride
++        "lea (%%"FF_REG_d", %2, 2), %%"FF_REG_c"\n\t" // 7*stride
++        "movq (%0), %%mm0                       \n\t" // L0
++        "movq (%0, %2), %%mm1                   \n\t" // L1
++        "movq (%0, %2, 2), %%mm2                \n\t" // L2
++        "movq (%0, %%"FF_REG_a"), %%mm3         \n\t" // L3
++        "movq (%1), %%mm4                       \n\t" // R0
++        "movq (%1, %2), %%mm5                   \n\t" // R1
++        "movq (%1, %2, 2), %%mm6                \n\t" // R2
++        "movq (%1, %%"FF_REG_a"), %%mm7         \n\t" // R3
++        PAVGB(%%mm4, %%mm0)
++        PAVGB(%%mm5, %%mm1)
++        PAVGB(%%mm6, %%mm2)
++        PAVGB(%%mm7, %%mm3)
++        PAVGB(%%mm4, %%mm0)
++        PAVGB(%%mm5, %%mm1)
++        PAVGB(%%mm6, %%mm2)
++        PAVGB(%%mm7, %%mm3)
++        "movq %%mm0, (%1)                       \n\t" // R0
++        "movq %%mm1, (%1, %2)                   \n\t" // R1
++        "movq %%mm2, (%1, %2, 2)                \n\t" // R2
++        "movq %%mm3, (%1, %%"FF_REG_a")         \n\t" // R3
++        "movq %%mm0, (%0)                       \n\t" // L0
++        "movq %%mm1, (%0, %2)                   \n\t" // L1
++        "movq %%mm2, (%0, %2, 2)                \n\t" // L2
++        "movq %%mm3, (%0, %%"FF_REG_a")         \n\t" // L3
++
++        "movq (%0, %2, 4), %%mm0                \n\t" // L4
++        "movq (%0, %%"FF_REG_d"), %%mm1         \n\t" // L5
++        "movq (%0, %%"FF_REG_a", 2), %%mm2      \n\t" // L6
++        "movq (%0, %%"FF_REG_c"), %%mm3         \n\t" // L7
++        "movq (%1, %2, 4), %%mm4                \n\t" // R4
++        "movq (%1, %%"FF_REG_d"), %%mm5         \n\t" // R5
++        "movq (%1, %%"FF_REG_a", 2), %%mm6      \n\t" // R6
++        "movq (%1, %%"FF_REG_c"), %%mm7         \n\t" // R7
++        PAVGB(%%mm4, %%mm0)
++        PAVGB(%%mm5, %%mm1)
++        PAVGB(%%mm6, %%mm2)
++        PAVGB(%%mm7, %%mm3)
++        PAVGB(%%mm4, %%mm0)
++        PAVGB(%%mm5, %%mm1)
++        PAVGB(%%mm6, %%mm2)
++        PAVGB(%%mm7, %%mm3)
++        "movq %%mm0, (%1, %2, 4)                \n\t" // R4
++        "movq %%mm1, (%1, %%"FF_REG_d")         \n\t" // R5
++        "movq %%mm2, (%1, %%"FF_REG_a", 2)      \n\t" // R6
++        "movq %%mm3, (%1, %%"FF_REG_c")         \n\t" // R7
++        "movq %%mm0, (%0, %2, 4)                \n\t" // L4
++        "movq %%mm1, (%0, %%"FF_REG_d")         \n\t" // L5
++        "movq %%mm2, (%0, %%"FF_REG_a", 2)      \n\t" // L6
++        "movq %%mm3, (%0, %%"FF_REG_c")         \n\t" // L7
++        "jmp 4f                                 \n\t"
++
++        "3:                                     \n\t"
++        "lea (%%"FF_REG_a", %2, 2), %%"FF_REG_d"\n\t" // 5*stride
++        "lea (%%"FF_REG_d", %2, 2), %%"FF_REG_c"\n\t" // 7*stride
++        "movq (%0), %%mm0                       \n\t" // L0
++        "movq (%0, %2), %%mm1                   \n\t" // L1
++        "movq (%0, %2, 2), %%mm2                \n\t" // L2
++        "movq (%0, %%"FF_REG_a"), %%mm3         \n\t" // L3
++        "movq (%1), %%mm4                       \n\t" // R0
++        "movq (%1, %2), %%mm5                   \n\t" // R1
++        "movq (%1, %2, 2), %%mm6                \n\t" // R2
++        "movq (%1, %%"FF_REG_a"), %%mm7         \n\t" // R3
++        PAVGB(%%mm4, %%mm0)
++        PAVGB(%%mm5, %%mm1)
++        PAVGB(%%mm6, %%mm2)
++        PAVGB(%%mm7, %%mm3)
++        PAVGB(%%mm4, %%mm0)
++        PAVGB(%%mm5, %%mm1)
++        PAVGB(%%mm6, %%mm2)
++        PAVGB(%%mm7, %%mm3)
++        PAVGB(%%mm4, %%mm0)
++        PAVGB(%%mm5, %%mm1)
++        PAVGB(%%mm6, %%mm2)
++        PAVGB(%%mm7, %%mm3)
++        "movq %%mm0, (%1)                       \n\t" // R0
++        "movq %%mm1, (%1, %2)                   \n\t" // R1
++        "movq %%mm2, (%1, %2, 2)                \n\t" // R2
++        "movq %%mm3, (%1, %%"FF_REG_a")         \n\t" // R3
++        "movq %%mm0, (%0)                       \n\t" // L0
++        "movq %%mm1, (%0, %2)                   \n\t" // L1
++        "movq %%mm2, (%0, %2, 2)                \n\t" // L2
++        "movq %%mm3, (%0, %%"FF_REG_a")         \n\t" // L3
++
++        "movq (%0, %2, 4), %%mm0                \n\t" // L4
++        "movq (%0, %%"FF_REG_d"), %%mm1         \n\t" // L5
++        "movq (%0, %%"FF_REG_a", 2), %%mm2      \n\t" // L6
++        "movq (%0, %%"FF_REG_c"), %%mm3         \n\t" // L7
++        "movq (%1, %2, 4), %%mm4                \n\t" // R4
++        "movq (%1, %%"FF_REG_d"), %%mm5         \n\t" // R5
++        "movq (%1, %%"FF_REG_a", 2), %%mm6      \n\t" // R6
++        "movq (%1, %%"FF_REG_c"), %%mm7         \n\t" // R7
++        PAVGB(%%mm4, %%mm0)
++        PAVGB(%%mm5, %%mm1)
++        PAVGB(%%mm6, %%mm2)
++        PAVGB(%%mm7, %%mm3)
++        PAVGB(%%mm4, %%mm0)
++        PAVGB(%%mm5, %%mm1)
++        PAVGB(%%mm6, %%mm2)
++        PAVGB(%%mm7, %%mm3)
++        PAVGB(%%mm4, %%mm0)
++        PAVGB(%%mm5, %%mm1)
++        PAVGB(%%mm6, %%mm2)
++        PAVGB(%%mm7, %%mm3)
++        "movq %%mm0, (%1, %2, 4)                \n\t" // R4
++        "movq %%mm1, (%1, %%"FF_REG_d")         \n\t" // R5
++        "movq %%mm2, (%1, %%"FF_REG_a", 2)      \n\t" // R6
++        "movq %%mm3, (%1, %%"FF_REG_c")         \n\t" // R7
++        "movq %%mm0, (%0, %2, 4)                \n\t" // L4
++        "movq %%mm1, (%0, %%"FF_REG_d")         \n\t" // L5
++        "movq %%mm2, (%0, %%"FF_REG_a", 2)      \n\t" // L6
++        "movq %%mm3, (%0, %%"FF_REG_c")         \n\t" // L7
++
++        "4:                                     \n\t"
++
++        :: "r" (src), "r" (tempBlurred), "r"((x86_reg)stride), "m" (tempBlurredPast)
++          NAMED_CONSTRAINTS_ADD(b80)
++        : "%"FF_REG_a, "%"FF_REG_d, "%"FF_REG_c, "memory"
++    );
++#else //TEMPLATE_PP_MMXEXT && HAVE_6REGS
++{
++    int y;
++    int d=0;
++//    int sysd=0;
++    int i;
++
++    for(y=0; y<8; y++){
++        int x;
++        for(x=0; x<8; x++){
++            int ref= tempBlurred[ x + y*stride ];
++            int cur= src[ x + y*stride ];
++            int d1=ref - cur;
++//            if(x==0 || x==7) d1+= d1>>1;
++//            if(y==0 || y==7) d1+= d1>>1;
++//            d+= FFABS(d1);
++            d+= d1*d1;
++//            sysd+= d1;
++        }
++    }
++    i=d;
++    d=  (
++        4*d
++        +(*(tempBlurredPast-256))
++        +(*(tempBlurredPast-1))+ (*(tempBlurredPast+1))
++        +(*(tempBlurredPast+256))
++        +4)>>3;
++    *tempBlurredPast=i;
++//    ((*tempBlurredPast)*3 + d + 2)>>2;
++
++/*
++Switch between
++ 1  0  0  0  0  0  0  (0)
++64 32 16  8  4  2  1  (1)
++64 48 36 27 20 15 11 (33) (approx)
++64 56 49 43 37 33 29 (200) (approx)
++*/
++    if(d > maxNoise[1]){
++        if(d < maxNoise[2]){
++            for(y=0; y<8; y++){
++                int x;
++                for(x=0; x<8; x++){
++                    int ref= tempBlurred[ x + y*stride ];
++                    int cur= src[ x + y*stride ];
++                    tempBlurred[ x + y*stride ]=
++                    src[ x + y*stride ]=
++                        (ref + cur + 1)>>1;
++                }
++            }
++        }else{
++            for(y=0; y<8; y++){
++                int x;
++                for(x=0; x<8; x++){
++                    tempBlurred[ x + y*stride ]= src[ x + y*stride ];
++                }
++            }
++        }
++    }else{
++        if(d < maxNoise[0]){
++            for(y=0; y<8; y++){
++                int x;
++                for(x=0; x<8; x++){
++                    int ref= tempBlurred[ x + y*stride ];
++                    int cur= src[ x + y*stride ];
++                    tempBlurred[ x + y*stride ]=
++                    src[ x + y*stride ]=
++                        (ref*7 + cur + 4)>>3;
++                }
++            }
++        }else{
++            for(y=0; y<8; y++){
++                int x;
++                for(x=0; x<8; x++){
++                    int ref= tempBlurred[ x + y*stride ];
++                    int cur= src[ x + y*stride ];
++                    tempBlurred[ x + y*stride ]=
++                    src[ x + y*stride ]=
++                        (ref*3 + cur + 2)>>2;
++                }
++            }
++        }
++    }
++}
++#endif //TEMPLATE_PP_MMXEXT && HAVE_6REGS
++}
++#endif //TEMPLATE_PP_ALTIVEC
++
++#if TEMPLATE_PP_MMXEXT
++/**
++ * accurate deblock filter
++ */
++static av_always_inline void RENAME(do_a_deblock)(uint8_t *src, int step, int stride, const PPContext *c, int mode){
++    int64_t dc_mask, eq_mask, both_masks;
++    int64_t sums[10*8*2];
++    src+= step*3; // src points to begin of the 8x8 Block
++
++    __asm__ volatile(
++        "movq %0, %%mm7                         \n\t"
++        "movq %1, %%mm6                         \n\t"
++        : : "m" (c->mmxDcOffset[c->nonBQP]),  "m" (c->mmxDcThreshold[c->nonBQP])
++        );
++
++    __asm__ volatile(
++        "lea (%2, %3), %%"FF_REG_a"             \n\t"
++//      0       1       2       3       4       5       6       7       8       9
++//      %1      eax     eax+%2  eax+2%2 %1+4%2  ecx     ecx+%2  ecx+2%2 %1+8%2  ecx+4%2
++
++        "movq (%2), %%mm0                       \n\t"
++        "movq (%%"FF_REG_a"), %%mm1             \n\t"
++        "movq %%mm1, %%mm3                      \n\t"
++        "movq %%mm1, %%mm4                      \n\t"
++        "psubb %%mm1, %%mm0                     \n\t" // mm0 = difference
++        "paddb %%mm7, %%mm0                     \n\t"
++        "pcmpgtb %%mm6, %%mm0                   \n\t"
++
++        "movq (%%"FF_REG_a",%3), %%mm2          \n\t"
++        PMAXUB(%%mm2, %%mm4)
++        PMINUB(%%mm2, %%mm3, %%mm5)
++        "psubb %%mm2, %%mm1                     \n\t"
++        "paddb %%mm7, %%mm1                     \n\t"
++        "pcmpgtb %%mm6, %%mm1                   \n\t"
++        "paddb %%mm1, %%mm0                     \n\t"
++
++        "movq (%%"FF_REG_a", %3, 2), %%mm1      \n\t"
++        PMAXUB(%%mm1, %%mm4)
++        PMINUB(%%mm1, %%mm3, %%mm5)
++        "psubb %%mm1, %%mm2                     \n\t"
++        "paddb %%mm7, %%mm2                     \n\t"
++        "pcmpgtb %%mm6, %%mm2                   \n\t"
++        "paddb %%mm2, %%mm0                     \n\t"
++
++        "lea (%%"FF_REG_a", %3, 4), %%"FF_REG_a"\n\t"
++
++        "movq (%2, %3, 4), %%mm2                \n\t"
++        PMAXUB(%%mm2, %%mm4)
++        PMINUB(%%mm2, %%mm3, %%mm5)
++        "psubb %%mm2, %%mm1                     \n\t"
++        "paddb %%mm7, %%mm1                     \n\t"
++        "pcmpgtb %%mm6, %%mm1                   \n\t"
++        "paddb %%mm1, %%mm0                     \n\t"
++
++        "movq (%%"FF_REG_a"), %%mm1             \n\t"
++        PMAXUB(%%mm1, %%mm4)
++        PMINUB(%%mm1, %%mm3, %%mm5)
++        "psubb %%mm1, %%mm2                     \n\t"
++        "paddb %%mm7, %%mm2                     \n\t"
++        "pcmpgtb %%mm6, %%mm2                   \n\t"
++        "paddb %%mm2, %%mm0                     \n\t"
++
++        "movq (%%"FF_REG_a", %3), %%mm2         \n\t"
++        PMAXUB(%%mm2, %%mm4)
++        PMINUB(%%mm2, %%mm3, %%mm5)
++        "psubb %%mm2, %%mm1                     \n\t"
++        "paddb %%mm7, %%mm1                     \n\t"
++        "pcmpgtb %%mm6, %%mm1                   \n\t"
++        "paddb %%mm1, %%mm0                     \n\t"
++
++        "movq (%%"FF_REG_a", %3, 2), %%mm1      \n\t"
++        PMAXUB(%%mm1, %%mm4)
++        PMINUB(%%mm1, %%mm3, %%mm5)
++        "psubb %%mm1, %%mm2                     \n\t"
++        "paddb %%mm7, %%mm2                     \n\t"
++        "pcmpgtb %%mm6, %%mm2                   \n\t"
++        "paddb %%mm2, %%mm0                     \n\t"
++
++        "movq (%2, %3, 8), %%mm2                \n\t"
++        PMAXUB(%%mm2, %%mm4)
++        PMINUB(%%mm2, %%mm3, %%mm5)
++        "psubb %%mm2, %%mm1                     \n\t"
++        "paddb %%mm7, %%mm1                     \n\t"
++        "pcmpgtb %%mm6, %%mm1                   \n\t"
++        "paddb %%mm1, %%mm0                     \n\t"
++
++        "movq (%%"FF_REG_a", %3, 4), %%mm1      \n\t"
++        "psubb %%mm1, %%mm2                     \n\t"
++        "paddb %%mm7, %%mm2                     \n\t"
++        "pcmpgtb %%mm6, %%mm2                   \n\t"
++        "paddb %%mm2, %%mm0                     \n\t"
++        "psubusb %%mm3, %%mm4                   \n\t"
++
++        "pxor %%mm6, %%mm6                      \n\t"
++        "movq %4, %%mm7                         \n\t" // QP,..., QP
++        "paddusb %%mm7, %%mm7                   \n\t" // 2QP ... 2QP
++        "psubusb %%mm4, %%mm7                   \n\t" // Diff >=2QP -> 0
++        "pcmpeqb %%mm6, %%mm7                   \n\t" // Diff < 2QP -> 0
++        "pcmpeqb %%mm6, %%mm7                   \n\t" // Diff < 2QP -> 0
++        "movq %%mm7, %1                         \n\t"
++
++        "movq %5, %%mm7                         \n\t"
++        "punpcklbw %%mm7, %%mm7                 \n\t"
++        "punpcklbw %%mm7, %%mm7                 \n\t"
++        "punpcklbw %%mm7, %%mm7                 \n\t"
++        "psubb %%mm0, %%mm6                     \n\t"
++        "pcmpgtb %%mm7, %%mm6                   \n\t"
++        "movq %%mm6, %0                         \n\t"
++
++        : "=m" (eq_mask), "=m" (dc_mask)
++        : "r" (src), "r" ((x86_reg)step), "m" (c->pQPb), "m"(c->ppMode.flatnessThreshold)
++        : "%"FF_REG_a
++    );
++
++    both_masks = dc_mask & eq_mask;
++
++    if(both_masks){
++        x86_reg offset= -8*step;
++        int64_t *temp_sums= sums;
++
++        __asm__ volatile(
++            "movq %2, %%mm0                         \n\t"  // QP,..., QP
++            "pxor %%mm4, %%mm4                      \n\t"
++
++            "movq (%0), %%mm6                       \n\t"
++            "movq (%0, %1), %%mm5                   \n\t"
++            "movq %%mm5, %%mm1                      \n\t"
++            "movq %%mm6, %%mm2                      \n\t"
++            "psubusb %%mm6, %%mm5                   \n\t"
++            "psubusb %%mm1, %%mm2                   \n\t"
++            "por %%mm5, %%mm2                       \n\t" // ABS Diff of lines
++            "psubusb %%mm2, %%mm0                   \n\t" // diff >= QP -> 0
++            "pcmpeqb %%mm4, %%mm0                   \n\t" // diff >= QP -> FF
++
++            "pxor %%mm6, %%mm1                      \n\t"
++            "pand %%mm0, %%mm1                      \n\t"
++            "pxor %%mm1, %%mm6                      \n\t"
++            // 0:QP  6:First
++
++            "movq (%0, %1, 8), %%mm5                \n\t"
++            "add %1, %0                             \n\t" // %0 points to line 1 not 0
++            "movq (%0, %1, 8), %%mm7                \n\t"
++            "movq %%mm5, %%mm1                      \n\t"
++            "movq %%mm7, %%mm2                      \n\t"
++            "psubusb %%mm7, %%mm5                   \n\t"
++            "psubusb %%mm1, %%mm2                   \n\t"
++            "por %%mm5, %%mm2                       \n\t" // ABS Diff of lines
++            "movq %2, %%mm0                         \n\t"  // QP,..., QP
++            "psubusb %%mm2, %%mm0                   \n\t" // diff >= QP -> 0
++            "pcmpeqb %%mm4, %%mm0                   \n\t" // diff >= QP -> FF
++
++            "pxor %%mm7, %%mm1                      \n\t"
++            "pand %%mm0, %%mm1                      \n\t"
++            "pxor %%mm1, %%mm7                      \n\t"
++
++            "movq %%mm6, %%mm5                      \n\t"
++            "punpckhbw %%mm4, %%mm6                 \n\t"
++            "punpcklbw %%mm4, %%mm5                 \n\t"
++            // 4:0 5/6:First 7:Last
++
++            "movq %%mm5, %%mm0                      \n\t"
++            "movq %%mm6, %%mm1                      \n\t"
++            "psllw $2, %%mm0                        \n\t"
++            "psllw $2, %%mm1                        \n\t"
++            "paddw "MANGLE(w04)", %%mm0             \n\t"
++            "paddw "MANGLE(w04)", %%mm1             \n\t"
++
++#define NEXT\
++            "movq (%0), %%mm2                       \n\t"\
++            "movq (%0), %%mm3                       \n\t"\
++            "add %1, %0                             \n\t"\
++            "punpcklbw %%mm4, %%mm2                 \n\t"\
++            "punpckhbw %%mm4, %%mm3                 \n\t"\
++            "paddw %%mm2, %%mm0                     \n\t"\
++            "paddw %%mm3, %%mm1                     \n\t"
++
++#define PREV\
++            "movq (%0), %%mm2                       \n\t"\
++            "movq (%0), %%mm3                       \n\t"\
++            "add %1, %0                             \n\t"\
++            "punpcklbw %%mm4, %%mm2                 \n\t"\
++            "punpckhbw %%mm4, %%mm3                 \n\t"\
++            "psubw %%mm2, %%mm0                     \n\t"\
++            "psubw %%mm3, %%mm1                     \n\t"
++
++
++            NEXT //0
++            NEXT //1
++            NEXT //2
++            "movq %%mm0, (%3)                       \n\t"
++            "movq %%mm1, 8(%3)                      \n\t"
++
++            NEXT //3
++            "psubw %%mm5, %%mm0                     \n\t"
++            "psubw %%mm6, %%mm1                     \n\t"
++            "movq %%mm0, 16(%3)                     \n\t"
++            "movq %%mm1, 24(%3)                     \n\t"
++
++            NEXT //4
++            "psubw %%mm5, %%mm0                     \n\t"
++            "psubw %%mm6, %%mm1                     \n\t"
++            "movq %%mm0, 32(%3)                     \n\t"
++            "movq %%mm1, 40(%3)                     \n\t"
++
++            NEXT //5
++            "psubw %%mm5, %%mm0                     \n\t"
++            "psubw %%mm6, %%mm1                     \n\t"
++            "movq %%mm0, 48(%3)                     \n\t"
++            "movq %%mm1, 56(%3)                     \n\t"
++
++            NEXT //6
++            "psubw %%mm5, %%mm0                     \n\t"
++            "psubw %%mm6, %%mm1                     \n\t"
++            "movq %%mm0, 64(%3)                     \n\t"
++            "movq %%mm1, 72(%3)                     \n\t"
++
++            "movq %%mm7, %%mm6                      \n\t"
++            "punpckhbw %%mm4, %%mm7                 \n\t"
++            "punpcklbw %%mm4, %%mm6                 \n\t"
++
++            NEXT //7
++            "mov %4, %0                             \n\t"
++            "add %1, %0                             \n\t"
++            PREV //0
++            "movq %%mm0, 80(%3)                     \n\t"
++            "movq %%mm1, 88(%3)                     \n\t"
++
++            PREV //1
++            "paddw %%mm6, %%mm0                     \n\t"
++            "paddw %%mm7, %%mm1                     \n\t"
++            "movq %%mm0, 96(%3)                     \n\t"
++            "movq %%mm1, 104(%3)                    \n\t"
++
++            PREV //2
++            "paddw %%mm6, %%mm0                     \n\t"
++            "paddw %%mm7, %%mm1                     \n\t"
++            "movq %%mm0, 112(%3)                    \n\t"
++            "movq %%mm1, 120(%3)                    \n\t"
++
++            PREV //3
++            "paddw %%mm6, %%mm0                     \n\t"
++            "paddw %%mm7, %%mm1                     \n\t"
++            "movq %%mm0, 128(%3)                    \n\t"
++            "movq %%mm1, 136(%3)                    \n\t"
++
++            PREV //4
++            "paddw %%mm6, %%mm0                     \n\t"
++            "paddw %%mm7, %%mm1                     \n\t"
++            "movq %%mm0, 144(%3)                    \n\t"
++            "movq %%mm1, 152(%3)                    \n\t"
++
++            "mov %4, %0                             \n\t" //FIXME
++
++            : "+&r"(src)
++            : "r" ((x86_reg)step), "m" (c->pQPb), "r"(sums), "g"(src)
++              NAMED_CONSTRAINTS_ADD(w04)
++        );
++
++        src+= step; // src points to begin of the 8x8 Block
++
++        __asm__ volatile(
++            "movq %4, %%mm6                         \n\t"
++            "pcmpeqb %%mm5, %%mm5                   \n\t"
++            "pxor %%mm6, %%mm5                      \n\t"
++            "pxor %%mm7, %%mm7                      \n\t"
++
++            "1:                                     \n\t"
++            "movq (%1), %%mm0                       \n\t"
++            "movq 8(%1), %%mm1                      \n\t"
++            "paddw 32(%1), %%mm0                    \n\t"
++            "paddw 40(%1), %%mm1                    \n\t"
++            "movq (%0, %3), %%mm2                   \n\t"
++            "movq %%mm2, %%mm3                      \n\t"
++            "movq %%mm2, %%mm4                      \n\t"
++            "punpcklbw %%mm7, %%mm2                 \n\t"
++            "punpckhbw %%mm7, %%mm3                 \n\t"
++            "paddw %%mm2, %%mm0                     \n\t"
++            "paddw %%mm3, %%mm1                     \n\t"
++            "paddw %%mm2, %%mm0                     \n\t"
++            "paddw %%mm3, %%mm1                     \n\t"
++            "psrlw $4, %%mm0                        \n\t"
++            "psrlw $4, %%mm1                        \n\t"
++            "packuswb %%mm1, %%mm0                  \n\t"
++            "pand %%mm6, %%mm0                      \n\t"
++            "pand %%mm5, %%mm4                      \n\t"
++            "por %%mm4, %%mm0                       \n\t"
++            "movq %%mm0, (%0, %3)                   \n\t"
++            "add $16, %1                            \n\t"
++            "add %2, %0                             \n\t"
++            " js 1b                                 \n\t"
++
++            : "+r"(offset), "+r"(temp_sums)
++            : "r" ((x86_reg)step), "r"(src - offset), "m"(both_masks)
++        );
++    }else
++        src+= step; // src points to begin of the 8x8 Block
++
++    if(eq_mask != -1LL){
++        uint8_t *temp_src= src;
++        DECLARE_ALIGNED(8, uint64_t, tmp)[4]; // make space for 4 8-byte vars
++        __asm__ volatile(
++            "pxor %%mm7, %%mm7                      \n\t"
++//      0       1       2       3       4       5       6       7       8       9
++//      %0      eax     eax+%1  eax+2%1 %0+4%1  ecx     ecx+%1  ecx+2%1 %1+8%1  ecx+4%1
++
++            "movq (%0), %%mm0                       \n\t"
++            "movq %%mm0, %%mm1                      \n\t"
++            "punpcklbw %%mm7, %%mm0                 \n\t" // low part of line 0
++            "punpckhbw %%mm7, %%mm1                 \n\t" // high part of line 0
++
++            "movq (%0, %1), %%mm2                   \n\t"
++            "lea (%0, %1, 2), %%"FF_REG_a"          \n\t"
++            "movq %%mm2, %%mm3                      \n\t"
++            "punpcklbw %%mm7, %%mm2                 \n\t" // low part of line 1
++            "punpckhbw %%mm7, %%mm3                 \n\t" // high part of line 1
++
++            "movq (%%"FF_REG_a"), %%mm4             \n\t"
++            "movq %%mm4, %%mm5                      \n\t"
++            "punpcklbw %%mm7, %%mm4                 \n\t" // low part of line 2
++            "punpckhbw %%mm7, %%mm5                 \n\t" // high part of line 2
++
++            "paddw %%mm0, %%mm0                     \n\t" // 2L0
++            "paddw %%mm1, %%mm1                     \n\t" // 2H0
++            "psubw %%mm4, %%mm2                     \n\t" // L1 - L2
++            "psubw %%mm5, %%mm3                     \n\t" // H1 - H2
++            "psubw %%mm2, %%mm0                     \n\t" // 2L0 - L1 + L2
++            "psubw %%mm3, %%mm1                     \n\t" // 2H0 - H1 + H2
++
++            "psllw $2, %%mm2                        \n\t" // 4L1 - 4L2
++            "psllw $2, %%mm3                        \n\t" // 4H1 - 4H2
++            "psubw %%mm2, %%mm0                     \n\t" // 2L0 - 5L1 + 5L2
++            "psubw %%mm3, %%mm1                     \n\t" // 2H0 - 5H1 + 5H2
++
++            "movq (%%"FF_REG_a", %1), %%mm2         \n\t"
++            "movq %%mm2, %%mm3                      \n\t"
++            "punpcklbw %%mm7, %%mm2                 \n\t" // L3
++            "punpckhbw %%mm7, %%mm3                 \n\t" // H3
++
++            "psubw %%mm2, %%mm0                     \n\t" // 2L0 - 5L1 + 5L2 - L3
++            "psubw %%mm3, %%mm1                     \n\t" // 2H0 - 5H1 + 5H2 - H3
++            "psubw %%mm2, %%mm0                     \n\t" // 2L0 - 5L1 + 5L2 - 2L3
++            "psubw %%mm3, %%mm1                     \n\t" // 2H0 - 5H1 + 5H2 - 2H3
++            "movq %%mm0, (%4)                       \n\t" // 2L0 - 5L1 + 5L2 - 2L3
++            "movq %%mm1, 8(%4)                      \n\t" // 2H0 - 5H1 + 5H2 - 2H3
++
++            "movq (%%"FF_REG_a", %1, 2), %%mm0      \n\t"
++            "movq %%mm0, %%mm1                      \n\t"
++            "punpcklbw %%mm7, %%mm0                 \n\t" // L4
++            "punpckhbw %%mm7, %%mm1                 \n\t" // H4
++
++            "psubw %%mm0, %%mm2                     \n\t" // L3 - L4
++            "psubw %%mm1, %%mm3                     \n\t" // H3 - H4
++            "movq %%mm2, 16(%4)                     \n\t" // L3 - L4
++            "movq %%mm3, 24(%4)                     \n\t" // H3 - H4
++            "paddw %%mm4, %%mm4                     \n\t" // 2L2
++            "paddw %%mm5, %%mm5                     \n\t" // 2H2
++            "psubw %%mm2, %%mm4                     \n\t" // 2L2 - L3 + L4
++            "psubw %%mm3, %%mm5                     \n\t" // 2H2 - H3 + H4
++
++            "lea (%%"FF_REG_a", %1), %0             \n\t"
++            "psllw $2, %%mm2                        \n\t" // 4L3 - 4L4
++            "psllw $2, %%mm3                        \n\t" // 4H3 - 4H4
++            "psubw %%mm2, %%mm4                     \n\t" // 2L2 - 5L3 + 5L4
++            "psubw %%mm3, %%mm5                     \n\t" // 2H2 - 5H3 + 5H4
++//50 opcodes so far
++            "movq (%0, %1, 2), %%mm2                \n\t"
++            "movq %%mm2, %%mm3                      \n\t"
++            "punpcklbw %%mm7, %%mm2                 \n\t" // L5
++            "punpckhbw %%mm7, %%mm3                 \n\t" // H5
++            "psubw %%mm2, %%mm4                     \n\t" // 2L2 - 5L3 + 5L4 - L5
++            "psubw %%mm3, %%mm5                     \n\t" // 2H2 - 5H3 + 5H4 - H5
++            "psubw %%mm2, %%mm4                     \n\t" // 2L2 - 5L3 + 5L4 - 2L5
++            "psubw %%mm3, %%mm5                     \n\t" // 2H2 - 5H3 + 5H4 - 2H5
++
++            "movq (%%"FF_REG_a", %1, 4), %%mm6      \n\t"
++            "punpcklbw %%mm7, %%mm6                 \n\t" // L6
++            "psubw %%mm6, %%mm2                     \n\t" // L5 - L6
++            "movq (%%"FF_REG_a", %1, 4), %%mm6      \n\t"
++            "punpckhbw %%mm7, %%mm6                 \n\t" // H6
++            "psubw %%mm6, %%mm3                     \n\t" // H5 - H6
++
++            "paddw %%mm0, %%mm0                     \n\t" // 2L4
++            "paddw %%mm1, %%mm1                     \n\t" // 2H4
++            "psubw %%mm2, %%mm0                     \n\t" // 2L4 - L5 + L6
++            "psubw %%mm3, %%mm1                     \n\t" // 2H4 - H5 + H6
++
++            "psllw $2, %%mm2                        \n\t" // 4L5 - 4L6
++            "psllw $2, %%mm3                        \n\t" // 4H5 - 4H6
++            "psubw %%mm2, %%mm0                     \n\t" // 2L4 - 5L5 + 5L6
++            "psubw %%mm3, %%mm1                     \n\t" // 2H4 - 5H5 + 5H6
++
++            "movq (%0, %1, 4), %%mm2                \n\t"
++            "movq %%mm2, %%mm3                      \n\t"
++            "punpcklbw %%mm7, %%mm2                 \n\t" // L7
++            "punpckhbw %%mm7, %%mm3                 \n\t" // H7
++
++            "paddw %%mm2, %%mm2                     \n\t" // 2L7
++            "paddw %%mm3, %%mm3                     \n\t" // 2H7
++            "psubw %%mm2, %%mm0                     \n\t" // 2L4 - 5L5 + 5L6 - 2L7
++            "psubw %%mm3, %%mm1                     \n\t" // 2H4 - 5H5 + 5H6 - 2H7
++
++            "movq (%4), %%mm2                       \n\t" // 2L0 - 5L1 + 5L2 - 2L3
++            "movq 8(%4), %%mm3                      \n\t" // 2H0 - 5H1 + 5H2 - 2H3
++
++            "movq %%mm7, %%mm6                      \n\t" // 0
++            "psubw %%mm0, %%mm6                     \n\t"
++            "pmaxsw %%mm6, %%mm0                    \n\t" // |2L4 - 5L5 + 5L6 - 2L7|
++            "movq %%mm7, %%mm6                      \n\t" // 0
++            "psubw %%mm1, %%mm6                     \n\t"
++            "pmaxsw %%mm6, %%mm1                    \n\t" // |2H4 - 5H5 + 5H6 - 2H7|
++            "movq %%mm7, %%mm6                      \n\t" // 0
++            "psubw %%mm2, %%mm6                     \n\t"
++            "pmaxsw %%mm6, %%mm2                    \n\t" // |2L0 - 5L1 + 5L2 - 2L3|
++            "movq %%mm7, %%mm6                      \n\t" // 0
++            "psubw %%mm3, %%mm6                     \n\t"
++            "pmaxsw %%mm6, %%mm3                    \n\t" // |2H0 - 5H1 + 5H2 - 2H3|
++
++            "pminsw %%mm2, %%mm0                    \n\t"
++            "pminsw %%mm3, %%mm1                    \n\t"
++
++            "movd %2, %%mm2                         \n\t" // QP
++            "punpcklbw %%mm7, %%mm2                 \n\t"
++
++            "movq %%mm7, %%mm6                      \n\t" // 0
++            "pcmpgtw %%mm4, %%mm6                   \n\t" // sign(2L2 - 5L3 + 5L4 - 2L5)
++            "pxor %%mm6, %%mm4                      \n\t"
++            "psubw %%mm6, %%mm4                     \n\t" // |2L2 - 5L3 + 5L4 - 2L5|
++            "pcmpgtw %%mm5, %%mm7                   \n\t" // sign(2H2 - 5H3 + 5H4 - 2H5)
++            "pxor %%mm7, %%mm5                      \n\t"
++            "psubw %%mm7, %%mm5                     \n\t" // |2H2 - 5H3 + 5H4 - 2H5|
++// 100 opcodes
++            "psllw $3, %%mm2                        \n\t" // 8QP
++            "movq %%mm2, %%mm3                      \n\t" // 8QP
++            "pcmpgtw %%mm4, %%mm2                   \n\t"
++            "pcmpgtw %%mm5, %%mm3                   \n\t"
++            "pand %%mm2, %%mm4                      \n\t"
++            "pand %%mm3, %%mm5                      \n\t"
++
++
++            "psubusw %%mm0, %%mm4                   \n\t" // hd
++            "psubusw %%mm1, %%mm5                   \n\t" // ld
++
++
++            "movq "MANGLE(w05)", %%mm2              \n\t" // 5
++            "pmullw %%mm2, %%mm4                    \n\t"
++            "pmullw %%mm2, %%mm5                    \n\t"
++            "movq "MANGLE(w20)", %%mm2              \n\t" // 32
++            "paddw %%mm2, %%mm4                     \n\t"
++            "paddw %%mm2, %%mm5                     \n\t"
++            "psrlw $6, %%mm4                        \n\t"
++            "psrlw $6, %%mm5                        \n\t"
++
++            "movq 16(%4), %%mm0                     \n\t" // L3 - L4
++            "movq 24(%4), %%mm1                     \n\t" // H3 - H4
++
++            "pxor %%mm2, %%mm2                      \n\t"
++            "pxor %%mm3, %%mm3                      \n\t"
++
++            "pcmpgtw %%mm0, %%mm2                   \n\t" // sign (L3-L4)
++            "pcmpgtw %%mm1, %%mm3                   \n\t" // sign (H3-H4)
++            "pxor %%mm2, %%mm0                      \n\t"
++            "pxor %%mm3, %%mm1                      \n\t"
++            "psubw %%mm2, %%mm0                     \n\t" // |L3-L4|
++            "psubw %%mm3, %%mm1                     \n\t" // |H3-H4|
++            "psrlw $1, %%mm0                        \n\t" // |L3 - L4|/2
++            "psrlw $1, %%mm1                        \n\t" // |H3 - H4|/2
++
++            "pxor %%mm6, %%mm2                      \n\t"
++            "pxor %%mm7, %%mm3                      \n\t"
++            "pand %%mm2, %%mm4                      \n\t"
++            "pand %%mm3, %%mm5                      \n\t"
++
++            "pminsw %%mm0, %%mm4                    \n\t"
++            "pminsw %%mm1, %%mm5                    \n\t"
++            "pxor %%mm6, %%mm4                      \n\t"
++            "pxor %%mm7, %%mm5                      \n\t"
++            "psubw %%mm6, %%mm4                     \n\t"
++            "psubw %%mm7, %%mm5                     \n\t"
++            "packsswb %%mm5, %%mm4                  \n\t"
++            "movq %3, %%mm1                         \n\t"
++            "pandn %%mm4, %%mm1                     \n\t"
++            "movq (%0), %%mm0                       \n\t"
++            "paddb   %%mm1, %%mm0                   \n\t"
++            "movq %%mm0, (%0)                       \n\t"
++            "movq (%0, %1), %%mm0                   \n\t"
++            "psubb %%mm1, %%mm0                     \n\t"
++            "movq %%mm0, (%0, %1)                   \n\t"
++
++            : "+r" (temp_src)
++            : "r" ((x86_reg)step), "m" (c->pQPb), "m"(eq_mask), "r"(tmp)
++              NAMED_CONSTRAINTS_ADD(w05,w20)
++            : "%"FF_REG_a
++        );
++    }
++}
++#endif //TEMPLATE_PP_MMX
++
++static void RENAME(postProcess)(const uint8_t src[], int srcStride, uint8_t dst[], int dstStride, int width, int height,
++                                const int8_t QPs[], int QPStride, int isColor, PPContext *c);
++
++/**
++ * Copy a block from src to dst and fixes the blacklevel.
++ * levelFix == 0 -> do not touch the brightness & contrast
++ */
++#undef REAL_SCALED_CPY
++#undef SCALED_CPY
++
++static inline void RENAME(blockCopy)(uint8_t dst[], int dstStride, const uint8_t src[], int srcStride,
++                                     int levelFix, int64_t *packedOffsetAndScale)
++{
++    if(levelFix){
++#if TEMPLATE_PP_MMXEXT && HAVE_6REGS
++    __asm__ volatile(
++        "movq (%%"FF_REG_a"), %%mm2     \n\t" // packedYOffset
++        "movq 8(%%"FF_REG_a"), %%mm3    \n\t" // packedYScale
++        "lea (%2,%4), %%"FF_REG_a"      \n\t"
++        "lea (%3,%5), %%"FF_REG_d"      \n\t"
++        "pxor %%mm4, %%mm4              \n\t"
++#define REAL_SCALED_CPY(src1, src2, dst1, dst2)                                                \
++        "movq " #src1 ", %%mm0          \n\t"\
++        "movq " #src1 ", %%mm5          \n\t"\
++        "movq " #src2 ", %%mm1          \n\t"\
++        "movq " #src2 ", %%mm6          \n\t"\
++        "punpcklbw %%mm0, %%mm0         \n\t"\
++        "punpckhbw %%mm5, %%mm5         \n\t"\
++        "punpcklbw %%mm1, %%mm1         \n\t"\
++        "punpckhbw %%mm6, %%mm6         \n\t"\
++        "pmulhuw %%mm3, %%mm0           \n\t"\
++        "pmulhuw %%mm3, %%mm5           \n\t"\
++        "pmulhuw %%mm3, %%mm1           \n\t"\
++        "pmulhuw %%mm3, %%mm6           \n\t"\
++        "psubw %%mm2, %%mm0             \n\t"\
++        "psubw %%mm2, %%mm5             \n\t"\
++        "psubw %%mm2, %%mm1             \n\t"\
++        "psubw %%mm2, %%mm6             \n\t"\
++        "packuswb %%mm5, %%mm0          \n\t"\
++        "packuswb %%mm6, %%mm1          \n\t"\
++        "movq %%mm0, " #dst1 "          \n\t"\
++        "movq %%mm1, " #dst2 "          \n\t"\
++
++#define SCALED_CPY(src1, src2, dst1, dst2)\
++   REAL_SCALED_CPY(src1, src2, dst1, dst2)
++
++SCALED_CPY((%2)       , (%2, %4)      , (%3)       , (%3, %5))
++SCALED_CPY((%2, %4, 2), (%%FF_REGa, %4, 2), (%3, %5, 2), (%%FF_REGd, %5, 2))
++SCALED_CPY((%2, %4, 4), (%%FF_REGa, %4, 4), (%3, %5, 4), (%%FF_REGd, %5, 4))
++        "lea (%%"FF_REG_a",%4,4), %%"FF_REG_a"        \n\t"
++        "lea (%%"FF_REG_d",%5,4), %%"FF_REG_d"        \n\t"
++SCALED_CPY((%%FF_REGa, %4), (%%FF_REGa, %4, 2), (%%FF_REGd, %5), (%%FF_REGd, %5, 2))
++
++
++        : "=&a" (packedOffsetAndScale)
++        : "0" (packedOffsetAndScale),
++        "r"(src),
++        "r"(dst),
++        "r" ((x86_reg)srcStride),
++        "r" ((x86_reg)dstStride)
++        : "%"FF_REG_d
++    );
++#else //TEMPLATE_PP_MMX && HAVE_6REGS
++    for (int i = 0; i < 8; i++)
++        memcpy( &(dst[dstStride*i]),
++                &(src[srcStride*i]), BLOCK_SIZE);
++#endif //TEMPLATE_PP_MMX && HAVE_6REGS
++    }else{
++#if TEMPLATE_PP_MMX && HAVE_6REGS
++    __asm__ volatile(
++        "lea (%0,%2), %%"FF_REG_a"      \n\t"
++        "lea (%1,%3), %%"FF_REG_d"      \n\t"
++
++#define REAL_SIMPLE_CPY(src1, src2, dst1, dst2)                              \
++        "movq " #src1 ", %%mm0          \n\t"\
++        "movq " #src2 ", %%mm1          \n\t"\
++        "movq %%mm0, " #dst1 "          \n\t"\
++        "movq %%mm1, " #dst2 "          \n\t"\
++
++#define SIMPLE_CPY(src1, src2, dst1, dst2)\
++   REAL_SIMPLE_CPY(src1, src2, dst1, dst2)
++
++SIMPLE_CPY((%0)       , (%0, %2)          , (%1)       , (%1, %3))
++SIMPLE_CPY((%0, %2, 2), (%%FF_REGa, %2, 2), (%1, %3, 2), (%%FF_REGd, %3, 2))
++SIMPLE_CPY((%0, %2, 4), (%%FF_REGa, %2, 4), (%1, %3, 4), (%%FF_REGd, %3, 4))
++        "lea (%%"FF_REG_a",%2,4), %%"FF_REG_a"        \n\t"
++        "lea (%%"FF_REG_d",%3,4), %%"FF_REG_d"        \n\t"
++SIMPLE_CPY((%%FF_REGa, %2), (%%FF_REGa, %2, 2), (%%FF_REGd, %3), (%%FF_REGd, %3, 2))
++
++        : : "r" (src),
++        "r" (dst),
++        "r" ((x86_reg)srcStride),
++        "r" ((x86_reg)dstStride)
++        : "%"FF_REG_a, "%"FF_REG_d
++    );
++#else //TEMPLATE_PP_MMX && HAVE_6REGS
++    for (int i = 0; i < 8; i++)
++        memcpy( &(dst[dstStride*i]),
++                &(src[srcStride*i]), BLOCK_SIZE);
++#endif //TEMPLATE_PP_MMX && HAVE_6REGS
++    }
++}
++
++/**
++ * Duplicate the given 8 src pixels ? times upward
++ */
++static inline void RENAME(duplicate)(uint8_t src[], int stride)
++{
++#if TEMPLATE_PP_MMX
++    __asm__ volatile(
++        "movq (%0), %%mm0               \n\t"
++        "movq %%mm0, (%0, %1, 4)        \n\t"
++        "add %1, %0                     \n\t"
++        "movq %%mm0, (%0)               \n\t"
++        "movq %%mm0, (%0, %1)           \n\t"
++        "movq %%mm0, (%0, %1, 2)        \n\t"
++        "movq %%mm0, (%0, %1, 4)        \n\t"
++        : "+r" (src)
++        : "r" ((x86_reg)-stride)
++    );
++#else
++    int i;
++    uint8_t *p=src;
++    for(i=0; i<5; i++){
++        p-= stride;
++        memcpy(p, src, 8);
++    }
++#endif
++}
++
++#if ARCH_X86 && TEMPLATE_PP_MMXEXT
++static inline void RENAME(prefetchnta)(const void *p)
++{
++    __asm__ volatile(   "prefetchnta (%0)\n\t"
++        : : "r" (p)
++    );
++}
++
++static inline void RENAME(prefetcht0)(const void *p)
++{
++    __asm__ volatile(   "prefetcht0 (%0)\n\t"
++        : : "r" (p)
++    );
++}
++
++static inline void RENAME(prefetcht1)(const void *p)
++{
++    __asm__ volatile(   "prefetcht1 (%0)\n\t"
++        : : "r" (p)
++    );
++}
++
++static inline void RENAME(prefetcht2)(const void *p)
++{
++    __asm__ volatile(   "prefetcht2 (%0)\n\t"
++        : : "r" (p)
++    );
++}
++#elif !ARCH_X86 && AV_GCC_VERSION_AT_LEAST(3,2)
++static inline void RENAME(prefetchnta)(const void *p)
++{
++    __builtin_prefetch(p,0,0);
++}
++static inline void RENAME(prefetcht0)(const void *p)
++{
++    __builtin_prefetch(p,0,1);
++}
++static inline void RENAME(prefetcht1)(const void *p)
++{
++    __builtin_prefetch(p,0,2);
++}
++static inline void RENAME(prefetcht2)(const void *p)
++{
++    __builtin_prefetch(p,0,3);
++}
++#else
++static inline void RENAME(prefetchnta)(const void *p)
++{
++    return;
++}
++static inline void RENAME(prefetcht0)(const void *p)
++{
++    return;
++}
++static inline void RENAME(prefetcht1)(const void *p)
++{
++    return;
++}
++static inline void RENAME(prefetcht2)(const void *p)
++{
++    return;
++}
++#endif
++/**
++ * Filter array of bytes (Y or U or V values)
++ */
++static void RENAME(postProcess)(const uint8_t src[], int srcStride, uint8_t dst[], int dstStride, int width, int height,
++                                const int8_t QPs[], int QPStride, int isColor, PPContext *c)
++{
++    int x,y;
++#ifdef TEMPLATE_PP_TIME_MODE
++    const int mode= TEMPLATE_PP_TIME_MODE;
++#else
++    const int mode = isColor ? c->ppMode.chromMode : c->ppMode.lumMode;
++#endif
++    int black=0, white=255; // blackest black and whitest white in the picture
++    int QPCorrecture= 256*256;
++
++    int copyAhead;
++#if TEMPLATE_PP_MMX
++    int i;
++#endif
++
++    const int qpHShift = isColor ? 4 - c->hChromaSubSample : 4;
++    const int qpVShift = isColor ? 4 - c->vChromaSubSample : 4;
++
++    //FIXME remove
++    uint64_t * const yHistogram= c->yHistogram;
++    uint8_t * const tempSrc =  srcStride > 0 ? c->tempSrc : c->tempSrc - 23*srcStride;
++    uint8_t * const tempDst = (dstStride > 0 ? c->tempDst : c->tempDst - 23*dstStride) + 32;
++    //const int mbWidth= isColor ? (width+7)>>3 : (width+15)>>4;
++
++    if (mode & VISUALIZE){
++        if(!(mode & (V_A_DEBLOCK | H_A_DEBLOCK)) || TEMPLATE_PP_MMX) {
++            av_log(c, AV_LOG_WARNING, "Visualization is currently only supported with the accurate deblock filter without SIMD\n");
++        }
++    }
++
++#if TEMPLATE_PP_MMX
++    for(i=0; i<57; i++){
++        int offset = ((i * c->ppMode.baseDcDiff) >> 8) + 1;
++        int threshold= offset*2 + 1;
++        c->mmxDcOffset[i]     = 0x7F - offset;
++        c->mmxDcThreshold[i]  = 0x7F - threshold;
++        c->mmxDcOffset[i]    *= 0x0101010101010101LL;
++        c->mmxDcThreshold[i] *= 0x0101010101010101LL;
++    }
++#endif
++
++    if(mode & CUBIC_IPOL_DEINT_FILTER) copyAhead=16;
++    else if(   (mode & LINEAR_BLEND_DEINT_FILTER)
++            || (mode & FFMPEG_DEINT_FILTER)
++            || (mode & LOWPASS5_DEINT_FILTER)) copyAhead=14;
++    else if(   (mode & V_DEBLOCK)
++            || (mode & LINEAR_IPOL_DEINT_FILTER)
++            || (mode & MEDIAN_DEINT_FILTER)
++            || (mode & V_A_DEBLOCK)) copyAhead=13;
++    else if(mode & V_X1_FILTER) copyAhead=11;
++//    else if(mode & V_RK1_FILTER) copyAhead=10;
++    else if(mode & DERING) copyAhead=9;
++    else copyAhead=8;
++
++    copyAhead-= 8;
++
++    if(!isColor){
++        uint64_t sum= 0;
++        int i;
++        uint64_t maxClipped;
++        uint64_t clipped;
++        AVRational scale;
++
++        c->frameNum++;
++        // first frame is fscked so we ignore it
++        if (c->frameNum == 1)
++            yHistogram[0] = width * (uint64_t)height/64*15/256;
++
++        for(i=0; i<256; i++){
++            sum+= yHistogram[i];
++        }
++
++        /* We always get a completely black picture first. */
++        maxClipped = av_rescale(sum, c->ppMode.maxClippedThreshold.num,
++                                     c->ppMode.maxClippedThreshold.den);
++
++        clipped= sum;
++        for(black=255; black>0; black--){
++            if(clipped < maxClipped) break;
++            clipped-= yHistogram[black];
++        }
++
++        clipped= sum;
++        for(white=0; white<256; white++){
++            if(clipped < maxClipped) break;
++            clipped-= yHistogram[white];
++        }
++
++        scale = (AVRational){c->ppMode.maxAllowedY - c->ppMode.minAllowedY, white - black};
++
++#if TEMPLATE_PP_MMXEXT
++        c->packedYScale  = (uint16_t)av_rescale(scale.num, 256, scale.den);
++        c->packedYOffset = (((black*c->packedYScale)>>8) - c->ppMode.minAllowedY) & 0xFFFF;
++#else
++        c->packedYScale  = (uint16_t)av_rescale(scale.num, 1024, scale.den);
++        c->packedYOffset = (black - c->ppMode.minAllowedY) & 0xFFFF;
++#endif
++
++        c->packedYOffset |= c->packedYOffset<<32;
++        c->packedYOffset |= c->packedYOffset<<16;
++
++        c->packedYScale |= c->packedYScale<<32;
++        c->packedYScale |= c->packedYScale<<16;
++
++        if(mode & LEVEL_FIX)        QPCorrecture= (int)av_rescale(scale.num, 256*256, scale.den);
++        else                        QPCorrecture= 256*256;
++    }else{
++        c->packedYScale  = 0x0100010001000100LL;
++        c->packedYOffset = 0;
++        QPCorrecture= 256*256;
++    }
++
++    /* copy & deinterlace first row of blocks */
++    y=-BLOCK_SIZE;
++    {
++        const uint8_t *srcBlock= &(src[y*srcStride]);
++        uint8_t *dstBlock= tempDst + dstStride;
++
++        // From this point on it is guaranteed that we can read and write 16 lines downward
++        // finish 1 block before the next otherwise we might have a problem
++        // with the L1 Cache of the P4 ... or only a few blocks at a time or something
++        for(x=0; x<width; x+=BLOCK_SIZE){
++            RENAME(prefetchnta)(srcBlock + (((x>>2)&6) + copyAhead)*srcStride + 32);
++            RENAME(prefetchnta)(srcBlock + (((x>>2)&6) + copyAhead+1)*srcStride + 32);
++            RENAME(prefetcht0)(dstBlock + (((x>>2)&6) + copyAhead)*dstStride + 32);
++            RENAME(prefetcht0)(dstBlock + (((x>>2)&6) + copyAhead+1)*dstStride + 32);
++
++            RENAME(blockCopy)(dstBlock + dstStride*8, dstStride,
++                              srcBlock + srcStride*8, srcStride, mode & LEVEL_FIX, &c->packedYOffset);
++
++            RENAME(duplicate)(dstBlock + dstStride*8, dstStride);
++
++            if(mode & LINEAR_IPOL_DEINT_FILTER)
++                RENAME(deInterlaceInterpolateLinear)(dstBlock, dstStride);
++            else if(mode & LINEAR_BLEND_DEINT_FILTER)
++                RENAME(deInterlaceBlendLinear)(dstBlock, dstStride, c->deintTemp + x);
++            else if(mode & MEDIAN_DEINT_FILTER)
++                RENAME(deInterlaceMedian)(dstBlock, dstStride);
++            else if(mode & CUBIC_IPOL_DEINT_FILTER)
++                RENAME(deInterlaceInterpolateCubic)(dstBlock, dstStride);
++            else if(mode & FFMPEG_DEINT_FILTER)
++                RENAME(deInterlaceFF)(dstBlock, dstStride, c->deintTemp + x);
++            else if(mode & LOWPASS5_DEINT_FILTER)
++                RENAME(deInterlaceL5)(dstBlock, dstStride, c->deintTemp + x, c->deintTemp + width + x);
++/*          else if(mode & CUBIC_BLEND_DEINT_FILTER)
++                RENAME(deInterlaceBlendCubic)(dstBlock, dstStride);
++*/
++            dstBlock+=8;
++            srcBlock+=8;
++        }
++        if(width==FFABS(dstStride))
++            linecpy(dst, tempDst + 9*dstStride, copyAhead, dstStride);
++        else{
++            int i;
++            for(i=0; i<copyAhead; i++){
++                memcpy(dst + i*dstStride, tempDst + (9+i)*dstStride, width);
++            }
++        }
++    }
++
++    for(y=0; y<height; y+=BLOCK_SIZE){
++        //1% speedup if these are here instead of the inner loop
++        const uint8_t *srcBlock= &(src[y*srcStride]);
++        uint8_t *dstBlock= &(dst[y*dstStride]);
++#if TEMPLATE_PP_MMX
++        uint8_t *tempBlock1 = c->tempBlocks;
++        uint8_t *tempBlock2 = c->tempBlocks + 8;
++#endif
++        const int8_t *QPptr= &QPs[(y>>qpVShift)*QPStride];
++        int8_t *nonBQPptr = &c->nonBQPTable[(y>>qpVShift)*FFABS(QPStride)];
++        int QP=0, nonBQP=0;
++        /* can we mess with a 8x16 block from srcBlock/dstBlock downwards and 1 line upwards
++           if not than use a temporary buffer */
++        if(y+15 >= height){
++            int i;
++            /* copy from line (copyAhead) to (copyAhead+7) of src, these will be copied with
++               blockcopy to dst later */
++            linecpy(tempSrc + srcStride*copyAhead, srcBlock + srcStride*copyAhead,
++                    FFMAX(height-y-copyAhead, 0), srcStride);
++
++            /* duplicate last line of src to fill the void up to line (copyAhead+7) */
++            for(i=FFMAX(height-y, 8); i<copyAhead+8; i++)
++                    memcpy(tempSrc + srcStride*i, src + srcStride*(height-1), FFABS(srcStride));
++
++            /* copy up to (copyAhead+1) lines of dst (line -1 to (copyAhead-1))*/
++            linecpy(tempDst, dstBlock - dstStride, FFMIN(height-y+1, copyAhead+1), dstStride);
++
++            /* duplicate last line of dst to fill the void up to line (copyAhead) */
++            for(i=height-y+1; i<=copyAhead; i++)
++                    memcpy(tempDst + dstStride*i, dst + dstStride*(height-1), FFABS(dstStride));
++
++            dstBlock= tempDst + dstStride;
++            srcBlock= tempSrc;
++        }
++
++        // From this point on it is guaranteed that we can read and write 16 lines downward
++        // finish 1 block before the next otherwise we might have a problem
++        // with the L1 Cache of the P4 ... or only a few blocks at a time or something
++        for(x=0; x<width; ){
++            int startx = x;
++            int endx = FFMIN(width, x+32);
++            uint8_t *dstBlockStart = dstBlock;
++            const uint8_t *srcBlockStart = srcBlock;
++            int qp_index = 0;
++            for(qp_index=0; qp_index < (endx-startx)/BLOCK_SIZE; qp_index++){
++                QP = QPptr[(x+qp_index*BLOCK_SIZE)>>qpHShift];
++                nonBQP = nonBQPptr[(x+qp_index*BLOCK_SIZE)>>qpHShift];
++            if(!isColor){
++                QP= (QP* QPCorrecture + 256*128)>>16;
++                nonBQP= (nonBQP* QPCorrecture + 256*128)>>16;
++                yHistogram[(srcBlock+qp_index*8)[srcStride*12 + 4]]++;
++            }
++            c->QP_block[qp_index] = QP;
++            c->nonBQP_block[qp_index] = nonBQP;
++#if TEMPLATE_PP_MMX
++            __asm__ volatile(
++                "movd %1, %%mm7         \n\t"
++                "packuswb %%mm7, %%mm7  \n\t" // 0, 0, 0, QP, 0, 0, 0, QP
++                "packuswb %%mm7, %%mm7  \n\t" // 0,QP, 0, QP, 0,QP, 0, QP
++                "packuswb %%mm7, %%mm7  \n\t" // QP,..., QP
++                "movq %%mm7, %0         \n\t"
++                : "=m" (c->pQPb_block[qp_index])
++                : "r" (QP)
++            );
++#endif
++            }
++          for(; x < endx; x+=BLOCK_SIZE){
++            RENAME(prefetchnta)(srcBlock + (((x>>2)&6) + copyAhead)*srcStride + 32);
++            RENAME(prefetchnta)(srcBlock + (((x>>2)&6) + copyAhead+1)*srcStride + 32);
++            RENAME(prefetcht0)(dstBlock + (((x>>2)&6) + copyAhead)*dstStride + 32);
++            RENAME(prefetcht0)(dstBlock + (((x>>2)&6) + copyAhead+1)*dstStride + 32);
++
++            RENAME(blockCopy)(dstBlock + dstStride*copyAhead, dstStride,
++                              srcBlock + srcStride*copyAhead, srcStride, mode & LEVEL_FIX, &c->packedYOffset);
++
++            if(mode & LINEAR_IPOL_DEINT_FILTER)
++                RENAME(deInterlaceInterpolateLinear)(dstBlock, dstStride);
++            else if(mode & LINEAR_BLEND_DEINT_FILTER)
++                RENAME(deInterlaceBlendLinear)(dstBlock, dstStride, c->deintTemp + x);
++            else if(mode & MEDIAN_DEINT_FILTER)
++                RENAME(deInterlaceMedian)(dstBlock, dstStride);
++            else if(mode & CUBIC_IPOL_DEINT_FILTER)
++                RENAME(deInterlaceInterpolateCubic)(dstBlock, dstStride);
++            else if(mode & FFMPEG_DEINT_FILTER)
++                RENAME(deInterlaceFF)(dstBlock, dstStride, c->deintTemp + x);
++            else if(mode & LOWPASS5_DEINT_FILTER)
++                RENAME(deInterlaceL5)(dstBlock, dstStride, c->deintTemp + x, c->deintTemp + width + x);
++/*          else if(mode & CUBIC_BLEND_DEINT_FILTER)
++                RENAME(deInterlaceBlendCubic)(dstBlock, dstStride);
++*/
++            dstBlock+=8;
++            srcBlock+=8;
++          }
++
++          dstBlock = dstBlockStart;
++          srcBlock = srcBlockStart;
++
++          for(x = startx, qp_index = 0; x < endx; x+=BLOCK_SIZE, qp_index++){
++            const int stride= dstStride;
++            //temporary while changing QP stuff to make things continue to work
++            //eventually QP,nonBQP,etc will be arrays and this will be unnecessary
++            c->QP     = c->QP_block[qp_index];
++            c->nonBQP = c->nonBQP_block[qp_index];
++            c->pQPb   = c->pQPb_block[qp_index];
++            c->pQPb2  = c->pQPb2_block[qp_index];
++
++            /* only deblock if we have 2 blocks */
++            if(y + 8 < height){
++                if(mode & V_X1_FILTER)
++                    RENAME(vertX1Filter)(dstBlock, stride, c);
++                else if(mode & V_DEBLOCK){
++                    const int t = RENAME(vertClassify)(dstBlock, stride, c);
++
++                    if(t==1)
++                        RENAME(doVertLowPass)(dstBlock, stride, c);
++                    else if(t==2)
++                        RENAME(doVertDefFilter)(dstBlock, stride, c);
++                }else if(mode & V_A_DEBLOCK){
++                    RENAME(do_a_deblock)(dstBlock, stride, 1, c, mode);
++                }
++            }
++
++            dstBlock+=8;
++            srcBlock+=8;
++          }
++
++          dstBlock = dstBlockStart;
++          srcBlock = srcBlockStart;
++
++          for(x = startx, qp_index=0; x < endx; x+=BLOCK_SIZE, qp_index++){
++            const int stride= dstStride;
++            c->QP     = c->QP_block[qp_index];
++            c->nonBQP = c->nonBQP_block[qp_index];
++            c->pQPb   = c->pQPb_block[qp_index];
++            c->pQPb2  = c->pQPb2_block[qp_index];
++#if TEMPLATE_PP_MMX
++            RENAME(transpose1)(tempBlock1, tempBlock2, dstBlock, dstStride);
++#endif
++            /* check if we have a previous block to deblock it with dstBlock */
++            if(x - 8 >= 0){
++#if TEMPLATE_PP_MMX
++                if(mode & H_X1_FILTER)
++                        RENAME(vertX1Filter)(tempBlock1, 16, c);
++                else if(mode & H_DEBLOCK){
++                    const int t= RENAME(vertClassify)(tempBlock1, 16, c);
++                    if(t==1)
++                        RENAME(doVertLowPass)(tempBlock1, 16, c);
++                    else if(t==2)
++                        RENAME(doVertDefFilter)(tempBlock1, 16, c);
++                }else if(mode & H_A_DEBLOCK){
++                        RENAME(do_a_deblock)(tempBlock1, 16, 1, c, mode);
++                }
++
++                RENAME(transpose2)(dstBlock-4, dstStride, tempBlock1 + 4*16);
++
++#else
++                if(mode & H_X1_FILTER)
++                    horizX1Filter(dstBlock-4, stride, c->QP);
++                else if(mode & H_DEBLOCK){
++#if TEMPLATE_PP_ALTIVEC
++                    DECLARE_ALIGNED(16, unsigned char, tempBlock)[272];
++                    int t;
++                    transpose_16x8_char_toPackedAlign_altivec(tempBlock, dstBlock - (4 + 1), stride);
++
++                    t = vertClassify_altivec(tempBlock-48, 16, c);
++                    if(t==1) {
++                        doVertLowPass_altivec(tempBlock-48, 16, c);
++                        transpose_8x16_char_fromPackedAlign_altivec(dstBlock - (4 + 1), tempBlock, stride);
++                    }
++                    else if(t==2) {
++                        doVertDefFilter_altivec(tempBlock-48, 16, c);
++                        transpose_8x16_char_fromPackedAlign_altivec(dstBlock - (4 + 1), tempBlock, stride);
++                    }
++#else
++                    const int t= RENAME(horizClassify)(dstBlock-4, stride, c);
++
++                    if(t==1)
++                        RENAME(doHorizLowPass)(dstBlock-4, stride, c);
++                    else if(t==2)
++                        RENAME(doHorizDefFilter)(dstBlock-4, stride, c);
++#endif
++                }else if(mode & H_A_DEBLOCK){
++                    RENAME(do_a_deblock)(dstBlock-8, 1, stride, c, mode);
++                }
++#endif //TEMPLATE_PP_MMX
++                if(mode & DERING){
++                    RENAME(dering)(dstBlock - stride - 8, stride, c, x<=8, 0, y<=0);
++                }
++
++                if(mode & TEMP_NOISE_FILTER)
++                {
++                    RENAME(tempNoiseReducer)(dstBlock-8, stride,
++                            c->tempBlurred[isColor] + y*dstStride + x,
++                            c->tempBlurredPast[isColor] + (y>>3)*256 + (x>>3) + 256,
++                            c->ppMode.maxTmpNoise);
++                }
++            }
++
++            dstBlock+=8;
++            srcBlock+=8;
++
++#if TEMPLATE_PP_MMX
++            FFSWAP(uint8_t *, tempBlock1, tempBlock2);
++#endif
++          }
++        }
++
++        if(mode & DERING){
++            RENAME(dering)(dstBlock - dstStride - 8, dstStride, c, x<=8, 1, y<=0);
++        }
++
++        if((mode & TEMP_NOISE_FILTER)){
++            RENAME(tempNoiseReducer)(dstBlock-8, dstStride,
++                    c->tempBlurred[isColor] + y*dstStride + x,
++                    c->tempBlurredPast[isColor] + (y>>3)*256 + (x>>3) + 256,
++                    c->ppMode.maxTmpNoise);
++        }
++
++        /* did we use a tmp buffer for the last lines*/
++        if(y+15 >= height){
++            uint8_t *dstBlock= &(dst[y*dstStride]);
++            if(width==FFABS(dstStride))
++                linecpy(dstBlock, tempDst + dstStride, height-y, dstStride);
++            else{
++                int i;
++                for(i=0; i<height-y; i++){
++                    memcpy(dstBlock + i*dstStride, tempDst + (i+1)*dstStride, width);
++                }
++            }
++        }
++    }
++#if TEMPLATE_PP_MMX
++    __asm__ volatile("emms");
++#endif
++
++#ifdef DEBUG_BRIGHTNESS
++    if(!isColor){
++        int max=1;
++        int i;
++        for(i=0; i<256; i++)
++            if(yHistogram[i] > max) max=yHistogram[i];
++
++        for(i=1; i<256; i++){
++            int x;
++            int start=yHistogram[i-1]/(max/256+1);
++            int end=yHistogram[i]/(max/256+1);
++            int inc= end > start ? 1 : -1;
++            for(x=start; x!=end+inc; x+=inc)
++                dst[ i*dstStride + x]+=128;
++        }
++
++        for(i=0; i<100; i+=2){
++            dst[ (white)*dstStride + i]+=128;
++            dst[ (black)*dstStride + i]+=128;
++        }
++    }
++#endif
++}
++
++#undef RENAME
++#undef TEMPLATE_PP_C
++#undef TEMPLATE_PP_ALTIVEC
++#undef TEMPLATE_PP_MMX
++#undef TEMPLATE_PP_MMXEXT
++#undef TEMPLATE_PP_SSE2
+diff --git a/libpostproc/postprocres.rc b/libpostproc/postprocres.rc
+new file mode 100644
+index 0000000000000..e6104ac88bfea
+--- /dev/null
++++ b/libpostproc/postprocres.rc
+@@ -0,0 +1,55 @@
++/*
++ * Windows resource file for libpostproc
++ *
++ * Copyright (C) 2012 James Almer
++ * Copyright (C) 2013 Tiancheng "Timothy" Gu
++ *
++ * This file is part of FFmpeg.
++ *
++ * FFmpeg is free software; you can redistribute it and/or
++ * modify it under the terms of the GNU Lesser General Public
++ * License as published by the Free Software Foundation; either
++ * version 2.1 of the License, or (at your option) any later version.
++ *
++ * FFmpeg is distributed in the hope that it will be useful,
++ * but WITHOUT ANY WARRANTY; without even the implied warranty of
++ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
++ * Lesser General Public License for more details.
++ *
++ * You should have received a copy of the GNU Lesser General Public
++ * License along with FFmpeg; if not, write to the Free Software
++ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
++ */
++
++#include <windows.h>
++#include "libpostproc/version.h"
++#include "libavutil/ffversion.h"
++#include "config.h"
++
++1 VERSIONINFO
++FILEVERSION     LIBPOSTPROC_VERSION_MAJOR, LIBPOSTPROC_VERSION_MINOR, LIBPOSTPROC_VERSION_MICRO, 0
++PRODUCTVERSION  LIBPOSTPROC_VERSION_MAJOR, LIBPOSTPROC_VERSION_MINOR, LIBPOSTPROC_VERSION_MICRO, 0
++FILEFLAGSMASK   VS_FFI_FILEFLAGSMASK
++FILEOS          VOS_NT_WINDOWS32
++FILETYPE        VFT_DLL
++{
++    BLOCK "StringFileInfo"
++    {
++        BLOCK "040904B0"
++        {
++            VALUE "CompanyName",      "FFmpeg Project"
++            VALUE "FileDescription",  "FFmpeg postprocessing library"
++            VALUE "FileVersion",      AV_STRINGIFY(LIBPOSTPROC_VERSION)
++            VALUE "InternalName",     "libpostproc"
++            VALUE "LegalCopyright",   "Copyright (C) 2000-" AV_STRINGIFY(CONFIG_THIS_YEAR) " FFmpeg Project"
++            VALUE "OriginalFilename", "postproc" BUILDSUF "-" AV_STRINGIFY(LIBPOSTPROC_VERSION_MAJOR) SLIBSUF
++            VALUE "ProductName",      "FFmpeg"
++            VALUE "ProductVersion",   FFMPEG_VERSION
++        }
++    }
++
++    BLOCK "VarFileInfo"
++    {
++        VALUE "Translation", 0x0409, 0x04B0
++    }
++}
+diff --git a/libpostproc/tests/.gitignore b/libpostproc/tests/.gitignore
+new file mode 100644
+index 0000000000000..60dc67fa74f13
+--- /dev/null
++++ b/libpostproc/tests/.gitignore
+@@ -0,0 +1,3 @@
++/blocktest
++/stripetest
++/temptest
+diff --git a/libpostproc/tests/blocktest.c b/libpostproc/tests/blocktest.c
+new file mode 100644
+index 0000000000000..e91fb0b569461
+--- /dev/null
++++ b/libpostproc/tests/blocktest.c
+@@ -0,0 +1,113 @@
++/*
++ * Copyright (c) 2025 Michael Niedermayer
++ *
++ * This file is part of FFmpeg.
++ *
++ * FFmpeg is free software; you can redistribute it and/or
++ * modify it under the terms of the GNU Lesser General Public
++ * License as published by the Free Software Foundation; either
++ * version 2.1 of the License, or (at your option) any later version.
++ *
++ * FFmpeg is distributed in the hope that it will be useful,
++ * but WITHOUT ANY WARRANTY; without even the implied warranty of
++ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
++ * Lesser General Public License for more details.
++ *
++ * You should have received a copy of the GNU Lesser General Public
++ * License along with FFmpeg; if not, write to the Free Software
++ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
++ */
++
++#include "libavutil/frame.h"
++#include "libavutil/adler32.h"
++#include "libpostproc/postprocess.h"
++#include "test_utils.h"
++
++typedef const uint8_t *cuint8;
++
++static void blocks(AVFrame *frame, int blocksize, int mul)
++{
++    for(int y=0; y<frame->height; y++) {
++        for(int x=0; x<frame->width; x++) {
++            frame->data[0][x + y*frame->linesize[0]] = x/blocksize*mul + y/blocksize*mul;
++        }
++    }
++    for(int y=0; y<(frame->height+1)/2; y++) {
++        for(int x=0; x<(frame->width+1)/2; x++) {
++            frame->data[1][x + y*frame->linesize[1]] = x/blocksize*mul + y/blocksize*mul;
++            frame->data[2][x + y*frame->linesize[2]] = x/blocksize * (y/blocksize)*mul;
++        }
++    }
++}
++
++static int64_t test(int width, int height, const char * filter_string, int blocksize, int flags, int pict_type, int quality) {
++    AVFrame *in  = av_frame_alloc();
++    AVFrame *out = av_frame_alloc();
++    pp_context *context = pp_get_context(width, height, flags);
++    pp_mode *mode = pp_get_mode_by_name_and_quality(filter_string, quality);
++    int64_t ret;
++#define  QP_STRIDE (352/16)
++    int8_t qp[QP_STRIDE * 352/16];
++
++    if (!in || !out || !context || !mode) {
++        ret = AVERROR(ENOMEM);
++        goto end;
++    }
++
++    in-> width = out->width  = width;
++    in->height = out->height = height;
++    in->format = out->format = AV_PIX_FMT_YUV420P;
++
++    ret = av_frame_get_buffer(in, 0);
++    if (ret < 0)
++        goto end;
++
++    ret = av_frame_get_buffer(out, 0);
++    if (ret < 0)
++        goto end;
++
++    blocks(in, blocksize, 11);
++
++    for(int i= 0; i<sizeof(qp); i++)
++        qp[i] = i % 31;
++
++    pp_postprocess( (cuint8[]){in->data[0], in->data[1], in->data[2]}, in->linesize,
++                   out->data, out->linesize,
++                   width, height, qp, QP_STRIDE,
++                   mode, context, pict_type);
++
++    ret = ff_chksum(out);
++end:
++    av_frame_free(&in);
++    av_frame_free(&out);
++    pp_free_context(context);
++    pp_free_mode(mode);
++
++    return ret;
++}
++
++int main(int argc, char **argv) {
++    const char *teststrings[] = {
++        "be,de",
++        "be,h1,v1",
++        "be,ha,va",
++        "be,al,de",
++        "be,vi,de",
++        "be,vi,ha,va",
++    };
++
++    for (int w=16; w< 352; w=w*3-16) {
++        for (int h=16; h< 352; h=h*5-16) {
++            for (int b=1; b<17; b*=2) {
++                for (int c=0; c<6; c++) {
++                    for (int q=0; q<17; q = 2*q+1) {
++                        int64_t ret = test(w, h, teststrings[c], b, PP_FORMAT_420, 0, q);
++                        printf("blocktest %dx%d %s b:%d q:%d result %"PRIX64"\n", w, h, teststrings[c], b, q, ret);
++                    }
++                }
++            }
++        }
++    }
++
++    return 0;
++}
+diff --git a/libpostproc/tests/stripetest.c b/libpostproc/tests/stripetest.c
+new file mode 100644
+index 0000000000000..def7aa3756303
+--- /dev/null
++++ b/libpostproc/tests/stripetest.c
+@@ -0,0 +1,115 @@
++/*
++ * Copyright (c) 2025 Michael Niedermayer
++ *
++ * This file is part of FFmpeg.
++ *
++ * FFmpeg is free software; you can redistribute it and/or
++ * modify it under the terms of the GNU Lesser General Public
++ * License as published by the Free Software Foundation; either
++ * version 2.1 of the License, or (at your option) any later version.
++ *
++ * FFmpeg is distributed in the hope that it will be useful,
++ * but WITHOUT ANY WARRANTY; without even the implied warranty of
++ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
++ * Lesser General Public License for more details.
++ *
++ * You should have received a copy of the GNU Lesser General Public
++ * License along with FFmpeg; if not, write to the Free Software
++ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
++ */
++
++#include "libavutil/frame.h"
++#include "libavutil/adler32.h"
++#include "libpostproc/postprocess.h"
++#include "test_utils.h"
++
++typedef const uint8_t *cuint8;
++
++static void strips(AVFrame *frame, int mul)
++{
++    for(int y=0; y<frame->height; y++) {
++        for(int x=0; x<frame->width; x++) {
++            if (y&1) {
++                frame->data[0][x + y*frame->linesize[0]] = x*x + y*mul;
++            } else {
++                frame->data[0][x + y*frame->linesize[0]] = (y-x)*(y-x);
++            }
++        }
++    }
++    for(int y=0; y<(frame->height+1)/2; y++) {
++        for(int x=0; x<(frame->width+1)/2; x++) {
++            if (y&1) {
++                frame->data[1][x + y*frame->linesize[1]] = x + y + mul;
++                frame->data[2][x + y*frame->linesize[2]] = mul*x - y*x;
++            } else {
++                frame->data[1][x + y*frame->linesize[1]] = (x - y)/(mul+1);
++                frame->data[2][x + y*frame->linesize[2]] = (y + x)/(mul+1);
++            }
++        }
++    }
++}
++
++static int64_t test(int width, int height, const char *testname, int mul, int flags, int pict_type, int quality) {
++    AVFrame *in  = av_frame_alloc();
++    AVFrame *out = av_frame_alloc();
++    pp_context *context = pp_get_context(width, height, flags);
++    pp_mode *mode = pp_get_mode_by_name_and_quality(testname, quality);
++    int64_t ret;
++
++    if (!in || !out || !context || !mode) {
++        ret = AVERROR(ENOMEM);
++        goto end;
++    }
++
++    in-> width = out->width  = width;
++    in->height = out->height = height;
++    in->format = out->format = AV_PIX_FMT_YUV420P;
++
++    ret = av_frame_get_buffer(in, 0);
++    if (ret < 0)
++        goto end;
++
++    ret = av_frame_get_buffer(out, 0);
++    if (ret < 0)
++        goto end;
++
++    strips(in, mul);
++
++    pp_postprocess( (cuint8[]){in->data[0], in->data[1], in->data[2]}, in->linesize,
++                   out->data, out->linesize,
++                   width, height, NULL, 0,
++                   mode, context, pict_type);
++
++    ret = ff_chksum(out);
++end:
++    av_frame_free(&in);
++    av_frame_free(&out);
++    pp_free_context(context);
++    pp_free_mode(mode);
++
++    return ret;
++}
++
++int main(int argc, char **argv) {
++    const char *teststrings[] = {
++        "be,lb",
++        "be,li",
++        "be,ci",
++        "be,md",
++        "be,fd",
++        "be,l5",
++    };
++
++    for (int w=16; w< 352; w=w*3-16) {
++        for (int h=16; h< 352; h=h*5-16) {
++            for (int b=0; b<6; b++) {
++                for (int m=0; m<17; m = 2*m+1) {
++                    int64_t ret = test(w, h, teststrings[b], m, PP_FORMAT_420, 0, 11);
++                    printf("striptest %dx%d T:%s m:%d result %"PRIX64"\n", w, h, teststrings[b], m, ret);
++                }
++            }
++        }
++    }
++
++    return 0;
++}
+diff --git a/libpostproc/tests/temptest.c b/libpostproc/tests/temptest.c
+new file mode 100644
+index 0000000000000..26414a1ce3a7b
+--- /dev/null
++++ b/libpostproc/tests/temptest.c
+@@ -0,0 +1,106 @@
++/*
++ * Copyright (c) 2025 Michael Niedermayer
++ *
++ * This file is part of FFmpeg.
++ *
++ * FFmpeg is free software; you can redistribute it and/or
++ * modify it under the terms of the GNU Lesser General Public
++ * License as published by the Free Software Foundation; either
++ * version 2.1 of the License, or (at your option) any later version.
++ *
++ * FFmpeg is distributed in the hope that it will be useful,
++ * but WITHOUT ANY WARRANTY; without even the implied warranty of
++ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
++ * Lesser General Public License for more details.
++ *
++ * You should have received a copy of the GNU Lesser General Public
++ * License along with FFmpeg; if not, write to the Free Software
++ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
++ */
++
++#include "libavutil/frame.h"
++#include "libavutil/adler32.h"
++#include "libpostproc/postprocess.h"
++#include "test_utils.h"
++
++typedef const uint8_t *cuint8;
++
++static void stuff(AVFrame *frame, unsigned *state, int mul)
++{
++    for(int y=0; y<frame->height; y++) {
++        for(int x=0; x<frame->width; x++) {
++            *state= *state*1664525+1013904223;
++            frame->data[0][x + y*frame->linesize[0]] = x*x + (y-x)*mul + ((((x+y)&0xFF)* (int64_t)(*state))>>32);
++        }
++    }
++    for(int y=0; y<(frame->height+1)/2; y++) {
++        for(int x=0; x<(frame->width+1)/2; x++) {
++            *state= *state*1664525+1013904223;
++            frame->data[1][x + y*frame->linesize[1]] = x + y + ((mul*(int64_t)(*state))>>32);
++            frame->data[2][x + y*frame->linesize[2]] = mul*x - ((y*x*(int64_t)(*state))>>32);
++        }
++    }
++}
++
++static int64_t test(int width, int height, const char *testname, int mul, int flags, int pict_type, int quality) {
++    AVFrame *in  = av_frame_alloc();
++    AVFrame *out = av_frame_alloc();
++    pp_context *context = pp_get_context(width, height, flags);
++    pp_mode *mode = pp_get_mode_by_name_and_quality(testname, quality);
++    int64_t ret;
++
++    if (!in || !out || !context || !mode) {
++        ret = AVERROR(ENOMEM);
++        goto end;
++    }
++
++    in-> width = out->width  = width;
++    in->height = out->height = height;
++    in->format = out->format = AV_PIX_FMT_YUV420P;
++
++    ret = av_frame_get_buffer(in, 0);
++    if (ret < 0)
++        goto end;
++
++    ret = av_frame_get_buffer(out, 0);
++    if (ret < 0)
++        goto end;
++
++    unsigned state = mul;
++    for(int f=0; f<10; f++) {
++        stuff(in, &state, mul);
++
++        pp_postprocess( (cuint8[]){in->data[0], in->data[1], in->data[2]}, in->linesize,
++                    out->data, out->linesize,
++                    width, height, NULL, 0,
++                    mode, context, pict_type);
++
++        ret += ff_chksum(out);
++        ret *= 1664525U;
++    }
++end:
++    av_frame_free(&in);
++    av_frame_free(&out);
++    pp_free_context(context);
++    pp_free_mode(mode);
++
++    return ret;
++}
++
++int main(int argc, char **argv) {
++
++    for(int a=0; a<600000; a= 17*a+1) {
++        for(int b=a; b<600000; b= 17*b+1) {
++            for(int c=b; c<600000; c= 17*c+1) {
++                for (int m=0; m<128; m = 3*m+1) {
++                    char buf[100];
++                    snprintf(buf, sizeof(buf), "be,tn:%d:%d:%d", a, b, c);
++                    int64_t ret = test(352, 288, buf, m, PP_FORMAT_420, 0, 11);
++                    printf("temptest %d %d %d %d result %"PRIX64"\n", a,b,c,m, ret);
++                }
++            }
++        }
++    }
++
++    return 0;
++}
+diff --git a/libpostproc/tests/test_utils.c b/libpostproc/tests/test_utils.c
+new file mode 100644
+index 0000000000000..f1642c0c81f68
+--- /dev/null
++++ b/libpostproc/tests/test_utils.c
+@@ -0,0 +1,38 @@
++/*
++ * Copyright (c) 2025 Michael Niedermayer
++ *
++ * This file is part of FFmpeg.
++ *
++ * FFmpeg is free software; you can redistribute it and/or
++ * modify it under the terms of the GNU Lesser General Public
++ * License as published by the Free Software Foundation; either
++ * version 2.1 of the License, or (at your option) any later version.
++ *
++ * FFmpeg is distributed in the hope that it will be useful,
++ * but WITHOUT ANY WARRANTY; without even the implied warranty of
++ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
++ * Lesser General Public License for more details.
++ *
++ * You should have received a copy of the GNU Lesser General Public
++ * License along with FFmpeg; if not, write to the Free Software
++ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
++ */
++
++#include "libavutil/frame.h"
++#include "libavutil/adler32.h"
++#include "test_utils.h"
++
++int64_t ff_chksum(AVFrame *f)
++{
++    AVAdler a = 123;
++
++    for(int y=0; y<f->height; y++) {
++        a = av_adler32_update(a, &f->data[0][y*f->linesize[0]], f->width);
++    }
++    for(int y=0; y<(f->height+1)/2; y++) {
++        a = av_adler32_update(a, &f->data[1][y*f->linesize[1]], (f->width+1)/2);
++        a = av_adler32_update(a, &f->data[2][y*f->linesize[2]], (f->width+1)/2);
++    }
++
++    return a;
++}
+diff --git a/libpostproc/tests/test_utils.h b/libpostproc/tests/test_utils.h
+new file mode 100644
+index 0000000000000..d73ea6cab84cb
+--- /dev/null
++++ b/libpostproc/tests/test_utils.h
+@@ -0,0 +1,27 @@
++/*
++ * Copyright (c) 2025 Michael Niedermayer
++ *
++ * This file is part of FFmpeg.
++ *
++ * FFmpeg is free software; you can redistribute it and/or
++ * modify it under the terms of the GNU Lesser General Public
++ * License as published by the Free Software Foundation; either
++ * version 2.1 of the License, or (at your option) any later version.
++ *
++ * FFmpeg is distributed in the hope that it will be useful,
++ * but WITHOUT ANY WARRANTY; without even the implied warranty of
++ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
++ * Lesser General Public License for more details.
++ *
++ * You should have received a copy of the GNU Lesser General Public
++ * License along with FFmpeg; if not, write to the Free Software
++ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
++ */
++
++
++#ifndef POSTPROC_TESTS_TEST_UTILS_H
++#define POSTPROC_TESTS_TEST_UTILS_H
++
++int64_t ff_chksum(AVFrame *f);
++
++#endif /* POSTPROC_TESTS_TEST_UTILS_H */
+diff --git a/libpostproc/version.c b/libpostproc/version.c
+new file mode 100644
+index 0000000000000..304abe08e6ac2
+--- /dev/null
++++ b/libpostproc/version.c
+@@ -0,0 +1,45 @@
++/*
++ * Version functions.
++ *
++ * This file is part of FFmpeg.
++ *
++ * FFmpeg is free software; you can redistribute it and/or
++ * modify it under the terms of the GNU Lesser General Public
++ * License as published by the Free Software Foundation; either
++ * version 2.1 of the License, or (at your option) any later version.
++ *
++ * FFmpeg is distributed in the hope that it will be useful,
++ * but WITHOUT ANY WARRANTY; without even the implied warranty of
++ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
++ * Lesser General Public License for more details.
++ *
++ * You should have received a copy of the GNU Lesser General Public
++ * License along with FFmpeg; if not, write to the Free Software
++ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
++ */
++
++#include <assert.h>
++
++#include "config.h"
++#include "postprocess.h"
++#include "version.h"
++
++#include "libavutil/ffversion.h"
++const char postproc_ffversion[] = "FFmpeg version " FFMPEG_VERSION;
++
++unsigned postproc_version(void)
++{
++    static_assert(LIBPOSTPROC_VERSION_MICRO >= 100, "micro version starts at 100");
++    return LIBPOSTPROC_VERSION_INT;
++}
++
++const char *postproc_configuration(void)
++{
++    return FFMPEG_CONFIGURATION;
++}
++
++const char *postproc_license(void)
++{
++#define LICENSE_PREFIX "libpostproc license: "
++    return &LICENSE_PREFIX FFMPEG_LICENSE[sizeof(LICENSE_PREFIX) - 1];
++}
+diff --git a/libpostproc/version.h b/libpostproc/version.h
+new file mode 100644
+index 0000000000000..111f075536906
+--- /dev/null
++++ b/libpostproc/version.h
+@@ -0,0 +1,48 @@
++/*
++ * Version macros.
++ *
++ * This file is part of FFmpeg.
++ *
++ * FFmpeg is free software; you can redistribute it and/or
++ * modify it under the terms of the GNU Lesser General Public
++ * License as published by the Free Software Foundation; either
++ * version 2.1 of the License, or (at your option) any later version.
++ *
++ * FFmpeg is distributed in the hope that it will be useful,
++ * but WITHOUT ANY WARRANTY; without even the implied warranty of
++ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
++ * Lesser General Public License for more details.
++ *
++ * You should have received a copy of the GNU Lesser General Public
++ * License along with FFmpeg; if not, write to the Free Software
++ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
++ */
++
++#ifndef POSTPROC_VERSION_H
++#define POSTPROC_VERSION_H
++
++/**
++ * @file
++ * Libpostproc version macros
++ */
++
++#include "libavutil/version.h"
++
++#include "version_major.h"
++
++#define LIBPOSTPROC_VERSION_MINOR   1
++#define LIBPOSTPROC_VERSION_MICRO 100
++
++#define LIBPOSTPROC_VERSION_INT AV_VERSION_INT(LIBPOSTPROC_VERSION_MAJOR, \
++                                               LIBPOSTPROC_VERSION_MINOR, \
++                                               LIBPOSTPROC_VERSION_MICRO)
++#define LIBPOSTPROC_VERSION     AV_VERSION(LIBPOSTPROC_VERSION_MAJOR, \
++                                           LIBPOSTPROC_VERSION_MINOR, \
++                                           LIBPOSTPROC_VERSION_MICRO)
++#define LIBPOSTPROC_BUILD       LIBPOSTPROC_VERSION_INT
++
++#define LIBPOSTPROC_IDENT       "postproc" AV_STRINGIFY(LIBPOSTPROC_VERSION)
++
++#define PP_AMD_3DNOW               (LIBPOSTPROC_VERSION_MAJOR < 60)
++
++#endif /* POSTPROC_VERSION_H */
+diff --git a/libpostproc/version_major.h b/libpostproc/version_major.h
+new file mode 100644
+index 0000000000000..b9946912db383
+--- /dev/null
++++ b/libpostproc/version_major.h
+@@ -0,0 +1,33 @@
++/*
++ * Version macros.
++ *
++ * This file is part of FFmpeg.
++ *
++ * FFmpeg is free software; you can redistribute it and/or
++ * modify it under the terms of the GNU Lesser General Public
++ * License as published by the Free Software Foundation; either
++ * version 2.1 of the License, or (at your option) any later version.
++ *
++ * FFmpeg is distributed in the hope that it will be useful,
++ * but WITHOUT ANY WARRANTY; without even the implied warranty of
++ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
++ * Lesser General Public License for more details.
++ *
++ * You should have received a copy of the GNU Lesser General Public
++ * License along with FFmpeg; if not, write to the Free Software
++ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
++ */
++
++#ifndef POSTPROC_VERSION_MAJOR_H
++#define POSTPROC_VERSION_MAJOR_H
++
++/**
++ * @file
++ * Libpostproc version macros
++ */
++
++#define LIBPOSTPROC_VERSION_MAJOR  59
++
++#define FF_API_PP_AMD_3DNOW      (LIBPOSTPROC_VERSION_MAJOR < 60)
++
++#endif /* POSTPROC_VERSION_MAJOR_H */
+diff --git a/tests/Makefile b/tests/Makefile
+index 505d7f9c6d6d4..c2043310207f8 100644
+--- a/tests/Makefile
++++ b/tests/Makefile
+@@ -208,6 +208,7 @@ include $(SRC_PATH)/tests/fate/libavformat.mak
+ include $(SRC_PATH)/tests/fate/libavutil.mak
+ include $(SRC_PATH)/tests/fate/libswresample.mak
+ include $(SRC_PATH)/tests/fate/libswscale.mak
++include $(SRC_PATH)/tests/fate/libpostproc.mak
+ include $(SRC_PATH)/tests/fate/lossless-audio.mak
+ include $(SRC_PATH)/tests/fate/lossless-video.mak
+ include $(SRC_PATH)/tests/fate/matroska.mak
+diff --git a/tests/fate/filter-video.mak b/tests/fate/filter-video.mak
+index df8a9327506c2..2ae7aed88dab3 100644
+--- a/tests/fate/filter-video.mak
++++ b/tests/fate/filter-video.mak
+@@ -533,6 +533,19 @@ fate-filter-idet: CMD = framecrc -flags bitexact -idct simple -i $(SRC) -vf idet
+ FATE_FILTER_VSYNTH_VIDEO_FILTER-$(CONFIG_PAD_FILTER) += fate-filter-pad
+ fate-filter-pad: CMD = video_filter "pad=iw*1.5:ih*1.5:iw*0.3:ih*0.2"
+ 
++fate-filter-pp1: CMD = video_filter "pp=fq|4/be/hb/vb/tn/l5/al"
++fate-filter-pp2: CMD = video_filter "qp=2*(x+y),pp=be/h1/v1/lb"
++fate-filter-pp3: CMD = video_filter "qp=2*(x+y),pp=be/ha|128|7/va/li"
++fate-filter-pp4: CMD = video_filter "pp=be/ci"
++fate-filter-pp5: CMD = video_filter "pp=md"
++fate-filter-pp6: CMD = video_filter "pp=be/fd"
++
++FATE_FILTER_VSYNTH_VIDEO_FILTER-$(CONFIG_PP_FILTER) += $(addprefix fate-filter-, pp1 pp4 pp5 pp6)
++FATE_FILTER_VSYNTH_VIDEO_FILTER-$(call ALLYES, PP_FILTER QP_FILTER) += fate-filter-pp2 fate-filter-pp3
++
++FATE_FILTER_VSYNTH1_MPEG4_QPRD-$(call FILTERDEMDEC, PP, AVI, MPEG4) += pp
++fate-filter-pp:  CMD = framecrc -flags bitexact -export_side_data venc_params -idct simple -i $(TARGET_PATH)/tests/data/fate/vsynth1-mpeg4-qprd.avi -frames:v 5 -flags +bitexact -vf "pp=be/hb/vb/tn/l5/al"
++
+ FATE_FILTER_VSYNTH1_MPEG4_QPRD-$(call FILTERDEMDEC, PP7, AVI, MPEG4) += pp7
+ fate-filter-pp7: CMD = framecrc -flags bitexact -export_side_data venc_params -idct simple -i $(TARGET_PATH)/tests/data/fate/vsynth1-mpeg4-qprd.avi -frames:v 5 -flags +bitexact -vf "pp7"
+ 
+@@ -550,6 +563,9 @@ FATE_FILTER_VSYNTH-yes += $(FATE_FILTER_VSYNTH1_MPEG4_QPRD)
+ $(FATE_FILTER_VSYNTH1_MPEG4_QPRD): fate-vsynth1-mpeg4-qprd
+ fate-vsynth1-mpeg4-qprd: KEEP_FILES ?= 1
+ 
++FATE_FILTER_VSYNTH_VIDEO_FILTER-$(call ALLYES, QP_FILTER PP_FILTER) += fate-filter-qp
++fate-filter-qp: CMD = video_filter "qp=34,pp=be/hb/vb/tn/l5/al"
++
+ FATE_FILTER_VSYNTH-$(call FILTERDEMDEC, SELECT, IMAGE2, PGM) += fate-filter-select
+ fate-filter-select: CMD = framecrc -flags bitexact -idct simple -i $(SRC) -vf "select=not(eq(mod(n\,2)\,0)+eq(mod(n\,3)\,0))" -frames:v 25 -flags +bitexact
+ 
+diff --git a/tests/fate/libpostproc.mak b/tests/fate/libpostproc.mak
+new file mode 100644
+index 0000000000000..07fb3dcd07b2c
+--- /dev/null
++++ b/tests/fate/libpostproc.mak
+@@ -0,0 +1,14 @@
++FATE_LIBPOSTPROC += fate-blocktest
++fate-blocktest: libpostproc/tests/blocktest$(EXESUF)
++fate-blocktest: CMD = run libpostproc/tests/blocktest$(EXESUF)
++
++FATE_LIBPOSTPROC += fate-stripetest
++fate-stripetest: libpostproc/tests/stripetest$(EXESUF)
++fate-stripetest: CMD = run libpostproc/tests/stripetest$(EXESUF)
++
++FATE_LIBPOSTPROC += fate-temptest
++fate-temptest: libpostproc/tests/temptest$(EXESUF)
++fate-temptest: CMD = run libpostproc/tests/temptest$(EXESUF)
++
++FATE-$(CONFIG_POSTPROC) += $(FATE_LIBPOSTPROC)
++fate-libpostproc: $(FATE_LIBPOSTPROC)
+diff --git a/tests/ref/fate/blocktest b/tests/ref/fate/blocktest
+new file mode 100644
+index 0000000000000..38cf195c95a9b
+--- /dev/null
++++ b/tests/ref/fate/blocktest
+@@ -0,0 +1,1800 @@
++blocktest 16x16 be,de b:1 q:0 result 67B4B06B
++blocktest 16x16 be,de b:1 q:1 result 67B4B06B
++blocktest 16x16 be,de b:1 q:3 result 67B4B06B
++blocktest 16x16 be,de b:1 q:7 result 62C1B05E
++blocktest 16x16 be,de b:1 q:15 result 62C1B05E
++blocktest 16x16 be,h1,v1 b:1 q:0 result 67B4B06B
++blocktest 16x16 be,h1,v1 b:1 q:1 result 67B4B06B
++blocktest 16x16 be,h1,v1 b:1 q:3 result 67B4B06B
++blocktest 16x16 be,h1,v1 b:1 q:7 result 67B4B06B
++blocktest 16x16 be,h1,v1 b:1 q:15 result 67B4B06B
++blocktest 16x16 be,ha,va b:1 q:0 result 67B4B06B
++blocktest 16x16 be,ha,va b:1 q:1 result 67B4B06B
++blocktest 16x16 be,ha,va b:1 q:3 result 67B4B06B
++blocktest 16x16 be,ha,va b:1 q:7 result 67B4B06B
++blocktest 16x16 be,ha,va b:1 q:15 result 67B4B06B
++blocktest 16x16 be,al,de b:1 q:0 result 67B4B06B
++blocktest 16x16 be,al,de b:1 q:1 result 67B4B06B
++blocktest 16x16 be,al,de b:1 q:3 result 67B4B06B
++blocktest 16x16 be,al,de b:1 q:7 result 62C1B05E
++blocktest 16x16 be,al,de b:1 q:15 result 62C1B05E
++blocktest 16x16 be,vi,de b:1 q:0 result 67B4B06B
++blocktest 16x16 be,vi,de b:1 q:1 result 67B4B06B
++blocktest 16x16 be,vi,de b:1 q:3 result 67B4B06B
++blocktest 16x16 be,vi,de b:1 q:7 result 62C1B05E
++blocktest 16x16 be,vi,de b:1 q:15 result 62C1B05E
++blocktest 16x16 be,vi,ha,va b:1 q:0 result 67B4B06B
++blocktest 16x16 be,vi,ha,va b:1 q:1 result 67B4B06B
++blocktest 16x16 be,vi,ha,va b:1 q:3 result 67B4B06B
++blocktest 16x16 be,vi,ha,va b:1 q:7 result 67B4B06B
++blocktest 16x16 be,vi,ha,va b:1 q:15 result 67B4B06B
++blocktest 16x16 be,de b:2 q:0 result BF005BEB
++blocktest 16x16 be,de b:2 q:1 result BF005BEB
++blocktest 16x16 be,de b:2 q:3 result BF005BEB
++blocktest 16x16 be,de b:2 q:7 result BE6E5BEB
++blocktest 16x16 be,de b:2 q:15 result BE6E5BEB
++blocktest 16x16 be,h1,v1 b:2 q:0 result BF005BEB
++blocktest 16x16 be,h1,v1 b:2 q:1 result BF005BEB
++blocktest 16x16 be,h1,v1 b:2 q:3 result BF005BEB
++blocktest 16x16 be,h1,v1 b:2 q:7 result BF005BEB
++blocktest 16x16 be,h1,v1 b:2 q:15 result BF005BEB
++blocktest 16x16 be,ha,va b:2 q:0 result BF005BEB
++blocktest 16x16 be,ha,va b:2 q:1 result BF005BEB
++blocktest 16x16 be,ha,va b:2 q:3 result BF005BEB
++blocktest 16x16 be,ha,va b:2 q:7 result BF005BEB
++blocktest 16x16 be,ha,va b:2 q:15 result BF005BEB
++blocktest 16x16 be,al,de b:2 q:0 result BF005BEB
++blocktest 16x16 be,al,de b:2 q:1 result BF005BEB
++blocktest 16x16 be,al,de b:2 q:3 result BF005BEB
++blocktest 16x16 be,al,de b:2 q:7 result BE6E5BEB
++blocktest 16x16 be,al,de b:2 q:15 result BE6E5BEB
++blocktest 16x16 be,vi,de b:2 q:0 result BF005BEB
++blocktest 16x16 be,vi,de b:2 q:1 result BF005BEB
++blocktest 16x16 be,vi,de b:2 q:3 result BF005BEB
++blocktest 16x16 be,vi,de b:2 q:7 result BE6E5BEB
++blocktest 16x16 be,vi,de b:2 q:15 result BE6E5BEB
++blocktest 16x16 be,vi,ha,va b:2 q:0 result BF005BEB
++blocktest 16x16 be,vi,ha,va b:2 q:1 result BF005BEB
++blocktest 16x16 be,vi,ha,va b:2 q:3 result BF005BEB
++blocktest 16x16 be,vi,ha,va b:2 q:7 result BF005BEB
++blocktest 16x16 be,vi,ha,va b:2 q:15 result BF005BEB
++blocktest 16x16 be,de b:4 q:0 result C39A24EB
++blocktest 16x16 be,de b:4 q:1 result C39A24EB
++blocktest 16x16 be,de b:4 q:3 result C39A24EB
++blocktest 16x16 be,de b:4 q:7 result B85024DF
++blocktest 16x16 be,de b:4 q:15 result B85024DF
++blocktest 16x16 be,h1,v1 b:4 q:0 result C39A24EB
++blocktest 16x16 be,h1,v1 b:4 q:1 result C39A24EB
++blocktest 16x16 be,h1,v1 b:4 q:3 result C39A24EB
++blocktest 16x16 be,h1,v1 b:4 q:7 result C39A24EB
++blocktest 16x16 be,h1,v1 b:4 q:15 result C39A24EB
++blocktest 16x16 be,ha,va b:4 q:0 result C39A24EB
++blocktest 16x16 be,ha,va b:4 q:1 result C39A24EB
++blocktest 16x16 be,ha,va b:4 q:3 result C39A24EB
++blocktest 16x16 be,ha,va b:4 q:7 result C39A24EB
++blocktest 16x16 be,ha,va b:4 q:15 result C39A24EB
++blocktest 16x16 be,al,de b:4 q:0 result C39A24EB
++blocktest 16x16 be,al,de b:4 q:1 result C39A24EB
++blocktest 16x16 be,al,de b:4 q:3 result C39A24EB
++blocktest 16x16 be,al,de b:4 q:7 result B85024DF
++blocktest 16x16 be,al,de b:4 q:15 result B85024DF
++blocktest 16x16 be,vi,de b:4 q:0 result C39A24EB
++blocktest 16x16 be,vi,de b:4 q:1 result C39A24EB
++blocktest 16x16 be,vi,de b:4 q:3 result C39A24EB
++blocktest 16x16 be,vi,de b:4 q:7 result B85024DF
++blocktest 16x16 be,vi,de b:4 q:15 result B85024DF
++blocktest 16x16 be,vi,ha,va b:4 q:0 result C39A24EB
++blocktest 16x16 be,vi,ha,va b:4 q:1 result C39A24EB
++blocktest 16x16 be,vi,ha,va b:4 q:3 result C39A24EB
++blocktest 16x16 be,vi,ha,va b:4 q:7 result C39A24EB
++blocktest 16x16 be,vi,ha,va b:4 q:15 result C39A24EB
++blocktest 16x16 be,de b:8 q:0 result 48960B7B
++blocktest 16x16 be,de b:8 q:1 result 48960B7B
++blocktest 16x16 be,de b:8 q:3 result 48960B7B
++blocktest 16x16 be,de b:8 q:7 result 48960B7B
++blocktest 16x16 be,de b:8 q:15 result 48960B7B
++blocktest 16x16 be,h1,v1 b:8 q:0 result 48960B7B
++blocktest 16x16 be,h1,v1 b:8 q:1 result 48960B7B
++blocktest 16x16 be,h1,v1 b:8 q:3 result 48960B7B
++blocktest 16x16 be,h1,v1 b:8 q:7 result 48960B7B
++blocktest 16x16 be,h1,v1 b:8 q:15 result 48960B7B
++blocktest 16x16 be,ha,va b:8 q:0 result 48960B7B
++blocktest 16x16 be,ha,va b:8 q:1 result 48960B7B
++blocktest 16x16 be,ha,va b:8 q:3 result 48960B7B
++blocktest 16x16 be,ha,va b:8 q:7 result 48960B7B
++blocktest 16x16 be,ha,va b:8 q:15 result 48960B7B
++blocktest 16x16 be,al,de b:8 q:0 result 48960B7B
++blocktest 16x16 be,al,de b:8 q:1 result 48960B7B
++blocktest 16x16 be,al,de b:8 q:3 result 48960B7B
++blocktest 16x16 be,al,de b:8 q:7 result 48960B7B
++blocktest 16x16 be,al,de b:8 q:15 result 48960B7B
++blocktest 16x16 be,vi,de b:8 q:0 result 48960B7B
++blocktest 16x16 be,vi,de b:8 q:1 result 48960B7B
++blocktest 16x16 be,vi,de b:8 q:3 result 48960B7B
++blocktest 16x16 be,vi,de b:8 q:7 result 48960B7B
++blocktest 16x16 be,vi,de b:8 q:15 result 48960B7B
++blocktest 16x16 be,vi,ha,va b:8 q:0 result 48960B7B
++blocktest 16x16 be,vi,ha,va b:8 q:1 result 48960B7B
++blocktest 16x16 be,vi,ha,va b:8 q:3 result 48960B7B
++blocktest 16x16 be,vi,ha,va b:8 q:7 result 48960B7B
++blocktest 16x16 be,vi,ha,va b:8 q:15 result 48960B7B
++blocktest 16x16 be,de b:16 q:0 result B880007B
++blocktest 16x16 be,de b:16 q:1 result B880007B
++blocktest 16x16 be,de b:16 q:3 result B880007B
++blocktest 16x16 be,de b:16 q:7 result B880007B
++blocktest 16x16 be,de b:16 q:15 result B880007B
++blocktest 16x16 be,h1,v1 b:16 q:0 result B880007B
++blocktest 16x16 be,h1,v1 b:16 q:1 result B880007B
++blocktest 16x16 be,h1,v1 b:16 q:3 result B880007B
++blocktest 16x16 be,h1,v1 b:16 q:7 result B880007B
++blocktest 16x16 be,h1,v1 b:16 q:15 result B880007B
++blocktest 16x16 be,ha,va b:16 q:0 result B880007B
++blocktest 16x16 be,ha,va b:16 q:1 result B880007B
++blocktest 16x16 be,ha,va b:16 q:3 result B880007B
++blocktest 16x16 be,ha,va b:16 q:7 result B880007B
++blocktest 16x16 be,ha,va b:16 q:15 result B880007B
++blocktest 16x16 be,al,de b:16 q:0 result B880007B
++blocktest 16x16 be,al,de b:16 q:1 result B880007B
++blocktest 16x16 be,al,de b:16 q:3 result B880007B
++blocktest 16x16 be,al,de b:16 q:7 result B880007B
++blocktest 16x16 be,al,de b:16 q:15 result B880007B
++blocktest 16x16 be,vi,de b:16 q:0 result B880007B
++blocktest 16x16 be,vi,de b:16 q:1 result B880007B
++blocktest 16x16 be,vi,de b:16 q:3 result B880007B
++blocktest 16x16 be,vi,de b:16 q:7 result B880007B
++blocktest 16x16 be,vi,de b:16 q:15 result B880007B
++blocktest 16x16 be,vi,ha,va b:16 q:0 result B880007B
++blocktest 16x16 be,vi,ha,va b:16 q:1 result B880007B
++blocktest 16x16 be,vi,ha,va b:16 q:3 result B880007B
++blocktest 16x16 be,vi,ha,va b:16 q:7 result B880007B
++blocktest 16x16 be,vi,ha,va b:16 q:15 result B880007B
++blocktest 16x64 be,de b:1 q:0 result 841FE459
++blocktest 16x64 be,de b:1 q:1 result 841FE459
++blocktest 16x64 be,de b:1 q:3 result 841FE459
++blocktest 16x64 be,de b:1 q:7 result 4081E42C
++blocktest 16x64 be,de b:1 q:15 result 4081E42C
++blocktest 16x64 be,h1,v1 b:1 q:0 result 841FE459
++blocktest 16x64 be,h1,v1 b:1 q:1 result 841FE459
++blocktest 16x64 be,h1,v1 b:1 q:3 result 841FE459
++blocktest 16x64 be,h1,v1 b:1 q:7 result 841FE459
++blocktest 16x64 be,h1,v1 b:1 q:15 result 841FE459
++blocktest 16x64 be,ha,va b:1 q:0 result 841FE459
++blocktest 16x64 be,ha,va b:1 q:1 result 841FE459
++blocktest 16x64 be,ha,va b:1 q:3 result 841FE459
++blocktest 16x64 be,ha,va b:1 q:7 result 841FE459
++blocktest 16x64 be,ha,va b:1 q:15 result 841FE459
++blocktest 16x64 be,al,de b:1 q:0 result 841FE459
++blocktest 16x64 be,al,de b:1 q:1 result 841FE459
++blocktest 16x64 be,al,de b:1 q:3 result 841FE459
++blocktest 16x64 be,al,de b:1 q:7 result 56DDE437
++blocktest 16x64 be,al,de b:1 q:15 result 56DDE437
++blocktest 16x64 be,vi,de b:1 q:0 result 841FE459
++blocktest 16x64 be,vi,de b:1 q:1 result 841FE459
++blocktest 16x64 be,vi,de b:1 q:3 result 841FE459
++blocktest 16x64 be,vi,de b:1 q:7 result 4081E42C
++blocktest 16x64 be,vi,de b:1 q:15 result 4081E42C
++blocktest 16x64 be,vi,ha,va b:1 q:0 result 841FE459
++blocktest 16x64 be,vi,ha,va b:1 q:1 result 841FE459
++blocktest 16x64 be,vi,ha,va b:1 q:3 result 841FE459
++blocktest 16x64 be,vi,ha,va b:1 q:7 result 841FE459
++blocktest 16x64 be,vi,ha,va b:1 q:15 result 841FE459
++blocktest 16x64 be,de b:2 q:0 result D1A38359
++blocktest 16x64 be,de b:2 q:1 result D1A38359
++blocktest 16x64 be,de b:2 q:3 result D1A38359
++blocktest 16x64 be,de b:2 q:7 result 9EE48356
++blocktest 16x64 be,de b:2 q:15 result 9EE48356
++blocktest 16x64 be,h1,v1 b:2 q:0 result 20D28359
++blocktest 16x64 be,h1,v1 b:2 q:1 result 20D28359
++blocktest 16x64 be,h1,v1 b:2 q:3 result 20D28359
++blocktest 16x64 be,h1,v1 b:2 q:7 result 20D28359
++blocktest 16x64 be,h1,v1 b:2 q:15 result 20D28359
++blocktest 16x64 be,ha,va b:2 q:0 result D1A38359
++blocktest 16x64 be,ha,va b:2 q:1 result D1A38359
++blocktest 16x64 be,ha,va b:2 q:3 result D1A38359
++blocktest 16x64 be,ha,va b:2 q:7 result D1A38359
++blocktest 16x64 be,ha,va b:2 q:15 result D1A38359
++blocktest 16x64 be,al,de b:2 q:0 result D1A38359
++blocktest 16x64 be,al,de b:2 q:1 result D1A38359
++blocktest 16x64 be,al,de b:2 q:3 result D1A38359
++blocktest 16x64 be,al,de b:2 q:7 result C11B8363
++blocktest 16x64 be,al,de b:2 q:15 result C11B8363
++blocktest 16x64 be,vi,de b:2 q:0 result D1A38359
++blocktest 16x64 be,vi,de b:2 q:1 result D1A38359
++blocktest 16x64 be,vi,de b:2 q:3 result D1A38359
++blocktest 16x64 be,vi,de b:2 q:7 result 9EE48356
++blocktest 16x64 be,vi,de b:2 q:15 result 9EE48356
++blocktest 16x64 be,vi,ha,va b:2 q:0 result D1A38359
++blocktest 16x64 be,vi,ha,va b:2 q:1 result D1A38359
++blocktest 16x64 be,vi,ha,va b:2 q:3 result D1A38359
++blocktest 16x64 be,vi,ha,va b:2 q:7 result D1A38359
++blocktest 16x64 be,vi,ha,va b:2 q:15 result D1A38359
++blocktest 16x64 be,de b:4 q:0 result 46DDCBCA
++blocktest 16x64 be,de b:4 q:1 result 445DCBCA
++blocktest 16x64 be,de b:4 q:3 result FD34CC5A
++blocktest 16x64 be,de b:4 q:7 result 540BCC13
++blocktest 16x64 be,de b:4 q:15 result 540BCC13
++blocktest 16x64 be,h1,v1 b:4 q:0 result 9B3DCBCA
++blocktest 16x64 be,h1,v1 b:4 q:1 result 9B3DCBCA
++blocktest 16x64 be,h1,v1 b:4 q:3 result 9B3DCBCA
++blocktest 16x64 be,h1,v1 b:4 q:7 result 9B3DCBCA
++blocktest 16x64 be,h1,v1 b:4 q:15 result 9B3DCBCA
++blocktest 16x64 be,ha,va b:4 q:0 result 57BDCBCA
++blocktest 16x64 be,ha,va b:4 q:1 result 57BDCBCA
++blocktest 16x64 be,ha,va b:4 q:3 result 57BDCBCA
++blocktest 16x64 be,ha,va b:4 q:7 result 57BDCBCA
++blocktest 16x64 be,ha,va b:4 q:15 result 57BDCBCA
++blocktest 16x64 be,al,de b:4 q:0 result 46DDCBCA
++blocktest 16x64 be,al,de b:4 q:1 result 472DCBCA
++blocktest 16x64 be,al,de b:4 q:3 result B586CB9A
++blocktest 16x64 be,al,de b:4 q:7 result 2701CB5D
++blocktest 16x64 be,al,de b:4 q:15 result 2701CB5D
++blocktest 16x64 be,vi,de b:4 q:0 result 46DDCBCA
++blocktest 16x64 be,vi,de b:4 q:1 result 445DCBCA
++blocktest 16x64 be,vi,de b:4 q:3 result FD34CC5A
++blocktest 16x64 be,vi,de b:4 q:7 result 540BCC13
++blocktest 16x64 be,vi,de b:4 q:15 result 540BCC13
++blocktest 16x64 be,vi,ha,va b:4 q:0 result 92CECBCA
++blocktest 16x64 be,vi,ha,va b:4 q:1 result 92CECBCA
++blocktest 16x64 be,vi,ha,va b:4 q:3 result 92CECBCA
++blocktest 16x64 be,vi,ha,va b:4 q:7 result 92CECBCA
++blocktest 16x64 be,vi,ha,va b:4 q:15 result 92CECBCA
++blocktest 16x64 be,de b:8 q:0 result 6F77C0FB
++blocktest 16x64 be,de b:8 q:1 result 7297C0FB
++blocktest 16x64 be,de b:8 q:3 result 23FFC0CB
++blocktest 16x64 be,de b:8 q:7 result 371BC0C3
++blocktest 16x64 be,de b:8 q:15 result 371BC0C3
++blocktest 16x64 be,h1,v1 b:8 q:0 result BC57C0FB
++blocktest 16x64 be,h1,v1 b:8 q:1 result BC57C0FB
++blocktest 16x64 be,h1,v1 b:8 q:3 result BC57C0FB
++blocktest 16x64 be,h1,v1 b:8 q:7 result BC57C0FB
++blocktest 16x64 be,h1,v1 b:8 q:15 result BC57C0FB
++blocktest 16x64 be,ha,va b:8 q:0 result 7ED7C0FB
++blocktest 16x64 be,ha,va b:8 q:1 result 7ED7C0FB
++blocktest 16x64 be,ha,va b:8 q:3 result 7ED7C0FB
++blocktest 16x64 be,ha,va b:8 q:7 result 7ED7C0FB
++blocktest 16x64 be,ha,va b:8 q:15 result 7ED7C0FB
++blocktest 16x64 be,al,de b:8 q:0 result 6F77C0FB
++blocktest 16x64 be,al,de b:8 q:1 result 7297C0FB
++blocktest 16x64 be,al,de b:8 q:3 result 23FFC0CB
++blocktest 16x64 be,al,de b:8 q:7 result 371BC0C3
++blocktest 16x64 be,al,de b:8 q:15 result 371BC0C3
++blocktest 16x64 be,vi,de b:8 q:0 result 6F77C0FB
++blocktest 16x64 be,vi,de b:8 q:1 result 7297C0FB
++blocktest 16x64 be,vi,de b:8 q:3 result 23FFC0CB
++blocktest 16x64 be,vi,de b:8 q:7 result 371BC0C3
++blocktest 16x64 be,vi,de b:8 q:15 result 371BC0C3
++blocktest 16x64 be,vi,ha,va b:8 q:0 result 41E9C2C5
++blocktest 16x64 be,vi,ha,va b:8 q:1 result 41E9C2C5
++blocktest 16x64 be,vi,ha,va b:8 q:3 result 41E9C2C5
++blocktest 16x64 be,vi,ha,va b:8 q:7 result 41E9C2C5
++blocktest 16x64 be,vi,ha,va b:8 q:15 result 41E9C2C5
++blocktest 16x64 be,de b:16 q:0 result E84A47FB
++blocktest 16x64 be,de b:16 q:1 result E84A47FB
++blocktest 16x64 be,de b:16 q:3 result 1A5947FB
++blocktest 16x64 be,de b:16 q:7 result 26D947FB
++blocktest 16x64 be,de b:16 q:15 result 26D947FB
++blocktest 16x64 be,h1,v1 b:16 q:0 result DD947FB
++blocktest 16x64 be,h1,v1 b:16 q:1 result DD947FB
++blocktest 16x64 be,h1,v1 b:16 q:3 result DD947FB
++blocktest 16x64 be,h1,v1 b:16 q:7 result DD947FB
++blocktest 16x64 be,h1,v1 b:16 q:15 result DD947FB
++blocktest 16x64 be,ha,va b:16 q:0 result EFCA47FB
++blocktest 16x64 be,ha,va b:16 q:1 result EFCA47FB
++blocktest 16x64 be,ha,va b:16 q:3 result EFCA47FB
++blocktest 16x64 be,ha,va b:16 q:7 result EFCA47FB
++blocktest 16x64 be,ha,va b:16 q:15 result EFCA47FB
++blocktest 16x64 be,al,de b:16 q:0 result E84A47FB
++blocktest 16x64 be,al,de b:16 q:1 result E84A47FB
++blocktest 16x64 be,al,de b:16 q:3 result 1A5947FB
++blocktest 16x64 be,al,de b:16 q:7 result 26D947FB
++blocktest 16x64 be,al,de b:16 q:15 result 26D947FB
++blocktest 16x64 be,vi,de b:16 q:0 result E84A47FB
++blocktest 16x64 be,vi,de b:16 q:1 result E84A47FB
++blocktest 16x64 be,vi,de b:16 q:3 result 1A5947FB
++blocktest 16x64 be,vi,de b:16 q:7 result 26D947FB
++blocktest 16x64 be,vi,de b:16 q:15 result 26D947FB
++blocktest 16x64 be,vi,ha,va b:16 q:0 result D5BA4AEB
++blocktest 16x64 be,vi,ha,va b:16 q:1 result D5BA4AEB
++blocktest 16x64 be,vi,ha,va b:16 q:3 result D5BA4AEB
++blocktest 16x64 be,vi,ha,va b:16 q:7 result D5BA4AEB
++blocktest 16x64 be,vi,ha,va b:16 q:15 result D5BA4AEB
++blocktest 16x304 be,de b:1 q:0 result F252DA0E
++blocktest 16x304 be,de b:1 q:1 result F252DA0E
++blocktest 16x304 be,de b:1 q:3 result F252DA0E
++blocktest 16x304 be,de b:1 q:7 result D3C0D9E4
++blocktest 16x304 be,de b:1 q:15 result D3C0D9E4
++blocktest 16x304 be,h1,v1 b:1 q:0 result F252DA0E
++blocktest 16x304 be,h1,v1 b:1 q:1 result F252DA0E
++blocktest 16x304 be,h1,v1 b:1 q:3 result F252DA0E
++blocktest 16x304 be,h1,v1 b:1 q:7 result F252DA0E
++blocktest 16x304 be,h1,v1 b:1 q:15 result F252DA0E
++blocktest 16x304 be,ha,va b:1 q:0 result F252DA0E
++blocktest 16x304 be,ha,va b:1 q:1 result F252DA0E
++blocktest 16x304 be,ha,va b:1 q:3 result F252DA0E
++blocktest 16x304 be,ha,va b:1 q:7 result F252DA0E
++blocktest 16x304 be,ha,va b:1 q:15 result F252DA0E
++blocktest 16x304 be,al,de b:1 q:0 result F252DA0E
++blocktest 16x304 be,al,de b:1 q:1 result F252DA0E
++blocktest 16x304 be,al,de b:1 q:3 result F252DA0E
++blocktest 16x304 be,al,de b:1 q:7 result D3C0D9E4
++blocktest 16x304 be,al,de b:1 q:15 result D3C0D9E4
++blocktest 16x304 be,vi,de b:1 q:0 result F252DA0E
++blocktest 16x304 be,vi,de b:1 q:1 result F252DA0E
++blocktest 16x304 be,vi,de b:1 q:3 result F252DA0E
++blocktest 16x304 be,vi,de b:1 q:7 result D3C0D9E4
++blocktest 16x304 be,vi,de b:1 q:15 result D3C0D9E4
++blocktest 16x304 be,vi,ha,va b:1 q:0 result F252DA0E
++blocktest 16x304 be,vi,ha,va b:1 q:1 result F252DA0E
++blocktest 16x304 be,vi,ha,va b:1 q:3 result F252DA0E
++blocktest 16x304 be,vi,ha,va b:1 q:7 result F252DA0E
++blocktest 16x304 be,vi,ha,va b:1 q:15 result F252DA0E
++blocktest 16x304 be,de b:2 q:0 result CFDF510E
++blocktest 16x304 be,de b:2 q:1 result CFDF510E
++blocktest 16x304 be,de b:2 q:3 result CFDF510E
++blocktest 16x304 be,de b:2 q:7 result E5625190
++blocktest 16x304 be,de b:2 q:15 result E5625190
++blocktest 16x304 be,h1,v1 b:2 q:0 result 9DD24D0E
++blocktest 16x304 be,h1,v1 b:2 q:1 result 9DD24D0E
++blocktest 16x304 be,h1,v1 b:2 q:3 result 9DD24D0E
++blocktest 16x304 be,h1,v1 b:2 q:7 result 9DD24D0E
++blocktest 16x304 be,h1,v1 b:2 q:15 result 9DD24D0E
++blocktest 16x304 be,ha,va b:2 q:0 result CFDF510E
++blocktest 16x304 be,ha,va b:2 q:1 result CFDF510E
++blocktest 16x304 be,ha,va b:2 q:3 result CFDF510E
++blocktest 16x304 be,ha,va b:2 q:7 result CFDF510E
++blocktest 16x304 be,ha,va b:2 q:15 result CFDF510E
++blocktest 16x304 be,al,de b:2 q:0 result CFDF510E
++blocktest 16x304 be,al,de b:2 q:1 result CFDF510E
++blocktest 16x304 be,al,de b:2 q:3 result CFDF510E
++blocktest 16x304 be,al,de b:2 q:7 result 6281518C
++blocktest 16x304 be,al,de b:2 q:15 result 6281518C
++blocktest 16x304 be,vi,de b:2 q:0 result CFDF510E
++blocktest 16x304 be,vi,de b:2 q:1 result CFDF510E
++blocktest 16x304 be,vi,de b:2 q:3 result CFDF510E
++blocktest 16x304 be,vi,de b:2 q:7 result E5625190
++blocktest 16x304 be,vi,de b:2 q:15 result E5625190
++blocktest 16x304 be,vi,ha,va b:2 q:0 result CFDF510E
++blocktest 16x304 be,vi,ha,va b:2 q:1 result CFDF510E
++blocktest 16x304 be,vi,ha,va b:2 q:3 result CFDF510E
++blocktest 16x304 be,vi,ha,va b:2 q:7 result CFDF510E
++blocktest 16x304 be,vi,ha,va b:2 q:15 result CFDF510E
++blocktest 16x304 be,de b:4 q:0 result 4B30C3F
++blocktest 16x304 be,de b:4 q:1 result 1B480C3F
++blocktest 16x304 be,de b:4 q:3 result 34840E77
++blocktest 16x304 be,de b:4 q:7 result B02B0D83
++blocktest 16x304 be,de b:4 q:15 result B02B0D83
++blocktest 16x304 be,h1,v1 b:4 q:0 result 49A20C3F
++blocktest 16x304 be,h1,v1 b:4 q:1 result 49A20C3F
++blocktest 16x304 be,h1,v1 b:4 q:3 result 49A20C3F
++blocktest 16x304 be,h1,v1 b:4 q:7 result 49A20C3F
++blocktest 16x304 be,h1,v1 b:4 q:15 result 49A20C3F
++blocktest 16x304 be,ha,va b:4 q:0 result 79680C3F
++blocktest 16x304 be,ha,va b:4 q:1 result 79680C3F
++blocktest 16x304 be,ha,va b:4 q:3 result 79680C3F
++blocktest 16x304 be,ha,va b:4 q:7 result 79680C3F
++blocktest 16x304 be,ha,va b:4 q:15 result 79680C3F
++blocktest 16x304 be,al,de b:4 q:0 result 4B30C3F
++blocktest 16x304 be,al,de b:4 q:1 result 20E80C3F
++blocktest 16x304 be,al,de b:4 q:3 result 23750CF7
++blocktest 16x304 be,al,de b:4 q:7 result 4B970C0B
++blocktest 16x304 be,al,de b:4 q:15 result 4B970C0B
++blocktest 16x304 be,vi,de b:4 q:0 result 4B30C3F
++blocktest 16x304 be,vi,de b:4 q:1 result 1B480C3F
++blocktest 16x304 be,vi,de b:4 q:3 result 34840E77
++blocktest 16x304 be,vi,de b:4 q:7 result B02B0D83
++blocktest 16x304 be,vi,de b:4 q:15 result B02B0D83
++blocktest 16x304 be,vi,ha,va b:4 q:0 result 4FC80C50
++blocktest 16x304 be,vi,ha,va b:4 q:1 result 4FC80C50
++blocktest 16x304 be,vi,ha,va b:4 q:3 result 4FC80C50
++blocktest 16x304 be,vi,ha,va b:4 q:7 result 4FC80C50
++blocktest 16x304 be,vi,ha,va b:4 q:15 result 4FC80C50
++blocktest 16x304 be,de b:8 q:0 result 6CD11A51
++blocktest 16x304 be,de b:8 q:1 result 83791A51
++blocktest 16x304 be,de b:8 q:3 result F7B518E0
++blocktest 16x304 be,de b:8 q:7 result 25E91888
++blocktest 16x304 be,de b:8 q:15 result 25E91888
++blocktest 16x304 be,h1,v1 b:8 q:0 result 849F1A51
++blocktest 16x304 be,h1,v1 b:8 q:1 result 849F1A51
++blocktest 16x304 be,h1,v1 b:8 q:3 result 849F1A51
++blocktest 16x304 be,h1,v1 b:8 q:7 result 849F1A51
++blocktest 16x304 be,h1,v1 b:8 q:15 result 849F1A51
++blocktest 16x304 be,ha,va b:8 q:0 result D8871A51
++blocktest 16x304 be,ha,va b:8 q:1 result D8871A51
++blocktest 16x304 be,ha,va b:8 q:3 result D8871A51
++blocktest 16x304 be,ha,va b:8 q:7 result D8871A51
++blocktest 16x304 be,ha,va b:8 q:15 result D8871A51
++blocktest 16x304 be,al,de b:8 q:0 result 6CD11A51
++blocktest 16x304 be,al,de b:8 q:1 result 83791A51
++blocktest 16x304 be,al,de b:8 q:3 result F7B518E0
++blocktest 16x304 be,al,de b:8 q:7 result 25E91888
++blocktest 16x304 be,al,de b:8 q:15 result 25E91888
++blocktest 16x304 be,vi,de b:8 q:0 result 6CD11A51
++blocktest 16x304 be,vi,de b:8 q:1 result 83791A51
++blocktest 16x304 be,vi,de b:8 q:3 result F7B518E0
++blocktest 16x304 be,vi,de b:8 q:7 result 25E91888
++blocktest 16x304 be,vi,de b:8 q:15 result 25E91888
++blocktest 16x304 be,vi,ha,va b:8 q:0 result C2FD1D43
++blocktest 16x304 be,vi,ha,va b:8 q:1 result C2FD1D43
++blocktest 16x304 be,vi,ha,va b:8 q:3 result C2FD1D43
++blocktest 16x304 be,vi,ha,va b:8 q:7 result C2FD1D43
++blocktest 16x304 be,vi,ha,va b:8 q:15 result C2FD1D43
++blocktest 16x304 be,de b:16 q:0 result 5FBD38B3
++blocktest 16x304 be,de b:16 q:1 result 5FBD38B3
++blocktest 16x304 be,de b:16 q:3 result BDCC38B3
++blocktest 16x304 be,de b:16 q:7 result 155B38B3
++blocktest 16x304 be,de b:16 q:15 result 155B38B3
++blocktest 16x304 be,h1,v1 b:16 q:0 result 664C38B3
++blocktest 16x304 be,h1,v1 b:16 q:1 result 664C38B3
++blocktest 16x304 be,h1,v1 b:16 q:3 result 664C38B3
++blocktest 16x304 be,h1,v1 b:16 q:7 result 664C38B3
++blocktest 16x304 be,h1,v1 b:16 q:15 result 664C38B3
++blocktest 16x304 be,ha,va b:16 q:0 result 943D38B3
++blocktest 16x304 be,ha,va b:16 q:1 result 943D38B3
++blocktest 16x304 be,ha,va b:16 q:3 result 943D38B3
++blocktest 16x304 be,ha,va b:16 q:7 result 943D38B3
++blocktest 16x304 be,ha,va b:16 q:15 result 943D38B3
++blocktest 16x304 be,al,de b:16 q:0 result 5FBD38B3
++blocktest 16x304 be,al,de b:16 q:1 result 5FBD38B3
++blocktest 16x304 be,al,de b:16 q:3 result BDCC38B3
++blocktest 16x304 be,al,de b:16 q:7 result 155B38B3
++blocktest 16x304 be,al,de b:16 q:15 result 155B38B3
++blocktest 16x304 be,vi,de b:16 q:0 result 5FBD38B3
++blocktest 16x304 be,vi,de b:16 q:1 result 5FBD38B3
++blocktest 16x304 be,vi,de b:16 q:3 result BDCC38B3
++blocktest 16x304 be,vi,de b:16 q:7 result 155B38B3
++blocktest 16x304 be,vi,de b:16 q:15 result 155B38B3
++blocktest 16x304 be,vi,ha,va b:16 q:0 result 94123BF3
++blocktest 16x304 be,vi,ha,va b:16 q:1 result 94123BF3
++blocktest 16x304 be,vi,ha,va b:16 q:3 result 94123BF3
++blocktest 16x304 be,vi,ha,va b:16 q:7 result 94123BF3
++blocktest 16x304 be,vi,ha,va b:16 q:15 result 94123BF3
++blocktest 32x16 be,de b:1 q:0 result 461C6D6A
++blocktest 32x16 be,de b:1 q:1 result 461C6D6A
++blocktest 32x16 be,de b:1 q:3 result 461C6D6A
++blocktest 32x16 be,de b:1 q:7 result 311C6D4E
++blocktest 32x16 be,de b:1 q:15 result 311C6D4E
++blocktest 32x16 be,h1,v1 b:1 q:0 result 461C6D6A
++blocktest 32x16 be,h1,v1 b:1 q:1 result 461C6D6A
++blocktest 32x16 be,h1,v1 b:1 q:3 result 461C6D6A
++blocktest 32x16 be,h1,v1 b:1 q:7 result 461C6D6A
++blocktest 32x16 be,h1,v1 b:1 q:15 result 461C6D6A
++blocktest 32x16 be,ha,va b:1 q:0 result 461C6D6A
++blocktest 32x16 be,ha,va b:1 q:1 result 461C6D6A
++blocktest 32x16 be,ha,va b:1 q:3 result 461C6D6A
++blocktest 32x16 be,ha,va b:1 q:7 result 461C6D6A
++blocktest 32x16 be,ha,va b:1 q:15 result 461C6D6A
++blocktest 32x16 be,al,de b:1 q:0 result 461C6D6A
++blocktest 32x16 be,al,de b:1 q:1 result 461C6D6A
++blocktest 32x16 be,al,de b:1 q:3 result 461C6D6A
++blocktest 32x16 be,al,de b:1 q:7 result 311C6D4E
++blocktest 32x16 be,al,de b:1 q:15 result 311C6D4E
++blocktest 32x16 be,vi,de b:1 q:0 result 461C6D6A
++blocktest 32x16 be,vi,de b:1 q:1 result 461C6D6A
++blocktest 32x16 be,vi,de b:1 q:3 result 461C6D6A
++blocktest 32x16 be,vi,de b:1 q:7 result 311C6D4E
++blocktest 32x16 be,vi,de b:1 q:15 result 311C6D4E
++blocktest 32x16 be,vi,ha,va b:1 q:0 result 461C6D6A
++blocktest 32x16 be,vi,ha,va b:1 q:1 result 461C6D6A
++blocktest 32x16 be,vi,ha,va b:1 q:3 result 461C6D6A
++blocktest 32x16 be,vi,ha,va b:1 q:7 result 461C6D6A
++blocktest 32x16 be,vi,ha,va b:1 q:15 result 461C6D6A
++blocktest 32x16 be,de b:2 q:0 result 73872AEA
++blocktest 32x16 be,de b:2 q:1 result 73872AEA
++blocktest 32x16 be,de b:2 q:3 result 73872AEA
++blocktest 32x16 be,de b:2 q:7 result 6B622AE4
++blocktest 32x16 be,de b:2 q:15 result 6B622AE4
++blocktest 32x16 be,h1,v1 b:2 q:0 result 73872AEA
++blocktest 32x16 be,h1,v1 b:2 q:1 result 73872AEA
++blocktest 32x16 be,h1,v1 b:2 q:3 result 73872AEA
++blocktest 32x16 be,h1,v1 b:2 q:7 result 73872AEA
++blocktest 32x16 be,h1,v1 b:2 q:15 result 73872AEA
++blocktest 32x16 be,ha,va b:2 q:0 result 73872AEA
++blocktest 32x16 be,ha,va b:2 q:1 result 73872AEA
++blocktest 32x16 be,ha,va b:2 q:3 result 73872AEA
++blocktest 32x16 be,ha,va b:2 q:7 result 73872AEA
++blocktest 32x16 be,ha,va b:2 q:15 result 73872AEA
++blocktest 32x16 be,al,de b:2 q:0 result 73872AEA
++blocktest 32x16 be,al,de b:2 q:1 result 73872AEA
++blocktest 32x16 be,al,de b:2 q:3 result 73872AEA
++blocktest 32x16 be,al,de b:2 q:7 result 6B622AE4
++blocktest 32x16 be,al,de b:2 q:15 result 6B622AE4
++blocktest 32x16 be,vi,de b:2 q:0 result 73872AEA
++blocktest 32x16 be,vi,de b:2 q:1 result 73872AEA
++blocktest 32x16 be,vi,de b:2 q:3 result 73872AEA
++blocktest 32x16 be,vi,de b:2 q:7 result 6B622AE4
++blocktest 32x16 be,vi,de b:2 q:15 result 6B622AE4
++blocktest 32x16 be,vi,ha,va b:2 q:0 result 73872AEA
++blocktest 32x16 be,vi,ha,va b:2 q:1 result 73872AEA
++blocktest 32x16 be,vi,ha,va b:2 q:3 result 73872AEA
++blocktest 32x16 be,vi,ha,va b:2 q:7 result 73872AEA
++blocktest 32x16 be,vi,ha,va b:2 q:15 result 73872AEA
++blocktest 32x16 be,de b:4 q:0 result 13BC7D9B
++blocktest 32x16 be,de b:4 q:1 result 13BC7D9B
++blocktest 32x16 be,de b:4 q:3 result 13BC7D9B
++blocktest 32x16 be,de b:4 q:7 result D7BD7D7A
++blocktest 32x16 be,de b:4 q:15 result D7BD7D7A
++blocktest 32x16 be,h1,v1 b:4 q:0 result 13BC7D9B
++blocktest 32x16 be,h1,v1 b:4 q:1 result 13BC7D9B
++blocktest 32x16 be,h1,v1 b:4 q:3 result 13BC7D9B
++blocktest 32x16 be,h1,v1 b:4 q:7 result 13BC7D9B
++blocktest 32x16 be,h1,v1 b:4 q:15 result 13BC7D9B
++blocktest 32x16 be,ha,va b:4 q:0 result 13BC7D9B
++blocktest 32x16 be,ha,va b:4 q:1 result 13BC7D9B
++blocktest 32x16 be,ha,va b:4 q:3 result 13BC7D9B
++blocktest 32x16 be,ha,va b:4 q:7 result 13BC7D9B
++blocktest 32x16 be,ha,va b:4 q:15 result 13BC7D9B
++blocktest 32x16 be,al,de b:4 q:0 result 13BC7D9B
++blocktest 32x16 be,al,de b:4 q:1 result 13BC7D9B
++blocktest 32x16 be,al,de b:4 q:3 result 13BC7D9B
++blocktest 32x16 be,al,de b:4 q:7 result D7BD7D7A
++blocktest 32x16 be,al,de b:4 q:15 result D7BD7D7A
++blocktest 32x16 be,vi,de b:4 q:0 result 13BC7D9B
++blocktest 32x16 be,vi,de b:4 q:1 result 13BC7D9B
++blocktest 32x16 be,vi,de b:4 q:3 result 13BC7D9B
++blocktest 32x16 be,vi,de b:4 q:7 result D7BD7D7A
++blocktest 32x16 be,vi,de b:4 q:15 result D7BD7D7A
++blocktest 32x16 be,vi,ha,va b:4 q:0 result 13BC7D9B
++blocktest 32x16 be,vi,ha,va b:4 q:1 result 13BC7D9B
++blocktest 32x16 be,vi,ha,va b:4 q:3 result 13BC7D9B
++blocktest 32x16 be,vi,ha,va b:4 q:7 result 13BC7D9B
++blocktest 32x16 be,vi,ha,va b:4 q:15 result 13BC7D9B
++blocktest 32x16 be,de b:8 q:0 result 9C4C2F3B
++blocktest 32x16 be,de b:8 q:1 result 9C4C2F3B
++blocktest 32x16 be,de b:8 q:3 result 9C4C2F3B
++blocktest 32x16 be,de b:8 q:7 result 9C4C2F3B
++blocktest 32x16 be,de b:8 q:15 result 9C4C2F3B
++blocktest 32x16 be,h1,v1 b:8 q:0 result 9C4C2F3B
++blocktest 32x16 be,h1,v1 b:8 q:1 result 9C4C2F3B
++blocktest 32x16 be,h1,v1 b:8 q:3 result 9C4C2F3B
++blocktest 32x16 be,h1,v1 b:8 q:7 result 9C4C2F3B
++blocktest 32x16 be,h1,v1 b:8 q:15 result 9C4C2F3B
++blocktest 32x16 be,ha,va b:8 q:0 result 9C4C2F3B
++blocktest 32x16 be,ha,va b:8 q:1 result 9C4C2F3B
++blocktest 32x16 be,ha,va b:8 q:3 result 9C4C2F3B
++blocktest 32x16 be,ha,va b:8 q:7 result 9C4C2F3B
++blocktest 32x16 be,ha,va b:8 q:15 result 9C4C2F3B
++blocktest 32x16 be,al,de b:8 q:0 result 9C4C2F3B
++blocktest 32x16 be,al,de b:8 q:1 result 9C4C2F3B
++blocktest 32x16 be,al,de b:8 q:3 result 9C4C2F3B
++blocktest 32x16 be,al,de b:8 q:7 result 9C4C2F3B
++blocktest 32x16 be,al,de b:8 q:15 result 9C4C2F3B
++blocktest 32x16 be,vi,de b:8 q:0 result 9C4C2F3B
++blocktest 32x16 be,vi,de b:8 q:1 result 9C4C2F3B
++blocktest 32x16 be,vi,de b:8 q:3 result 9C4C2F3B
++blocktest 32x16 be,vi,de b:8 q:7 result 9C4C2F3B
++blocktest 32x16 be,vi,de b:8 q:15 result 9C4C2F3B
++blocktest 32x16 be,vi,ha,va b:8 q:0 result 9C4C2F3B
++blocktest 32x16 be,vi,ha,va b:8 q:1 result 9C4C2F3B
++blocktest 32x16 be,vi,ha,va b:8 q:3 result 9C4C2F3B
++blocktest 32x16 be,vi,ha,va b:8 q:7 result 9C4C2F3B
++blocktest 32x16 be,vi,ha,va b:8 q:15 result 9C4C2F3B
++blocktest 32x16 be,de b:16 q:0 result 1FD90B7B
++blocktest 32x16 be,de b:16 q:1 result 1FD90B7B
++blocktest 32x16 be,de b:16 q:3 result 1FD90B7B
++blocktest 32x16 be,de b:16 q:7 result 1FD90B7B
++blocktest 32x16 be,de b:16 q:15 result 1FD90B7B
++blocktest 32x16 be,h1,v1 b:16 q:0 result 1FD90B7B
++blocktest 32x16 be,h1,v1 b:16 q:1 result 1FD90B7B
++blocktest 32x16 be,h1,v1 b:16 q:3 result 1FD90B7B
++blocktest 32x16 be,h1,v1 b:16 q:7 result 1FD90B7B
++blocktest 32x16 be,h1,v1 b:16 q:15 result 1FD90B7B
++blocktest 32x16 be,ha,va b:16 q:0 result 1FD90B7B
++blocktest 32x16 be,ha,va b:16 q:1 result 1FD90B7B
++blocktest 32x16 be,ha,va b:16 q:3 result 1FD90B7B
++blocktest 32x16 be,ha,va b:16 q:7 result 1FD90B7B
++blocktest 32x16 be,ha,va b:16 q:15 result 1FD90B7B
++blocktest 32x16 be,al,de b:16 q:0 result 1FD90B7B
++blocktest 32x16 be,al,de b:16 q:1 result 1FD90B7B
++blocktest 32x16 be,al,de b:16 q:3 result 1FD90B7B
++blocktest 32x16 be,al,de b:16 q:7 result 1FD90B7B
++blocktest 32x16 be,al,de b:16 q:15 result 1FD90B7B
++blocktest 32x16 be,vi,de b:16 q:0 result 1FD90B7B
++blocktest 32x16 be,vi,de b:16 q:1 result 1FD90B7B
++blocktest 32x16 be,vi,de b:16 q:3 result 1FD90B7B
++blocktest 32x16 be,vi,de b:16 q:7 result 1FD90B7B
++blocktest 32x16 be,vi,de b:16 q:15 result 1FD90B7B
++blocktest 32x16 be,vi,ha,va b:16 q:0 result 1FD90B7B
++blocktest 32x16 be,vi,ha,va b:16 q:1 result 1FD90B7B
++blocktest 32x16 be,vi,ha,va b:16 q:3 result 1FD90B7B
++blocktest 32x16 be,vi,ha,va b:16 q:7 result 1FD90B7B
++blocktest 32x16 be,vi,ha,va b:16 q:15 result 1FD90B7B
++blocktest 32x64 be,de b:1 q:0 result 1816E246
++blocktest 32x64 be,de b:1 q:1 result 1816E246
++blocktest 32x64 be,de b:1 q:3 result 1816E246
++blocktest 32x64 be,de b:1 q:7 result FD1AE1E6
++blocktest 32x64 be,de b:1 q:15 result FD1AE1E6
++blocktest 32x64 be,h1,v1 b:1 q:0 result 1A76E246
++blocktest 32x64 be,h1,v1 b:1 q:1 result 1A76E246
++blocktest 32x64 be,h1,v1 b:1 q:3 result 1A76E246
++blocktest 32x64 be,h1,v1 b:1 q:7 result 1A76E246
++blocktest 32x64 be,h1,v1 b:1 q:15 result 1A76E246
++blocktest 32x64 be,ha,va b:1 q:0 result 1816E246
++blocktest 32x64 be,ha,va b:1 q:1 result 1816E246
++blocktest 32x64 be,ha,va b:1 q:3 result 1816E246
++blocktest 32x64 be,ha,va b:1 q:7 result 1816E246
++blocktest 32x64 be,ha,va b:1 q:15 result 1816E246
++blocktest 32x64 be,al,de b:1 q:0 result 1816E246
++blocktest 32x64 be,al,de b:1 q:1 result 1816E246
++blocktest 32x64 be,al,de b:1 q:3 result 1816E246
++blocktest 32x64 be,al,de b:1 q:7 result 11BAE1EB
++blocktest 32x64 be,al,de b:1 q:15 result 11BAE1EB
++blocktest 32x64 be,vi,de b:1 q:0 result 1816E246
++blocktest 32x64 be,vi,de b:1 q:1 result 1816E246
++blocktest 32x64 be,vi,de b:1 q:3 result 1816E246
++blocktest 32x64 be,vi,de b:1 q:7 result FD1AE1E6
++blocktest 32x64 be,vi,de b:1 q:15 result FD1AE1E6
++blocktest 32x64 be,vi,ha,va b:1 q:0 result 1816E246
++blocktest 32x64 be,vi,ha,va b:1 q:1 result 1816E246
++blocktest 32x64 be,vi,ha,va b:1 q:3 result 1816E246
++blocktest 32x64 be,vi,ha,va b:1 q:7 result 1816E246
++blocktest 32x64 be,vi,ha,va b:1 q:15 result 1816E246
++blocktest 32x64 be,de b:2 q:0 result 2ED7B446
++blocktest 32x64 be,de b:2 q:1 result 2ED7B446
++blocktest 32x64 be,de b:2 q:3 result 2ED7B446
++blocktest 32x64 be,de b:2 q:7 result 19F3B421
++blocktest 32x64 be,de b:2 q:15 result 19F3B421
++blocktest 32x64 be,h1,v1 b:2 q:0 result 6E26B446
++blocktest 32x64 be,h1,v1 b:2 q:1 result 6E26B446
++blocktest 32x64 be,h1,v1 b:2 q:3 result 6E26B446
++blocktest 32x64 be,h1,v1 b:2 q:7 result 6E26B446
++blocktest 32x64 be,h1,v1 b:2 q:15 result 6E26B446
++blocktest 32x64 be,ha,va b:2 q:0 result 2ED7B446
++blocktest 32x64 be,ha,va b:2 q:1 result 2ED7B446
++blocktest 32x64 be,ha,va b:2 q:3 result 2ED7B446
++blocktest 32x64 be,ha,va b:2 q:7 result 2ED7B446
++blocktest 32x64 be,ha,va b:2 q:15 result 2ED7B446
++blocktest 32x64 be,al,de b:2 q:0 result 2ED7B446
++blocktest 32x64 be,al,de b:2 q:1 result 2ED7B446
++blocktest 32x64 be,al,de b:2 q:3 result 2ED7B446
++blocktest 32x64 be,al,de b:2 q:7 result 1698B420
++blocktest 32x64 be,al,de b:2 q:15 result 1698B420
++blocktest 32x64 be,vi,de b:2 q:0 result 2ED7B446
++blocktest 32x64 be,vi,de b:2 q:1 result 2ED7B446
++blocktest 32x64 be,vi,de b:2 q:3 result 2ED7B446
++blocktest 32x64 be,vi,de b:2 q:7 result 19F3B421
++blocktest 32x64 be,vi,de b:2 q:15 result 19F3B421
++blocktest 32x64 be,vi,ha,va b:2 q:0 result 2ED7B446
++blocktest 32x64 be,vi,ha,va b:2 q:1 result 2ED7B446
++blocktest 32x64 be,vi,ha,va b:2 q:3 result 2ED7B446
++blocktest 32x64 be,vi,ha,va b:2 q:7 result 2ED7B446
++blocktest 32x64 be,vi,ha,va b:2 q:15 result 2ED7B446
++blocktest 32x64 be,de b:4 q:0 result 6B4AA37
++blocktest 32x64 be,de b:4 q:1 result FE3FAAF7
++blocktest 32x64 be,de b:4 q:3 result E050AC17
++blocktest 32x64 be,de b:4 q:7 result B92AAB2E
++blocktest 32x64 be,de b:4 q:15 result B92AAB2E
++blocktest 32x64 be,h1,v1 b:4 q:0 result 85D7AA37
++blocktest 32x64 be,h1,v1 b:4 q:1 result 85D7AA37
++blocktest 32x64 be,h1,v1 b:4 q:3 result 85D7AA37
++blocktest 32x64 be,h1,v1 b:4 q:7 result 85D7AA37
++blocktest 32x64 be,h1,v1 b:4 q:15 result 85D7AA37
++blocktest 32x64 be,ha,va b:4 q:0 result 5AACAA37
++blocktest 32x64 be,ha,va b:4 q:1 result 5AACAA37
++blocktest 32x64 be,ha,va b:4 q:3 result 5AACAA37
++blocktest 32x64 be,ha,va b:4 q:7 result 5AACAA37
++blocktest 32x64 be,ha,va b:4 q:15 result 5AACAA37
++blocktest 32x64 be,al,de b:4 q:0 result 6B4AA37
++blocktest 32x64 be,al,de b:4 q:1 result A27CAB57
++blocktest 32x64 be,al,de b:4 q:3 result 1634ABBE
++blocktest 32x64 be,al,de b:4 q:7 result D5E4AACD
++blocktest 32x64 be,al,de b:4 q:15 result D5E4AACD
++blocktest 32x64 be,vi,de b:4 q:0 result 6B4AA37
++blocktest 32x64 be,vi,de b:4 q:1 result FE3FAAF7
++blocktest 32x64 be,vi,de b:4 q:3 result E050AC17
++blocktest 32x64 be,vi,de b:4 q:7 result B92AAB2E
++blocktest 32x64 be,vi,de b:4 q:15 result B92AAB2E
++blocktest 32x64 be,vi,ha,va b:4 q:0 result CDACAA2E
++blocktest 32x64 be,vi,ha,va b:4 q:1 result CDACAA2E
++blocktest 32x64 be,vi,ha,va b:4 q:3 result CDACAA2E
++blocktest 32x64 be,vi,ha,va b:4 q:7 result CDACAA2E
++blocktest 32x64 be,vi,ha,va b:4 q:15 result CDACAA2E
++blocktest 32x64 be,de b:8 q:0 result 345AF50A
++blocktest 32x64 be,de b:8 q:1 result 3D9CF4CA
++blocktest 32x64 be,de b:8 q:3 result 12EDF472
++blocktest 32x64 be,de b:8 q:7 result 8A7DF45A
++blocktest 32x64 be,de b:8 q:15 result 8A7DF45A
++blocktest 32x64 be,h1,v1 b:8 q:0 result 857BF50A
++blocktest 32x64 be,h1,v1 b:8 q:1 result 857BF50A
++blocktest 32x64 be,h1,v1 b:8 q:3 result 857BF50A
++blocktest 32x64 be,h1,v1 b:8 q:7 result 857BF50A
++blocktest 32x64 be,h1,v1 b:8 q:15 result 857BF50A
++blocktest 32x64 be,ha,va b:8 q:0 result 7E5EF50A
++blocktest 32x64 be,ha,va b:8 q:1 result 7E5EF50A
++blocktest 32x64 be,ha,va b:8 q:3 result 7E5EF50A
++blocktest 32x64 be,ha,va b:8 q:7 result 7E5EF50A
++blocktest 32x64 be,ha,va b:8 q:15 result 7E5EF50A
++blocktest 32x64 be,al,de b:8 q:0 result 345AF50A
++blocktest 32x64 be,al,de b:8 q:1 result 3D9CF4CA
++blocktest 32x64 be,al,de b:8 q:3 result 12EDF472
++blocktest 32x64 be,al,de b:8 q:7 result 8A7DF45A
++blocktest 32x64 be,al,de b:8 q:15 result 8A7DF45A
++blocktest 32x64 be,vi,de b:8 q:0 result 345AF50A
++blocktest 32x64 be,vi,de b:8 q:1 result 3D9CF4CA
++blocktest 32x64 be,vi,de b:8 q:3 result 12EDF472
++blocktest 32x64 be,vi,de b:8 q:7 result 8A7DF45A
++blocktest 32x64 be,vi,de b:8 q:15 result 8A7DF45A
++blocktest 32x64 be,vi,ha,va b:8 q:0 result 83DCFAE4
++blocktest 32x64 be,vi,ha,va b:8 q:1 result 83DCFAE4
++blocktest 32x64 be,vi,ha,va b:8 q:3 result 83DCFAE4
++blocktest 32x64 be,vi,ha,va b:8 q:7 result 83DCFAE4
++blocktest 32x64 be,vi,ha,va b:8 q:15 result 83DCFAE4
++blocktest 32x64 be,de b:16 q:0 result 600CBB7B
++blocktest 32x64 be,de b:16 q:1 result 632CBB7B
++blocktest 32x64 be,de b:16 q:3 result 2B3BBB7B
++blocktest 32x64 be,de b:16 q:7 result 5D3BBB7B
++blocktest 32x64 be,de b:16 q:15 result 5D3BBB7B
++blocktest 32x64 be,h1,v1 b:16 q:0 result F7ECBB7B
++blocktest 32x64 be,h1,v1 b:16 q:1 result F7ECBB7B
++blocktest 32x64 be,h1,v1 b:16 q:3 result F7ECBB7B
++blocktest 32x64 be,h1,v1 b:16 q:7 result F7ECBB7B
++blocktest 32x64 be,h1,v1 b:16 q:15 result F7ECBB7B
++blocktest 32x64 be,ha,va b:16 q:0 result 7E9CBB7B
++blocktest 32x64 be,ha,va b:16 q:1 result 7E9CBB7B
++blocktest 32x64 be,ha,va b:16 q:3 result 7E9CBB7B
++blocktest 32x64 be,ha,va b:16 q:7 result 7E9CBB7B
++blocktest 32x64 be,ha,va b:16 q:15 result 7E9CBB7B
++blocktest 32x64 be,al,de b:16 q:0 result 600CBB7B
++blocktest 32x64 be,al,de b:16 q:1 result 632CBB7B
++blocktest 32x64 be,al,de b:16 q:3 result 2B3BBB7B
++blocktest 32x64 be,al,de b:16 q:7 result 5D3BBB7B
++blocktest 32x64 be,al,de b:16 q:15 result 5D3BBB7B
++blocktest 32x64 be,vi,de b:16 q:0 result 600CBB7B
++blocktest 32x64 be,vi,de b:16 q:1 result 632CBB7B
++blocktest 32x64 be,vi,de b:16 q:3 result 2B3BBB7B
++blocktest 32x64 be,vi,de b:16 q:7 result 5D3BBB7B
++blocktest 32x64 be,vi,de b:16 q:15 result 5D3BBB7B
++blocktest 32x64 be,vi,ha,va b:16 q:0 result BEB6C1D2
++blocktest 32x64 be,vi,ha,va b:16 q:1 result BEB6C1D2
++blocktest 32x64 be,vi,ha,va b:16 q:3 result BEB6C1D2
++blocktest 32x64 be,vi,ha,va b:16 q:7 result BEB6C1D2
++blocktest 32x64 be,vi,ha,va b:16 q:15 result BEB6C1D2
++blocktest 32x304 be,de b:1 q:0 result FE2813BF
++blocktest 32x304 be,de b:1 q:1 result FE2813BF
++blocktest 32x304 be,de b:1 q:3 result FE2813BF
++blocktest 32x304 be,de b:1 q:7 result D7F3135F
++blocktest 32x304 be,de b:1 q:15 result D7F3135F
++blocktest 32x304 be,h1,v1 b:1 q:0 result D6A414BF
++blocktest 32x304 be,h1,v1 b:1 q:1 result D6A414BF
++blocktest 32x304 be,h1,v1 b:1 q:3 result D6A414BF
++blocktest 32x304 be,h1,v1 b:1 q:7 result D6A414BF
++blocktest 32x304 be,h1,v1 b:1 q:15 result D6A414BF
++blocktest 32x304 be,ha,va b:1 q:0 result FE2813BF
++blocktest 32x304 be,ha,va b:1 q:1 result FE2813BF
++blocktest 32x304 be,ha,va b:1 q:3 result FE2813BF
++blocktest 32x304 be,ha,va b:1 q:7 result FE2813BF
++blocktest 32x304 be,ha,va b:1 q:15 result FE2813BF
++blocktest 32x304 be,al,de b:1 q:0 result FE2813BF
++blocktest 32x304 be,al,de b:1 q:1 result FE2813BF
++blocktest 32x304 be,al,de b:1 q:3 result FE2813BF
++blocktest 32x304 be,al,de b:1 q:7 result D7F3135F
++blocktest 32x304 be,al,de b:1 q:15 result D7F3135F
++blocktest 32x304 be,vi,de b:1 q:0 result FE2813BF
++blocktest 32x304 be,vi,de b:1 q:1 result FE2813BF
++blocktest 32x304 be,vi,de b:1 q:3 result FE2813BF
++blocktest 32x304 be,vi,de b:1 q:7 result D7F3135F
++blocktest 32x304 be,vi,de b:1 q:15 result D7F3135F
++blocktest 32x304 be,vi,ha,va b:1 q:0 result FE2813BF
++blocktest 32x304 be,vi,ha,va b:1 q:1 result FE2813BF
++blocktest 32x304 be,vi,ha,va b:1 q:3 result FE2813BF
++blocktest 32x304 be,vi,ha,va b:1 q:7 result FE2813BF
++blocktest 32x304 be,vi,ha,va b:1 q:15 result FE2813BF
++blocktest 32x304 be,de b:2 q:0 result 99FEA830
++blocktest 32x304 be,de b:2 q:1 result 99FEA830
++blocktest 32x304 be,de b:2 q:3 result 99FEA830
++blocktest 32x304 be,de b:2 q:7 result 8781A8E5
++blocktest 32x304 be,de b:2 q:15 result 8781A8E5
++blocktest 32x304 be,h1,v1 b:2 q:0 result B124A230
++blocktest 32x304 be,h1,v1 b:2 q:1 result B124A230
++blocktest 32x304 be,h1,v1 b:2 q:3 result B124A230
++blocktest 32x304 be,h1,v1 b:2 q:7 result B124A230
++blocktest 32x304 be,h1,v1 b:2 q:15 result B124A230
++blocktest 32x304 be,ha,va b:2 q:0 result 99FEA830
++blocktest 32x304 be,ha,va b:2 q:1 result 99FEA830
++blocktest 32x304 be,ha,va b:2 q:3 result 99FEA830
++blocktest 32x304 be,ha,va b:2 q:7 result 99FEA830
++blocktest 32x304 be,ha,va b:2 q:15 result 99FEA830
++blocktest 32x304 be,al,de b:2 q:0 result 99FEA830
++blocktest 32x304 be,al,de b:2 q:1 result 99FEA830
++blocktest 32x304 be,al,de b:2 q:3 result 99FEA830
++blocktest 32x304 be,al,de b:2 q:7 result 24D4A8E9
++blocktest 32x304 be,al,de b:2 q:15 result 24D4A8E9
++blocktest 32x304 be,vi,de b:2 q:0 result 99FEA830
++blocktest 32x304 be,vi,de b:2 q:1 result 99FEA830
++blocktest 32x304 be,vi,de b:2 q:3 result 99FEA830
++blocktest 32x304 be,vi,de b:2 q:7 result 8781A8E5
++blocktest 32x304 be,vi,de b:2 q:15 result 8781A8E5
++blocktest 32x304 be,vi,ha,va b:2 q:0 result 99FEA830
++blocktest 32x304 be,vi,ha,va b:2 q:1 result 99FEA830
++blocktest 32x304 be,vi,ha,va b:2 q:3 result 99FEA830
++blocktest 32x304 be,vi,ha,va b:2 q:7 result 99FEA830
++blocktest 32x304 be,vi,ha,va b:2 q:15 result 99FEA830
++blocktest 32x304 be,de b:4 q:0 result 4293C1D2
++blocktest 32x304 be,de b:4 q:1 result DF76C556
++blocktest 32x304 be,de b:4 q:3 result 1A4C8EE
++blocktest 32x304 be,de b:4 q:7 result 4770C79D
++blocktest 32x304 be,de b:4 q:15 result 4770C79D
++blocktest 32x304 be,h1,v1 b:4 q:0 result E12FC1D2
++blocktest 32x304 be,h1,v1 b:4 q:1 result E12FC1D2
++blocktest 32x304 be,h1,v1 b:4 q:3 result E12FC1D2
++blocktest 32x304 be,h1,v1 b:4 q:7 result E12FC1D2
++blocktest 32x304 be,h1,v1 b:4 q:15 result E12FC1D2
++blocktest 32x304 be,ha,va b:4 q:0 result 3A4CC1D2
++blocktest 32x304 be,ha,va b:4 q:1 result 3A4CC1D2
++blocktest 32x304 be,ha,va b:4 q:3 result 3A4CC1D2
++blocktest 32x304 be,ha,va b:4 q:7 result 3A4CC1D2
++blocktest 32x304 be,ha,va b:4 q:15 result 3A4CC1D2
++blocktest 32x304 be,al,de b:4 q:0 result 4293C1D2
++blocktest 32x304 be,al,de b:4 q:1 result B364C532
++blocktest 32x304 be,al,de b:4 q:3 result 9246C710
++blocktest 32x304 be,al,de b:4 q:7 result 98D1C5E5
++blocktest 32x304 be,al,de b:4 q:15 result 98D1C5E5
++blocktest 32x304 be,vi,de b:4 q:0 result 4293C1D2
++blocktest 32x304 be,vi,de b:4 q:1 result DF76C556
++blocktest 32x304 be,vi,de b:4 q:3 result 1A4C8EE
++blocktest 32x304 be,vi,de b:4 q:7 result 4770C79D
++blocktest 32x304 be,vi,de b:4 q:15 result 4770C79D
++blocktest 32x304 be,vi,ha,va b:4 q:0 result 61E5C07A
++blocktest 32x304 be,vi,ha,va b:4 q:1 result 61E5C07A
++blocktest 32x304 be,vi,ha,va b:4 q:3 result 61E5C07A
++blocktest 32x304 be,vi,ha,va b:4 q:7 result 61E5C07A
++blocktest 32x304 be,vi,ha,va b:4 q:15 result 61E5C07A
++blocktest 32x304 be,de b:8 q:0 result 281DE0C5
++blocktest 32x304 be,de b:8 q:1 result 1A4ADF1D
++blocktest 32x304 be,de b:8 q:3 result 5524DC6E
++blocktest 32x304 be,de b:8 q:7 result ACECDB77
++blocktest 32x304 be,de b:8 q:15 result ACECDB77
++blocktest 32x304 be,h1,v1 b:8 q:0 result 1986E0C5
++blocktest 32x304 be,h1,v1 b:8 q:1 result 1986E0C5
++blocktest 32x304 be,h1,v1 b:8 q:3 result 1986E0C5
++blocktest 32x304 be,h1,v1 b:8 q:7 result 1986E0C5
++blocktest 32x304 be,h1,v1 b:8 q:15 result 1986E0C5
++blocktest 32x304 be,ha,va b:8 q:0 result 665E0C5
++blocktest 32x304 be,ha,va b:8 q:1 result 665E0C5
++blocktest 32x304 be,ha,va b:8 q:3 result 665E0C5
++blocktest 32x304 be,ha,va b:8 q:7 result 665E0C5
++blocktest 32x304 be,ha,va b:8 q:15 result 665E0C5
++blocktest 32x304 be,al,de b:8 q:0 result 281DE0C5
++blocktest 32x304 be,al,de b:8 q:1 result 1A4ADF1D
++blocktest 32x304 be,al,de b:8 q:3 result 5524DC6E
++blocktest 32x304 be,al,de b:8 q:7 result ACECDB77
++blocktest 32x304 be,al,de b:8 q:15 result ACECDB77
++blocktest 32x304 be,vi,de b:8 q:0 result 281DE0C5
++blocktest 32x304 be,vi,de b:8 q:1 result 1A4ADF1D
++blocktest 32x304 be,vi,de b:8 q:3 result 5524DC6E
++blocktest 32x304 be,vi,de b:8 q:7 result ACECDB77
++blocktest 32x304 be,vi,de b:8 q:15 result ACECDB77
++blocktest 32x304 be,vi,ha,va b:8 q:0 result 5DBFE942
++blocktest 32x304 be,vi,ha,va b:8 q:1 result 5DBFE942
++blocktest 32x304 be,vi,ha,va b:8 q:3 result 5DBFE942
++blocktest 32x304 be,vi,ha,va b:8 q:7 result 5DBFE942
++blocktest 32x304 be,vi,ha,va b:8 q:15 result 5DBFE942
++blocktest 32x304 be,de b:16 q:0 result 93C541FA
++blocktest 32x304 be,de b:16 q:1 result A9A541FA
++blocktest 32x304 be,de b:16 q:3 result BB6941FF
++blocktest 32x304 be,de b:16 q:7 result 16834201
++blocktest 32x304 be,de b:16 q:15 result 16834201
++blocktest 32x304 be,h1,v1 b:16 q:0 result 8C4F41FA
++blocktest 32x304 be,h1,v1 b:16 q:1 result 8C4F41FA
++blocktest 32x304 be,h1,v1 b:16 q:3 result 8C4F41FA
++blocktest 32x304 be,h1,v1 b:16 q:7 result 8C4F41FA
++blocktest 32x304 be,h1,v1 b:16 q:15 result 8C4F41FA
++blocktest 32x304 be,ha,va b:16 q:0 result 68A141FA
++blocktest 32x304 be,ha,va b:16 q:1 result 68A141FA
++blocktest 32x304 be,ha,va b:16 q:3 result 68A141FA
++blocktest 32x304 be,ha,va b:16 q:7 result 68A141FA
++blocktest 32x304 be,ha,va b:16 q:15 result 68A141FA
++blocktest 32x304 be,al,de b:16 q:0 result 93C541FA
++blocktest 32x304 be,al,de b:16 q:1 result A9A541FA
++blocktest 32x304 be,al,de b:16 q:3 result BB6941FF
++blocktest 32x304 be,al,de b:16 q:7 result 16834201
++blocktest 32x304 be,al,de b:16 q:15 result 16834201
++blocktest 32x304 be,vi,de b:16 q:0 result 93C541FA
++blocktest 32x304 be,vi,de b:16 q:1 result A9A541FA
++blocktest 32x304 be,vi,de b:16 q:3 result BB6941FF
++blocktest 32x304 be,vi,de b:16 q:7 result 16834201
++blocktest 32x304 be,vi,de b:16 q:15 result 16834201
++blocktest 32x304 be,vi,ha,va b:16 q:0 result 84A649E0
++blocktest 32x304 be,vi,ha,va b:16 q:1 result 84A649E0
++blocktest 32x304 be,vi,ha,va b:16 q:3 result 84A649E0
++blocktest 32x304 be,vi,ha,va b:16 q:7 result 84A649E0
++blocktest 32x304 be,vi,ha,va b:16 q:15 result 84A649E0
++blocktest 80x16 be,de b:1 q:0 result 8B49A358
++blocktest 80x16 be,de b:1 q:1 result 8B49A358
++blocktest 80x16 be,de b:1 q:3 result 8B49A358
++blocktest 80x16 be,de b:1 q:7 result 5D51A2B5
++blocktest 80x16 be,de b:1 q:15 result 5D51A2B5
++blocktest 80x16 be,h1,v1 b:1 q:0 result 8B49A358
++blocktest 80x16 be,h1,v1 b:1 q:1 result 8B49A358
++blocktest 80x16 be,h1,v1 b:1 q:3 result 8B49A358
++blocktest 80x16 be,h1,v1 b:1 q:7 result 8B49A358
++blocktest 80x16 be,h1,v1 b:1 q:15 result 8B49A358
++blocktest 80x16 be,ha,va b:1 q:0 result 8B49A358
++blocktest 80x16 be,ha,va b:1 q:1 result 8B49A358
++blocktest 80x16 be,ha,va b:1 q:3 result 8B49A358
++blocktest 80x16 be,ha,va b:1 q:7 result 8B49A358
++blocktest 80x16 be,ha,va b:1 q:15 result 8B49A358
++blocktest 80x16 be,al,de b:1 q:0 result 8B49A358
++blocktest 80x16 be,al,de b:1 q:1 result 8B49A358
++blocktest 80x16 be,al,de b:1 q:3 result 8B49A358
++blocktest 80x16 be,al,de b:1 q:7 result 8B35A2C7
++blocktest 80x16 be,al,de b:1 q:15 result 8B35A2C7
++blocktest 80x16 be,vi,de b:1 q:0 result 8B49A358
++blocktest 80x16 be,vi,de b:1 q:1 result 8B49A358
++blocktest 80x16 be,vi,de b:1 q:3 result 8B49A358
++blocktest 80x16 be,vi,de b:1 q:7 result 5D51A2B5
++blocktest 80x16 be,vi,de b:1 q:15 result 5D51A2B5
++blocktest 80x16 be,vi,ha,va b:1 q:0 result 8B49A358
++blocktest 80x16 be,vi,ha,va b:1 q:1 result 8B49A358
++blocktest 80x16 be,vi,ha,va b:1 q:3 result 8B49A358
++blocktest 80x16 be,vi,ha,va b:1 q:7 result 8B49A358
++blocktest 80x16 be,vi,ha,va b:1 q:15 result 8B49A358
++blocktest 80x16 be,de b:2 q:0 result FB737CD8
++blocktest 80x16 be,de b:2 q:1 result FB737CD8
++blocktest 80x16 be,de b:2 q:3 result FB737CD8
++blocktest 80x16 be,de b:2 q:7 result 1BE97C8A
++blocktest 80x16 be,de b:2 q:15 result 1BE97C8A
++blocktest 80x16 be,h1,v1 b:2 q:0 result FB737CD8
++blocktest 80x16 be,h1,v1 b:2 q:1 result FB737CD8
++blocktest 80x16 be,h1,v1 b:2 q:3 result FB737CD8
++blocktest 80x16 be,h1,v1 b:2 q:7 result FB737CD8
++blocktest 80x16 be,h1,v1 b:2 q:15 result FB737CD8
++blocktest 80x16 be,ha,va b:2 q:0 result FB737CD8
++blocktest 80x16 be,ha,va b:2 q:1 result FB737CD8
++blocktest 80x16 be,ha,va b:2 q:3 result FB737CD8
++blocktest 80x16 be,ha,va b:2 q:7 result FB737CD8
++blocktest 80x16 be,ha,va b:2 q:15 result FB737CD8
++blocktest 80x16 be,al,de b:2 q:0 result FB737CD8
++blocktest 80x16 be,al,de b:2 q:1 result FB737CD8
++blocktest 80x16 be,al,de b:2 q:3 result FB737CD8
++blocktest 80x16 be,al,de b:2 q:7 result 5C0A7C9B
++blocktest 80x16 be,al,de b:2 q:15 result 5C0A7C9B
++blocktest 80x16 be,vi,de b:2 q:0 result FB737CD8
++blocktest 80x16 be,vi,de b:2 q:1 result FB737CD8
++blocktest 80x16 be,vi,de b:2 q:3 result FB737CD8
++blocktest 80x16 be,vi,de b:2 q:7 result 1BE97C8A
++blocktest 80x16 be,vi,de b:2 q:15 result 1BE97C8A
++blocktest 80x16 be,vi,ha,va b:2 q:0 result FB737CD8
++blocktest 80x16 be,vi,ha,va b:2 q:1 result FB737CD8
++blocktest 80x16 be,vi,ha,va b:2 q:3 result FB737CD8
++blocktest 80x16 be,vi,ha,va b:2 q:7 result FB737CD8
++blocktest 80x16 be,vi,ha,va b:2 q:15 result FB737CD8
++blocktest 80x16 be,de b:4 q:0 result 6E3FC149
++blocktest 80x16 be,de b:4 q:1 result 6E3FC149
++blocktest 80x16 be,de b:4 q:3 result 6E3FC149
++blocktest 80x16 be,de b:4 q:7 result D701C039
++blocktest 80x16 be,de b:4 q:15 result D701C039
++blocktest 80x16 be,h1,v1 b:4 q:0 result 6E3FC149
++blocktest 80x16 be,h1,v1 b:4 q:1 result 6E3FC149
++blocktest 80x16 be,h1,v1 b:4 q:3 result 6E3FC149
++blocktest 80x16 be,h1,v1 b:4 q:7 result 6E3FC149
++blocktest 80x16 be,h1,v1 b:4 q:15 result 6E3FC149
++blocktest 80x16 be,ha,va b:4 q:0 result 6E3FC149
++blocktest 80x16 be,ha,va b:4 q:1 result 6E3FC149
++blocktest 80x16 be,ha,va b:4 q:3 result 6E3FC149
++blocktest 80x16 be,ha,va b:4 q:7 result 6E3FC149
++blocktest 80x16 be,ha,va b:4 q:15 result 6E3FC149
++blocktest 80x16 be,al,de b:4 q:0 result 6E3FC149
++blocktest 80x16 be,al,de b:4 q:1 result 6E3FC149
++blocktest 80x16 be,al,de b:4 q:3 result 6E3FC149
++blocktest 80x16 be,al,de b:4 q:7 result D3E0C071
++blocktest 80x16 be,al,de b:4 q:15 result D3E0C071
++blocktest 80x16 be,vi,de b:4 q:0 result 6E3FC149
++blocktest 80x16 be,vi,de b:4 q:1 result 6E3FC149
++blocktest 80x16 be,vi,de b:4 q:3 result 6E3FC149
++blocktest 80x16 be,vi,de b:4 q:7 result D701C039
++blocktest 80x16 be,vi,de b:4 q:15 result D701C039
++blocktest 80x16 be,vi,ha,va b:4 q:0 result 6E3FC149
++blocktest 80x16 be,vi,ha,va b:4 q:1 result 6E3FC149
++blocktest 80x16 be,vi,ha,va b:4 q:3 result 6E3FC149
++blocktest 80x16 be,vi,ha,va b:4 q:7 result 6E3FC149
++blocktest 80x16 be,vi,ha,va b:4 q:15 result 6E3FC149
++blocktest 80x16 be,de b:8 q:0 result 9DCA2F0A
++blocktest 80x16 be,de b:8 q:1 result 9DCA2F0A
++blocktest 80x16 be,de b:8 q:3 result 9DCA2F0A
++blocktest 80x16 be,de b:8 q:7 result 9DCA2F0A
++blocktest 80x16 be,de b:8 q:15 result 9DCA2F0A
++blocktest 80x16 be,h1,v1 b:8 q:0 result 9DCA2F0A
++blocktest 80x16 be,h1,v1 b:8 q:1 result 9DCA2F0A
++blocktest 80x16 be,h1,v1 b:8 q:3 result 9DCA2F0A
++blocktest 80x16 be,h1,v1 b:8 q:7 result 9DCA2F0A
++blocktest 80x16 be,h1,v1 b:8 q:15 result 9DCA2F0A
++blocktest 80x16 be,ha,va b:8 q:0 result 9DCA2F0A
++blocktest 80x16 be,ha,va b:8 q:1 result 9DCA2F0A
++blocktest 80x16 be,ha,va b:8 q:3 result 9DCA2F0A
++blocktest 80x16 be,ha,va b:8 q:7 result 9DCA2F0A
++blocktest 80x16 be,ha,va b:8 q:15 result 9DCA2F0A
++blocktest 80x16 be,al,de b:8 q:0 result 9DCA2F0A
++blocktest 80x16 be,al,de b:8 q:1 result 9DCA2F0A
++blocktest 80x16 be,al,de b:8 q:3 result 9DCA2F0A
++blocktest 80x16 be,al,de b:8 q:7 result 9DCA2F0A
++blocktest 80x16 be,al,de b:8 q:15 result 9DCA2F0A
++blocktest 80x16 be,vi,de b:8 q:0 result 9DCA2F0A
++blocktest 80x16 be,vi,de b:8 q:1 result 9DCA2F0A
++blocktest 80x16 be,vi,de b:8 q:3 result 9DCA2F0A
++blocktest 80x16 be,vi,de b:8 q:7 result 9DCA2F0A
++blocktest 80x16 be,vi,de b:8 q:15 result 9DCA2F0A
++blocktest 80x16 be,vi,ha,va b:8 q:0 result 9DCA2F0A
++blocktest 80x16 be,vi,ha,va b:8 q:1 result 9DCA2F0A
++blocktest 80x16 be,vi,ha,va b:8 q:3 result 9DCA2F0A
++blocktest 80x16 be,vi,ha,va b:8 q:7 result 9DCA2F0A
++blocktest 80x16 be,vi,ha,va b:8 q:15 result 9DCA2F0A
++blocktest 80x16 be,de b:16 q:0 result 45DF797B
++blocktest 80x16 be,de b:16 q:1 result 45DF797B
++blocktest 80x16 be,de b:16 q:3 result 45DF797B
++blocktest 80x16 be,de b:16 q:7 result 45DF797B
++blocktest 80x16 be,de b:16 q:15 result 45DF797B
++blocktest 80x16 be,h1,v1 b:16 q:0 result 45DF797B
++blocktest 80x16 be,h1,v1 b:16 q:1 result 45DF797B
++blocktest 80x16 be,h1,v1 b:16 q:3 result 45DF797B
++blocktest 80x16 be,h1,v1 b:16 q:7 result 45DF797B
++blocktest 80x16 be,h1,v1 b:16 q:15 result 45DF797B
++blocktest 80x16 be,ha,va b:16 q:0 result 45DF797B
++blocktest 80x16 be,ha,va b:16 q:1 result 45DF797B
++blocktest 80x16 be,ha,va b:16 q:3 result 45DF797B
++blocktest 80x16 be,ha,va b:16 q:7 result 45DF797B
++blocktest 80x16 be,ha,va b:16 q:15 result 45DF797B
++blocktest 80x16 be,al,de b:16 q:0 result 45DF797B
++blocktest 80x16 be,al,de b:16 q:1 result 45DF797B
++blocktest 80x16 be,al,de b:16 q:3 result 45DF797B
++blocktest 80x16 be,al,de b:16 q:7 result 45DF797B
++blocktest 80x16 be,al,de b:16 q:15 result 45DF797B
++blocktest 80x16 be,vi,de b:16 q:0 result 45DF797B
++blocktest 80x16 be,vi,de b:16 q:1 result 45DF797B
++blocktest 80x16 be,vi,de b:16 q:3 result 45DF797B
++blocktest 80x16 be,vi,de b:16 q:7 result 45DF797B
++blocktest 80x16 be,vi,de b:16 q:15 result 45DF797B
++blocktest 80x16 be,vi,ha,va b:16 q:0 result 45DF797B
++blocktest 80x16 be,vi,ha,va b:16 q:1 result 45DF797B
++blocktest 80x16 be,vi,ha,va b:16 q:3 result 45DF797B
++blocktest 80x16 be,vi,ha,va b:16 q:7 result 45DF797B
++blocktest 80x16 be,vi,ha,va b:16 q:15 result 45DF797B
++blocktest 80x64 be,de b:1 q:0 result D4BEC0D
++blocktest 80x64 be,de b:1 q:1 result D4BEC0D
++blocktest 80x64 be,de b:1 q:3 result D4BEC0D
++blocktest 80x64 be,de b:1 q:7 result 315BEB14
++blocktest 80x64 be,de b:1 q:15 result 315BEB14
++blocktest 80x64 be,h1,v1 b:1 q:0 result 8AFEC0D
++blocktest 80x64 be,h1,v1 b:1 q:1 result 8AFEC0D
++blocktest 80x64 be,h1,v1 b:1 q:3 result 8AFEC0D
++blocktest 80x64 be,h1,v1 b:1 q:7 result 8AFEC0D
++blocktest 80x64 be,h1,v1 b:1 q:15 result 8AFEC0D
++blocktest 80x64 be,ha,va b:1 q:0 result D4BEC0D
++blocktest 80x64 be,ha,va b:1 q:1 result D4BEC0D
++blocktest 80x64 be,ha,va b:1 q:3 result D4BEC0D
++blocktest 80x64 be,ha,va b:1 q:7 result D4BEC0D
++blocktest 80x64 be,ha,va b:1 q:15 result D4BEC0D
++blocktest 80x64 be,al,de b:1 q:0 result D4BEC0D
++blocktest 80x64 be,al,de b:1 q:1 result D4BEC0D
++blocktest 80x64 be,al,de b:1 q:3 result D4BEC0D
++blocktest 80x64 be,al,de b:1 q:7 result 64DCEB19
++blocktest 80x64 be,al,de b:1 q:15 result 64DCEB19
++blocktest 80x64 be,vi,de b:1 q:0 result D4BEC0D
++blocktest 80x64 be,vi,de b:1 q:1 result D4BEC0D
++blocktest 80x64 be,vi,de b:1 q:3 result D4BEC0D
++blocktest 80x64 be,vi,de b:1 q:7 result 315BEB14
++blocktest 80x64 be,vi,de b:1 q:15 result 315BEB14
++blocktest 80x64 be,vi,ha,va b:1 q:0 result D4BEC0D
++blocktest 80x64 be,vi,ha,va b:1 q:1 result D4BEC0D
++blocktest 80x64 be,vi,ha,va b:1 q:3 result D4BEC0D
++blocktest 80x64 be,vi,ha,va b:1 q:7 result D4BEC0D
++blocktest 80x64 be,vi,ha,va b:1 q:15 result D4BEC0D
++blocktest 80x64 be,de b:2 q:0 result E0C4BF0D
++blocktest 80x64 be,de b:2 q:1 result E0C4BF0D
++blocktest 80x64 be,de b:2 q:3 result E0C4BF0D
++blocktest 80x64 be,de b:2 q:7 result E0EEBE71
++blocktest 80x64 be,de b:2 q:15 result E0EEBE71
++blocktest 80x64 be,h1,v1 b:2 q:0 result CF40BF0D
++blocktest 80x64 be,h1,v1 b:2 q:1 result CF40BF0D
++blocktest 80x64 be,h1,v1 b:2 q:3 result CF40BF0D
++blocktest 80x64 be,h1,v1 b:2 q:7 result CF40BF0D
++blocktest 80x64 be,h1,v1 b:2 q:15 result CF40BF0D
++blocktest 80x64 be,ha,va b:2 q:0 result E0C4BF0D
++blocktest 80x64 be,ha,va b:2 q:1 result E0C4BF0D
++blocktest 80x64 be,ha,va b:2 q:3 result E0C4BF0D
++blocktest 80x64 be,ha,va b:2 q:7 result E0C4BF0D
++blocktest 80x64 be,ha,va b:2 q:15 result E0C4BF0D
++blocktest 80x64 be,al,de b:2 q:0 result E0C4BF0D
++blocktest 80x64 be,al,de b:2 q:1 result E0C4BF0D
++blocktest 80x64 be,al,de b:2 q:3 result E0C4BF0D
++blocktest 80x64 be,al,de b:2 q:7 result 5907BE97
++blocktest 80x64 be,al,de b:2 q:15 result 5907BE97
++blocktest 80x64 be,vi,de b:2 q:0 result E0C4BF0D
++blocktest 80x64 be,vi,de b:2 q:1 result E0C4BF0D
++blocktest 80x64 be,vi,de b:2 q:3 result E0C4BF0D
++blocktest 80x64 be,vi,de b:2 q:7 result E0EEBE71
++blocktest 80x64 be,vi,de b:2 q:15 result E0EEBE71
++blocktest 80x64 be,vi,ha,va b:2 q:0 result E0C4BF0D
++blocktest 80x64 be,vi,ha,va b:2 q:1 result E0C4BF0D
++blocktest 80x64 be,vi,ha,va b:2 q:3 result E0C4BF0D
++blocktest 80x64 be,vi,ha,va b:2 q:7 result E0C4BF0D
++blocktest 80x64 be,vi,ha,va b:2 q:15 result E0C4BF0D
++blocktest 80x64 be,de b:4 q:0 result AFCCD77E
++blocktest 80x64 be,de b:4 q:1 result 43ABD976
++blocktest 80x64 be,de b:4 q:3 result A155DBE2
++blocktest 80x64 be,de b:4 q:7 result 2EAED8DF
++blocktest 80x64 be,de b:4 q:15 result 2EAED8DF
++blocktest 80x64 be,h1,v1 b:4 q:0 result B6DFD77E
++blocktest 80x64 be,h1,v1 b:4 q:1 result B6DFD77E
++blocktest 80x64 be,h1,v1 b:4 q:3 result B6DFD77E
++blocktest 80x64 be,h1,v1 b:4 q:7 result B6DFD77E
++blocktest 80x64 be,h1,v1 b:4 q:15 result B6DFD77E
++blocktest 80x64 be,ha,va b:4 q:0 result 9B7AD77E
++blocktest 80x64 be,ha,va b:4 q:1 result 9B7AD77E
++blocktest 80x64 be,ha,va b:4 q:3 result 9B7AD77E
++blocktest 80x64 be,ha,va b:4 q:7 result 9B7AD77E
++blocktest 80x64 be,ha,va b:4 q:15 result 9B7AD77E
++blocktest 80x64 be,al,de b:4 q:0 result AFCCD77E
++blocktest 80x64 be,al,de b:4 q:1 result DEBDD9D6
++blocktest 80x64 be,al,de b:4 q:3 result 4FE9DB7E
++blocktest 80x64 be,al,de b:4 q:7 result C492D87D
++blocktest 80x64 be,al,de b:4 q:15 result C492D87D
++blocktest 80x64 be,vi,de b:4 q:0 result AFCCD77E
++blocktest 80x64 be,vi,de b:4 q:1 result 43ABD976
++blocktest 80x64 be,vi,de b:4 q:3 result A155DBE2
++blocktest 80x64 be,vi,de b:4 q:7 result 2EAED8DF
++blocktest 80x64 be,vi,de b:4 q:15 result 2EAED8DF
++blocktest 80x64 be,vi,ha,va b:4 q:0 result 6A81D3BF
++blocktest 80x64 be,vi,ha,va b:4 q:1 result 6A81D3BF
++blocktest 80x64 be,vi,ha,va b:4 q:3 result 6A81D3BF
++blocktest 80x64 be,vi,ha,va b:4 q:7 result 6A81D3BF
++blocktest 80x64 be,vi,ha,va b:4 q:15 result 6A81D3BF
++blocktest 80x64 be,de b:8 q:0 result 70654673
++blocktest 80x64 be,de b:8 q:1 result B03D4523
++blocktest 80x64 be,de b:8 q:3 result 2D5A43C0
++blocktest 80x64 be,de b:8 q:7 result 2D994325
++blocktest 80x64 be,de b:8 q:15 result 2D994325
++blocktest 80x64 be,h1,v1 b:8 q:0 result F0B94673
++blocktest 80x64 be,h1,v1 b:8 q:1 result F0B94673
++blocktest 80x64 be,h1,v1 b:8 q:3 result F0B94673
++blocktest 80x64 be,h1,v1 b:8 q:7 result F0B94673
++blocktest 80x64 be,h1,v1 b:8 q:15 result F0B94673
++blocktest 80x64 be,ha,va b:8 q:0 result AC814673
++blocktest 80x64 be,ha,va b:8 q:1 result AC814673
++blocktest 80x64 be,ha,va b:8 q:3 result AC814673
++blocktest 80x64 be,ha,va b:8 q:7 result AC814673
++blocktest 80x64 be,ha,va b:8 q:15 result AC814673
++blocktest 80x64 be,al,de b:8 q:0 result 70654673
++blocktest 80x64 be,al,de b:8 q:1 result 3D3B4543
++blocktest 80x64 be,al,de b:8 q:3 result 161043F0
++blocktest 80x64 be,al,de b:8 q:7 result 164F4355
++blocktest 80x64 be,al,de b:8 q:15 result 164F4355
++blocktest 80x64 be,vi,de b:8 q:0 result 70654673
++blocktest 80x64 be,vi,de b:8 q:1 result B03D4523
++blocktest 80x64 be,vi,de b:8 q:3 result 2D5A43C0
++blocktest 80x64 be,vi,de b:8 q:7 result 2D994325
++blocktest 80x64 be,vi,de b:8 q:15 result 2D994325
++blocktest 80x64 be,vi,ha,va b:8 q:0 result 7E744EC3
++blocktest 80x64 be,vi,ha,va b:8 q:1 result 7E744EC3
++blocktest 80x64 be,vi,ha,va b:8 q:3 result 7E744EC3
++blocktest 80x64 be,vi,ha,va b:8 q:7 result 7E744EC3
++blocktest 80x64 be,vi,ha,va b:8 q:15 result 7E744EC3
++blocktest 80x64 be,de b:16 q:0 result ED376028
++blocktest 80x64 be,de b:16 q:1 result FE676028
++blocktest 80x64 be,de b:16 q:3 result E8826028
++blocktest 80x64 be,de b:16 q:7 result 5FA76038
++blocktest 80x64 be,de b:16 q:15 result 5FA76038
++blocktest 80x64 be,h1,v1 b:16 q:0 result 3EC36028
++blocktest 80x64 be,h1,v1 b:16 q:1 result 3EC36028
++blocktest 80x64 be,h1,v1 b:16 q:3 result 3EC36028
++blocktest 80x64 be,h1,v1 b:16 q:7 result 3EC36028
++blocktest 80x64 be,h1,v1 b:16 q:15 result 3EC36028
++blocktest 80x64 be,ha,va b:16 q:0 result C7756028
++blocktest 80x64 be,ha,va b:16 q:1 result C7756028
++blocktest 80x64 be,ha,va b:16 q:3 result C7756028
++blocktest 80x64 be,ha,va b:16 q:7 result C7756028
++blocktest 80x64 be,ha,va b:16 q:15 result C7756028
++blocktest 80x64 be,al,de b:16 q:0 result ED376028
++blocktest 80x64 be,al,de b:16 q:1 result FCD76028
++blocktest 80x64 be,al,de b:16 q:3 result E6F26028
++blocktest 80x64 be,al,de b:16 q:7 result 5E176038
++blocktest 80x64 be,al,de b:16 q:15 result 5E176038
++blocktest 80x64 be,vi,de b:16 q:0 result ED376028
++blocktest 80x64 be,vi,de b:16 q:1 result FE676028
++blocktest 80x64 be,vi,de b:16 q:3 result E8826028
++blocktest 80x64 be,vi,de b:16 q:7 result 5FA76038
++blocktest 80x64 be,vi,de b:16 q:15 result 5FA76038
++blocktest 80x64 be,vi,ha,va b:16 q:0 result 5B487283
++blocktest 80x64 be,vi,ha,va b:16 q:1 result 5B487283
++blocktest 80x64 be,vi,ha,va b:16 q:3 result 5B487283
++blocktest 80x64 be,vi,ha,va b:16 q:7 result 5B487283
++blocktest 80x64 be,vi,ha,va b:16 q:15 result 5B487283
++blocktest 80x304 be,de b:1 q:0 result 9FAE9EA5
++blocktest 80x304 be,de b:1 q:1 result 9FAE9EA5
++blocktest 80x304 be,de b:1 q:3 result 9FAE9EA5
++blocktest 80x304 be,de b:1 q:7 result 98109DA6
++blocktest 80x304 be,de b:1 q:15 result 98109DA6
++blocktest 80x304 be,h1,v1 b:1 q:0 result DEFCA0A5
++blocktest 80x304 be,h1,v1 b:1 q:1 result DEFCA0A5
++blocktest 80x304 be,h1,v1 b:1 q:3 result DEFCA0A5
++blocktest 80x304 be,h1,v1 b:1 q:7 result DEFCA0A5
++blocktest 80x304 be,h1,v1 b:1 q:15 result DEFCA0A5
++blocktest 80x304 be,ha,va b:1 q:0 result 9FAE9EA5
++blocktest 80x304 be,ha,va b:1 q:1 result 9FAE9EA5
++blocktest 80x304 be,ha,va b:1 q:3 result 9FAE9EA5
++blocktest 80x304 be,ha,va b:1 q:7 result 9FAE9EA5
++blocktest 80x304 be,ha,va b:1 q:15 result 9FAE9EA5
++blocktest 80x304 be,al,de b:1 q:0 result 9FAE9EA5
++blocktest 80x304 be,al,de b:1 q:1 result 9FAE9EA5
++blocktest 80x304 be,al,de b:1 q:3 result 9FAE9EA5
++blocktest 80x304 be,al,de b:1 q:7 result 98109DA6
++blocktest 80x304 be,al,de b:1 q:15 result 98109DA6
++blocktest 80x304 be,vi,de b:1 q:0 result 9FAE9EA5
++blocktest 80x304 be,vi,de b:1 q:1 result 9FAE9EA5
++blocktest 80x304 be,vi,de b:1 q:3 result 9FAE9EA5
++blocktest 80x304 be,vi,de b:1 q:7 result 98109DA6
++blocktest 80x304 be,vi,de b:1 q:15 result 98109DA6
++blocktest 80x304 be,vi,ha,va b:1 q:0 result 9FAE9EA5
++blocktest 80x304 be,vi,ha,va b:1 q:1 result 9FAE9EA5
++blocktest 80x304 be,vi,ha,va b:1 q:3 result 9FAE9EA5
++blocktest 80x304 be,vi,ha,va b:1 q:7 result 9FAE9EA5
++blocktest 80x304 be,vi,ha,va b:1 q:15 result 9FAE9EA5
++blocktest 80x304 be,de b:2 q:0 result 6A5144A5
++blocktest 80x304 be,de b:2 q:1 result 6A5144A5
++blocktest 80x304 be,de b:2 q:3 result 6A5144A5
++blocktest 80x304 be,de b:2 q:7 result 2DF345B5
++blocktest 80x304 be,de b:2 q:15 result 2DF345B5
++blocktest 80x304 be,h1,v1 b:2 q:0 result A7E836A5
++blocktest 80x304 be,h1,v1 b:2 q:1 result A7E836A5
++blocktest 80x304 be,h1,v1 b:2 q:3 result A7E836A5
++blocktest 80x304 be,h1,v1 b:2 q:7 result A7E836A5
++blocktest 80x304 be,h1,v1 b:2 q:15 result A7E836A5
++blocktest 80x304 be,ha,va b:2 q:0 result 6A5144A5
++blocktest 80x304 be,ha,va b:2 q:1 result 6A5144A5
++blocktest 80x304 be,ha,va b:2 q:3 result 6A5144A5
++blocktest 80x304 be,ha,va b:2 q:7 result 6A5144A5
++blocktest 80x304 be,ha,va b:2 q:15 result 6A5144A5
++blocktest 80x304 be,al,de b:2 q:0 result 6A5144A5
++blocktest 80x304 be,al,de b:2 q:1 result 6A5144A5
++blocktest 80x304 be,al,de b:2 q:3 result 6A5144A5
++blocktest 80x304 be,al,de b:2 q:7 result 5E084557
++blocktest 80x304 be,al,de b:2 q:15 result 5E084557
++blocktest 80x304 be,vi,de b:2 q:0 result 6A5144A5
++blocktest 80x304 be,vi,de b:2 q:1 result 6A5144A5
++blocktest 80x304 be,vi,de b:2 q:3 result 6A5144A5
++blocktest 80x304 be,vi,de b:2 q:7 result 2DF345B5
++blocktest 80x304 be,vi,de b:2 q:15 result 2DF345B5
++blocktest 80x304 be,vi,ha,va b:2 q:0 result 6A5144A5
++blocktest 80x304 be,vi,ha,va b:2 q:1 result 6A5144A5
++blocktest 80x304 be,vi,ha,va b:2 q:3 result 6A5144A5
++blocktest 80x304 be,vi,ha,va b:2 q:7 result 6A5144A5
++blocktest 80x304 be,vi,ha,va b:2 q:15 result 6A5144A5
++blocktest 80x304 be,de b:4 q:0 result E605D56
++blocktest 80x304 be,de b:4 q:1 result BA1C6B96
++blocktest 80x304 be,de b:4 q:3 result C6D877AB
++blocktest 80x304 be,de b:4 q:7 result 539D6FC6
++blocktest 80x304 be,de b:4 q:15 result 539D6FC6
++blocktest 80x304 be,h1,v1 b:4 q:0 result 62F55D56
++blocktest 80x304 be,h1,v1 b:4 q:1 result 62F55D56
++blocktest 80x304 be,h1,v1 b:4 q:3 result 62F55D56
++blocktest 80x304 be,h1,v1 b:4 q:7 result 62F55D56
++blocktest 80x304 be,h1,v1 b:4 q:15 result 62F55D56
++blocktest 80x304 be,ha,va b:4 q:0 result D92E5D56
++blocktest 80x304 be,ha,va b:4 q:1 result D92E5D56
++blocktest 80x304 be,ha,va b:4 q:3 result D92E5D56
++blocktest 80x304 be,ha,va b:4 q:7 result D92E5D56
++blocktest 80x304 be,ha,va b:4 q:15 result D92E5D56
++blocktest 80x304 be,al,de b:4 q:0 result E605D56
++blocktest 80x304 be,al,de b:4 q:1 result 8BE26AFA
++blocktest 80x304 be,al,de b:4 q:3 result 75737478
++blocktest 80x304 be,al,de b:4 q:7 result 53516C47
++blocktest 80x304 be,al,de b:4 q:15 result 53516C47
++blocktest 80x304 be,vi,de b:4 q:0 result E605D56
++blocktest 80x304 be,vi,de b:4 q:1 result BA1C6B96
++blocktest 80x304 be,vi,de b:4 q:3 result C6D877AB
++blocktest 80x304 be,vi,de b:4 q:7 result 539D6FC6
++blocktest 80x304 be,vi,de b:4 q:15 result 539D6FC6
++blocktest 80x304 be,vi,ha,va b:4 q:0 result 3586591D
++blocktest 80x304 be,vi,ha,va b:4 q:1 result 3586591D
++blocktest 80x304 be,vi,ha,va b:4 q:3 result 3586591D
++blocktest 80x304 be,vi,ha,va b:4 q:7 result 3586591D
++blocktest 80x304 be,vi,ha,va b:4 q:15 result 3586591D
++blocktest 80x304 be,de b:8 q:0 result 24D6BF99
++blocktest 80x304 be,de b:8 q:1 result 11CBB8C1
++blocktest 80x304 be,de b:8 q:3 result 76CFB06A
++blocktest 80x304 be,de b:8 q:7 result C22CAD49
++blocktest 80x304 be,de b:8 q:15 result C22CAD49
++blocktest 80x304 be,h1,v1 b:8 q:0 result B7BEBF99
++blocktest 80x304 be,h1,v1 b:8 q:1 result B7BEBF99
++blocktest 80x304 be,h1,v1 b:8 q:3 result B7BEBF99
++blocktest 80x304 be,h1,v1 b:8 q:7 result B7BEBF99
++blocktest 80x304 be,h1,v1 b:8 q:15 result B7BEBF99
++blocktest 80x304 be,ha,va b:8 q:0 result 2C8DBF99
++blocktest 80x304 be,ha,va b:8 q:1 result 2C8DBF99
++blocktest 80x304 be,ha,va b:8 q:3 result 2C8DBF99
++blocktest 80x304 be,ha,va b:8 q:7 result 2C8DBF99
++blocktest 80x304 be,ha,va b:8 q:15 result 2C8DBF99
++blocktest 80x304 be,al,de b:8 q:0 result 24D6BF99
++blocktest 80x304 be,al,de b:8 q:1 result 566DB911
++blocktest 80x304 be,al,de b:8 q:3 result 5D4DB136
++blocktest 80x304 be,al,de b:8 q:7 result A8AAAE15
++blocktest 80x304 be,al,de b:8 q:15 result A8AAAE15
++blocktest 80x304 be,vi,de b:8 q:0 result 24D6BF99
++blocktest 80x304 be,vi,de b:8 q:1 result 11CBB8C1
++blocktest 80x304 be,vi,de b:8 q:3 result 76CFB06A
++blocktest 80x304 be,vi,de b:8 q:7 result C22CAD49
++blocktest 80x304 be,vi,de b:8 q:15 result C22CAD49
++blocktest 80x304 be,vi,ha,va b:8 q:0 result BA23C574
++blocktest 80x304 be,vi,ha,va b:8 q:1 result BA23C574
++blocktest 80x304 be,vi,ha,va b:8 q:3 result BA23C574
++blocktest 80x304 be,vi,ha,va b:8 q:7 result BA23C574
++blocktest 80x304 be,vi,ha,va b:8 q:15 result BA23C574
++blocktest 80x304 be,de b:16 q:0 result ABE69056
++blocktest 80x304 be,de b:16 q:1 result 8259056
++blocktest 80x304 be,de b:16 q:3 result 39779099
++blocktest 80x304 be,de b:16 q:7 result E39890D0
++blocktest 80x304 be,de b:16 q:15 result E39890D0
++blocktest 80x304 be,h1,v1 b:16 q:0 result E75E9056
++blocktest 80x304 be,h1,v1 b:16 q:1 result E75E9056
++blocktest 80x304 be,h1,v1 b:16 q:3 result E75E9056
++blocktest 80x304 be,h1,v1 b:16 q:7 result E75E9056
++blocktest 80x304 be,h1,v1 b:16 q:15 result E75E9056
++blocktest 80x304 be,ha,va b:16 q:0 result C6359056
++blocktest 80x304 be,ha,va b:16 q:1 result C6359056
++blocktest 80x304 be,ha,va b:16 q:3 result C6359056
++blocktest 80x304 be,ha,va b:16 q:7 result C6359056
++blocktest 80x304 be,ha,va b:16 q:15 result C6359056
++blocktest 80x304 be,al,de b:16 q:0 result ABE69056
++blocktest 80x304 be,al,de b:16 q:1 result 3759056
++blocktest 80x304 be,al,de b:16 q:3 result 23459096
++blocktest 80x304 be,al,de b:16 q:7 result CD6690CD
++blocktest 80x304 be,al,de b:16 q:15 result CD6690CD
++blocktest 80x304 be,vi,de b:16 q:0 result ABE69056
++blocktest 80x304 be,vi,de b:16 q:1 result 8259056
++blocktest 80x304 be,vi,de b:16 q:3 result 39779099
++blocktest 80x304 be,vi,de b:16 q:7 result E39890D0
++blocktest 80x304 be,vi,de b:16 q:15 result E39890D0
++blocktest 80x304 be,vi,ha,va b:16 q:0 result 533A780
++blocktest 80x304 be,vi,ha,va b:16 q:1 result 533A780
++blocktest 80x304 be,vi,ha,va b:16 q:3 result 533A780
++blocktest 80x304 be,vi,ha,va b:16 q:7 result 533A780
++blocktest 80x304 be,vi,ha,va b:16 q:15 result 533A780
++blocktest 224x16 be,de b:1 q:0 result 7B974D31
++blocktest 224x16 be,de b:1 q:1 result 7B974D31
++blocktest 224x16 be,de b:1 q:3 result 7B974D31
++blocktest 224x16 be,de b:1 q:7 result EB794AC0
++blocktest 224x16 be,de b:1 q:15 result EB794AC0
++blocktest 224x16 be,h1,v1 b:1 q:0 result 7B974D31
++blocktest 224x16 be,h1,v1 b:1 q:1 result 7B974D31
++blocktest 224x16 be,h1,v1 b:1 q:3 result 7B974D31
++blocktest 224x16 be,h1,v1 b:1 q:7 result 7B974D31
++blocktest 224x16 be,h1,v1 b:1 q:15 result 7B974D31
++blocktest 224x16 be,ha,va b:1 q:0 result 7B974D31
++blocktest 224x16 be,ha,va b:1 q:1 result 7B974D31
++blocktest 224x16 be,ha,va b:1 q:3 result 7B974D31
++blocktest 224x16 be,ha,va b:1 q:7 result 7B974D31
++blocktest 224x16 be,ha,va b:1 q:15 result 7B974D31
++blocktest 224x16 be,al,de b:1 q:0 result 7B974D31
++blocktest 224x16 be,al,de b:1 q:1 result 7B974D31
++blocktest 224x16 be,al,de b:1 q:3 result 7B974D31
++blocktest 224x16 be,al,de b:1 q:7 result 470B4ACC
++blocktest 224x16 be,al,de b:1 q:15 result 470B4ACC
++blocktest 224x16 be,vi,de b:1 q:0 result 7B974D31
++blocktest 224x16 be,vi,de b:1 q:1 result 7B974D31
++blocktest 224x16 be,vi,de b:1 q:3 result 7B974D31
++blocktest 224x16 be,vi,de b:1 q:7 result EB794AC0
++blocktest 224x16 be,vi,de b:1 q:15 result EB794AC0
++blocktest 224x16 be,vi,ha,va b:1 q:0 result 7B974D31
++blocktest 224x16 be,vi,ha,va b:1 q:1 result 7B974D31
++blocktest 224x16 be,vi,ha,va b:1 q:3 result 7B974D31
++blocktest 224x16 be,vi,ha,va b:1 q:7 result 7B974D31
++blocktest 224x16 be,vi,ha,va b:1 q:15 result 7B974D31
++blocktest 224x16 be,de b:2 q:0 result 7C63EBA2
++blocktest 224x16 be,de b:2 q:1 result 7C63EBA2
++blocktest 224x16 be,de b:2 q:3 result 7C63EBA2
++blocktest 224x16 be,de b:2 q:7 result 52FEBA4
++blocktest 224x16 be,de b:2 q:15 result 52FEBA4
++blocktest 224x16 be,h1,v1 b:2 q:0 result 370E9A2
++blocktest 224x16 be,h1,v1 b:2 q:1 result 370E9A2
++blocktest 224x16 be,h1,v1 b:2 q:3 result 370E9A2
++blocktest 224x16 be,h1,v1 b:2 q:7 result 370E9A2
++blocktest 224x16 be,h1,v1 b:2 q:15 result 370E9A2
++blocktest 224x16 be,ha,va b:2 q:0 result 7C63EBA2
++blocktest 224x16 be,ha,va b:2 q:1 result 7C63EBA2
++blocktest 224x16 be,ha,va b:2 q:3 result 7C63EBA2
++blocktest 224x16 be,ha,va b:2 q:7 result 7C63EBA2
++blocktest 224x16 be,ha,va b:2 q:15 result 7C63EBA2
++blocktest 224x16 be,al,de b:2 q:0 result 7C63EBA2
++blocktest 224x16 be,al,de b:2 q:1 result 7C63EBA2
++blocktest 224x16 be,al,de b:2 q:3 result 7C63EBA2
++blocktest 224x16 be,al,de b:2 q:7 result 9A22EB6E
++blocktest 224x16 be,al,de b:2 q:15 result 9A22EB6E
++blocktest 224x16 be,vi,de b:2 q:0 result 7C63EBA2
++blocktest 224x16 be,vi,de b:2 q:1 result 7C63EBA2
++blocktest 224x16 be,vi,de b:2 q:3 result 7C63EBA2
++blocktest 224x16 be,vi,de b:2 q:7 result 52FEBA4
++blocktest 224x16 be,vi,de b:2 q:15 result 52FEBA4
++blocktest 224x16 be,vi,ha,va b:2 q:0 result 7C63EBA2
++blocktest 224x16 be,vi,ha,va b:2 q:1 result 7C63EBA2
++blocktest 224x16 be,vi,ha,va b:2 q:3 result 7C63EBA2
++blocktest 224x16 be,vi,ha,va b:2 q:7 result 7C63EBA2
++blocktest 224x16 be,vi,ha,va b:2 q:15 result 7C63EBA2
++blocktest 224x16 be,de b:4 q:0 result E4F2C1D3
++blocktest 224x16 be,de b:4 q:1 result 2500C2CF
++blocktest 224x16 be,de b:4 q:3 result 73CDC2CD
++blocktest 224x16 be,de b:4 q:7 result A0B7C1F4
++blocktest 224x16 be,de b:4 q:15 result A0B7C1F4
++blocktest 224x16 be,h1,v1 b:4 q:0 result 45ACC1D3
++blocktest 224x16 be,h1,v1 b:4 q:1 result 45ACC1D3
++blocktest 224x16 be,h1,v1 b:4 q:3 result 45ACC1D3
++blocktest 224x16 be,h1,v1 b:4 q:7 result 45ACC1D3
++blocktest 224x16 be,h1,v1 b:4 q:15 result 45ACC1D3
++blocktest 224x16 be,ha,va b:4 q:0 result 4E66C1D3
++blocktest 224x16 be,ha,va b:4 q:1 result 4E66C1D3
++blocktest 224x16 be,ha,va b:4 q:3 result 4E66C1D3
++blocktest 224x16 be,ha,va b:4 q:7 result 4E66C1D3
++blocktest 224x16 be,ha,va b:4 q:15 result 4E66C1D3
++blocktest 224x16 be,al,de b:4 q:0 result E4F2C1D3
++blocktest 224x16 be,al,de b:4 q:1 result F942C1D3
++blocktest 224x16 be,al,de b:4 q:3 result 57C4C1DC
++blocktest 224x16 be,al,de b:4 q:7 result 6F21C0E2
++blocktest 224x16 be,al,de b:4 q:15 result 6F21C0E2
++blocktest 224x16 be,vi,de b:4 q:0 result E4F2C1D3
++blocktest 224x16 be,vi,de b:4 q:1 result 2500C2CF
++blocktest 224x16 be,vi,de b:4 q:3 result 73CDC2CD
++blocktest 224x16 be,vi,de b:4 q:7 result A0B7C1F4
++blocktest 224x16 be,vi,de b:4 q:15 result A0B7C1F4
++blocktest 224x16 be,vi,ha,va b:4 q:0 result E4DEC108
++blocktest 224x16 be,vi,ha,va b:4 q:1 result E4DEC108
++blocktest 224x16 be,vi,ha,va b:4 q:3 result E4DEC108
++blocktest 224x16 be,vi,ha,va b:4 q:7 result E4DEC108
++blocktest 224x16 be,vi,ha,va b:4 q:15 result E4DEC108
++blocktest 224x16 be,de b:8 q:0 result 74FB2724
++blocktest 224x16 be,de b:8 q:1 result 4B862654
++blocktest 224x16 be,de b:8 q:3 result EA182630
++blocktest 224x16 be,de b:8 q:7 result EA182630
++blocktest 224x16 be,de b:8 q:15 result EA182630
++blocktest 224x16 be,h1,v1 b:8 q:0 result A0A22724
++blocktest 224x16 be,h1,v1 b:8 q:1 result A0A22724
++blocktest 224x16 be,h1,v1 b:8 q:3 result A0A22724
++blocktest 224x16 be,h1,v1 b:8 q:7 result A0A22724
++blocktest 224x16 be,h1,v1 b:8 q:15 result A0A22724
++blocktest 224x16 be,ha,va b:8 q:0 result DE0C2724
++blocktest 224x16 be,ha,va b:8 q:1 result DE0C2724
++blocktest 224x16 be,ha,va b:8 q:3 result DE0C2724
++blocktest 224x16 be,ha,va b:8 q:7 result DE0C2724
++blocktest 224x16 be,ha,va b:8 q:15 result DE0C2724
++blocktest 224x16 be,al,de b:8 q:0 result 74FB2724
++blocktest 224x16 be,al,de b:8 q:1 result 9842674
++blocktest 224x16 be,al,de b:8 q:3 result 49372650
++blocktest 224x16 be,al,de b:8 q:7 result 49372650
++blocktest 224x16 be,al,de b:8 q:15 result 49372650
++blocktest 224x16 be,vi,de b:8 q:0 result 74FB2724
++blocktest 224x16 be,vi,de b:8 q:1 result 4B862654
++blocktest 224x16 be,vi,de b:8 q:3 result EA182630
++blocktest 224x16 be,vi,de b:8 q:7 result EA182630
++blocktest 224x16 be,vi,de b:8 q:15 result EA182630
++blocktest 224x16 be,vi,ha,va b:8 q:0 result 629B2562
++blocktest 224x16 be,vi,ha,va b:8 q:1 result 629B2562
++blocktest 224x16 be,vi,ha,va b:8 q:3 result 629B2562
++blocktest 224x16 be,vi,ha,va b:8 q:7 result 629B2562
++blocktest 224x16 be,vi,ha,va b:8 q:15 result 629B2562
++blocktest 224x16 be,de b:16 q:0 result 6BB5D37
++blocktest 224x16 be,de b:16 q:1 result 133B5D37
++blocktest 224x16 be,de b:16 q:3 result 165B5D37
++blocktest 224x16 be,de b:16 q:7 result 165B5D37
++blocktest 224x16 be,de b:16 q:15 result 165B5D37
++blocktest 224x16 be,h1,v1 b:16 q:0 result 9135D37
++blocktest 224x16 be,h1,v1 b:16 q:1 result 9135D37
++blocktest 224x16 be,h1,v1 b:16 q:3 result 9135D37
++blocktest 224x16 be,h1,v1 b:16 q:7 result 9135D37
++blocktest 224x16 be,h1,v1 b:16 q:15 result 9135D37
++blocktest 224x16 be,ha,va b:16 q:0 result 8CB5D37
++blocktest 224x16 be,ha,va b:16 q:1 result 8CB5D37
++blocktest 224x16 be,ha,va b:16 q:3 result 8CB5D37
++blocktest 224x16 be,ha,va b:16 q:7 result 8CB5D37
++blocktest 224x16 be,ha,va b:16 q:15 result 8CB5D37
++blocktest 224x16 be,al,de b:16 q:0 result 6BB5D37
++blocktest 224x16 be,al,de b:16 q:1 result 11AB5D37
++blocktest 224x16 be,al,de b:16 q:3 result 14CB5D37
++blocktest 224x16 be,al,de b:16 q:7 result 14CB5D37
++blocktest 224x16 be,al,de b:16 q:15 result 14CB5D37
++blocktest 224x16 be,vi,de b:16 q:0 result 6BB5D37
++blocktest 224x16 be,vi,de b:16 q:1 result 133B5D37
++blocktest 224x16 be,vi,de b:16 q:3 result 165B5D37
++blocktest 224x16 be,vi,de b:16 q:7 result 165B5D37
++blocktest 224x16 be,vi,de b:16 q:15 result 165B5D37
++blocktest 224x16 be,vi,ha,va b:16 q:0 result 1D1A5D87
++blocktest 224x16 be,vi,ha,va b:16 q:1 result 1D1A5D87
++blocktest 224x16 be,vi,ha,va b:16 q:3 result 1D1A5D87
++blocktest 224x16 be,vi,ha,va b:16 q:7 result 1D1A5D87
++blocktest 224x16 be,vi,ha,va b:16 q:15 result 1D1A5D87
++blocktest 224x64 be,de b:1 q:0 result 9DC4B662
++blocktest 224x64 be,de b:1 q:1 result 9DC4B662
++blocktest 224x64 be,de b:1 q:3 result 9DC4B662
++blocktest 224x64 be,de b:1 q:7 result 5196B3A7
++blocktest 224x64 be,de b:1 q:15 result 5196B3A7
++blocktest 224x64 be,h1,v1 b:1 q:0 result 8043B662
++blocktest 224x64 be,h1,v1 b:1 q:1 result 8043B662
++blocktest 224x64 be,h1,v1 b:1 q:3 result 8043B662
++blocktest 224x64 be,h1,v1 b:1 q:7 result 8043B662
++blocktest 224x64 be,h1,v1 b:1 q:15 result 8043B662
++blocktest 224x64 be,ha,va b:1 q:0 result 9DC4B662
++blocktest 224x64 be,ha,va b:1 q:1 result 9DC4B662
++blocktest 224x64 be,ha,va b:1 q:3 result 9DC4B662
++blocktest 224x64 be,ha,va b:1 q:7 result 9DC4B662
++blocktest 224x64 be,ha,va b:1 q:15 result 9DC4B662
++blocktest 224x64 be,al,de b:1 q:0 result 9DC4B662
++blocktest 224x64 be,al,de b:1 q:1 result 9DC4B662
++blocktest 224x64 be,al,de b:1 q:3 result 9DC4B662
++blocktest 224x64 be,al,de b:1 q:7 result E1E7B3AC
++blocktest 224x64 be,al,de b:1 q:15 result E1E7B3AC
++blocktest 224x64 be,vi,de b:1 q:0 result 9DC4B662
++blocktest 224x64 be,vi,de b:1 q:1 result 9DC4B662
++blocktest 224x64 be,vi,de b:1 q:3 result 9DC4B662
++blocktest 224x64 be,vi,de b:1 q:7 result 5196B3A7
++blocktest 224x64 be,vi,de b:1 q:15 result 5196B3A7
++blocktest 224x64 be,vi,ha,va b:1 q:0 result 9DC4B662
++blocktest 224x64 be,vi,ha,va b:1 q:1 result 9DC4B662
++blocktest 224x64 be,vi,ha,va b:1 q:3 result 9DC4B662
++blocktest 224x64 be,vi,ha,va b:1 q:7 result 9DC4B662
++blocktest 224x64 be,vi,ha,va b:1 q:15 result 9DC4B662
++blocktest 224x64 be,de b:2 q:0 result 79DF7B62
++blocktest 224x64 be,de b:2 q:1 result 79DF7B62
++blocktest 224x64 be,de b:2 q:3 result 79DF7B62
++blocktest 224x64 be,de b:2 q:7 result 2D8E7BE4
++blocktest 224x64 be,de b:2 q:15 result 2D8E7BE4
++blocktest 224x64 be,h1,v1 b:2 q:0 result 5C657162
++blocktest 224x64 be,h1,v1 b:2 q:1 result 5C657162
++blocktest 224x64 be,h1,v1 b:2 q:3 result 5C657162
++blocktest 224x64 be,h1,v1 b:2 q:7 result 5C657162
++blocktest 224x64 be,h1,v1 b:2 q:15 result 5C657162
++blocktest 224x64 be,ha,va b:2 q:0 result 79DF7B62
++blocktest 224x64 be,ha,va b:2 q:1 result 79DF7B62
++blocktest 224x64 be,ha,va b:2 q:3 result 79DF7B62
++blocktest 224x64 be,ha,va b:2 q:7 result 79DF7B62
++blocktest 224x64 be,ha,va b:2 q:15 result 79DF7B62
++blocktest 224x64 be,al,de b:2 q:0 result 79DF7B62
++blocktest 224x64 be,al,de b:2 q:1 result 79DF7B62
++blocktest 224x64 be,al,de b:2 q:3 result 79DF7B62
++blocktest 224x64 be,al,de b:2 q:7 result AD9D7B81
++blocktest 224x64 be,al,de b:2 q:15 result AD9D7B81
++blocktest 224x64 be,vi,de b:2 q:0 result 79DF7B62
++blocktest 224x64 be,vi,de b:2 q:1 result 79DF7B62
++blocktest 224x64 be,vi,de b:2 q:3 result 79DF7B62
++blocktest 224x64 be,vi,de b:2 q:7 result 2D8E7BE4
++blocktest 224x64 be,vi,de b:2 q:15 result 2D8E7BE4
++blocktest 224x64 be,vi,ha,va b:2 q:0 result 79DF7B62
++blocktest 224x64 be,vi,ha,va b:2 q:1 result 79DF7B62
++blocktest 224x64 be,vi,ha,va b:2 q:3 result 79DF7B62
++blocktest 224x64 be,vi,ha,va b:2 q:7 result 79DF7B62
++blocktest 224x64 be,vi,ha,va b:2 q:15 result 79DF7B62
++blocktest 224x64 be,de b:4 q:0 result AE914153
++blocktest 224x64 be,de b:4 q:1 result DE0C4AFB
++blocktest 224x64 be,de b:4 q:3 result 979F51FD
++blocktest 224x64 be,de b:4 q:7 result CE154DF1
++blocktest 224x64 be,de b:4 q:15 result CE154DF1
++blocktest 224x64 be,h1,v1 b:4 q:0 result 5F14153
++blocktest 224x64 be,h1,v1 b:4 q:1 result 5F14153
++blocktest 224x64 be,h1,v1 b:4 q:3 result 5F14153
++blocktest 224x64 be,h1,v1 b:4 q:7 result 5F14153
++blocktest 224x64 be,h1,v1 b:4 q:15 result 5F14153
++blocktest 224x64 be,ha,va b:4 q:0 result 1DE74153
++blocktest 224x64 be,ha,va b:4 q:1 result 1DE74153
++blocktest 224x64 be,ha,va b:4 q:3 result 1DE74153
++blocktest 224x64 be,ha,va b:4 q:7 result 1DE74153
++blocktest 224x64 be,ha,va b:4 q:15 result 1DE74153
++blocktest 224x64 be,al,de b:4 q:0 result AE914153
++blocktest 224x64 be,al,de b:4 q:1 result AEBA49E7
++blocktest 224x64 be,al,de b:4 q:3 result 84954F94
++blocktest 224x64 be,al,de b:4 q:7 result C4C54B42
++blocktest 224x64 be,al,de b:4 q:15 result C4C54B42
++blocktest 224x64 be,vi,de b:4 q:0 result AE914153
++blocktest 224x64 be,vi,de b:4 q:1 result DE0C4AFB
++blocktest 224x64 be,vi,de b:4 q:3 result 979F51FD
++blocktest 224x64 be,vi,de b:4 q:7 result CE154DF1
++blocktest 224x64 be,vi,de b:4 q:15 result CE154DF1
++blocktest 224x64 be,vi,ha,va b:4 q:0 result BC013AC4
++blocktest 224x64 be,vi,ha,va b:4 q:1 result BC013AC4
++blocktest 224x64 be,vi,ha,va b:4 q:3 result BC013AC4
++blocktest 224x64 be,vi,ha,va b:4 q:7 result BC013AC4
++blocktest 224x64 be,vi,ha,va b:4 q:15 result BC013AC4
++blocktest 224x64 be,de b:8 q:0 result D73397F9
++blocktest 224x64 be,de b:8 q:1 result 47779359
++blocktest 224x64 be,de b:8 q:3 result 91918F0D
++blocktest 224x64 be,de b:8 q:7 result D4E08E8A
++blocktest 224x64 be,de b:8 q:15 result D4E08E8A
++blocktest 224x64 be,h1,v1 b:8 q:0 result B21997F9
++blocktest 224x64 be,h1,v1 b:8 q:1 result B21997F9
++blocktest 224x64 be,h1,v1 b:8 q:3 result B21997F9
++blocktest 224x64 be,h1,v1 b:8 q:7 result B21997F9
++blocktest 224x64 be,h1,v1 b:8 q:15 result B21997F9
++blocktest 224x64 be,ha,va b:8 q:0 result 76FD97F9
++blocktest 224x64 be,ha,va b:8 q:1 result 76FD97F9
++blocktest 224x64 be,ha,va b:8 q:3 result 76FD97F9
++blocktest 224x64 be,ha,va b:8 q:7 result 76FD97F9
++blocktest 224x64 be,ha,va b:8 q:15 result 76FD97F9
++blocktest 224x64 be,al,de b:8 q:0 result D73397F9
++blocktest 224x64 be,al,de b:8 q:1 result 4C099399
++blocktest 224x64 be,al,de b:8 q:3 result 93148F7D
++blocktest 224x64 be,al,de b:8 q:7 result D6638EFA
++blocktest 224x64 be,al,de b:8 q:15 result D6638EFA
++blocktest 224x64 be,vi,de b:8 q:0 result D73397F9
++blocktest 224x64 be,vi,de b:8 q:1 result 47779359
++blocktest 224x64 be,vi,de b:8 q:3 result 91918F0D
++blocktest 224x64 be,vi,de b:8 q:7 result D4E08E8A
++blocktest 224x64 be,vi,de b:8 q:15 result D4E08E8A
++blocktest 224x64 be,vi,ha,va b:8 q:0 result D5DE9A8F
++blocktest 224x64 be,vi,ha,va b:8 q:1 result D5DE9A8F
++blocktest 224x64 be,vi,ha,va b:8 q:3 result D5DE9A8F
++blocktest 224x64 be,vi,ha,va b:8 q:7 result D5DE9A8F
++blocktest 224x64 be,vi,ha,va b:8 q:15 result D5DE9A8F
++blocktest 224x64 be,de b:16 q:0 result B4243C5
++blocktest 224x64 be,de b:16 q:1 result 4B5243C5
++blocktest 224x64 be,de b:16 q:3 result 9F5443CD
++blocktest 224x64 be,de b:16 q:7 result 940743DE
++blocktest 224x64 be,de b:16 q:15 result 940743DE
++blocktest 224x64 be,h1,v1 b:16 q:0 result 87943C5
++blocktest 224x64 be,h1,v1 b:16 q:1 result 87943C5
++blocktest 224x64 be,h1,v1 b:16 q:3 result 87943C5
++blocktest 224x64 be,h1,v1 b:16 q:7 result 87943C5
++blocktest 224x64 be,h1,v1 b:16 q:15 result 87943C5
++blocktest 224x64 be,ha,va b:16 q:0 result 39B843C5
++blocktest 224x64 be,ha,va b:16 q:1 result 39B843C5
++blocktest 224x64 be,ha,va b:16 q:3 result 39B843C5
++blocktest 224x64 be,ha,va b:16 q:7 result 39B843C5
++blocktest 224x64 be,ha,va b:16 q:15 result 39B843C5
++blocktest 224x64 be,al,de b:16 q:0 result B4243C5
++blocktest 224x64 be,al,de b:16 q:1 result 483243C5
++blocktest 224x64 be,al,de b:16 q:3 result 3DF543CD
++blocktest 224x64 be,al,de b:16 q:7 result 32A843DE
++blocktest 224x64 be,al,de b:16 q:15 result 32A843DE
++blocktest 224x64 be,vi,de b:16 q:0 result B4243C5
++blocktest 224x64 be,vi,de b:16 q:1 result 4B5243C5
++blocktest 224x64 be,vi,de b:16 q:3 result 9F5443CD
++blocktest 224x64 be,vi,de b:16 q:7 result 940743DE
++blocktest 224x64 be,vi,de b:16 q:15 result 940743DE
++blocktest 224x64 be,vi,ha,va b:16 q:0 result D0645BCD
++blocktest 224x64 be,vi,ha,va b:16 q:1 result D0645BCD
++blocktest 224x64 be,vi,ha,va b:16 q:3 result D0645BCD
++blocktest 224x64 be,vi,ha,va b:16 q:7 result D0645BCD
++blocktest 224x64 be,vi,ha,va b:16 q:15 result D0645BCD
++blocktest 224x304 be,de b:1 q:0 result 53B54275
++blocktest 224x304 be,de b:1 q:1 result 53B54275
++blocktest 224x304 be,de b:1 q:3 result 53B54275
++blocktest 224x304 be,de b:1 q:7 result A08B4021
++blocktest 224x304 be,de b:1 q:15 result A08B4021
++blocktest 224x304 be,h1,v1 b:1 q:0 result C3264475
++blocktest 224x304 be,h1,v1 b:1 q:1 result C3264475
++blocktest 224x304 be,h1,v1 b:1 q:3 result C3264475
++blocktest 224x304 be,h1,v1 b:1 q:7 result C3264475
++blocktest 224x304 be,h1,v1 b:1 q:15 result C3264475
++blocktest 224x304 be,ha,va b:1 q:0 result 53B54275
++blocktest 224x304 be,ha,va b:1 q:1 result 53B54275
++blocktest 224x304 be,ha,va b:1 q:3 result 53B54275
++blocktest 224x304 be,ha,va b:1 q:7 result 53B54275
++blocktest 224x304 be,ha,va b:1 q:15 result 53B54275
++blocktest 224x304 be,al,de b:1 q:0 result 53B54275
++blocktest 224x304 be,al,de b:1 q:1 result 53B54275
++blocktest 224x304 be,al,de b:1 q:3 result 53B54275
++blocktest 224x304 be,al,de b:1 q:7 result 59FD402C
++blocktest 224x304 be,al,de b:1 q:15 result 59FD402C
++blocktest 224x304 be,vi,de b:1 q:0 result 53B54275
++blocktest 224x304 be,vi,de b:1 q:1 result 53B54275
++blocktest 224x304 be,vi,de b:1 q:3 result 53B54275
++blocktest 224x304 be,vi,de b:1 q:7 result A08B4021
++blocktest 224x304 be,vi,de b:1 q:15 result A08B4021
++blocktest 224x304 be,vi,ha,va b:1 q:0 result 53B54275
++blocktest 224x304 be,vi,ha,va b:1 q:1 result 53B54275
++blocktest 224x304 be,vi,ha,va b:1 q:3 result 53B54275
++blocktest 224x304 be,vi,ha,va b:1 q:7 result 53B54275
++blocktest 224x304 be,vi,ha,va b:1 q:15 result 53B54275
++blocktest 224x304 be,de b:2 q:0 result B84AE0E6
++blocktest 224x304 be,de b:2 q:1 result B84AE0E6
++blocktest 224x304 be,de b:2 q:3 result B84AE0E6
++blocktest 224x304 be,de b:2 q:7 result A383E65F
++blocktest 224x304 be,de b:2 q:15 result A383E65F
++blocktest 224x304 be,h1,v1 b:2 q:0 result F73DB6E6
++blocktest 224x304 be,h1,v1 b:2 q:1 result F73DB6E6
++blocktest 224x304 be,h1,v1 b:2 q:3 result F73DB6E6
++blocktest 224x304 be,h1,v1 b:2 q:7 result F73DB6E6
++blocktest 224x304 be,h1,v1 b:2 q:15 result F73DB6E6
++blocktest 224x304 be,ha,va b:2 q:0 result B84AE0E6
++blocktest 224x304 be,ha,va b:2 q:1 result B84AE0E6
++blocktest 224x304 be,ha,va b:2 q:3 result B84AE0E6
++blocktest 224x304 be,ha,va b:2 q:7 result B84AE0E6
++blocktest 224x304 be,ha,va b:2 q:15 result B84AE0E6
++blocktest 224x304 be,al,de b:2 q:0 result B84AE0E6
++blocktest 224x304 be,al,de b:2 q:1 result B84AE0E6
++blocktest 224x304 be,al,de b:2 q:3 result B84AE0E6
++blocktest 224x304 be,al,de b:2 q:7 result CFBE4AC
++blocktest 224x304 be,al,de b:2 q:15 result CFBE4AC
++blocktest 224x304 be,vi,de b:2 q:0 result B84AE0E6
++blocktest 224x304 be,vi,de b:2 q:1 result B84AE0E6
++blocktest 224x304 be,vi,de b:2 q:3 result B84AE0E6
++blocktest 224x304 be,vi,de b:2 q:7 result A383E65F
++blocktest 224x304 be,vi,de b:2 q:15 result A383E65F
++blocktest 224x304 be,vi,ha,va b:2 q:0 result B84AE0E6
++blocktest 224x304 be,vi,ha,va b:2 q:1 result B84AE0E6
++blocktest 224x304 be,vi,ha,va b:2 q:3 result B84AE0E6
++blocktest 224x304 be,vi,ha,va b:2 q:7 result B84AE0E6
++blocktest 224x304 be,vi,ha,va b:2 q:15 result B84AE0E6
++blocktest 224x304 be,de b:4 q:0 result B44F6E17
++blocktest 224x304 be,de b:4 q:1 result 324A9B17
++blocktest 224x304 be,de b:4 q:3 result D4C4BFDA
++blocktest 224x304 be,de b:4 q:7 result F406B4B4
++blocktest 224x304 be,de b:4 q:15 result F406B4B4
++blocktest 224x304 be,h1,v1 b:4 q:0 result FB6D6E17
++blocktest 224x304 be,h1,v1 b:4 q:1 result FB6D6E17
++blocktest 224x304 be,h1,v1 b:4 q:3 result FB6D6E17
++blocktest 224x304 be,h1,v1 b:4 q:7 result FB6D6E17
++blocktest 224x304 be,h1,v1 b:4 q:15 result FB6D6E17
++blocktest 224x304 be,ha,va b:4 q:0 result 937B6E17
++blocktest 224x304 be,ha,va b:4 q:1 result 937B6E17
++blocktest 224x304 be,ha,va b:4 q:3 result 937B6E17
++blocktest 224x304 be,ha,va b:4 q:7 result 937B6E17
++blocktest 224x304 be,ha,va b:4 q:15 result 937B6E17
++blocktest 224x304 be,al,de b:4 q:0 result B44F6E17
++blocktest 224x304 be,al,de b:4 q:1 result B59295FB
++blocktest 224x304 be,al,de b:4 q:3 result D448B333
++blocktest 224x304 be,al,de b:4 q:7 result B3E7A6A1
++blocktest 224x304 be,al,de b:4 q:15 result B3E7A6A1
++blocktest 224x304 be,vi,de b:4 q:0 result B44F6E17
++blocktest 224x304 be,vi,de b:4 q:1 result 324A9B17
++blocktest 224x304 be,vi,de b:4 q:3 result D4C4BFDA
++blocktest 224x304 be,vi,de b:4 q:7 result F406B4B4
++blocktest 224x304 be,vi,de b:4 q:15 result F406B4B4
++blocktest 224x304 be,vi,ha,va b:4 q:0 result DB095E70
++blocktest 224x304 be,vi,ha,va b:4 q:1 result DB095E70
++blocktest 224x304 be,vi,ha,va b:4 q:3 result DB095E70
++blocktest 224x304 be,vi,ha,va b:4 q:7 result DB095E70
++blocktest 224x304 be,vi,ha,va b:4 q:15 result DB095E70
++blocktest 224x304 be,de b:8 q:0 result 1759FECA
++blocktest 224x304 be,de b:8 q:1 result 300CE922
++blocktest 224x304 be,de b:8 q:3 result 57A4D129
++blocktest 224x304 be,de b:8 q:7 result 198ECCCC
++blocktest 224x304 be,de b:8 q:15 result 198ECCCC
++blocktest 224x304 be,h1,v1 b:8 q:0 result A492FECA
++blocktest 224x304 be,h1,v1 b:8 q:1 result A492FECA
++blocktest 224x304 be,h1,v1 b:8 q:3 result A492FECA
++blocktest 224x304 be,h1,v1 b:8 q:7 result A492FECA
++blocktest 224x304 be,h1,v1 b:8 q:15 result A492FECA
++blocktest 224x304 be,ha,va b:8 q:0 result F6C9FECA
++blocktest 224x304 be,ha,va b:8 q:1 result F6C9FECA
++blocktest 224x304 be,ha,va b:8 q:3 result F6C9FECA
++blocktest 224x304 be,ha,va b:8 q:7 result F6C9FECA
++blocktest 224x304 be,ha,va b:8 q:15 result F6C9FECA
++blocktest 224x304 be,al,de b:8 q:0 result 1759FECA
++blocktest 224x304 be,al,de b:8 q:1 result F53CEA12
++blocktest 224x304 be,al,de b:8 q:3 result 4381D346
++blocktest 224x304 be,al,de b:8 q:7 result 56BCEE9
++blocktest 224x304 be,al,de b:8 q:15 result 56BCEE9
++blocktest 224x304 be,vi,de b:8 q:0 result 1759FECA
++blocktest 224x304 be,vi,de b:8 q:1 result 300CE922
++blocktest 224x304 be,vi,de b:8 q:3 result 57A4D129
++blocktest 224x304 be,vi,de b:8 q:7 result 198ECCCC
++blocktest 224x304 be,vi,de b:8 q:15 result 198ECCCC
++blocktest 224x304 be,vi,ha,va b:8 q:0 result 9B1F09C
++blocktest 224x304 be,vi,ha,va b:8 q:1 result 9B1F09C
++blocktest 224x304 be,vi,ha,va b:8 q:3 result 9B1F09C
++blocktest 224x304 be,vi,ha,va b:8 q:7 result 9B1F09C
++blocktest 224x304 be,vi,ha,va b:8 q:15 result 9B1F09C
++blocktest 224x304 be,de b:16 q:0 result DA0000A5
++blocktest 224x304 be,de b:16 q:1 result FCAF00A5
++blocktest 224x304 be,de b:16 q:3 result 699D0124
++blocktest 224x304 be,de b:16 q:7 result D64E01B1
++blocktest 224x304 be,de b:16 q:15 result D64E01B1
++blocktest 224x304 be,h1,v1 b:16 q:0 result C12F00A5
++blocktest 224x304 be,h1,v1 b:16 q:1 result C12F00A5
++blocktest 224x304 be,h1,v1 b:16 q:3 result C12F00A5
++blocktest 224x304 be,h1,v1 b:16 q:7 result C12F00A5
++blocktest 224x304 be,h1,v1 b:16 q:15 result C12F00A5
++blocktest 224x304 be,ha,va b:16 q:0 result 8C0700A5
++blocktest 224x304 be,ha,va b:16 q:1 result 8C0700A5
++blocktest 224x304 be,ha,va b:16 q:3 result 8C0700A5
++blocktest 224x304 be,ha,va b:16 q:7 result 8C0700A5
++blocktest 224x304 be,ha,va b:16 q:15 result 8C0700A5
++blocktest 224x304 be,al,de b:16 q:0 result DA0000A5
++blocktest 224x304 be,al,de b:16 q:1 result EE9F00A5
++blocktest 224x304 be,al,de b:16 q:3 result 5B1B011E
++blocktest 224x304 be,al,de b:16 q:7 result C7CC01AB
++blocktest 224x304 be,al,de b:16 q:15 result C7CC01AB
++blocktest 224x304 be,vi,de b:16 q:0 result DA0000A5
++blocktest 224x304 be,vi,de b:16 q:1 result FCAF00A5
++blocktest 224x304 be,vi,de b:16 q:3 result 699D0124
++blocktest 224x304 be,vi,de b:16 q:7 result D64E01B1
++blocktest 224x304 be,vi,de b:16 q:15 result D64E01B1
++blocktest 224x304 be,vi,ha,va b:16 q:0 result 9B150165
++blocktest 224x304 be,vi,ha,va b:16 q:1 result 9B150165
++blocktest 224x304 be,vi,ha,va b:16 q:3 result 9B150165
++blocktest 224x304 be,vi,ha,va b:16 q:7 result 9B150165
++blocktest 224x304 be,vi,ha,va b:16 q:15 result 9B150165
+diff --git a/tests/ref/fate/filter-pp b/tests/ref/fate/filter-pp
+new file mode 100644
+index 0000000000000..5c0e2994c64da
+--- /dev/null
++++ b/tests/ref/fate/filter-pp
+@@ -0,0 +1,10 @@
++#tb 0: 1/25
++#media_type 0: video
++#codec_id 0: rawvideo
++#dimensions 0: 352x288
++#sar 0: 1/1
++0,          1,          1,        1,   152064, 0x0af8a873
++0,          2,          2,        1,   152064, 0xaeb99897
++0,          3,          3,        1,   152064, 0x8f3712c8
++0,          4,          4,        1,   152064, 0x5bf6a64c
++0,          5,          5,        1,   152064, 0x262de352
+diff --git a/tests/ref/fate/filter-pp1 b/tests/ref/fate/filter-pp1
+new file mode 100644
+index 0000000000000..8c6b7ba18e32c
+--- /dev/null
++++ b/tests/ref/fate/filter-pp1
+@@ -0,0 +1 @@
++pp1                 1a45041dd20a941e36b7729116950107
+diff --git a/tests/ref/fate/filter-pp2 b/tests/ref/fate/filter-pp2
+new file mode 100644
+index 0000000000000..ed5e77322ab9b
+--- /dev/null
++++ b/tests/ref/fate/filter-pp2
+@@ -0,0 +1 @@
++pp2                 566d48ad25dfa7a9680de933cbdf66d9
+diff --git a/tests/ref/fate/filter-pp3 b/tests/ref/fate/filter-pp3
+new file mode 100644
+index 0000000000000..536bf8e9d2d96
+--- /dev/null
++++ b/tests/ref/fate/filter-pp3
+@@ -0,0 +1 @@
++pp3                 586fc14a52699540a865c070dd113229
+diff --git a/tests/ref/fate/filter-pp4 b/tests/ref/fate/filter-pp4
+new file mode 100644
+index 0000000000000..efa9c8a2f2082
+--- /dev/null
++++ b/tests/ref/fate/filter-pp4
+@@ -0,0 +1 @@
++pp4                 8a072806ae6b5c68c5c3c57197641e4a
+diff --git a/tests/ref/fate/filter-pp5 b/tests/ref/fate/filter-pp5
+new file mode 100644
+index 0000000000000..682e8481ff201
+--- /dev/null
++++ b/tests/ref/fate/filter-pp5
+@@ -0,0 +1 @@
++pp5                 5695b8193095a63b9f397fff8343d1a6
+diff --git a/tests/ref/fate/filter-pp6 b/tests/ref/fate/filter-pp6
+new file mode 100644
+index 0000000000000..3280a69004575
+--- /dev/null
++++ b/tests/ref/fate/filter-pp6
+@@ -0,0 +1 @@
++pp6                 f823b3330935cd1824d526041b429d9a
+diff --git a/tests/ref/fate/filter-qp b/tests/ref/fate/filter-qp
+new file mode 100644
+index 0000000000000..3dd4c958746af
+--- /dev/null
++++ b/tests/ref/fate/filter-qp
+@@ -0,0 +1 @@
++qp                  2d4da13e883e073084d547a6b41ba688
+diff --git a/tests/ref/fate/stripetest b/tests/ref/fate/stripetest
+new file mode 100644
+index 0000000000000..31c30c8e59845
+--- /dev/null
++++ b/tests/ref/fate/stripetest
+@@ -0,0 +1,360 @@
++striptest 16x16 T:be,lb m:0 result B75464A3
++striptest 16x16 T:be,lb m:1 result B15C5EE1
++striptest 16x16 T:be,lb m:3 result 92D058DD
++striptest 16x16 T:be,lb m:7 result 32044FFD
++striptest 16x16 T:be,lb m:15 result E10A5D71
++striptest 16x16 T:be,li m:0 result BDD047EB
++striptest 16x16 T:be,li m:1 result 616441B0
++striptest 16x16 T:be,li m:3 result 558C37C7
++striptest 16x16 T:be,li m:7 result 7C432D31
++striptest 16x16 T:be,li m:15 result A1EA2DE3
++striptest 16x16 T:be,ci m:0 result B274814D
++striptest 16x16 T:be,ci m:1 result 87857BD2
++striptest 16x16 T:be,ci m:3 result 22D37968
++striptest 16x16 T:be,ci m:7 result 3DE37214
++striptest 16x16 T:be,ci m:15 result 8DFC8C6B
++striptest 16x16 T:be,md m:0 result ECC6470F
++striptest 16x16 T:be,md m:1 result 26B8426B
++striptest 16x16 T:be,md m:3 result 29023B89
++striptest 16x16 T:be,md m:7 result BE9D3241
++striptest 16x16 T:be,md m:15 result A68334B7
++striptest 16x16 T:be,fd m:0 result E1654815
++striptest 16x16 T:be,fd m:1 result 47CB41A7
++striptest 16x16 T:be,fd m:3 result 72937A6
++striptest 16x16 T:be,fd m:7 result F1522C31
++striptest 16x16 T:be,fd m:15 result 9AD82C81
++striptest 16x16 T:be,l5 m:0 result 3C796608
++striptest 16x16 T:be,l5 m:1 result E5DB5FD8
++striptest 16x16 T:be,l5 m:3 result 8C405943
++striptest 16x16 T:be,l5 m:7 result 11AE4FBB
++striptest 16x16 T:be,l5 m:15 result F9D5D70
++striptest 16x64 T:be,lb m:0 result 1E6F2D39
++striptest 16x64 T:be,lb m:1 result A4A45080
++striptest 16x64 T:be,lb m:3 result E3F9754A
++striptest 16x64 T:be,lb m:7 result F07062E9
++striptest 16x64 T:be,lb m:15 result 146B3ABB
++striptest 16x64 T:be,li m:0 result 902769D9
++striptest 16x64 T:be,li m:1 result 587F5FDD
++striptest 16x64 T:be,li m:3 result 98C64F74
++striptest 16x64 T:be,li m:7 result D04F2E9D
++striptest 16x64 T:be,li m:15 result B5BBEE5E
++striptest 16x64 T:be,ci m:0 result 3B54EFEC
++striptest 16x64 T:be,ci m:1 result 40553F60
++striptest 16x64 T:be,ci m:3 result 6CD498B5
++striptest 16x64 T:be,ci m:7 result 758F94A9
++striptest 16x64 T:be,ci m:15 result D93F8464
++striptest 16x64 T:be,md m:0 result 1534468B
++striptest 16x64 T:be,md m:1 result 51034B7D
++striptest 16x64 T:be,md m:3 result 8C8D5298
++striptest 16x64 T:be,md m:7 result BFAE319B
++striptest 16x64 T:be,md m:15 result AF99F19A
++striptest 16x64 T:be,fd m:0 result 331B6F73
++striptest 16x64 T:be,fd m:1 result F0BC60FD
++striptest 16x64 T:be,fd m:3 result CF484DC1
++striptest 16x64 T:be,fd m:7 result 4A6D2CF6
++striptest 16x64 T:be,fd m:15 result A66EEDEB
++striptest 16x64 T:be,l5 m:0 result 8D5B31DB
++striptest 16x64 T:be,l5 m:1 result BEF45364
++striptest 16x64 T:be,l5 m:3 result 49DF773B
++striptest 16x64 T:be,l5 m:7 result 74C16528
++striptest 16x64 T:be,l5 m:15 result FE573D47
++striptest 16x304 T:be,lb m:0 result D64AF689
++striptest 16x304 T:be,lb m:1 result 4A939516
++striptest 16x304 T:be,lb m:3 result 6CC4A9F1
++striptest 16x304 T:be,lb m:7 result B54DA3E6
++striptest 16x304 T:be,lb m:15 result E8ED947D
++striptest 16x304 T:be,li m:0 result 18F45FFF
++striptest 16x304 T:be,li m:1 result 6CFD4AC3
++striptest 16x304 T:be,li m:3 result 916325A
++striptest 16x304 T:be,li m:7 result 256D0CC4
++striptest 16x304 T:be,li m:15 result 89DCCBAC
++striptest 16x304 T:be,ci m:0 result 126A89B2
++striptest 16x304 T:be,ci m:1 result 792DD640
++striptest 16x304 T:be,ci m:3 result F8B15D3
++striptest 16x304 T:be,ci m:7 result 670C2E42
++striptest 16x304 T:be,ci m:15 result 71EF500A
++striptest 16x304 T:be,md m:0 result AA5ECCA8
++striptest 16x304 T:be,md m:1 result 99A74EF3
++striptest 16x304 T:be,md m:3 result 732A49B6
++striptest 16x304 T:be,md m:7 result 41152671
++striptest 16x304 T:be,md m:15 result 556AE624
++striptest 16x304 T:be,fd m:0 result 7338643
++striptest 16x304 T:be,fd m:1 result 752146F0
++striptest 16x304 T:be,fd m:3 result 4D4D2B2F
++striptest 16x304 T:be,fd m:7 result 296D03F3
++striptest 16x304 T:be,fd m:15 result 8362C227
++striptest 16x304 T:be,l5 m:0 result 2F06030A
++striptest 16x304 T:be,l5 m:1 result ECA299C7
++striptest 16x304 T:be,l5 m:3 result 5844ADCA
++striptest 16x304 T:be,l5 m:7 result 8A9CA976
++striptest 16x304 T:be,l5 m:15 result 8CDC9B7D
++striptest 32x16 T:be,lb m:0 result D62DF0CB
++striptest 32x16 T:be,lb m:1 result 303AE741
++striptest 32x16 T:be,lb m:3 result 37BFDEB2
++striptest 32x16 T:be,lb m:7 result 81F3CDB9
++striptest 32x16 T:be,lb m:15 result 1E7EE673
++striptest 32x16 T:be,li m:0 result D5CFBCDB
++striptest 32x16 T:be,li m:1 result 3151B49A
++striptest 32x16 T:be,li m:3 result 3964A991
++striptest 32x16 T:be,li m:7 result 6E5D9B68
++striptest 32x16 T:be,li m:15 result 450E9D09
++striptest 32x16 T:be,ci m:0 result 160E24FC
++striptest 32x16 T:be,ci m:1 result 54B5199D
++striptest 32x16 T:be,ci m:3 result 6B4912C9
++striptest 32x16 T:be,ci m:7 result 144FEB1
++striptest 32x16 T:be,ci m:15 result E96E2EFB
++striptest 32x16 T:be,md m:0 result 46FEBFE7
++striptest 32x16 T:be,md m:1 result ED2BBAD3
++striptest 32x16 T:be,md m:3 result B352B490
++striptest 32x16 T:be,md m:7 result 9ECDA45C
++striptest 32x16 T:be,md m:15 result B303A918
++striptest 32x16 T:be,fd m:0 result 3236BCFF
++striptest 32x16 T:be,fd m:1 result A9B4B49F
++striptest 32x16 T:be,fd m:3 result DFEDA9A4
++striptest 32x16 T:be,fd m:7 result 7BFC9A10
++striptest 32x16 T:be,fd m:15 result 7DAA9BC1
++striptest 32x16 T:be,l5 m:0 result EFE7F276
++striptest 32x16 T:be,l5 m:1 result FA1DE825
++striptest 32x16 T:be,l5 m:3 result 5005DF04
++striptest 32x16 T:be,l5 m:7 result C1E4CD9A
++striptest 32x16 T:be,l5 m:15 result 8178E6BC
++striptest 32x64 T:be,lb m:0 result 8C56EF7
++striptest 32x64 T:be,lb m:1 result F4DA575
++striptest 32x64 T:be,lb m:3 result C53DC302
++striptest 32x64 T:be,lb m:7 result 45489A36
++striptest 32x64 T:be,lb m:15 result 6412575D
++striptest 32x64 T:be,li m:0 result 5C779137
++striptest 32x64 T:be,li m:1 result 21DE74DF
++striptest 32x64 T:be,li m:3 result E3BC4E4D
++striptest 32x64 T:be,li m:7 result D8010B20
++striptest 32x64 T:be,li m:15 result 97ED88B0
++striptest 32x64 T:be,ci m:0 result F52C4BCA
++striptest 32x64 T:be,ci m:1 result 9F97D29C
++striptest 32x64 T:be,ci m:3 result 571D32E8
++striptest 32x64 T:be,ci m:7 result B61244F
++striptest 32x64 T:be,ci m:15 result 411D20E5
++striptest 32x64 T:be,md m:0 result 9D0A6629
++striptest 32x64 T:be,md m:1 result E0BA6229
++striptest 32x64 T:be,md m:3 result 895759F9
++striptest 32x64 T:be,md m:7 result E56F1265
++striptest 32x64 T:be,md m:15 result D56C91BF
++striptest 32x64 T:be,fd m:0 result B28194AC
++striptest 32x64 T:be,fd m:1 result DAFA71B2
++striptest 32x64 T:be,fd m:3 result 46374997
++striptest 32x64 T:be,fd m:7 result 49BD07FF
++striptest 32x64 T:be,fd m:15 result C37F87F8
++striptest 32x64 T:be,l5 m:0 result 31C27724
++striptest 32x64 T:be,l5 m:1 result 1E34AB3F
++striptest 32x64 T:be,l5 m:3 result 937CC78C
++striptest 32x64 T:be,l5 m:7 result E3AE9FA6
++striptest 32x64 T:be,l5 m:15 result E3CB5D3A
++striptest 32x304 T:be,lb m:0 result 96873EC4
++striptest 32x304 T:be,lb m:1 result F73560B0
++striptest 32x304 T:be,lb m:3 result 23868DD
++striptest 32x304 T:be,lb m:7 result 660D5005
++striptest 32x304 T:be,lb m:15 result 21D72EDC
++striptest 32x304 T:be,li m:0 result 3578C383
++striptest 32x304 T:be,li m:1 result 7E372AB
++striptest 32x304 T:be,li m:3 result 72DC2E19
++striptest 32x304 T:be,li m:7 result 5BF2D9DD
++striptest 32x304 T:be,li m:15 result 562D5100
++striptest 32x304 T:be,ci m:0 result 9B18B34C
++striptest 32x304 T:be,ci m:1 result D6973C87
++striptest 32x304 T:be,ci m:3 result 80A18C1C
++striptest 32x304 T:be,ci m:7 result D954AC92
++striptest 32x304 T:be,ci m:15 result 182F259
++striptest 32x304 T:be,md m:0 result 612A1191
++striptest 32x304 T:be,md m:1 result 11D3893C
++striptest 32x304 T:be,md m:3 result AB4D607C
++striptest 32x304 T:be,md m:7 result AD580914
++striptest 32x304 T:be,md m:15 result 6CB686E3
++striptest 32x304 T:be,fd m:0 result 2DFBF2FD
++striptest 32x304 T:be,fd m:1 result 43C640C
++striptest 32x304 T:be,fd m:3 result 31FF1A7F
++striptest 32x304 T:be,fd m:7 result C845C5A8
++striptest 32x304 T:be,fd m:15 result DFCD3EF6
++striptest 32x304 T:be,l5 m:0 result 9E04521A
++striptest 32x304 T:be,l5 m:1 result DA7E69FB
++striptest 32x304 T:be,l5 m:3 result 65A87204
++striptest 32x304 T:be,l5 m:7 result 5965E41
++striptest 32x304 T:be,l5 m:15 result EC7C4054
++striptest 80x16 T:be,lb m:0 result 111DA361
++striptest 80x16 T:be,lb m:1 result BEE5807F
++striptest 80x16 T:be,lb m:3 result 211C7853
++striptest 80x16 T:be,lb m:7 result 5450697F
++striptest 80x16 T:be,lb m:15 result 58E9478
++striptest 80x16 T:be,li m:0 result 38874149
++striptest 80x16 T:be,li m:1 result 2BBC2576
++striptest 80x16 T:be,li m:3 result 8A5714ED
++striptest 80x16 T:be,li m:7 result 5B0CFB30
++striptest 80x16 T:be,li m:15 result 66AA0055
++striptest 80x16 T:be,ci m:0 result 824D064D
++striptest 80x16 T:be,ci m:1 result 66AEDA81
++striptest 80x16 T:be,ci m:3 result A0EFD91E
++striptest 80x16 T:be,ci m:7 result F3BD56D
++striptest 80x16 T:be,ci m:15 result DF272622
++striptest 80x16 T:be,md m:0 result AFA5463D
++striptest 80x16 T:be,md m:1 result AC1C2EEA
++striptest 80x16 T:be,md m:3 result B13928CA
++striptest 80x16 T:be,md m:7 result 623E0985
++striptest 80x16 T:be,md m:15 result 11AD17F7
++striptest 80x16 T:be,fd m:0 result F2E403A
++striptest 80x16 T:be,fd m:1 result 74442449
++striptest 80x16 T:be,fd m:3 result 99161651
++striptest 80x16 T:be,fd m:7 result 735FF9A0
++striptest 80x16 T:be,fd m:15 result 52C70073
++striptest 80x16 T:be,l5 m:0 result 502A713
++striptest 80x16 T:be,l5 m:1 result 92B68284
++striptest 80x16 T:be,l5 m:3 result 8379797F
++striptest 80x16 T:be,l5 m:7 result 60986B80
++striptest 80x16 T:be,l5 m:15 result 172B954D
++striptest 80x64 T:be,lb m:0 result 5F5E1A40
++striptest 80x64 T:be,lb m:1 result D4573B0B
++striptest 80x64 T:be,lb m:3 result 878952B3
++striptest 80x64 T:be,lb m:7 result D8C714A1
++striptest 80x64 T:be,lb m:15 result 2EF9CC8F
++striptest 80x64 T:be,li m:0 result 997474D1
++striptest 80x64 T:be,li m:1 result 70B0FA2D
++striptest 80x64 T:be,li m:3 result A3D59129
++striptest 80x64 T:be,li m:7 result 3D6A10FC
++striptest 80x64 T:be,li m:15 result B2A16481
++striptest 80x64 T:be,ci m:0 result 8642BD76
++striptest 80x64 T:be,ci m:1 result D9E472E9
++striptest 80x64 T:be,ci m:3 result B68707CC
++striptest 80x64 T:be,ci m:7 result 3A580B8E
++striptest 80x64 T:be,ci m:15 result EF5E2771
++striptest 80x64 T:be,md m:0 result 12FB40C9
++striptest 80x64 T:be,md m:1 result 417FF439
++striptest 80x64 T:be,md m:3 result 9887B9A9
++striptest 80x64 T:be,md m:7 result AC03159
++striptest 80x64 T:be,md m:15 result DC2B8B70
++striptest 80x64 T:be,fd m:0 result 486E6CA9
++striptest 80x64 T:be,fd m:1 result 4740E6D8
++striptest 80x64 T:be,fd m:3 result FB284A3
++striptest 80x64 T:be,fd m:7 result C6C409A5
++striptest 80x64 T:be,fd m:15 result CA3F6366
++striptest 80x64 T:be,l5 m:0 result 9DAA28DE
++striptest 80x64 T:be,l5 m:1 result ECE545D4
++striptest 80x64 T:be,l5 m:3 result CD7D5CB2
++striptest 80x64 T:be,l5 m:7 result 77382111
++striptest 80x64 T:be,l5 m:15 result CFDED94C
++striptest 80x304 T:be,lb m:0 result 5F319B66
++striptest 80x304 T:be,lb m:1 result 12EF231E
++striptest 80x304 T:be,lb m:3 result 550BD604
++striptest 80x304 T:be,lb m:7 result B7327E26
++striptest 80x304 T:be,lb m:15 result 3740245A
++striptest 80x304 T:be,li m:0 result D685F82D
++striptest 80x304 T:be,li m:1 result A0A30EB2
++striptest 80x304 T:be,li m:3 result D8F4D287
++striptest 80x304 T:be,li m:7 result E8ABBB88
++striptest 80x304 T:be,li m:15 result CBE440B3
++striptest 80x304 T:be,ci m:0 result 4DD92E38
++striptest 80x304 T:be,ci m:1 result 80570956
++striptest 80x304 T:be,ci m:3 result B9199E43
++striptest 80x304 T:be,ci m:7 result 379900A8
++striptest 80x304 T:be,ci m:15 result C9CC544
++striptest 80x304 T:be,md m:0 result C9A0AA1
++striptest 80x304 T:be,md m:1 result D71C6826
++striptest 80x304 T:be,md m:3 result 358C53FF
++striptest 80x304 T:be,md m:7 result CC983926
++striptest 80x304 T:be,md m:15 result F1FAC564
++striptest 80x304 T:be,fd m:0 result 2CA4360A
++striptest 80x304 T:be,fd m:1 result CF71D48F
++striptest 80x304 T:be,fd m:3 result 5C849085
++striptest 80x304 T:be,fd m:7 result 560B833A
++striptest 80x304 T:be,fd m:15 result 6A3C1C08
++striptest 80x304 T:be,l5 m:0 result 659DC22A
++striptest 80x304 T:be,l5 m:1 result F5C03787
++striptest 80x304 T:be,l5 m:3 result 462BF053
++striptest 80x304 T:be,l5 m:7 result 82BDA906
++striptest 80x304 T:be,l5 m:15 result ACD5942
++striptest 224x16 T:be,lb m:0 result 356C0D23
++striptest 224x16 T:be,lb m:1 result D00F7A2A
++striptest 224x16 T:be,lb m:3 result E5EA5D23
++striptest 224x16 T:be,lb m:7 result 526D674E
++striptest 224x16 T:be,lb m:15 result BCE3B81D
++striptest 224x16 T:be,li m:0 result F1126804
++striptest 224x16 T:be,li m:1 result AF23B0EC
++striptest 224x16 T:be,li m:3 result 42C4FC3
++striptest 224x16 T:be,li m:7 result F87C00B2
++striptest 224x16 T:be,li m:15 result EC6026F
++striptest 224x16 T:be,ci m:0 result 297FB291
++striptest 224x16 T:be,ci m:1 result 1E673D4B
++striptest 224x16 T:be,ci m:3 result 8456644B
++striptest 224x16 T:be,ci m:7 result 3DC9CA10
++striptest 224x16 T:be,ci m:15 result 73EB67B2
++striptest 224x16 T:be,md m:0 result 43E06F84
++striptest 224x16 T:be,md m:1 result 8B4BD0B4
++striptest 224x16 T:be,md m:3 result F9E282D7
++striptest 224x16 T:be,md m:7 result CF442864
++striptest 224x16 T:be,md m:15 result 40FF4C35
++striptest 224x16 T:be,fd m:0 result E9136713
++striptest 224x16 T:be,fd m:1 result 5504AAD5
++striptest 224x16 T:be,fd m:3 result 62CF4ED1
++striptest 224x16 T:be,fd m:7 result 1FBFFEB5
++striptest 224x16 T:be,fd m:15 result 1A8802F2
++striptest 224x16 T:be,l5 m:0 result 6B4E140C
++striptest 224x16 T:be,l5 m:1 result 317D78DE
++striptest 224x16 T:be,l5 m:3 result 10D76452
++striptest 224x16 T:be,l5 m:7 result B4157203
++striptest 224x16 T:be,l5 m:15 result 7485BB4E
++striptest 224x64 T:be,lb m:0 result 2B8AC21B
++striptest 224x64 T:be,lb m:1 result 20901C76
++striptest 224x64 T:be,lb m:3 result 9DD93F3D
++striptest 224x64 T:be,lb m:7 result 7344B91E
++striptest 224x64 T:be,lb m:15 result 1AF370A4
++striptest 224x64 T:be,li m:0 result DBBDD6BD
++striptest 224x64 T:be,li m:1 result 11F7C325
++striptest 224x64 T:be,li m:3 result 3CE50C42
++striptest 224x64 T:be,li m:7 result 7E69E47E
++striptest 224x64 T:be,li m:15 result A4BBE1A1
++striptest 224x64 T:be,ci m:0 result F82BA5E8
++striptest 224x64 T:be,ci m:1 result 85115A85
++striptest 224x64 T:be,ci m:3 result 58C651AE
++striptest 224x64 T:be,ci m:7 result A9126A8F
++striptest 224x64 T:be,ci m:15 result 7B9FDB4F
++striptest 224x64 T:be,md m:0 result C2526431
++striptest 224x64 T:be,md m:1 result 827DC726
++striptest 224x64 T:be,md m:3 result 8DA3941F
++striptest 224x64 T:be,md m:7 result 51B05951
++striptest 224x64 T:be,md m:15 result ED5F5AD8
++striptest 224x64 T:be,fd m:0 result 12A1C5DC
++striptest 224x64 T:be,fd m:1 result 73CF788F
++striptest 224x64 T:be,fd m:3 result DA0EC20B
++striptest 224x64 T:be,fd m:7 result 5F61C207
++striptest 224x64 T:be,fd m:15 result D315E2C2
++striptest 224x64 T:be,l5 m:0 result B838DBE8
++striptest 224x64 T:be,l5 m:1 result 9DDA2818
++striptest 224x64 T:be,l5 m:3 result 936E539F
++striptest 224x64 T:be,l5 m:7 result B72DD580
++striptest 224x64 T:be,l5 m:15 result DEF9939C
++striptest 224x304 T:be,lb m:0 result 1FEC5688
++striptest 224x304 T:be,lb m:1 result 90A34708
++striptest 224x304 T:be,lb m:3 result A7392576
++striptest 224x304 T:be,lb m:7 result 5CE6F508
++striptest 224x304 T:be,lb m:15 result 1AED25A0
++striptest 224x304 T:be,li m:0 result 9DDCEAD8
++striptest 224x304 T:be,li m:1 result A0734E1E
++striptest 224x304 T:be,li m:3 result 1F7E2AA8
++striptest 224x304 T:be,li m:7 result A77BC413
++striptest 224x304 T:be,li m:15 result B2066E34
++striptest 224x304 T:be,ci m:0 result A1F1930F
++striptest 224x304 T:be,ci m:1 result B0BCBBCB
++striptest 224x304 T:be,ci m:3 result BC517C16
++striptest 224x304 T:be,ci m:7 result 42B87247
++striptest 224x304 T:be,ci m:15 result 390F228A
++striptest 224x304 T:be,md m:0 result 26DE8A64
++striptest 224x304 T:be,md m:1 result 422A5459
++striptest 224x304 T:be,md m:3 result 3FBA4F6
++striptest 224x304 T:be,md m:7 result 16B03C7E
++striptest 224x304 T:be,md m:15 result DC1EC11
++striptest 224x304 T:be,fd m:0 result AAC476C5
++striptest 224x304 T:be,fd m:1 result 43724E73
++striptest 224x304 T:be,fd m:3 result A35E0764
++striptest 224x304 T:be,fd m:7 result 7A17EA8D
++striptest 224x304 T:be,fd m:15 result FACA116D
++striptest 224x304 T:be,l5 m:0 result E9D6B236
++striptest 224x304 T:be,l5 m:1 result B4336EAD
++striptest 224x304 T:be,l5 m:3 result 284B6451
++striptest 224x304 T:be,l5 m:7 result 637B6C54
++striptest 224x304 T:be,l5 m:15 result 3503C609
+diff --git a/tests/ref/fate/temptest b/tests/ref/fate/temptest
+new file mode 100644
+index 0000000000000..e90fc46f81eea
+--- /dev/null
++++ b/tests/ref/fate/temptest
+@@ -0,0 +1,336 @@
++temptest 0 0 0 0 result 4747FD2B6BCBD98D
++temptest 0 0 0 1 result B131E49BB453EC88
++temptest 0 0 0 4 result 38CC2AC032A60E8E
++temptest 0 0 0 13 result B2C1B45AE4547480
++temptest 0 0 0 40 result 7CCF1AC011E2ACEB
++temptest 0 0 0 121 result CEFAC9CA19A5F777
++temptest 0 0 1 0 result 4747FD2B6BCBD98D
++temptest 0 0 1 1 result B131E49BB453EC88
++temptest 0 0 1 4 result 38CC2AC032A60E8E
++temptest 0 0 1 13 result B2C1B45AE4547480
++temptest 0 0 1 40 result 7CCF1AC011E2ACEB
++temptest 0 0 1 121 result CEFAC9CA19A5F777
++temptest 0 0 18 0 result 4747FD2B6BCBD98D
++temptest 0 0 18 1 result B131E49BB453EC88
++temptest 0 0 18 4 result 38CC2AC032A60E8E
++temptest 0 0 18 13 result B2C1B45AE4547480
++temptest 0 0 18 40 result 7CCF1AC011E2ACEB
++temptest 0 0 18 121 result CEFAC9CA19A5F777
++temptest 0 0 307 0 result 4747FD2B6BCBD98D
++temptest 0 0 307 1 result B131E49BB453EC88
++temptest 0 0 307 4 result 9A1F4C627F31E806
++temptest 0 0 307 13 result B2C1B45AE4547480
++temptest 0 0 307 40 result 7CCF1AC011E2ACEB
++temptest 0 0 307 121 result CEFAC9CA19A5F777
++temptest 0 0 5220 0 result A3F4794F3A735E24
++temptest 0 0 5220 1 result 2FEB559286787E28
++temptest 0 0 5220 4 result E77D4EBDFA3E06BF
++temptest 0 0 5220 13 result D77446C32EEDD169
++temptest 0 0 5220 40 result 7CCF1AC011E2ACEB
++temptest 0 0 5220 121 result CEFAC9CA19A5F777
++temptest 0 0 88741 0 result FBDDA11DF717CD14
++temptest 0 0 88741 1 result FB7C8CEBFD07B08B
++temptest 0 0 88741 4 result 677BF6D89305A705
++temptest 0 0 88741 13 result AC256153D241FEAC
++temptest 0 0 88741 40 result 53E5C6EFC8DA58D1
++temptest 0 0 88741 121 result 284B4DD880549A05
++temptest 0 1 1 0 result 4747FD2B6BCBD98D
++temptest 0 1 1 1 result B131E49BB453EC88
++temptest 0 1 1 4 result 38CC2AC032A60E8E
++temptest 0 1 1 13 result B2C1B45AE4547480
++temptest 0 1 1 40 result 7CCF1AC011E2ACEB
++temptest 0 1 1 121 result CEFAC9CA19A5F777
++temptest 0 1 18 0 result 4747FD2B6BCBD98D
++temptest 0 1 18 1 result B131E49BB453EC88
++temptest 0 1 18 4 result 38CC2AC032A60E8E
++temptest 0 1 18 13 result B2C1B45AE4547480
++temptest 0 1 18 40 result 7CCF1AC011E2ACEB
++temptest 0 1 18 121 result CEFAC9CA19A5F777
++temptest 0 1 307 0 result 4747FD2B6BCBD98D
++temptest 0 1 307 1 result B131E49BB453EC88
++temptest 0 1 307 4 result 9A1F4C627F31E806
++temptest 0 1 307 13 result B2C1B45AE4547480
++temptest 0 1 307 40 result 7CCF1AC011E2ACEB
++temptest 0 1 307 121 result CEFAC9CA19A5F777
++temptest 0 1 5220 0 result A3F4794F3A735E24
++temptest 0 1 5220 1 result 2FEB559286787E28
++temptest 0 1 5220 4 result E77D4EBDFA3E06BF
++temptest 0 1 5220 13 result D77446C32EEDD169
++temptest 0 1 5220 40 result 7CCF1AC011E2ACEB
++temptest 0 1 5220 121 result CEFAC9CA19A5F777
++temptest 0 1 88741 0 result FBDDA11DF717CD14
++temptest 0 1 88741 1 result FB7C8CEBFD07B08B
++temptest 0 1 88741 4 result 677BF6D89305A705
++temptest 0 1 88741 13 result AC256153D241FEAC
++temptest 0 1 88741 40 result 53E5C6EFC8DA58D1
++temptest 0 1 88741 121 result 284B4DD880549A05
++temptest 0 18 18 0 result 4747FD2B6BCBD98D
++temptest 0 18 18 1 result B131E49BB453EC88
++temptest 0 18 18 4 result 38CC2AC032A60E8E
++temptest 0 18 18 13 result B2C1B45AE4547480
++temptest 0 18 18 40 result 7CCF1AC011E2ACEB
++temptest 0 18 18 121 result CEFAC9CA19A5F777
++temptest 0 18 307 0 result 4747FD2B6BCBD98D
++temptest 0 18 307 1 result B131E49BB453EC88
++temptest 0 18 307 4 result 9A1F4C627F31E806
++temptest 0 18 307 13 result B2C1B45AE4547480
++temptest 0 18 307 40 result 7CCF1AC011E2ACEB
++temptest 0 18 307 121 result CEFAC9CA19A5F777
++temptest 0 18 5220 0 result E2D79A25DEB7D8A0
++temptest 0 18 5220 1 result 6ECE76692ABCF8A4
++temptest 0 18 5220 4 result E77D4EBDFA3E06BF
++temptest 0 18 5220 13 result D77446C32EEDD169
++temptest 0 18 5220 40 result 7CCF1AC011E2ACEB
++temptest 0 18 5220 121 result CEFAC9CA19A5F777
++temptest 0 18 88741 0 result FBDDA11DF717CD14
++temptest 0 18 88741 1 result FB7C8CEBFD07B08B
++temptest 0 18 88741 4 result 677BF6D89305A705
++temptest 0 18 88741 13 result AC256153D241FEAC
++temptest 0 18 88741 40 result 53E5C6EFC8DA58D1
++temptest 0 18 88741 121 result 284B4DD880549A05
++temptest 0 307 307 0 result 4747FD2B6BCBD98D
++temptest 0 307 307 1 result B131E49BB453EC88
++temptest 0 307 307 4 result B17A67893E803FB9
++temptest 0 307 307 13 result B2C1B45AE4547480
++temptest 0 307 307 40 result 7CCF1AC011E2ACEB
++temptest 0 307 307 121 result CEFAC9CA19A5F777
++temptest 0 307 5220 0 result 555181C06E0FA1AA
++temptest 0 307 5220 1 result 3235D486256EC1AE
++temptest 0 307 5220 4 result 964FE2F503607C70
++temptest 0 307 5220 13 result D77446C32EEDD169
++temptest 0 307 5220 40 result 7CCF1AC011E2ACEB
++temptest 0 307 5220 121 result CEFAC9CA19A5F777
++temptest 0 307 88741 0 result 797EDCC74D223AE8
++temptest 0 307 88741 1 result 791DC89553121E5F
++temptest 0 307 88741 4 result 46E37B54A5142319
++temptest 0 307 88741 13 result AC256153D241FEAC
++temptest 0 307 88741 40 result 53E5C6EFC8DA58D1
++temptest 0 307 88741 121 result 284B4DD880549A05
++temptest 0 5220 5220 0 result 4A2207CA23BA4CC0
++temptest 0 5220 5220 1 result E5B4E54A5D48B507
++temptest 0 5220 5220 4 result EA39A4876A38648F
++temptest 0 5220 5220 13 result B6B4F5C1A6864CBD
++temptest 0 5220 5220 40 result 7CCF1AC011E2ACEB
++temptest 0 5220 5220 121 result CEFAC9CA19A5F777
++temptest 0 5220 88741 0 result 706EBAB75F0C52EA
++temptest 0 5220 88741 1 result D4F0475270F0795C
++temptest 0 5220 88741 4 result DF8A5296FD69B527
++temptest 0 5220 88741 13 result BB5686FA9BA23C7B
++temptest 0 5220 88741 40 result A9201E8DBD3B9B3
++temptest 0 5220 88741 121 result 284B4DD880549A05
++temptest 0 88741 88741 0 result CF4F8ABE751594E0
++temptest 0 88741 88741 1 result 9222D52614EFA86B
++temptest 0 88741 88741 4 result DFC399F2247B7714
++temptest 0 88741 88741 13 result 4781E2B92F5BD91B
++temptest 0 88741 88741 40 result 8986560C6636BCBA
++temptest 0 88741 88741 121 result 31FBA2F823230BBF
++temptest 1 1 1 0 result 4747FD2B6BCBD98D
++temptest 1 1 1 1 result B131E49BB453EC88
++temptest 1 1 1 4 result 38CC2AC032A60E8E
++temptest 1 1 1 13 result B2C1B45AE4547480
++temptest 1 1 1 40 result 7CCF1AC011E2ACEB
++temptest 1 1 1 121 result CEFAC9CA19A5F777
++temptest 1 1 18 0 result 4747FD2B6BCBD98D
++temptest 1 1 18 1 result B131E49BB453EC88
++temptest 1 1 18 4 result 38CC2AC032A60E8E
++temptest 1 1 18 13 result B2C1B45AE4547480
++temptest 1 1 18 40 result 7CCF1AC011E2ACEB
++temptest 1 1 18 121 result CEFAC9CA19A5F777
++temptest 1 1 307 0 result 4747FD2B6BCBD98D
++temptest 1 1 307 1 result B131E49BB453EC88
++temptest 1 1 307 4 result 9A1F4C627F31E806
++temptest 1 1 307 13 result B2C1B45AE4547480
++temptest 1 1 307 40 result 7CCF1AC011E2ACEB
++temptest 1 1 307 121 result CEFAC9CA19A5F777
++temptest 1 1 5220 0 result A3F4794F3A735E24
++temptest 1 1 5220 1 result 2FEB559286787E28
++temptest 1 1 5220 4 result E77D4EBDFA3E06BF
++temptest 1 1 5220 13 result D77446C32EEDD169
++temptest 1 1 5220 40 result 7CCF1AC011E2ACEB
++temptest 1 1 5220 121 result CEFAC9CA19A5F777
++temptest 1 1 88741 0 result FBDDA11DF717CD14
++temptest 1 1 88741 1 result FB7C8CEBFD07B08B
++temptest 1 1 88741 4 result 677BF6D89305A705
++temptest 1 1 88741 13 result AC256153D241FEAC
++temptest 1 1 88741 40 result 53E5C6EFC8DA58D1
++temptest 1 1 88741 121 result 284B4DD880549A05
++temptest 1 18 18 0 result 4747FD2B6BCBD98D
++temptest 1 18 18 1 result B131E49BB453EC88
++temptest 1 18 18 4 result 38CC2AC032A60E8E
++temptest 1 18 18 13 result B2C1B45AE4547480
++temptest 1 18 18 40 result 7CCF1AC011E2ACEB
++temptest 1 18 18 121 result CEFAC9CA19A5F777
++temptest 1 18 307 0 result 4747FD2B6BCBD98D
++temptest 1 18 307 1 result B131E49BB453EC88
++temptest 1 18 307 4 result 9A1F4C627F31E806
++temptest 1 18 307 13 result B2C1B45AE4547480
++temptest 1 18 307 40 result 7CCF1AC011E2ACEB
++temptest 1 18 307 121 result CEFAC9CA19A5F777
++temptest 1 18 5220 0 result E2D79A25DEB7D8A0
++temptest 1 18 5220 1 result 6ECE76692ABCF8A4
++temptest 1 18 5220 4 result E77D4EBDFA3E06BF
++temptest 1 18 5220 13 result D77446C32EEDD169
++temptest 1 18 5220 40 result 7CCF1AC011E2ACEB
++temptest 1 18 5220 121 result CEFAC9CA19A5F777
++temptest 1 18 88741 0 result FBDDA11DF717CD14
++temptest 1 18 88741 1 result FB7C8CEBFD07B08B
++temptest 1 18 88741 4 result 677BF6D89305A705
++temptest 1 18 88741 13 result AC256153D241FEAC
++temptest 1 18 88741 40 result 53E5C6EFC8DA58D1
++temptest 1 18 88741 121 result 284B4DD880549A05
++temptest 1 307 307 0 result 4747FD2B6BCBD98D
++temptest 1 307 307 1 result B131E49BB453EC88
++temptest 1 307 307 4 result B17A67893E803FB9
++temptest 1 307 307 13 result B2C1B45AE4547480
++temptest 1 307 307 40 result 7CCF1AC011E2ACEB
++temptest 1 307 307 121 result CEFAC9CA19A5F777
++temptest 1 307 5220 0 result 555181C06E0FA1AA
++temptest 1 307 5220 1 result 3235D486256EC1AE
++temptest 1 307 5220 4 result 964FE2F503607C70
++temptest 1 307 5220 13 result D77446C32EEDD169
++temptest 1 307 5220 40 result 7CCF1AC011E2ACEB
++temptest 1 307 5220 121 result CEFAC9CA19A5F777
++temptest 1 307 88741 0 result 797EDCC74D223AE8
++temptest 1 307 88741 1 result 791DC89553121E5F
++temptest 1 307 88741 4 result 46E37B54A5142319
++temptest 1 307 88741 13 result AC256153D241FEAC
++temptest 1 307 88741 40 result 53E5C6EFC8DA58D1
++temptest 1 307 88741 121 result 284B4DD880549A05
++temptest 1 5220 5220 0 result 4A2207CA23BA4CC0
++temptest 1 5220 5220 1 result E5B4E54A5D48B507
++temptest 1 5220 5220 4 result EA39A4876A38648F
++temptest 1 5220 5220 13 result B6B4F5C1A6864CBD
++temptest 1 5220 5220 40 result 7CCF1AC011E2ACEB
++temptest 1 5220 5220 121 result CEFAC9CA19A5F777
++temptest 1 5220 88741 0 result 706EBAB75F0C52EA
++temptest 1 5220 88741 1 result D4F0475270F0795C
++temptest 1 5220 88741 4 result DF8A5296FD69B527
++temptest 1 5220 88741 13 result BB5686FA9BA23C7B
++temptest 1 5220 88741 40 result A9201E8DBD3B9B3
++temptest 1 5220 88741 121 result 284B4DD880549A05
++temptest 1 88741 88741 0 result CF4F8ABE751594E0
++temptest 1 88741 88741 1 result 9222D52614EFA86B
++temptest 1 88741 88741 4 result DFC399F2247B7714
++temptest 1 88741 88741 13 result 4781E2B92F5BD91B
++temptest 1 88741 88741 40 result 8986560C6636BCBA
++temptest 1 88741 88741 121 result 31FBA2F823230BBF
++temptest 18 18 18 0 result 4747FD2B6BCBD98D
++temptest 18 18 18 1 result B131E49BB453EC88
++temptest 18 18 18 4 result 38CC2AC032A60E8E
++temptest 18 18 18 13 result B2C1B45AE4547480
++temptest 18 18 18 40 result 7CCF1AC011E2ACEB
++temptest 18 18 18 121 result CEFAC9CA19A5F777
++temptest 18 18 307 0 result 4747FD2B6BCBD98D
++temptest 18 18 307 1 result B131E49BB453EC88
++temptest 18 18 307 4 result 9A1F4C627F31E806
++temptest 18 18 307 13 result B2C1B45AE4547480
++temptest 18 18 307 40 result 7CCF1AC011E2ACEB
++temptest 18 18 307 121 result CEFAC9CA19A5F777
++temptest 18 18 5220 0 result E2D79A25DEB7D8A0
++temptest 18 18 5220 1 result 6ECE76692ABCF8A4
++temptest 18 18 5220 4 result E77D4EBDFA3E06BF
++temptest 18 18 5220 13 result D77446C32EEDD169
++temptest 18 18 5220 40 result 7CCF1AC011E2ACEB
++temptest 18 18 5220 121 result CEFAC9CA19A5F777
++temptest 18 18 88741 0 result FBDDA11DF717CD14
++temptest 18 18 88741 1 result FB7C8CEBFD07B08B
++temptest 18 18 88741 4 result 677BF6D89305A705
++temptest 18 18 88741 13 result AC256153D241FEAC
++temptest 18 18 88741 40 result 53E5C6EFC8DA58D1
++temptest 18 18 88741 121 result 284B4DD880549A05
++temptest 18 307 307 0 result 4747FD2B6BCBD98D
++temptest 18 307 307 1 result B131E49BB453EC88
++temptest 18 307 307 4 result B17A67893E803FB9
++temptest 18 307 307 13 result B2C1B45AE4547480
++temptest 18 307 307 40 result 7CCF1AC011E2ACEB
++temptest 18 307 307 121 result CEFAC9CA19A5F777
++temptest 18 307 5220 0 result 555181C06E0FA1AA
++temptest 18 307 5220 1 result 3235D486256EC1AE
++temptest 18 307 5220 4 result 964FE2F503607C70
++temptest 18 307 5220 13 result D77446C32EEDD169
++temptest 18 307 5220 40 result 7CCF1AC011E2ACEB
++temptest 18 307 5220 121 result CEFAC9CA19A5F777
++temptest 18 307 88741 0 result 797EDCC74D223AE8
++temptest 18 307 88741 1 result 791DC89553121E5F
++temptest 18 307 88741 4 result 46E37B54A5142319
++temptest 18 307 88741 13 result AC256153D241FEAC
++temptest 18 307 88741 40 result 53E5C6EFC8DA58D1
++temptest 18 307 88741 121 result 284B4DD880549A05
++temptest 18 5220 5220 0 result 4A2207CA23BA4CC0
++temptest 18 5220 5220 1 result E5B4E54A5D48B507
++temptest 18 5220 5220 4 result EA39A4876A38648F
++temptest 18 5220 5220 13 result B6B4F5C1A6864CBD
++temptest 18 5220 5220 40 result 7CCF1AC011E2ACEB
++temptest 18 5220 5220 121 result CEFAC9CA19A5F777
++temptest 18 5220 88741 0 result 706EBAB75F0C52EA
++temptest 18 5220 88741 1 result D4F0475270F0795C
++temptest 18 5220 88741 4 result DF8A5296FD69B527
++temptest 18 5220 88741 13 result BB5686FA9BA23C7B
++temptest 18 5220 88741 40 result A9201E8DBD3B9B3
++temptest 18 5220 88741 121 result 284B4DD880549A05
++temptest 18 88741 88741 0 result CF4F8ABE751594E0
++temptest 18 88741 88741 1 result 9222D52614EFA86B
++temptest 18 88741 88741 4 result DFC399F2247B7714
++temptest 18 88741 88741 13 result 4781E2B92F5BD91B
++temptest 18 88741 88741 40 result 8986560C6636BCBA
++temptest 18 88741 88741 121 result 31FBA2F823230BBF
++temptest 307 307 307 0 result 4747FD2B6BCBD98D
++temptest 307 307 307 1 result B131E49BB453EC88
++temptest 307 307 307 4 result 8B1D395E5808B6DC
++temptest 307 307 307 13 result B2C1B45AE4547480
++temptest 307 307 307 40 result 7CCF1AC011E2ACEB
++temptest 307 307 307 121 result CEFAC9CA19A5F777
++temptest 307 307 5220 0 result A69033A091FC2080
++temptest 307 307 5220 1 result 32870FE3DE014084
++temptest 307 307 5220 4 result B2649AC2BCF207E4
++temptest 307 307 5220 13 result D77446C32EEDD169
++temptest 307 307 5220 40 result 7CCF1AC011E2ACEB
++temptest 307 307 5220 121 result CEFAC9CA19A5F777
++temptest 307 307 88741 0 result 6148B9F1437BB580
++temptest 307 307 88741 1 result 6F49A40209698F7
++temptest 307 307 88741 4 result 9E9DD518954D5E5
++temptest 307 307 88741 13 result AC256153D241FEAC
++temptest 307 307 88741 40 result 53E5C6EFC8DA58D1
++temptest 307 307 88741 121 result 284B4DD880549A05
++temptest 307 5220 5220 0 result 2A63D0D557F45750
++temptest 307 5220 5220 1 result 9254608D71205E52
++temptest 307 5220 5220 4 result E46F831B8295F417
++temptest 307 5220 5220 13 result B6B4F5C1A6864CBD
++temptest 307 5220 5220 40 result 7CCF1AC011E2ACEB
++temptest 307 5220 5220 121 result CEFAC9CA19A5F777
++temptest 307 5220 88741 0 result EADD24BF32F80792
++temptest 307 5220 88741 1 result DABC179FB1931BE8
++temptest 307 5220 88741 4 result 8AA934A713F0D4AD
++temptest 307 5220 88741 13 result BB5686FA9BA23C7B
++temptest 307 5220 88741 40 result A9201E8DBD3B9B3
++temptest 307 5220 88741 121 result 284B4DD880549A05
++temptest 307 88741 88741 0 result 1A2909BF51BC6E28
++temptest 307 88741 88741 1 result 6614127EF76D81B3
++temptest 307 88741 88741 4 result 9B0BC4A00B7DB1F2
++temptest 307 88741 88741 13 result 4781E2B92F5BD91B
++temptest 307 88741 88741 40 result 8986560C6636BCBA
++temptest 307 88741 88741 121 result 31FBA2F823230BBF
++temptest 5220 5220 5220 0 result 7FE69B4F88AD274B
++temptest 5220 5220 5220 1 result 2262574F78791826
++temptest 5220 5220 5220 4 result 597A21AB80E82FAC
++temptest 5220 5220 5220 13 result 7F930A71275853B8
++temptest 5220 5220 5220 40 result 7CCF1AC011E2ACEB
++temptest 5220 5220 5220 121 result CEFAC9CA19A5F777
++temptest 5220 5220 88741 0 result D5F7F8D19289D7C3
++temptest 5220 5220 88741 1 result CD3256F7DFF12EE2
++temptest 5220 5220 88741 4 result 84E2DB3DECECD065
++temptest 5220 5220 88741 13 result A751FC922A9A8365
++temptest 5220 5220 88741 40 result 2FA93067097FB349
++temptest 5220 5220 88741 121 result 284B4DD880549A05
++temptest 5220 88741 88741 0 result 684F350A49E03B23
++temptest 5220 88741 88741 1 result 6E9FD32757E3AD46
++temptest 5220 88741 88741 4 result 5F4C037B5CFEDACB
++temptest 5220 88741 88741 13 result 6B03209BFA60079D
++temptest 5220 88741 88741 40 result 8986560C6636BCBA
++temptest 5220 88741 88741 121 result 31FBA2F823230BBF
++temptest 88741 88741 88741 0 result B1D4DA59CAAF6224
++temptest 88741 88741 88741 1 result 42DD8F9FBDC2D6C0
++temptest 88741 88741 88741 4 result B40B6B1CAD3A609F
++temptest 88741 88741 88741 13 result 221AA124FEFA141C
++temptest 88741 88741 88741 40 result FC31041053B7B237
++temptest 88741 88741 88741 121 result CB3E66FC05552055
+diff --git a/tools/gen-rc b/tools/gen-rc
+index 797e0baafadbc..a28b013aaeb7a 100755
+--- a/tools/gen-rc
++++ b/tools/gen-rc
+@@ -42,6 +42,7 @@ EOF
+ # gen-rc libavformat   "FFmpeg container format library"
+ # gen-rc libavdevice   "FFmpeg device handling library"
+ # gen-rc libavfilter   "FFmpeg audio/video filtering library"
++# gen-rc libpostproc   "FFmpeg postprocessing library"
+ # gen-rc libswscale    "FFmpeg image rescaling library"
+ # gen-rc libswresample "FFmpeg audio resampling library"
+ 
diff --git a/tools/depends/target/ffmpeg/0001-libpostproc-plugin.patch b/tools/depends/target/ffmpeg/0001-libpostproc-plugin.patch
new file mode 100644
index 0000000000000..5d8c1eb84a1c2
--- /dev/null
+++ b/tools/depends/target/ffmpeg/0001-libpostproc-plugin.patch
@@ -0,0 +1,9759 @@
+diff --git a/LICENSE.md b/LICENSE.md
+index 371b0913ce7c1..613070e1b631a 100644
+--- a/LICENSE.md
++++ b/LICENSE.md
+@@ -12,6 +12,7 @@ configure to activate them. In this case, FFmpeg's license changes to GPL v2+.
+ 
+ Specifically, the GPL parts of FFmpeg are:
+ 
++- libpostproc
+ - optional x86 optimization in the files
+     - `libavcodec/x86/flac_dsp_gpl.asm`
+     - `libavcodec/x86/idct_mmx.c`
+@@ -44,6 +45,7 @@ Specifically, the GPL parts of FFmpeg are:
+     - `vf_owdenoise.c`
+     - `vf_perspective.c`
+     - `vf_phase.c`
++    - `vf_pp.c`
+     - `vf_pp7.c`
+     - `vf_pullup.c`
+     - `vf_repeatfields.c`
+diff --git a/MAINTAINERS b/MAINTAINERS
+index d1d87752b9193..c410293c323c9 100644
+--- a/MAINTAINERS
++++ b/MAINTAINERS
+@@ -135,6 +135,8 @@ Generic Parts:
+     ratecontrol.c                   [2] Michael Niedermayer
+   simple IDCT:
+     simple_idct.c, simple_idct.h    [2] Michael Niedermayer
++  postprocessing:
++    libpostproc/*                   [2] Michael Niedermayer
+   table generation:
+     tableprint.c, tableprint.h          Reimar Doeffinger
+   fixed point FFT:
+diff --git a/Makefile b/Makefile
+index 877b0071f6cc7..d7b5a360a4d94 100644
+--- a/Makefile
++++ b/Makefile
+@@ -25,6 +25,7 @@ ALLFFLIBS =            \
+     avfilter           \
+     avformat           \
+     avutil             \
++    postproc           \
+     swscale            \
+     swresample         \
+ 
+@@ -33,6 +34,7 @@ FFLIBS-$(CONFIG_AVDEVICE)   += avdevice
+ FFLIBS-$(CONFIG_AVFILTER)   += avfilter
+ FFLIBS-$(CONFIG_AVFORMAT)   += avformat
+ FFLIBS-$(CONFIG_AVCODEC)    += avcodec
++FFLIBS-$(CONFIG_POSTPROC)   += postproc
+ FFLIBS-$(CONFIG_SWRESAMPLE) += swresample
+ FFLIBS-$(CONFIG_SWSCALE)    += swscale
+ 
+diff --git a/configure b/configure
+index ae74efc09f412..625a09ad385b5 100755
+--- a/configure
++++ b/configure
+@@ -130,6 +130,7 @@ Component options:
+   --disable-avformat       disable libavformat build
+   --disable-swresample     disable libswresample build
+   --disable-swscale        disable libswscale build
++  --disable-postproc       disable libpostproc build
+   --disable-avfilter       disable libavfilter build
+   --disable-pthreads       disable pthreads [autodetect]
+   --disable-w32threads     disable Win32 threads [autodetect]
+@@ -2072,6 +2073,7 @@ LIBRARY_LIST="
+     avdevice
+     avfilter
+     swscale
++    postproc
+     avformat
+     avcodec
+     swresample
+@@ -3969,6 +3971,7 @@ pan_filter_deps="swresample"
+ perspective_filter_deps="gpl"
+ phase_filter_deps="gpl"
+ pp7_filter_deps="gpl"
++pp_filter_deps="gpl postproc"
+ prewitt_opencl_filter_deps="opencl"
+ procamp_vaapi_filter_deps="vaapi"
+ program_opencl_filter_deps="opencl"
+@@ -4085,6 +4088,8 @@ avfilter_suggest="libm stdatomic spirv_compiler"
+ avformat_deps="avcodec avutil"
+ avformat_suggest="libm network zlib stdatomic"
+ avutil_suggest="clock_gettime ffnvcodec gcrypt libm libdrm libmfx opencl openssl user32 vaapi vulkan videotoolbox corefoundation corevideo coremedia bcrypt stdatomic"
++postproc_deps="avutil gpl"
++postproc_suggest="libm stdatomic"
+ swresample_deps="avutil"
+ swresample_suggest="libm libsoxr stdatomic"
+ swscale_deps="avutil"
+@@ -7535,7 +7540,7 @@ void (^block)(void);
+ EOF
+ 
+ # add some linker flags
+-check_ldflags -Wl,-rpath-link=:libswresample:libswscale:libavfilter:libavdevice:libavformat:libavcodec:libavutil
++check_ldflags -Wl,-rpath-link=:libpostproc:libswresample:libswscale:libavfilter:libavdevice:libavformat:libavcodec:libavutil
+ enabled rpath && add_ldexeflags -Wl,-rpath,$libdir && add_ldsoflags -Wl,-rpath,$libdir
+ test_ldflags -Wl,-Bsymbolic && append SHFLAGS -Wl,-Bsymbolic
+ 
+@@ -7900,6 +7905,7 @@ enabled fsync_filter        && prepend avfilter_deps "avformat"
+ enabled mcdeint_filter      && prepend avfilter_deps "avcodec"
+ enabled movie_filter        && prepend avfilter_deps "avformat avcodec"
+ enabled pan_filter          && prepend avfilter_deps "swresample"
++enabled pp_filter           && prepend avfilter_deps "postproc"
+ enabled qrencode_filter     && prepend avfilter_deps "swscale"
+ enabled qrencodesrc_filter  && prepend avfilter_deps "swscale"
+ enabled removelogo_filter   && prepend avfilter_deps "avformat avcodec swscale"
+@@ -7951,6 +7957,9 @@ expand_deps(){
+     reorder_by ${1}_deps LIBRARY_LIST  # linking order is expected later
+ }
+ 
++#we have to remove gpl from the deps here as some code assumes all lib deps are libs
++postproc_deps="$(filter_out 'gpl' $postproc_deps)"
++
+ map 'expand_deps $v' $LIBRARY_LIST
+ 
+ if test "$quiet" != "yes"; then
+@@ -8041,6 +8050,7 @@ echo "optimize for size         ${small-no}"
+ echo "optimizations             ${optimizations-no}"
+ echo "static                    ${static-no}"
+ echo "shared                    ${shared-no}"
++echo "postprocessing support    ${postproc-no}"
+ echo "network support           ${network-no}"
+ echo "threading support         ${thread_type-no}"
+ echo "safe bitstream reader     ${safe_bitstream_reader-no}"
+@@ -8417,6 +8427,7 @@ extralibs_avcodec="$avcodec_extralibs"
+ extralibs_avformat="$avformat_extralibs"
+ extralibs_avdevice="$avdevice_extralibs"
+ extralibs_avfilter="$avfilter_extralibs"
++extralibs_postproc="$postproc_extralibs"
+ extralibs_swscale="$swscale_extralibs"
+ extralibs_swresample="$swresample_extralibs"
+ EOF
+diff --git a/doc/filters.texi b/doc/filters.texi
+index 6d2df075083c3..47ca7000ca374 100644
+--- a/doc/filters.texi
++++ b/doc/filters.texi
+@@ -19409,6 +19409,181 @@ Set window Y position, relative offset on Y axis.
+ 
+ This filter supports same @ref{commands} as options.
+ 
++@section pp
++
++Enable the specified chain of postprocessing subfilters using libpostproc. This
++library should be automatically selected with a GPL build (@code{--enable-gpl}).
++Subfilters must be separated by '/' and can be disabled by prepending a '-'.
++Each subfilter and some options have a short and a long name that can be used
++interchangeably, i.e. dr/dering are the same.
++
++The filters accept the following options:
++
++@table @option
++@item subfilters
++Set postprocessing subfilters string.
++@end table
++
++All subfilters share common options to determine their scope:
++
++@table @option
++@item a/autoq
++Honor the quality commands for this subfilter.
++
++@item c/chrom
++Do chrominance filtering, too (default).
++
++@item y/nochrom
++Do luma filtering only (no chrominance).
++
++@item n/noluma
++Do chrominance filtering only (no luma).
++@end table
++
++These options can be appended after the subfilter name, separated by a '|'.
++
++Available subfilters are:
++
++@table @option
++@item hb/hdeblock[|difference[|flatness]]
++Horizontal deblocking filter
++@table @option
++@item difference
++Difference factor where higher values mean more deblocking (default: @code{32}).
++@item flatness
++Flatness threshold where lower values mean more deblocking (default: @code{39}).
++@end table
++
++@item vb/vdeblock[|difference[|flatness]]
++Vertical deblocking filter
++@table @option
++@item difference
++Difference factor where higher values mean more deblocking (default: @code{32}).
++@item flatness
++Flatness threshold where lower values mean more deblocking (default: @code{39}).
++@end table
++
++@item ha/hadeblock[|difference[|flatness]]
++Accurate horizontal deblocking filter
++@table @option
++@item difference
++Difference factor where higher values mean more deblocking (default: @code{32}).
++@item flatness
++Flatness threshold where lower values mean more deblocking (default: @code{39}).
++@end table
++
++@item va/vadeblock[|difference[|flatness]]
++Accurate vertical deblocking filter
++@table @option
++@item difference
++Difference factor where higher values mean more deblocking (default: @code{32}).
++@item flatness
++Flatness threshold where lower values mean more deblocking (default: @code{39}).
++@end table
++@end table
++
++The horizontal and vertical deblocking filters share the difference and
++flatness values so you cannot set different horizontal and vertical
++thresholds.
++
++@table @option
++@item h1/x1hdeblock
++Experimental horizontal deblocking filter
++
++@item v1/x1vdeblock
++Experimental vertical deblocking filter
++
++@item dr/dering
++Deringing filter
++
++@item tn/tmpnoise[|threshold1[|threshold2[|threshold3]]], temporal noise reducer
++@table @option
++@item threshold1
++larger -> stronger filtering
++@item threshold2
++larger -> stronger filtering
++@item threshold3
++larger -> stronger filtering
++@end table
++
++@item al/autolevels[:f/fullyrange], automatic brightness / contrast correction
++@table @option
++@item f/fullyrange
++Stretch luma to @code{0-255}.
++@end table
++
++@item lb/linblenddeint
++Linear blend deinterlacing filter that deinterlaces the given block by
++filtering all lines with a @code{(1 2 1)} filter.
++
++@item li/linipoldeint
++Linear interpolating deinterlacing filter that deinterlaces the given block by
++linearly interpolating every second line.
++
++@item ci/cubicipoldeint
++Cubic interpolating deinterlacing filter deinterlaces the given block by
++cubically interpolating every second line.
++
++@item md/mediandeint
++Median deinterlacing filter that deinterlaces the given block by applying a
++median filter to every second line.
++
++@item fd/ffmpegdeint
++FFmpeg deinterlacing filter that deinterlaces the given block by filtering every
++second line with a @code{(-1 4 2 4 -1)} filter.
++
++@item l5/lowpass5
++Vertically applied FIR lowpass deinterlacing filter that deinterlaces the given
++block by filtering all lines with a @code{(-1 2 6 2 -1)} filter.
++
++@item fq/forceQuant[|quantizer]
++Overrides the quantizer table from the input with the constant quantizer you
++specify.
++@table @option
++@item quantizer
++Quantizer to use
++@end table
++
++@item de/default
++Default pp filter combination (@code{hb|a,vb|a,dr|a})
++
++@item fa/fast
++Fast pp filter combination (@code{h1|a,v1|a,dr|a})
++
++@item ac
++High quality pp filter combination (@code{ha|a|128|7,va|a,dr|a})
++@end table
++
++@subsection Examples
++
++@itemize
++@item
++Apply horizontal and vertical deblocking, deringing and automatic
++brightness/contrast:
++@example
++pp=hb/vb/dr/al
++@end example
++
++@item
++Apply default filters without brightness/contrast correction:
++@example
++pp=de/-al
++@end example
++
++@item
++Apply default filters and temporal denoiser:
++@example
++pp=default/tmpnoise|1|2|3
++@end example
++
++@item
++Apply deblocking on luma only, and switch vertical deblocking on or off
++automatically depending on available CPU time:
++@example
++pp=hb|y/vb|a
++@end example
++@end itemize
++
+ @section pp7
+ Apply Postprocessing filter 7. It is variant of the @ref{spp} filter,
+ similar to spp = 6 with 7 point DCT, where only the center sample is
+diff --git a/fftools/ffprobe.c b/fftools/ffprobe.c
+index 80ce38e73bd2e..e6f8b16e1eaaa 100644
+--- a/fftools/ffprobe.c
++++ b/fftools/ffprobe.c
+@@ -62,6 +62,8 @@
+ #include "libswscale/version.h"
+ #include "libswresample/swresample.h"
+ #include "libswresample/version.h"
++#include "libpostproc/postprocess.h"
++#include "libpostproc/version.h"
+ #include "libavfilter/version.h"
+ #include "textformat/avtextformat.h"
+ #include "cmdutils.h"
+@@ -2571,6 +2573,7 @@ static void ffprobe_show_library_versions(AVTextFormatContext *tfc)
+     SHOW_LIB_VERSION(avfilter,   AVFILTER);
+     SHOW_LIB_VERSION(swscale,    SWSCALE);
+     SHOW_LIB_VERSION(swresample, SWRESAMPLE);
++    SHOW_LIB_VERSION(postproc,   POSTPROC);
+     avtext_print_section_footer(tfc);
+ }
+ 
+diff --git a/fftools/opt_common.c b/fftools/opt_common.c
+index c2f6b9de2a75d..2ac3fd4fb364c 100644
+--- a/fftools/opt_common.c
++++ b/fftools/opt_common.c
+@@ -60,6 +60,8 @@
+ #include "libswresample/swresample.h"
+ #include "libswresample/version.h"
+ 
++#include "libpostproc/postprocess.h"
++#include "libpostproc/version.h"
+ 
+ enum show_muxdemuxers {
+     SHOW_DEFAULT,
+@@ -189,6 +191,7 @@ static void print_all_libs_info(int flags, int level)
+     PRINT_LIB_INFO(avfilter,   AVFILTER,   flags, level);
+     PRINT_LIB_INFO(swscale,    SWSCALE,    flags, level);
+     PRINT_LIB_INFO(swresample, SWRESAMPLE, flags, level);
++    PRINT_LIB_INFO(postproc,   POSTPROC,   flags, level);
+ }
+ 
+ static void print_program_info(int flags, int level)
+diff --git a/libavfilter/Makefile b/libavfilter/Makefile
+index 0effe4127ffd3..7c0d879ec9c4e 100644
+--- a/libavfilter/Makefile
++++ b/libavfilter/Makefile
+@@ -431,6 +431,7 @@ OBJS-$(CONFIG_PHOTOSENSITIVITY_FILTER)       += vf_photosensitivity.o
+ OBJS-$(CONFIG_PIXDESCTEST_FILTER)            += vf_pixdesctest.o
+ OBJS-$(CONFIG_PIXELIZE_FILTER)               += vf_pixelize.o
+ OBJS-$(CONFIG_PIXSCOPE_FILTER)               += vf_datascope.o
++OBJS-$(CONFIG_PP_FILTER)                     += vf_pp.o qp_table.o
+ OBJS-$(CONFIG_PP7_FILTER)                    += vf_pp7.o qp_table.o
+ OBJS-$(CONFIG_PREMULTIPLY_FILTER)            += vf_premultiply.o framesync.o
+ OBJS-$(CONFIG_PREWITT_FILTER)                += vf_convolution.o
+diff --git a/libavfilter/allfilters.c b/libavfilter/allfilters.c
+index 5ea33cdf01b91..740d9ab265cc5 100644
+--- a/libavfilter/allfilters.c
++++ b/libavfilter/allfilters.c
+@@ -404,6 +404,7 @@ extern const FFFilter ff_vf_photosensitivity;
+ extern const FFFilter ff_vf_pixdesctest;
+ extern const FFFilter ff_vf_pixelize;
+ extern const FFFilter ff_vf_pixscope;
++extern const FFFilter ff_vf_pp;
+ extern const FFFilter ff_vf_pp7;
+ extern const FFFilter ff_vf_premultiply;
+ extern const FFFilter ff_vf_prewitt;
+diff --git a/libavfilter/vf_pp.c b/libavfilter/vf_pp.c
+new file mode 100644
+index 0000000000000..9e9903eb97461
+--- /dev/null
++++ b/libavfilter/vf_pp.c
+@@ -0,0 +1,191 @@
++/*
++ * Copyright (c) 2002 A'rpi
++ * Copyright (C) 2012 Clément Bœsch
++ *
++ * This file is part of FFmpeg.
++ *
++ * FFmpeg is free software; you can redistribute it and/or modify
++ * it under the terms of the GNU General Public License as published by
++ * the Free Software Foundation; either version 2 of the License, or
++ * (at your option) any later version.
++ *
++ * FFmpeg is distributed in the hope that it will be useful,
++ * but WITHOUT ANY WARRANTY; without even the implied warranty of
++ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
++ * GNU General Public License for more details.
++ *
++ * You should have received a copy of the GNU General Public License along
++ * with FFmpeg; if not, write to the Free Software Foundation, Inc.,
++ * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
++ */
++
++/**
++ * @file
++ * libpostproc filter, ported from MPlayer.
++ */
++
++#include "libavutil/avassert.h"
++#include "libavutil/mem.h"
++#include "libavutil/opt.h"
++
++#include "filters.h"
++#include "qp_table.h"
++#include "video.h"
++
++#include "libpostproc/postprocess.h"
++
++typedef struct PPFilterContext {
++    const AVClass *class;
++    char *subfilters;
++    int mode_id;
++    pp_mode *modes[PP_QUALITY_MAX + 1];
++    void *pp_ctx;
++} PPFilterContext;
++
++#define OFFSET(x) offsetof(PPFilterContext, x)
++#define FLAGS AV_OPT_FLAG_FILTERING_PARAM|AV_OPT_FLAG_VIDEO_PARAM
++static const AVOption pp_options[] = {
++    { "subfilters", "set postprocess subfilters", OFFSET(subfilters), AV_OPT_TYPE_STRING, {.str="de"}, .flags = FLAGS },
++    { NULL }
++};
++
++AVFILTER_DEFINE_CLASS(pp);
++
++static av_cold int pp_init(AVFilterContext *ctx)
++{
++    int i;
++    PPFilterContext *pp = ctx->priv;
++
++    for (i = 0; i <= PP_QUALITY_MAX; i++) {
++        pp->modes[i] = pp_get_mode_by_name_and_quality(pp->subfilters, i);
++        if (!pp->modes[i])
++            return AVERROR_EXTERNAL;
++    }
++    pp->mode_id = PP_QUALITY_MAX;
++    return 0;
++}
++
++static int pp_process_command(AVFilterContext *ctx, const char *cmd, const char *args,
++                              char *res, int res_len, int flags)
++{
++    PPFilterContext *pp = ctx->priv;
++
++    if (!strcmp(cmd, "quality")) {
++        pp->mode_id = av_clip(strtol(args, NULL, 10), 0, PP_QUALITY_MAX);
++        return 0;
++    }
++    return AVERROR(ENOSYS);
++}
++
++static const enum AVPixelFormat pix_fmts[] = {
++    AV_PIX_FMT_YUV420P, AV_PIX_FMT_YUVJ420P,
++    AV_PIX_FMT_YUV422P, AV_PIX_FMT_YUVJ422P,
++    AV_PIX_FMT_YUV411P,
++    AV_PIX_FMT_GBRP,
++    AV_PIX_FMT_YUV444P, AV_PIX_FMT_YUVJ444P,
++    AV_PIX_FMT_YUV440P, AV_PIX_FMT_YUVJ440P,
++    AV_PIX_FMT_GRAY8,
++    AV_PIX_FMT_NONE
++};
++
++static int pp_config_props(AVFilterLink *inlink)
++{
++    int flags = PP_CPU_CAPS_AUTO;
++    PPFilterContext *pp = inlink->dst->priv;
++
++    switch (inlink->format) {
++    case AV_PIX_FMT_GRAY8:
++    case AV_PIX_FMT_YUVJ420P:
++    case AV_PIX_FMT_YUV420P: flags |= PP_FORMAT_420; break;
++    case AV_PIX_FMT_YUVJ422P:
++    case AV_PIX_FMT_YUV422P: flags |= PP_FORMAT_422; break;
++    case AV_PIX_FMT_YUV411P: flags |= PP_FORMAT_411; break;
++    case AV_PIX_FMT_GBRP:
++    case AV_PIX_FMT_YUVJ444P:
++    case AV_PIX_FMT_YUV444P: flags |= PP_FORMAT_444; break;
++    case AV_PIX_FMT_YUVJ440P:
++    case AV_PIX_FMT_YUV440P: flags |= PP_FORMAT_440; break;
++    default: av_assert0(0);
++    }
++
++    pp->pp_ctx = pp_get_context(inlink->w, inlink->h, flags);
++    if (!pp->pp_ctx)
++        return AVERROR(ENOMEM);
++    return 0;
++}
++
++static int pp_filter_frame(AVFilterLink *inlink, AVFrame *inbuf)
++{
++    AVFilterContext *ctx = inlink->dst;
++    PPFilterContext *pp = ctx->priv;
++    AVFilterLink *outlink = ctx->outputs[0];
++    const int aligned_w = FFALIGN(outlink->w, 8);
++    const int aligned_h = FFALIGN(outlink->h, 8);
++    AVFrame *outbuf;
++    int qstride = 0;
++    int8_t *qp_table = NULL;
++    int ret;
++
++    outbuf = ff_get_video_buffer(outlink, aligned_w, aligned_h);
++    if (!outbuf) {
++        av_frame_free(&inbuf);
++        return AVERROR(ENOMEM);
++    }
++    av_frame_copy_props(outbuf, inbuf);
++    outbuf->width  = inbuf->width;
++    outbuf->height = inbuf->height;
++
++    ret = ff_qp_table_extract(inbuf, &qp_table, &qstride, NULL, NULL);
++    if (ret < 0) {
++        av_frame_free(&inbuf);
++        av_frame_free(&outbuf);
++        return ret;
++    }
++
++    pp_postprocess((const uint8_t **)inbuf->data, inbuf->linesize,
++                   outbuf->data,                 outbuf->linesize,
++                   aligned_w, outlink->h,
++                   qp_table,
++                   qstride,
++                   pp->modes[pp->mode_id],
++                   pp->pp_ctx,
++                   outbuf->pict_type | (qp_table ? PP_PICT_TYPE_QP2 : 0));
++
++    av_frame_free(&inbuf);
++    av_freep(&qp_table);
++    return ff_filter_frame(outlink, outbuf);
++}
++
++static av_cold void pp_uninit(AVFilterContext *ctx)
++{
++    int i;
++    PPFilterContext *pp = ctx->priv;
++
++    for (i = 0; i <= PP_QUALITY_MAX; i++)
++        pp_free_mode(pp->modes[i]);
++    if (pp->pp_ctx)
++        pp_free_context(pp->pp_ctx);
++}
++
++static const AVFilterPad pp_inputs[] = {
++    {
++        .name         = "default",
++        .type         = AVMEDIA_TYPE_VIDEO,
++        .config_props = pp_config_props,
++        .filter_frame = pp_filter_frame,
++    },
++};
++
++const FFFilter ff_vf_pp = {
++    .p.name          = "pp",
++    .p.description   = NULL_IF_CONFIG_SMALL("Filter video using libpostproc."),
++    .p.priv_class    = &pp_class,
++    .p.flags         = AVFILTER_FLAG_SUPPORT_TIMELINE_GENERIC,
++    .priv_size       = sizeof(PPFilterContext),
++    .init            = pp_init,
++    .uninit          = pp_uninit,
++    FILTER_INPUTS(pp_inputs),
++    FILTER_OUTPUTS(ff_video_default_filterpad),
++    FILTER_PIXFMTS_ARRAY(pix_fmts),
++    .process_command = pp_process_command,
++};
+diff --git a/libavutil/avutil.h b/libavutil/avutil.h
+index c8ae114ab6f37..ee709fbb2abe7 100644
+--- a/libavutil/avutil.h
++++ b/libavutil/avutil.h
+@@ -41,6 +41,7 @@
+  * @li @ref lavd "libavdevice" special devices muxing/demuxing library
+  * @li @ref lavu "libavutil" common utility library
+  * @li @ref lswr "libswresample" audio resampling, format conversion and mixing
++ * @li @ref lpp  "libpostproc" post processing library
+  * @li @ref libsws "libswscale" color conversion and scaling library
+  *
+  * @section ffmpeg_versioning Versioning and compatibility
+diff --git a/libpostproc/Makefile b/libpostproc/Makefile
+new file mode 100644
+index 0000000000000..d78fc0277f413
+--- /dev/null
++++ b/libpostproc/Makefile
+@@ -0,0 +1,23 @@
++NAME = postproc
++DESC = FFmpeg postprocessing library
++FFLIBS = avutil
++
++HEADERS = postprocess.h        \
++          version.h            \
++          version_major.h      \
++
++OBJS = postprocess.o           \
++       version.o               \
++
++TESTOBJS = tests/test_utils.o        \
++
++# Windows resource file
++SHLIBOBJS-$(HAVE_GNU_WINDRES) += postprocres.o
++
++TESTPROGS = blocktest          \
++            stripetest         \
++            temptest	       \
++
++$(SUBDIR)tests/blocktest$(EXESUF):  $(SUBDIR)tests/test_utils.o
++$(SUBDIR)tests/stripetest$(EXESUF): $(SUBDIR)tests/test_utils.o
++$(SUBDIR)tests/temptest$(EXESUF):  $(SUBDIR)tests/test_utils.o
+diff --git a/libpostproc/libpostproc.v b/libpostproc/libpostproc.v
+new file mode 100644
+index 0000000000000..27381c6aca3ca
+--- /dev/null
++++ b/libpostproc/libpostproc.v
+@@ -0,0 +1,7 @@
++LIBPOSTPROC_MAJOR {
++    global:
++        postproc_*;
++        pp_*;
++    local:
++        *;
++};
+diff --git a/libpostproc/postprocess.c b/libpostproc/postprocess.c
+new file mode 100644
+index 0000000000000..eab2228919265
+--- /dev/null
++++ b/libpostproc/postprocess.c
+@@ -0,0 +1,992 @@
++/*
++ * Copyright (C) 2001-2003 Michael Niedermayer (michaelni@gmx.at)
++ *
++ * AltiVec optimizations (C) 2004 Romain Dolbeau <romain@dolbeau.org>
++ *
++ * This file is part of FFmpeg.
++ *
++ * FFmpeg is free software; you can redistribute it and/or modify
++ * it under the terms of the GNU General Public License as published by
++ * the Free Software Foundation; either version 2 of the License, or
++ * (at your option) any later version.
++ *
++ * FFmpeg is distributed in the hope that it will be useful,
++ * but WITHOUT ANY WARRANTY; without even the implied warranty of
++ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
++ * GNU General Public License for more details.
++ *
++ * You should have received a copy of the GNU General Public License
++ * along with FFmpeg; if not, write to the Free Software
++ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
++ */
++
++/**
++ * @file
++ * postprocessing.
++ */
++
++/*
++                        C       MMX     MMX2    AltiVec
++isVertDC                Ec      Ec              Ec
++isVertMinMaxOk          Ec      Ec              Ec
++doVertLowPass           E               e       Ec
++doVertDefFilter         Ec      Ec      e       Ec
++isHorizDC               Ec      Ec              Ec
++isHorizMinMaxOk         a       E               Ec
++doHorizLowPass          E               e       Ec
++doHorizDefFilter        Ec      Ec      e       Ec
++do_a_deblock            Ec      E       Ec
++deRing                  E               e       Ecp
++Vertical RKAlgo1        E               a
++Horizontal RKAlgo1                      a
++Vertical X1#            a               E
++Horizontal X1#          a               E
++LinIpolDeinterlace      e               E
++CubicIpolDeinterlace    a               e
++LinBlendDeinterlace     e               E
++MedianDeinterlace#      E       Ec      Ec
++TempDeNoiser#           E               e       Ec
++
++# more or less selfinvented filters so the exactness is not too meaningful
++E = Exact implementation
++e = almost exact implementation (slightly different rounding,...)
++a = alternative / approximate impl
++c = checked against the other implementations (-vo md5)
++p = partially optimized, still some work to do
++*/
++
++/*
++TODO:
++reduce the time wasted on the mem transfer
++unroll stuff if instructions depend too much on the prior one
++move YScale thing to the end instead of fixing QP
++write a faster and higher quality deblocking filter :)
++make the mainloop more flexible (variable number of blocks at once
++        (the if/else stuff per block is slowing things down)
++compare the quality & speed of all filters
++split this huge file
++optimize c versions
++try to unroll inner for(x=0 ... loop to avoid these damn if(x ... checks
++...
++*/
++
++//Changelog: use git log
++
++#include <stddef.h>
++#include <stdlib.h>
++#include <string.h>
++
++#include "config.h"
++#include "libavutil/common.h"
++#include "libavutil/cpu.h"
++#include "libavutil/intreadwrite.h"
++#include "libavutil/mem.h"
++//#undef HAVE_MMXEXT_INLINE
++//#undef HAVE_MMX_INLINE
++//#undef ARCH_X86
++//#define DEBUG_BRIGHTNESS
++#include "postprocess.h"
++#include "postprocess_internal.h"
++#include "libavutil/avstring.h"
++
++#define GET_MODE_BUFFER_SIZE 500
++#define OPTIONS_ARRAY_SIZE 10
++#define BLOCK_SIZE 8
++#define TEMP_STRIDE 8
++//#define NUM_BLOCKS_AT_ONCE 16 //not used yet
++
++#define DERING_THRESHOLD 20
++
++#if ARCH_X86 && HAVE_INLINE_ASM
++DECLARE_ASM_CONST(8, uint64_t, w05)= 0x0005000500050005LL;
++DECLARE_ASM_CONST(8, uint64_t, w04)= 0x0004000400040004LL;
++DECLARE_ASM_CONST(8, uint64_t, w20)= 0x0020002000200020LL;
++DECLARE_ASM_CONST(8, uint64_t, b00)= 0x0000000000000000LL;
++DECLARE_ASM_CONST(8, uint64_t, b01)= 0x0101010101010101LL;
++DECLARE_ASM_CONST(8, uint64_t, b08)= 0x0808080808080808LL;
++DECLARE_ASM_CONST(8, uint64_t, b80)= 0x8080808080808080LL;
++#endif
++
++static const struct PPFilter filters[]=
++{
++    {"hb", "hdeblock",              1, 1, 3, H_DEBLOCK},
++    {"vb", "vdeblock",              1, 2, 4, V_DEBLOCK},
++/*  {"hr", "rkhdeblock",            1, 1, 3, H_RK1_FILTER},
++    {"vr", "rkvdeblock",            1, 2, 4, V_RK1_FILTER},*/
++    {"h1", "x1hdeblock",            1, 1, 3, H_X1_FILTER},
++    {"v1", "x1vdeblock",            1, 2, 4, V_X1_FILTER},
++    {"ha", "ahdeblock",             1, 1, 3, H_A_DEBLOCK},
++    {"va", "avdeblock",             1, 2, 4, V_A_DEBLOCK},
++    {"dr", "dering",                1, 5, 6, DERING},
++    {"al", "autolevels",            0, 1, 2, LEVEL_FIX},
++    {"lb", "linblenddeint",         1, 1, 4, LINEAR_BLEND_DEINT_FILTER},
++    {"li", "linipoldeint",          1, 1, 4, LINEAR_IPOL_DEINT_FILTER},
++    {"ci", "cubicipoldeint",        1, 1, 4, CUBIC_IPOL_DEINT_FILTER},
++    {"md", "mediandeint",           1, 1, 4, MEDIAN_DEINT_FILTER},
++    {"fd", "ffmpegdeint",           1, 1, 4, FFMPEG_DEINT_FILTER},
++    {"l5", "lowpass5",              1, 1, 4, LOWPASS5_DEINT_FILTER},
++    {"tn", "tmpnoise",              1, 7, 8, TEMP_NOISE_FILTER},
++    {"fq", "forcequant",            1, 0, 0, FORCE_QUANT},
++    {"be", "bitexact",              1, 0, 0, BITEXACT},
++    {"vi", "visualize",             1, 0, 0, VISUALIZE},
++    {NULL, NULL,0,0,0,0} //End Marker
++};
++
++static const char * const replaceTable[]=
++{
++    "default",      "hb:a,vb:a,dr:a",
++    "de",           "hb:a,vb:a,dr:a",
++    "fast",         "h1:a,v1:a,dr:a",
++    "fa",           "h1:a,v1:a,dr:a",
++    "ac",           "ha:a:128:7,va:a,dr:a",
++    NULL //End Marker
++};
++
++/* The horizontal functions exist only in C because the MMX
++ * code is faster with vertical filters and transposing. */
++
++/**
++ * Check if the given 8x8 Block is mostly "flat"
++ */
++static inline int isHorizDC_C(const uint8_t src[], int stride, const PPContext *c)
++{
++    int numEq= 0;
++    int y;
++    const int dcOffset= ((c->nonBQP*c->ppMode.baseDcDiff)>>8) + 1;
++    const int dcThreshold= dcOffset*2 + 1;
++
++    for(y=0; y<BLOCK_SIZE; y++){
++        numEq += ((unsigned)(src[0] - src[1] + dcOffset)) < dcThreshold;
++        numEq += ((unsigned)(src[1] - src[2] + dcOffset)) < dcThreshold;
++        numEq += ((unsigned)(src[2] - src[3] + dcOffset)) < dcThreshold;
++        numEq += ((unsigned)(src[3] - src[4] + dcOffset)) < dcThreshold;
++        numEq += ((unsigned)(src[4] - src[5] + dcOffset)) < dcThreshold;
++        numEq += ((unsigned)(src[5] - src[6] + dcOffset)) < dcThreshold;
++        numEq += ((unsigned)(src[6] - src[7] + dcOffset)) < dcThreshold;
++        src+= stride;
++    }
++    return numEq > c->ppMode.flatnessThreshold;
++}
++
++/**
++ * Check if the middle 8x8 Block in the given 8x16 block is flat
++ */
++static inline int isVertDC_C(const uint8_t src[], int stride, const PPContext *c)
++{
++    int numEq= 0;
++    int y;
++    const int dcOffset= ((c->nonBQP*c->ppMode.baseDcDiff)>>8) + 1;
++    const int dcThreshold= dcOffset*2 + 1;
++
++    src+= stride*4; // src points to begin of the 8x8 Block
++    for(y=0; y<BLOCK_SIZE-1; y++){
++        numEq += ((unsigned)(src[0] - src[0+stride] + dcOffset)) < dcThreshold;
++        numEq += ((unsigned)(src[1] - src[1+stride] + dcOffset)) < dcThreshold;
++        numEq += ((unsigned)(src[2] - src[2+stride] + dcOffset)) < dcThreshold;
++        numEq += ((unsigned)(src[3] - src[3+stride] + dcOffset)) < dcThreshold;
++        numEq += ((unsigned)(src[4] - src[4+stride] + dcOffset)) < dcThreshold;
++        numEq += ((unsigned)(src[5] - src[5+stride] + dcOffset)) < dcThreshold;
++        numEq += ((unsigned)(src[6] - src[6+stride] + dcOffset)) < dcThreshold;
++        numEq += ((unsigned)(src[7] - src[7+stride] + dcOffset)) < dcThreshold;
++        src+= stride;
++    }
++    return numEq > c->ppMode.flatnessThreshold;
++}
++
++static inline int isHorizMinMaxOk_C(const uint8_t src[], int stride, int QP)
++{
++    int i;
++    for(i=0; i<2; i++){
++        if((unsigned)(src[0] - src[5] + 2*QP) > 4*QP) return 0;
++        src += stride;
++        if((unsigned)(src[2] - src[7] + 2*QP) > 4*QP) return 0;
++        src += stride;
++        if((unsigned)(src[4] - src[1] + 2*QP) > 4*QP) return 0;
++        src += stride;
++        if((unsigned)(src[6] - src[3] + 2*QP) > 4*QP) return 0;
++        src += stride;
++    }
++    return 1;
++}
++
++static inline int isVertMinMaxOk_C(const uint8_t src[], int stride, int QP)
++{
++    int x;
++    src+= stride*4;
++    for(x=0; x<BLOCK_SIZE; x+=4){
++        if((unsigned)(src[  x + 0*stride] - src[  x + 5*stride] + 2*QP) > 4*QP) return 0;
++        if((unsigned)(src[1+x + 2*stride] - src[1+x + 7*stride] + 2*QP) > 4*QP) return 0;
++        if((unsigned)(src[2+x + 4*stride] - src[2+x + 1*stride] + 2*QP) > 4*QP) return 0;
++        if((unsigned)(src[3+x + 6*stride] - src[3+x + 3*stride] + 2*QP) > 4*QP) return 0;
++    }
++    return 1;
++}
++
++static inline int horizClassify_C(const uint8_t src[], int stride, const PPContext *c)
++{
++    if( isHorizDC_C(src, stride, c) ){
++        return isHorizMinMaxOk_C(src, stride, c->QP);
++    }else{
++        return 2;
++    }
++}
++
++static inline int vertClassify_C(const uint8_t src[], int stride, const PPContext *c)
++{
++    if( isVertDC_C(src, stride, c) ){
++        return isVertMinMaxOk_C(src, stride, c->QP);
++    }else{
++        return 2;
++    }
++}
++
++static inline void doHorizDefFilter_C(uint8_t dst[], int stride, const PPContext *c)
++{
++    int y;
++    for(y=0; y<BLOCK_SIZE; y++){
++        const int middleEnergy= 5*(dst[4] - dst[3]) + 2*(dst[2] - dst[5]);
++
++        if(FFABS(middleEnergy) < 8*c->QP){
++            const int q=(dst[3] - dst[4])/2;
++            const int leftEnergy=  5*(dst[2] - dst[1]) + 2*(dst[0] - dst[3]);
++            const int rightEnergy= 5*(dst[6] - dst[5]) + 2*(dst[4] - dst[7]);
++
++            int d= FFABS(middleEnergy) - FFMIN( FFABS(leftEnergy), FFABS(rightEnergy) );
++            d= FFMAX(d, 0);
++
++            d= (5*d + 32) >> 6;
++            d*= FFSIGN(-middleEnergy);
++
++            if(q>0)
++            {
++                d = FFMAX(d, 0);
++                d = FFMIN(d, q);
++            }
++            else
++            {
++                d = FFMIN(d, 0);
++                d = FFMAX(d, q);
++            }
++
++            dst[3]-= d;
++            dst[4]+= d;
++        }
++        dst+= stride;
++    }
++}
++
++/**
++ * Do a horizontal low pass filter on the 10x8 block (dst points to middle 8x8 Block)
++ * using the 9-Tap Filter (1,1,2,2,4,2,2,1,1)/16 (C version)
++ */
++static inline void doHorizLowPass_C(uint8_t dst[], int stride, const PPContext *c)
++{
++    int y;
++    for(y=0; y<BLOCK_SIZE; y++){
++        const int first= FFABS(dst[-1] - dst[0]) < c->QP ? dst[-1] : dst[0];
++        const int last= FFABS(dst[8] - dst[7]) < c->QP ? dst[8] : dst[7];
++
++        int sums[10];
++        sums[0] = 4*first + dst[0] + dst[1] + dst[2] + 4;
++        sums[1] = sums[0] - first  + dst[3];
++        sums[2] = sums[1] - first  + dst[4];
++        sums[3] = sums[2] - first  + dst[5];
++        sums[4] = sums[3] - first  + dst[6];
++        sums[5] = sums[4] - dst[0] + dst[7];
++        sums[6] = sums[5] - dst[1] + last;
++        sums[7] = sums[6] - dst[2] + last;
++        sums[8] = sums[7] - dst[3] + last;
++        sums[9] = sums[8] - dst[4] + last;
++
++        dst[0]= (sums[0] + sums[2] + 2*dst[0])>>4;
++        dst[1]= (sums[1] + sums[3] + 2*dst[1])>>4;
++        dst[2]= (sums[2] + sums[4] + 2*dst[2])>>4;
++        dst[3]= (sums[3] + sums[5] + 2*dst[3])>>4;
++        dst[4]= (sums[4] + sums[6] + 2*dst[4])>>4;
++        dst[5]= (sums[5] + sums[7] + 2*dst[5])>>4;
++        dst[6]= (sums[6] + sums[8] + 2*dst[6])>>4;
++        dst[7]= (sums[7] + sums[9] + 2*dst[7])>>4;
++
++        dst+= stride;
++    }
++}
++
++/**
++ * Experimental Filter 1 (Horizontal)
++ * will not damage linear gradients
++ * Flat blocks should look like they were passed through the (1,1,2,2,4,2,2,1,1) 9-Tap filter
++ * can only smooth blocks at the expected locations (it cannot smooth them if they did move)
++ * MMX2 version does correct clipping C version does not
++ * not identical with the vertical one
++ */
++static inline void horizX1Filter(uint8_t *src, int stride, int QP)
++{
++    int y;
++    static uint64_t lut[256];
++    if(!lut[255])
++    {
++        int i;
++        for(i=0; i<256; i++)
++        {
++            int v= i < 128 ? 2*i : 2*(i-256);
++/*
++//Simulate 112242211 9-Tap filter
++            uint64_t a= (v/16)  & 0xFF;
++            uint64_t b= (v/8)   & 0xFF;
++            uint64_t c= (v/4)   & 0xFF;
++            uint64_t d= (3*v/8) & 0xFF;
++*/
++//Simulate piecewise linear interpolation
++            uint64_t a= (v/16)   & 0xFF;
++            uint64_t b= (v*3/16) & 0xFF;
++            uint64_t c= (v*5/16) & 0xFF;
++            uint64_t d= (7*v/16) & 0xFF;
++            uint64_t A= (0x100 - a)&0xFF;
++            uint64_t B= (0x100 - b)&0xFF;
++            uint64_t C= (0x100 - c)&0xFF;
++            uint64_t D= (0x100 - c)&0xFF;
++
++            lut[i]   = (a<<56) | (b<<48) | (c<<40) | (d<<32) |
++                       (D<<24) | (C<<16) | (B<<8)  | (A);
++            //lut[i] = (v<<32) | (v<<24);
++        }
++    }
++
++    for(y=0; y<BLOCK_SIZE; y++){
++        int a= src[1] - src[2];
++        int b= src[3] - src[4];
++        int c= src[5] - src[6];
++
++        int d= FFMAX(FFABS(b) - (FFABS(a) + FFABS(c))/2, 0);
++
++        if(d < QP){
++            int v = d * FFSIGN(-b);
++
++            src[1] +=v/8;
++            src[2] +=v/4;
++            src[3] +=3*v/8;
++            src[4] -=3*v/8;
++            src[5] -=v/4;
++            src[6] -=v/8;
++        }
++        src+=stride;
++    }
++}
++
++/**
++ * accurate deblock filter
++ */
++static av_always_inline void do_a_deblock_C(uint8_t *src, int step,
++                                            int stride, const PPContext *c, int mode)
++{
++    int y;
++    const int QP= c->QP;
++    const int dcOffset= ((c->nonBQP*c->ppMode.baseDcDiff)>>8) + 1;
++    const int dcThreshold= dcOffset*2 + 1;
++
++    src+= step*4; // src points to begin of the 8x8 Block
++    for(y=0; y<8; y++){
++        int numEq= 0;
++
++        numEq += ((unsigned)(src[-1*step] - src[0*step] + dcOffset)) < dcThreshold;
++        numEq += ((unsigned)(src[ 0*step] - src[1*step] + dcOffset)) < dcThreshold;
++        numEq += ((unsigned)(src[ 1*step] - src[2*step] + dcOffset)) < dcThreshold;
++        numEq += ((unsigned)(src[ 2*step] - src[3*step] + dcOffset)) < dcThreshold;
++        numEq += ((unsigned)(src[ 3*step] - src[4*step] + dcOffset)) < dcThreshold;
++        numEq += ((unsigned)(src[ 4*step] - src[5*step] + dcOffset)) < dcThreshold;
++        numEq += ((unsigned)(src[ 5*step] - src[6*step] + dcOffset)) < dcThreshold;
++        numEq += ((unsigned)(src[ 6*step] - src[7*step] + dcOffset)) < dcThreshold;
++        numEq += ((unsigned)(src[ 7*step] - src[8*step] + dcOffset)) < dcThreshold;
++        if(numEq > c->ppMode.flatnessThreshold){
++            int min, max, x;
++
++            if(src[0] > src[step]){
++                max= src[0];
++                min= src[step];
++            }else{
++                max= src[step];
++                min= src[0];
++            }
++            for(x=2; x<8; x+=2){
++                if(src[x*step] > src[(x+1)*step]){
++                        if(src[x    *step] > max) max= src[ x   *step];
++                        if(src[(x+1)*step] < min) min= src[(x+1)*step];
++                }else{
++                        if(src[(x+1)*step] > max) max= src[(x+1)*step];
++                        if(src[ x   *step] < min) min= src[ x   *step];
++                }
++            }
++            if(max-min < 2*QP){
++                const int first= FFABS(src[-1*step] - src[0]) < QP ? src[-1*step] : src[0];
++                const int last= FFABS(src[8*step] - src[7*step]) < QP ? src[8*step] : src[7*step];
++
++                int sums[10];
++                sums[0] = 4*first + src[0*step] + src[1*step] + src[2*step] + 4;
++                sums[1] = sums[0] - first       + src[3*step];
++                sums[2] = sums[1] - first       + src[4*step];
++                sums[3] = sums[2] - first       + src[5*step];
++                sums[4] = sums[3] - first       + src[6*step];
++                sums[5] = sums[4] - src[0*step] + src[7*step];
++                sums[6] = sums[5] - src[1*step] + last;
++                sums[7] = sums[6] - src[2*step] + last;
++                sums[8] = sums[7] - src[3*step] + last;
++                sums[9] = sums[8] - src[4*step] + last;
++
++                if (mode & VISUALIZE) {
++                    src[0*step] =
++                    src[1*step] =
++                    src[2*step] =
++                    src[3*step] =
++                    src[4*step] =
++                    src[5*step] =
++                    src[6*step] =
++                    src[7*step] = 128;
++                }
++                src[0*step]= (sums[0] + sums[2] + 2*src[0*step])>>4;
++                src[1*step]= (sums[1] + sums[3] + 2*src[1*step])>>4;
++                src[2*step]= (sums[2] + sums[4] + 2*src[2*step])>>4;
++                src[3*step]= (sums[3] + sums[5] + 2*src[3*step])>>4;
++                src[4*step]= (sums[4] + sums[6] + 2*src[4*step])>>4;
++                src[5*step]= (sums[5] + sums[7] + 2*src[5*step])>>4;
++                src[6*step]= (sums[6] + sums[8] + 2*src[6*step])>>4;
++                src[7*step]= (sums[7] + sums[9] + 2*src[7*step])>>4;
++            }
++        }else{
++            const int middleEnergy= 5*(src[4*step] - src[3*step]) + 2*(src[2*step] - src[5*step]);
++
++            if(FFABS(middleEnergy) < 8*QP){
++                const int q=(src[3*step] - src[4*step])/2;
++                const int leftEnergy=  5*(src[2*step] - src[1*step]) + 2*(src[0*step] - src[3*step]);
++                const int rightEnergy= 5*(src[6*step] - src[5*step]) + 2*(src[4*step] - src[7*step]);
++
++                int d= FFABS(middleEnergy) - FFMIN( FFABS(leftEnergy), FFABS(rightEnergy) );
++                d= FFMAX(d, 0);
++
++                d= (5*d + 32) >> 6;
++                d*= FFSIGN(-middleEnergy);
++
++                if(q>0){
++                    d = FFMAX(d, 0);
++                    d = FFMIN(d, q);
++                }else{
++                    d = FFMIN(d, 0);
++                    d = FFMAX(d, q);
++                }
++
++                if ((mode & VISUALIZE) && d) {
++                    d= (d < 0) ? 32 : -32;
++                    src[3*step]= av_clip_uint8(src[3*step] - d);
++                    src[4*step]= av_clip_uint8(src[4*step] + d);
++                    d = 0;
++                }
++
++                src[3*step]-= d;
++                src[4*step]+= d;
++            }
++        }
++
++        src += stride;
++    }
++}
++
++//Note: we have C and SSE2 version (which uses MMX(EXT) when advantageous)
++//Plain C versions
++//we always compile C for testing which needs bitexactness
++#define TEMPLATE_PP_C 1
++#include "postprocess_template.c"
++
++#if HAVE_ALTIVEC
++#include "libavutil/ppc/util_altivec.h"
++
++#   define TEMPLATE_PP_ALTIVEC 1
++#   include "postprocess_altivec_template.c"
++#   include "postprocess_template.c"
++#endif
++
++#if ARCH_X86 && HAVE_INLINE_ASM
++#    if CONFIG_RUNTIME_CPUDETECT
++#        define TEMPLATE_PP_SSE2 1
++#        include "postprocess_template.c"
++#    else
++#        if HAVE_SSE2_INLINE
++#            define TEMPLATE_PP_SSE2 1
++#            include "postprocess_template.c"
++#        endif
++#    endif
++#endif
++
++typedef void (*pp_fn)(const uint8_t src[], int srcStride, uint8_t dst[], int dstStride, int width, int height,
++                      const int8_t QPs[], int QPStride, int isColor, PPContext *c2);
++
++static inline void postProcess(const uint8_t src[], int srcStride, uint8_t dst[], int dstStride, int width, int height,
++        const int8_t QPs[], int QPStride, int isColor, pp_mode *vm, pp_context *vc)
++{
++    pp_fn pp = postProcess_C;
++    PPContext *c= (PPContext *)vc;
++    PPMode *ppMode= (PPMode *)vm;
++    c->ppMode= *ppMode; //FIXME
++
++    if (!(ppMode->lumMode & BITEXACT)) {
++#if CONFIG_RUNTIME_CPUDETECT
++#if ARCH_X86 && HAVE_INLINE_ASM
++        // ordered per speed fastest first
++        if      (c->cpuCaps & AV_CPU_FLAG_SSE2)     pp = postProcess_SSE2;
++#elif HAVE_ALTIVEC
++        if      (c->cpuCaps & AV_CPU_FLAG_ALTIVEC)  pp = postProcess_altivec;
++#endif
++#else /* CONFIG_RUNTIME_CPUDETECT */
++#if     HAVE_SSE2_INLINE
++        pp = postProcess_SSE2;
++#elif HAVE_ALTIVEC
++        pp = postProcess_altivec;
++#endif
++#endif /* !CONFIG_RUNTIME_CPUDETECT */
++    }
++
++    pp(src, srcStride, dst, dstStride, width, height, QPs, QPStride, isColor, c);
++}
++
++/* -pp Command line Help
++*/
++const char pp_help[] =
++"Available postprocessing filters:\n"
++"Filters                        Options\n"
++"short  long name       short   long option     Description\n"
++"*      *               a       autoq           CPU power dependent enabler\n"
++"                       c       chrom           chrominance filtering enabled\n"
++"                       y       nochrom         chrominance filtering disabled\n"
++"                       n       noluma          luma filtering disabled\n"
++"hb     hdeblock        (2 threshold)           horizontal deblocking filter\n"
++"       1. difference factor: default=32, higher -> more deblocking\n"
++"       2. flatness threshold: default=39, lower -> more deblocking\n"
++"                       the h & v deblocking filters share these\n"
++"                       so you can't set different thresholds for h / v\n"
++"vb     vdeblock        (2 threshold)           vertical deblocking filter\n"
++"ha     hadeblock       (2 threshold)           horizontal deblocking filter\n"
++"va     vadeblock       (2 threshold)           vertical deblocking filter\n"
++"h1     x1hdeblock                              experimental h deblock filter 1\n"
++"v1     x1vdeblock                              experimental v deblock filter 1\n"
++"dr     dering                                  deringing filter\n"
++"al     autolevels                              automatic brightness / contrast\n"
++"                       f        fullyrange     stretch luminance to (0..255)\n"
++"lb     linblenddeint                           linear blend deinterlacer\n"
++"li     linipoldeint                            linear interpolating deinterlace\n"
++"ci     cubicipoldeint                          cubic interpolating deinterlacer\n"
++"md     mediandeint                             median deinterlacer\n"
++"fd     ffmpegdeint                             ffmpeg deinterlacer\n"
++"l5     lowpass5                                FIR lowpass deinterlacer\n"
++"de     default                                 hb:a,vb:a,dr:a\n"
++"fa     fast                                    h1:a,v1:a,dr:a\n"
++"ac                                             ha:a:128:7,va:a,dr:a\n"
++"tn     tmpnoise        (3 threshold)           temporal noise reducer\n"
++"                     1. <= 2. <= 3.            larger -> stronger filtering\n"
++"fq     forceQuant      <quantizer>             force quantizer\n"
++"Usage:\n"
++"<filterName>[:<option>[:<option>...]][[,|/][-]<filterName>[:<option>...]]...\n"
++"long form example:\n"
++"vdeblock:autoq/hdeblock:autoq/linblenddeint    default,-vdeblock\n"
++"short form example:\n"
++"vb:a/hb:a/lb                                   de,-vb\n"
++"more examples:\n"
++"tn:64:128:256\n"
++"\n"
++;
++
++pp_mode *pp_get_mode_by_name_and_quality(const char *name, int quality)
++{
++    char temp[GET_MODE_BUFFER_SIZE];
++    char *p= temp;
++    static const char filterDelimiters[] = ",/";
++    static const char optionDelimiters[] = ":|";
++    struct PPMode *ppMode;
++    char *filterToken;
++
++    if (!name)  {
++        av_log(NULL, AV_LOG_ERROR, "pp: Missing argument\n");
++        return NULL;
++    }
++
++    if (!strcmp(name, "help")) {
++        const char *p;
++        for (p = pp_help; strchr(p, '\n'); p = strchr(p, '\n') + 1) {
++            av_strlcpy(temp, p, FFMIN(sizeof(temp), strchr(p, '\n') - p + 2));
++            av_log(NULL, AV_LOG_INFO, "%s", temp);
++        }
++        return NULL;
++    }
++
++    ppMode= av_malloc(sizeof(PPMode));
++    if (!ppMode)
++        return NULL;
++
++    ppMode->lumMode= 0;
++    ppMode->chromMode= 0;
++    ppMode->maxTmpNoise[0]= 700;
++    ppMode->maxTmpNoise[1]= 1500;
++    ppMode->maxTmpNoise[2]= 3000;
++    ppMode->maxAllowedY= 234;
++    ppMode->minAllowedY= 16;
++    ppMode->baseDcDiff= 256/8;
++    ppMode->flatnessThreshold= 56-16-1;
++    ppMode->maxClippedThreshold= (AVRational){1,100};
++    ppMode->error=0;
++
++    memset(temp, 0, GET_MODE_BUFFER_SIZE);
++    av_strlcpy(temp, name, GET_MODE_BUFFER_SIZE - 1);
++
++    av_log(NULL, AV_LOG_DEBUG, "pp: %s\n", name);
++
++    for(;;){
++        const char *filterName;
++        int q= 1000000; //PP_QUALITY_MAX;
++        int chrom=-1;
++        int luma=-1;
++        const char *option;
++        const char *options[OPTIONS_ARRAY_SIZE];
++        int i;
++        int filterNameOk=0;
++        int numOfUnknownOptions=0;
++        int enable=1; //does the user want us to enabled or disabled the filter
++        char *tokstate;
++
++        filterToken= av_strtok(p, filterDelimiters, &tokstate);
++        if(!filterToken) break;
++        p+= strlen(filterToken) + 1; // p points to next filterToken
++        filterName= av_strtok(filterToken, optionDelimiters, &tokstate);
++        if (!filterName) {
++            ppMode->error++;
++            break;
++        }
++        av_log(NULL, AV_LOG_DEBUG, "pp: %s::%s\n", filterToken, filterName);
++
++        if(*filterName == '-'){
++            enable=0;
++            filterName++;
++        }
++
++        for(;;){ //for all options
++            option= av_strtok(NULL, optionDelimiters, &tokstate);
++            if(!option) break;
++
++            av_log(NULL, AV_LOG_DEBUG, "pp: option: %s\n", option);
++            if(!strcmp("autoq", option) || !strcmp("a", option)) q= quality;
++            else if(!strcmp("nochrom", option) || !strcmp("y", option)) chrom=0;
++            else if(!strcmp("chrom", option) || !strcmp("c", option)) chrom=1;
++            else if(!strcmp("noluma", option) || !strcmp("n", option)) luma=0;
++            else{
++                options[numOfUnknownOptions] = option;
++                numOfUnknownOptions++;
++            }
++            if(numOfUnknownOptions >= OPTIONS_ARRAY_SIZE-1) break;
++        }
++        options[numOfUnknownOptions] = NULL;
++
++        /* replace stuff from the replace Table */
++        for(i=0; replaceTable[2*i]; i++){
++            if(!strcmp(replaceTable[2*i], filterName)){
++                size_t newlen = strlen(replaceTable[2*i + 1]);
++                int plen;
++                int spaceLeft;
++
++                p--, *p=',';
++
++                plen= strlen(p);
++                spaceLeft= p - temp + plen;
++                if(spaceLeft + newlen  >= GET_MODE_BUFFER_SIZE - 1){
++                    ppMode->error++;
++                    break;
++                }
++                memmove(p + newlen, p, plen+1);
++                memcpy(p, replaceTable[2*i + 1], newlen);
++                filterNameOk=1;
++            }
++        }
++
++        for(i=0; filters[i].shortName; i++){
++            if(   !strcmp(filters[i].longName, filterName)
++               || !strcmp(filters[i].shortName, filterName)){
++                ppMode->lumMode &= ~filters[i].mask;
++                ppMode->chromMode &= ~filters[i].mask;
++
++                filterNameOk=1;
++                if(!enable) break; // user wants to disable it
++
++                if(q >= filters[i].minLumQuality && luma)
++                    ppMode->lumMode|= filters[i].mask;
++                if(chrom==1 || (chrom==-1 && filters[i].chromDefault))
++                    if(q >= filters[i].minChromQuality)
++                            ppMode->chromMode|= filters[i].mask;
++
++                if(filters[i].mask == LEVEL_FIX){
++                    int o;
++                    ppMode->minAllowedY= 16;
++                    ppMode->maxAllowedY= 234;
++                    for(o=0; options[o]; o++){
++                        if(  !strcmp(options[o],"fullyrange")
++                           ||!strcmp(options[o],"f")){
++                            ppMode->minAllowedY= 0;
++                            ppMode->maxAllowedY= 255;
++                            numOfUnknownOptions--;
++                        }
++                    }
++                }
++                else if(filters[i].mask == TEMP_NOISE_FILTER)
++                {
++                    int o;
++                    int numOfNoises=0;
++
++                    for(o=0; options[o]; o++){
++                        char *tail;
++                        ppMode->maxTmpNoise[numOfNoises]=
++                            strtol(options[o], &tail, 0);
++                        if(tail!=options[o]){
++                            numOfNoises++;
++                            numOfUnknownOptions--;
++                            if(numOfNoises >= 3) break;
++                        }
++                    }
++                }
++                else if(filters[i].mask == V_DEBLOCK   || filters[i].mask == H_DEBLOCK
++                     || filters[i].mask == V_A_DEBLOCK || filters[i].mask == H_A_DEBLOCK){
++                    int o;
++
++                    for(o=0; options[o] && o<2; o++){
++                        char *tail;
++                        int val= strtol(options[o], &tail, 0);
++                        if(tail==options[o]) break;
++
++                        numOfUnknownOptions--;
++                        if(o==0) ppMode->baseDcDiff= val;
++                        else ppMode->flatnessThreshold= val;
++                    }
++                }
++                else if(filters[i].mask == FORCE_QUANT){
++                    int o;
++                    ppMode->forcedQuant= 15;
++
++                    for(o=0; options[o] && o<1; o++){
++                        char *tail;
++                        int val= strtol(options[o], &tail, 0);
++                        if(tail==options[o]) break;
++
++                        numOfUnknownOptions--;
++                        ppMode->forcedQuant= val;
++                    }
++                }
++            }
++        }
++        if(!filterNameOk) ppMode->error++;
++        ppMode->error += numOfUnknownOptions;
++    }
++
++    av_log(NULL, AV_LOG_DEBUG, "pp: lumMode=%X, chromMode=%X\n", ppMode->lumMode, ppMode->chromMode);
++    if(ppMode->error){
++        av_log(NULL, AV_LOG_ERROR, "%d errors in postprocess string \"%s\"\n", ppMode->error, name);
++        av_free(ppMode);
++        return NULL;
++    }
++    return ppMode;
++}
++
++void pp_free_mode(pp_mode *mode){
++    av_free(mode);
++}
++
++static void reallocAlign(void **p, int size){
++    av_free(*p);
++    *p= av_mallocz(size);
++}
++
++static void reallocBuffers(PPContext *c, int width, int height, int stride, int qpStride){
++    int mbWidth = (width+15)>>4;
++    int mbHeight= (height+15)>>4;
++    int i;
++
++    c->stride= stride;
++    c->qpStride= qpStride;
++
++    reallocAlign((void **)&c->tempDst, stride*24+32);
++    reallocAlign((void **)&c->tempSrc, stride*24);
++    reallocAlign((void **)&c->tempBlocks, 2*16*8);
++    reallocAlign((void **)&c->yHistogram, 256*sizeof(uint64_t));
++    for(i=0; i<256; i++)
++            c->yHistogram[i]= width*height/64*15/256;
++
++    for(i=0; i<3; i++){
++        //Note: The +17*1024 is just there so I do not have to worry about r/w over the end.
++        reallocAlign((void **)&c->tempBlurred[i], stride*mbHeight*16 + 17*1024);
++        reallocAlign((void **)&c->tempBlurredPast[i], 256*((height+7)&(~7))/2 + 17*1024);//FIXME size
++    }
++
++    reallocAlign((void **)&c->deintTemp, 2*width+32);
++    reallocAlign((void **)&c->nonBQPTable, qpStride*mbHeight*sizeof(int8_t));
++    reallocAlign((void **)&c->stdQPTable, qpStride*mbHeight*sizeof(int8_t));
++    reallocAlign((void **)&c->forcedQPTable, mbWidth*sizeof(int8_t));
++}
++
++static const char * context_to_name(void * ptr) {
++    return "postproc";
++}
++
++static const AVClass av_codec_context_class = { "Postproc", context_to_name, NULL };
++
++av_cold pp_context *pp_get_context(int width, int height, int cpuCaps){
++    PPContext *c= av_mallocz(sizeof(PPContext));
++    int stride= FFALIGN(width, 16);  //assumed / will realloc if needed
++    int qpStride= (width+15)/16 + 2; //assumed / will realloc if needed
++
++    if (!c)
++        return NULL;
++
++    c->av_class = &av_codec_context_class;
++    if(cpuCaps&PP_FORMAT){
++        c->hChromaSubSample= cpuCaps&0x3;
++        c->vChromaSubSample= (cpuCaps>>4)&0x3;
++    }else{
++        c->hChromaSubSample= 1;
++        c->vChromaSubSample= 1;
++    }
++    if (cpuCaps & PP_CPU_CAPS_AUTO) {
++        c->cpuCaps = av_get_cpu_flags();
++    } else {
++        c->cpuCaps = 0;
++        if (cpuCaps & PP_CPU_CAPS_ALTIVEC)  c->cpuCaps |= AV_CPU_FLAG_ALTIVEC;
++    }
++
++    reallocBuffers(c, width, height, stride, qpStride);
++
++    c->frameNum=-1;
++
++    return c;
++}
++
++av_cold void pp_free_context(void *vc){
++    PPContext *c = (PPContext*)vc;
++    int i;
++
++    for(i=0; i<FF_ARRAY_ELEMS(c->tempBlurred); i++)
++        av_free(c->tempBlurred[i]);
++    for(i=0; i<FF_ARRAY_ELEMS(c->tempBlurredPast); i++)
++        av_free(c->tempBlurredPast[i]);
++
++    av_free(c->tempBlocks);
++    av_free(c->yHistogram);
++    av_free(c->tempDst);
++    av_free(c->tempSrc);
++    av_free(c->deintTemp);
++    av_free(c->stdQPTable);
++    av_free(c->nonBQPTable);
++    av_free(c->forcedQPTable);
++
++    memset(c, 0, sizeof(PPContext));
++
++    av_free(c);
++}
++
++void  pp_postprocess(const uint8_t * src[3], const int srcStride[3],
++                     uint8_t * dst[3], const int dstStride[3],
++                     int width, int height,
++                     const int8_t *QP_store,  int QPStride,
++                     pp_mode *vm,  void *vc, int pict_type)
++{
++    int mbWidth = (width+15)>>4;
++    int mbHeight= (height+15)>>4;
++    PPMode *mode = vm;
++    PPContext *c = vc;
++    int minStride= FFMAX(FFABS(srcStride[0]), FFABS(dstStride[0]));
++    int absQPStride = FFABS(QPStride);
++
++    if (width < 16 || height < 16) {
++        av_log(c, AV_LOG_ERROR, "Postproc is designed to filter 16x16 macroblock based formats, the minimum size is 1 macroblock\n");
++        return;
++    }
++
++    // c->stride and c->QPStride are always positive
++    if(c->stride < minStride || c->qpStride < absQPStride)
++        reallocBuffers(c, width, height,
++                       FFMAX(minStride, c->stride),
++                       FFMAX(c->qpStride, absQPStride));
++
++    if(!QP_store || (mode->lumMode & FORCE_QUANT)){
++        int i;
++        QP_store= c->forcedQPTable;
++        absQPStride = QPStride = 0;
++        if(mode->lumMode & FORCE_QUANT)
++            for(i=0; i<mbWidth; i++) c->forcedQPTable[i]= mode->forcedQuant;
++        else
++            for(i=0; i<mbWidth; i++) c->forcedQPTable[i]= 1;
++    }
++
++    if(pict_type & PP_PICT_TYPE_QP2){
++        int i;
++        const int count= FFMAX(mbHeight * absQPStride, mbWidth);
++        for(i=0; i<(count>>2); i++){
++            AV_WN32(c->stdQPTable + (i<<2), AV_RN32(QP_store + (i<<2)) >> 1 & 0x7F7F7F7F);
++        }
++        for(i<<=2; i<count; i++){
++            c->stdQPTable[i] = QP_store[i]>>1;
++        }
++        QP_store= c->stdQPTable;
++        QPStride= absQPStride;
++    }
++
++    if(0){
++        int x,y;
++        for(y=0; y<mbHeight; y++){
++            for(x=0; x<mbWidth; x++){
++                av_log(c, AV_LOG_INFO, "%2d ", QP_store[x + y*QPStride]);
++            }
++            av_log(c, AV_LOG_INFO, "\n");
++        }
++        av_log(c, AV_LOG_INFO, "\n");
++    }
++
++    if((pict_type&7)!=3){
++        if (QPStride >= 0){
++            int i;
++            const int count= FFMAX(mbHeight * QPStride, mbWidth);
++            for(i=0; i<(count>>2); i++){
++                AV_WN32(c->nonBQPTable + (i<<2), AV_RN32(QP_store + (i<<2)) & 0x3F3F3F3F);
++            }
++            for(i<<=2; i<count; i++){
++                c->nonBQPTable[i] = QP_store[i] & 0x3F;
++            }
++        } else {
++            int i,j;
++            for(i=0; i<mbHeight; i++) {
++                for(j=0; j<absQPStride; j++) {
++                    c->nonBQPTable[i*absQPStride+j] = QP_store[i*QPStride+j] & 0x3F;
++                }
++            }
++        }
++    }
++
++    av_log(c, AV_LOG_DEBUG, "using npp filters 0x%X/0x%X\n",
++           mode->lumMode, mode->chromMode);
++
++    postProcess(src[0], srcStride[0], dst[0], dstStride[0],
++                width, height, QP_store, QPStride, 0, mode, c);
++
++    if (!(src[1] && src[2] && dst[1] && dst[2]))
++        return;
++
++    width  = (width )>>c->hChromaSubSample;
++    height = (height)>>c->vChromaSubSample;
++
++    if(mode->chromMode){
++        postProcess(src[1], srcStride[1], dst[1], dstStride[1],
++                    width, height, QP_store, QPStride, 1, mode, c);
++        postProcess(src[2], srcStride[2], dst[2], dstStride[2],
++                    width, height, QP_store, QPStride, 2, mode, c);
++    }
++    else if(srcStride[1] == dstStride[1] && srcStride[2] == dstStride[2]){
++        linecpy(dst[1], src[1], height, srcStride[1]);
++        linecpy(dst[2], src[2], height, srcStride[2]);
++    }else{
++        int y;
++        for(y=0; y<height; y++){
++            memcpy(&(dst[1][y*dstStride[1]]), &(src[1][y*srcStride[1]]), width);
++            memcpy(&(dst[2][y*dstStride[2]]), &(src[2][y*srcStride[2]]), width);
++        }
++    }
++}
+diff --git a/libpostproc/postprocess.h b/libpostproc/postprocess.h
+new file mode 100644
+index 0000000000000..d2adb6ccad754
+--- /dev/null
++++ b/libpostproc/postprocess.h
+@@ -0,0 +1,109 @@
++/*
++ * Copyright (C) 2001-2003 Michael Niedermayer (michaelni@gmx.at)
++ *
++ * This file is part of FFmpeg.
++ *
++ * FFmpeg is free software; you can redistribute it and/or modify
++ * it under the terms of the GNU General Public License as published by
++ * the Free Software Foundation; either version 2 of the License, or
++ * (at your option) any later version.
++ *
++ * FFmpeg is distributed in the hope that it will be useful,
++ * but WITHOUT ANY WARRANTY; without even the implied warranty of
++ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
++ * GNU General Public License for more details.
++ *
++ * You should have received a copy of the GNU General Public License
++ * along with FFmpeg; if not, write to the Free Software
++ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
++ */
++
++#ifndef POSTPROC_POSTPROCESS_H
++#define POSTPROC_POSTPROCESS_H
++
++/**
++ * @file
++ * @ingroup lpp
++ * external API header
++ */
++
++/**
++ * @defgroup lpp libpostproc
++ * Video postprocessing library.
++ *
++ * @{
++ */
++
++#include "libpostproc/version_major.h"
++#ifndef HAVE_AV_CONFIG_H
++/* When included as part of the ffmpeg build, only include the major version
++ * to avoid unnecessary rebuilds. When included externally, keep including
++ * the full version information. */
++#include "libpostproc/version.h"
++#endif
++
++/**
++ * Return the LIBPOSTPROC_VERSION_INT constant.
++ */
++unsigned postproc_version(void);
++
++/**
++ * Return the libpostproc build-time configuration.
++ */
++const char *postproc_configuration(void);
++
++/**
++ * Return the libpostproc license.
++ */
++const char *postproc_license(void);
++
++#define PP_QUALITY_MAX 6
++
++#include <inttypes.h>
++
++typedef void pp_context;
++typedef void pp_mode;
++
++extern const char pp_help[]; ///< a simple help text
++
++void  pp_postprocess(const uint8_t * src[3], const int srcStride[3],
++                     uint8_t * dst[3], const int dstStride[3],
++                     int horizontalSize, int verticalSize,
++                     const int8_t *QP_store,  int QP_stride,
++                     pp_mode *mode, pp_context *ppContext, int pict_type);
++
++
++/**
++ * Return a pp_mode or NULL if an error occurred.
++ *
++ * @param name    the string after "-pp" on the command line
++ * @param quality a number from 0 to PP_QUALITY_MAX
++ */
++pp_mode *pp_get_mode_by_name_and_quality(const char *name, int quality);
++void pp_free_mode(pp_mode *mode);
++
++pp_context *pp_get_context(int width, int height, int flags);
++void pp_free_context(pp_context *ppContext);
++
++#define PP_CPU_CAPS_MMX   0x80000000
++#define PP_CPU_CAPS_MMX2  0x20000000
++#if FF_API_PP_AMD_3DNOW
++#define PP_CPU_CAPS_3DNOW 0x40000000
++#endif
++#define PP_CPU_CAPS_ALTIVEC 0x10000000
++#define PP_CPU_CAPS_AUTO  0x00080000
++
++#define PP_FORMAT         0x00000008
++#define PP_FORMAT_420    (0x00000011|PP_FORMAT)
++#define PP_FORMAT_422    (0x00000001|PP_FORMAT)
++#define PP_FORMAT_411    (0x00000002|PP_FORMAT)
++#define PP_FORMAT_444    (0x00000000|PP_FORMAT)
++#define PP_FORMAT_440    (0x00000010|PP_FORMAT)
++
++#define PP_PICT_TYPE_QP2  0x00000010 ///< MPEG2 style QScale
++
++/**
++ * @}
++ */
++
++#endif /* POSTPROC_POSTPROCESS_H */
+diff --git a/libpostproc/postprocess_altivec_template.c b/libpostproc/postprocess_altivec_template.c
+new file mode 100644
+index 0000000000000..feddab50356b9
+--- /dev/null
++++ b/libpostproc/postprocess_altivec_template.c
+@@ -0,0 +1,1214 @@
++/*
++ * AltiVec optimizations (C) 2004 Romain Dolbeau <romain@dolbeau.org>
++ *
++ * based on code by Copyright (C) 2001-2003 Michael Niedermayer (michaelni@gmx.at)
++ *
++ * This file is part of FFmpeg.
++ *
++ * FFmpeg is free software; you can redistribute it and/or modify
++ * it under the terms of the GNU General Public License as published by
++ * the Free Software Foundation; either version 2 of the License, or
++ * (at your option) any later version.
++ *
++ * FFmpeg is distributed in the hope that it will be useful,
++ * but WITHOUT ANY WARRANTY; without even the implied warranty of
++ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
++ * GNU General Public License for more details.
++ *
++ * You should have received a copy of the GNU General Public License
++ * along with FFmpeg; if not, write to the Free Software
++ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
++ */
++
++#include "libavutil/avutil.h"
++#include "libavutil/mem_internal.h"
++
++#define ALTIVEC_TRANSPOSE_8x8_SHORT(src_a,src_b,src_c,src_d,src_e,src_f,src_g,src_h) \
++    do {                                                          \
++        __typeof__(src_a) tempA1, tempB1, tempC1, tempD1;         \
++        __typeof__(src_a) tempE1, tempF1, tempG1, tempH1;         \
++        __typeof__(src_a) tempA2, tempB2, tempC2, tempD2;         \
++        __typeof__(src_a) tempE2, tempF2, tempG2, tempH2;         \
++        tempA1 = vec_mergeh (src_a, src_e);                       \
++        tempB1 = vec_mergel (src_a, src_e);                       \
++        tempC1 = vec_mergeh (src_b, src_f);                       \
++        tempD1 = vec_mergel (src_b, src_f);                       \
++        tempE1 = vec_mergeh (src_c, src_g);                       \
++        tempF1 = vec_mergel (src_c, src_g);                       \
++        tempG1 = vec_mergeh (src_d, src_h);                       \
++        tempH1 = vec_mergel (src_d, src_h);                       \
++        tempA2 = vec_mergeh (tempA1, tempE1);                     \
++        tempB2 = vec_mergel (tempA1, tempE1);                     \
++        tempC2 = vec_mergeh (tempB1, tempF1);                     \
++        tempD2 = vec_mergel (tempB1, tempF1);                     \
++        tempE2 = vec_mergeh (tempC1, tempG1);                     \
++        tempF2 = vec_mergel (tempC1, tempG1);                     \
++        tempG2 = vec_mergeh (tempD1, tempH1);                     \
++        tempH2 = vec_mergel (tempD1, tempH1);                     \
++        src_a = vec_mergeh (tempA2, tempE2);                      \
++        src_b = vec_mergel (tempA2, tempE2);                      \
++        src_c = vec_mergeh (tempB2, tempF2);                      \
++        src_d = vec_mergel (tempB2, tempF2);                      \
++        src_e = vec_mergeh (tempC2, tempG2);                      \
++        src_f = vec_mergel (tempC2, tempG2);                      \
++        src_g = vec_mergeh (tempD2, tempH2);                      \
++        src_h = vec_mergel (tempD2, tempH2);                      \
++    } while (0)
++
++
++static inline int vertClassify_altivec(uint8_t src[], int stride, PPContext *c) {
++    /*
++    this code makes no assumption on src or stride.
++    One could remove the recomputation of the perm
++    vector by assuming (stride % 16) == 0, unfortunately
++    this is not always true.
++    */
++    short data_0 = ((c->nonBQP*c->ppMode.baseDcDiff)>>8) + 1;
++    DECLARE_ALIGNED(16, short, data)[8] =
++                    {
++                        data_0,
++                        data_0 * 2 + 1,
++                        c->QP * 2,
++                        c->QP * 4
++                    };
++    int numEq;
++    uint8_t *src2 = src;
++    vector signed short v_dcOffset;
++    vector signed short v2QP;
++    vector unsigned short v4QP;
++    vector unsigned short v_dcThreshold;
++    const int properStride = (stride % 16);
++    const int srcAlign = ((unsigned long)src2 % 16);
++    const int two_vectors = ((srcAlign > 8) || properStride) ? 1 : 0;
++    const vector signed int zero = vec_splat_s32(0);
++    const vector signed short mask = vec_splat_s16(1);
++    vector signed int v_numEq = vec_splat_s32(0);
++    vector signed short v_data = vec_ld(0, data);
++    vector signed short v_srcAss0, v_srcAss1, v_srcAss2, v_srcAss3,
++                        v_srcAss4, v_srcAss5, v_srcAss6, v_srcAss7;
++//FIXME avoid this mess if possible
++    register int j0 = 0,
++                 j1 = stride,
++                 j2 = 2 * stride,
++                 j3 = 3 * stride,
++                 j4 = 4 * stride,
++                 j5 = 5 * stride,
++                 j6 = 6 * stride,
++                 j7 = 7 * stride;
++    vector unsigned char v_srcA0, v_srcA1, v_srcA2, v_srcA3,
++                         v_srcA4, v_srcA5, v_srcA6, v_srcA7;
++
++    v_dcOffset = vec_splat(v_data, 0);
++    v_dcThreshold = (vector unsigned short)vec_splat(v_data, 1);
++    v2QP = vec_splat(v_data, 2);
++    v4QP = (vector unsigned short)vec_splat(v_data, 3);
++
++    src2 += stride * 4;
++
++#define LOAD_LINE(i)                                                    \
++    {                                                                   \
++    vector unsigned char perm##i = vec_lvsl(j##i, src2);                \
++    vector unsigned char v_srcA2##i;                                    \
++    vector unsigned char v_srcA1##i = vec_ld(j##i, src2);               \
++    if (two_vectors)                                                    \
++        v_srcA2##i = vec_ld(j##i + 16, src2);                           \
++    v_srcA##i =                                                         \
++        vec_perm(v_srcA1##i, v_srcA2##i, perm##i);                      \
++    v_srcAss##i =                                                       \
++        (vector signed short)vec_mergeh((vector signed char)zero,       \
++                                        (vector signed char)v_srcA##i); }
++
++#define LOAD_LINE_ALIGNED(i)                                            \
++    v_srcA##i = vec_ld(j##i, src2);                                     \
++    v_srcAss##i =                                                       \
++        (vector signed short)vec_mergeh((vector signed char)zero,       \
++                                        (vector signed char)v_srcA##i)
++
++    /* Special-casing the aligned case is worthwhile, as all calls from
++     * the (transposed) horizontable deblocks will be aligned, in addition
++     * to the naturally aligned vertical deblocks. */
++    if (properStride && srcAlign) {
++        LOAD_LINE_ALIGNED(0);
++        LOAD_LINE_ALIGNED(1);
++        LOAD_LINE_ALIGNED(2);
++        LOAD_LINE_ALIGNED(3);
++        LOAD_LINE_ALIGNED(4);
++        LOAD_LINE_ALIGNED(5);
++        LOAD_LINE_ALIGNED(6);
++        LOAD_LINE_ALIGNED(7);
++    } else {
++        LOAD_LINE(0);
++        LOAD_LINE(1);
++        LOAD_LINE(2);
++        LOAD_LINE(3);
++        LOAD_LINE(4);
++        LOAD_LINE(5);
++        LOAD_LINE(6);
++        LOAD_LINE(7);
++    }
++#undef LOAD_LINE
++#undef LOAD_LINE_ALIGNED
++
++#define ITER(i, j)                                                      \
++    const vector signed short v_diff##i =                               \
++        vec_sub(v_srcAss##i, v_srcAss##j);                              \
++    const vector signed short v_sum##i =                                \
++        vec_add(v_diff##i, v_dcOffset);                                 \
++    const vector signed short v_comp##i =                               \
++        (vector signed short)vec_cmplt((vector unsigned short)v_sum##i, \
++                                       v_dcThreshold);                  \
++    const vector signed short v_part##i = vec_and(mask, v_comp##i);
++
++    {
++        ITER(0, 1)
++        ITER(1, 2)
++        ITER(2, 3)
++        ITER(3, 4)
++        ITER(4, 5)
++        ITER(5, 6)
++        ITER(6, 7)
++
++        v_numEq = vec_sum4s(v_part0, v_numEq);
++        v_numEq = vec_sum4s(v_part1, v_numEq);
++        v_numEq = vec_sum4s(v_part2, v_numEq);
++        v_numEq = vec_sum4s(v_part3, v_numEq);
++        v_numEq = vec_sum4s(v_part4, v_numEq);
++        v_numEq = vec_sum4s(v_part5, v_numEq);
++        v_numEq = vec_sum4s(v_part6, v_numEq);
++    }
++
++#undef ITER
++
++    v_numEq = vec_sums(v_numEq, zero);
++
++    v_numEq = vec_splat(v_numEq, 3);
++    vec_ste(v_numEq, 0, &numEq);
++
++    if (numEq > c->ppMode.flatnessThreshold){
++        const vector unsigned char mmoP1 = (const vector unsigned char)
++            {0x1f, 0x1f, 0x1f, 0x1f, 0x1f, 0x1f, 0x1f, 0x1f,
++             0x00, 0x01, 0x12, 0x13, 0x08, 0x09, 0x1A, 0x1B};
++        const vector unsigned char mmoP2 = (const vector unsigned char)
++            {0x04, 0x05, 0x16, 0x17, 0x0C, 0x0D, 0x1E, 0x1F,
++             0x1f, 0x1f, 0x1f, 0x1f, 0x1f, 0x1f, 0x1f, 0x1f};
++        const vector unsigned char mmoP = (const vector unsigned char)
++            vec_lvsl(8, (unsigned char*)0);
++
++        vector signed short mmoL1 = vec_perm(v_srcAss0, v_srcAss2, mmoP1);
++        vector signed short mmoL2 = vec_perm(v_srcAss4, v_srcAss6, mmoP2);
++        vector signed short mmoL = vec_perm(mmoL1, mmoL2, mmoP);
++        vector signed short mmoR1 = vec_perm(v_srcAss5, v_srcAss7, mmoP1);
++        vector signed short mmoR2 = vec_perm(v_srcAss1, v_srcAss3, mmoP2);
++        vector signed short mmoR = vec_perm(mmoR1, mmoR2, mmoP);
++        vector signed short mmoDiff = vec_sub(mmoL, mmoR);
++        vector unsigned short mmoSum = (vector unsigned short)vec_add(mmoDiff, v2QP);
++
++        if (vec_any_gt(mmoSum, v4QP))
++            return 0;
++        else
++            return 1;
++    }
++    else return 2;
++}
++
++static inline void doVertLowPass_altivec(uint8_t *src, int stride, PPContext *c) {
++    /*
++    this code makes no assumption on src or stride.
++    One could remove the recomputation of the perm
++    vector by assuming (stride % 16) == 0, unfortunately
++    this is not always true. Quite a lot of load/stores
++    can be removed by assuming proper alignment of
++    src & stride :-(
++    */
++    uint8_t *src2 = src;
++    const vector signed int zero = vec_splat_s32(0);
++    const int properStride = (stride % 16);
++    const int srcAlign = ((unsigned long)src2 % 16);
++    DECLARE_ALIGNED(16, short, qp)[8] = {c->QP};
++    vector signed short vqp = vec_ld(0, qp);
++    vector signed short vb0, vb1, vb2, vb3, vb4, vb5, vb6, vb7, vb8, vb9;
++    vector unsigned char vbA0, av_uninit(vbA1), av_uninit(vbA2), av_uninit(vbA3), av_uninit(vbA4), av_uninit(vbA5), av_uninit(vbA6), av_uninit(vbA7), av_uninit(vbA8), vbA9;
++    vector unsigned char vbB0, av_uninit(vbB1), av_uninit(vbB2), av_uninit(vbB3), av_uninit(vbB4), av_uninit(vbB5), av_uninit(vbB6), av_uninit(vbB7), av_uninit(vbB8), vbB9;
++    vector unsigned char vbT0, vbT1, vbT2, vbT3, vbT4, vbT5, vbT6, vbT7, vbT8, vbT9;
++    vector unsigned char perml0, perml1, perml2, perml3, perml4,
++                         perml5, perml6, perml7, perml8, perml9;
++    register int j0 = 0,
++                 j1 = stride,
++                 j2 = 2 * stride,
++                 j3 = 3 * stride,
++                 j4 = 4 * stride,
++                 j5 = 5 * stride,
++                 j6 = 6 * stride,
++                 j7 = 7 * stride,
++                 j8 = 8 * stride,
++                 j9 = 9 * stride;
++
++    vqp = vec_splat(vqp, 0);
++
++    src2 += stride*3;
++
++#define LOAD_LINE(i)                                                    \
++    perml##i = vec_lvsl(i * stride, src2);                              \
++    vbA##i = vec_ld(i * stride, src2);                                  \
++    vbB##i = vec_ld(i * stride + 16, src2);                             \
++    vbT##i = vec_perm(vbA##i, vbB##i, perml##i);                        \
++    vb##i =                                                             \
++        (vector signed short)vec_mergeh((vector unsigned char)zero,     \
++                                        (vector unsigned char)vbT##i)
++
++#define LOAD_LINE_ALIGNED(i)                                            \
++    vbT##i = vec_ld(j##i, src2);                                        \
++    vb##i =                                                             \
++        (vector signed short)vec_mergeh((vector signed char)zero,       \
++                                        (vector signed char)vbT##i)
++
++      /* Special-casing the aligned case is worthwhile, as all calls from
++       * the (transposed) horizontable deblocks will be aligned, in addition
++       * to the naturally aligned vertical deblocks. */
++    if (properStride && srcAlign) {
++          LOAD_LINE_ALIGNED(0);
++          LOAD_LINE_ALIGNED(1);
++          LOAD_LINE_ALIGNED(2);
++          LOAD_LINE_ALIGNED(3);
++          LOAD_LINE_ALIGNED(4);
++          LOAD_LINE_ALIGNED(5);
++          LOAD_LINE_ALIGNED(6);
++          LOAD_LINE_ALIGNED(7);
++          LOAD_LINE_ALIGNED(8);
++          LOAD_LINE_ALIGNED(9);
++    } else {
++          LOAD_LINE(0);
++          LOAD_LINE(1);
++          LOAD_LINE(2);
++          LOAD_LINE(3);
++          LOAD_LINE(4);
++          LOAD_LINE(5);
++          LOAD_LINE(6);
++          LOAD_LINE(7);
++          LOAD_LINE(8);
++          LOAD_LINE(9);
++    }
++#undef LOAD_LINE
++#undef LOAD_LINE_ALIGNED
++    {
++        const vector unsigned short v_2 = vec_splat_u16(2);
++        const vector unsigned short v_4 = vec_splat_u16(4);
++
++        const vector signed short v_diff01 = vec_sub(vb0, vb1);
++        const vector unsigned short v_cmp01 =
++            (const vector unsigned short) vec_cmplt(vec_abs(v_diff01), vqp);
++        const vector signed short v_first = vec_sel(vb1, vb0, v_cmp01);
++        const vector signed short v_diff89 = vec_sub(vb8, vb9);
++        const vector unsigned short v_cmp89 =
++            (const vector unsigned short) vec_cmplt(vec_abs(v_diff89), vqp);
++        const vector signed short v_last = vec_sel(vb8, vb9, v_cmp89);
++
++        const vector signed short temp01 = vec_mladd(v_first, (vector signed short)v_4, vb1);
++        const vector signed short temp02 = vec_add(vb2, vb3);
++        const vector signed short temp03 = vec_add(temp01, (vector signed short)v_4);
++        const vector signed short v_sumsB0 = vec_add(temp02, temp03);
++
++        const vector signed short temp11 = vec_sub(v_sumsB0, v_first);
++        const vector signed short v_sumsB1 = vec_add(temp11, vb4);
++
++        const vector signed short temp21 = vec_sub(v_sumsB1, v_first);
++        const vector signed short v_sumsB2 = vec_add(temp21, vb5);
++
++        const vector signed short temp31 = vec_sub(v_sumsB2, v_first);
++        const vector signed short v_sumsB3 = vec_add(temp31, vb6);
++
++        const vector signed short temp41 = vec_sub(v_sumsB3, v_first);
++        const vector signed short v_sumsB4 = vec_add(temp41, vb7);
++
++        const vector signed short temp51 = vec_sub(v_sumsB4, vb1);
++        const vector signed short v_sumsB5 = vec_add(temp51, vb8);
++
++        const vector signed short temp61 = vec_sub(v_sumsB5, vb2);
++        const vector signed short v_sumsB6 = vec_add(temp61, v_last);
++
++        const vector signed short temp71 = vec_sub(v_sumsB6, vb3);
++        const vector signed short v_sumsB7 = vec_add(temp71, v_last);
++
++        const vector signed short temp81 = vec_sub(v_sumsB7, vb4);
++        const vector signed short v_sumsB8 = vec_add(temp81, v_last);
++
++        const vector signed short temp91 = vec_sub(v_sumsB8, vb5);
++        const vector signed short v_sumsB9 = vec_add(temp91, v_last);
++
++    #define COMPUTE_VR(i, j, k)                                             \
++        const vector signed short temps1##i =                               \
++            vec_add(v_sumsB##i, v_sumsB##k);                                \
++        const vector signed short temps2##i =                               \
++            vec_mladd(vb##j, (vector signed short)v_2, temps1##i);          \
++        const vector signed short  vr##j = vec_sra(temps2##i, v_4)
++
++        COMPUTE_VR(0, 1, 2);
++        COMPUTE_VR(1, 2, 3);
++        COMPUTE_VR(2, 3, 4);
++        COMPUTE_VR(3, 4, 5);
++        COMPUTE_VR(4, 5, 6);
++        COMPUTE_VR(5, 6, 7);
++        COMPUTE_VR(6, 7, 8);
++        COMPUTE_VR(7, 8, 9);
++
++        const vector signed char neg1 = vec_splat_s8(-1);
++        const vector unsigned char permHH = (const vector unsigned char){0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07,
++                                                                         0x18, 0x19, 0x1A, 0x1B, 0x1C, 0x1D, 0x1E, 0x1F};
++
++#define PACK_AND_STORE(i)                                       \
++{   const vector unsigned char perms##i =                       \
++        vec_lvsr(i * stride, src2);                             \
++    const vector unsigned char vf##i =                          \
++        vec_packsu(vr##i, (vector signed short)zero);           \
++    const vector unsigned char vg##i =                          \
++        vec_perm(vf##i, vbT##i, permHH);                        \
++    const vector unsigned char mask##i =                        \
++        vec_perm((vector unsigned char)zero, (vector unsigned char)neg1, perms##i); \
++    const vector unsigned char vg2##i =                         \
++        vec_perm(vg##i, vg##i, perms##i);                       \
++    const vector unsigned char svA##i =                         \
++        vec_sel(vbA##i, vg2##i, mask##i);                       \
++    const vector unsigned char svB##i =                         \
++        vec_sel(vg2##i, vbB##i, mask##i);                       \
++    vec_st(svA##i, i * stride, src2);                           \
++    vec_st(svB##i, i * stride + 16, src2);}
++
++#define PACK_AND_STORE_ALIGNED(i)                               \
++{   const vector unsigned char vf##i =                          \
++        vec_packsu(vr##i, (vector signed short)zero);           \
++    const vector unsigned char vg##i =                          \
++        vec_perm(vf##i, vbT##i, permHH);                        \
++    vec_st(vg##i, i * stride, src2);}
++
++        /* Special-casing the aligned case is worthwhile, as all calls from
++         * the (transposed) horizontable deblocks will be aligned, in addition
++         * to the naturally aligned vertical deblocks. */
++        if (properStride && srcAlign) {
++            PACK_AND_STORE_ALIGNED(1)
++            PACK_AND_STORE_ALIGNED(2)
++            PACK_AND_STORE_ALIGNED(3)
++            PACK_AND_STORE_ALIGNED(4)
++            PACK_AND_STORE_ALIGNED(5)
++            PACK_AND_STORE_ALIGNED(6)
++            PACK_AND_STORE_ALIGNED(7)
++            PACK_AND_STORE_ALIGNED(8)
++        } else {
++            PACK_AND_STORE(1)
++            PACK_AND_STORE(2)
++            PACK_AND_STORE(3)
++            PACK_AND_STORE(4)
++            PACK_AND_STORE(5)
++            PACK_AND_STORE(6)
++            PACK_AND_STORE(7)
++            PACK_AND_STORE(8)
++        }
++    #undef PACK_AND_STORE
++    #undef PACK_AND_STORE_ALIGNED
++    }
++}
++
++
++
++static inline void doVertDefFilter_altivec(uint8_t src[], int stride, PPContext *c) {
++    /*
++    this code makes no assumption on src or stride.
++    One could remove the recomputation of the perm
++    vector by assuming (stride % 16) == 0, unfortunately
++    this is not always true. Quite a lot of load/stores
++    can be removed by assuming proper alignment of
++    src & stride :-(
++    */
++    uint8_t *src2 = src + stride*3;
++    const vector signed int zero = vec_splat_s32(0);
++    DECLARE_ALIGNED(16, short, qp)[8] = {8*c->QP};
++    vector signed short vqp = vec_splat(
++                                (vector signed short)vec_ld(0, qp), 0);
++
++#define LOAD_LINE(i)                                                    \
++    const vector unsigned char perm##i =                                \
++        vec_lvsl(i * stride, src2);                                     \
++    const vector unsigned char vbA##i =                                 \
++        vec_ld(i * stride, src2);                                       \
++    const vector unsigned char vbB##i =                                 \
++        vec_ld(i * stride + 16, src2);                                  \
++    const vector unsigned char vbT##i =                                 \
++        vec_perm(vbA##i, vbB##i, perm##i);                              \
++    const vector signed short vb##i =                                   \
++        (vector signed short)vec_mergeh((vector unsigned char)zero,     \
++                                        (vector unsigned char)vbT##i)
++
++     LOAD_LINE(1);
++     LOAD_LINE(2);
++     LOAD_LINE(3);
++     LOAD_LINE(4);
++     LOAD_LINE(5);
++     LOAD_LINE(6);
++     LOAD_LINE(7);
++     LOAD_LINE(8);
++#undef LOAD_LINE
++
++     const vector signed short v_1 = vec_splat_s16(1);
++     const vector signed short v_2 = vec_splat_s16(2);
++     const vector signed short v_5 = vec_splat_s16(5);
++     const vector signed short v_32 = vec_sl(v_1,
++                                             (vector unsigned short)v_5);
++     /* middle energy */
++     const vector signed short l3minusl6 = vec_sub(vb3, vb6);
++     const vector signed short l5minusl4 = vec_sub(vb5, vb4);
++     const vector signed short twotimes_l3minusl6 = vec_mladd(v_2, l3minusl6, (vector signed short)zero);
++     const vector signed short mE = vec_mladd(v_5, l5minusl4, twotimes_l3minusl6);
++     const vector signed short absmE = vec_abs(mE);
++     /* left & right energy */
++     const vector signed short l1minusl4 = vec_sub(vb1, vb4);
++     const vector signed short l3minusl2 = vec_sub(vb3, vb2);
++     const vector signed short l5minusl8 = vec_sub(vb5, vb8);
++     const vector signed short l7minusl6 = vec_sub(vb7, vb6);
++     const vector signed short twotimes_l1minusl4 = vec_mladd(v_2, l1minusl4, (vector signed short)zero);
++     const vector signed short twotimes_l5minusl8 = vec_mladd(v_2, l5minusl8, (vector signed short)zero);
++     const vector signed short lE = vec_mladd(v_5, l3minusl2, twotimes_l1minusl4);
++     const vector signed short rE = vec_mladd(v_5, l7minusl6, twotimes_l5minusl8);
++     /* d */
++     const vector signed short ddiff = vec_sub(absmE,
++                                               vec_min(vec_abs(lE),
++                                                       vec_abs(rE)));
++     const vector signed short ddiffclamp = vec_max(ddiff, (vector signed short)zero);
++     const vector signed short dtimes64 = vec_mladd(v_5, ddiffclamp, v_32);
++     const vector signed short d = vec_sra(dtimes64, vec_splat_u16(6));
++     const vector signed short minusd = vec_sub((vector signed short)zero, d);
++     const vector signed short finald = vec_sel(minusd,
++                                                d,
++                                                vec_cmpgt(vec_sub((vector signed short)zero, mE),
++                                                          (vector signed short)zero));
++     /* q */
++     const vector signed short qtimes2 = vec_sub(vb4, vb5);
++     /* for a shift right to behave like /2, we need to add one
++        to all negative integer */
++     const vector signed short rounddown = vec_sel((vector signed short)zero,
++                                                   v_1,
++                                                   vec_cmplt(qtimes2, (vector signed short)zero));
++     const vector signed short q = vec_sra(vec_add(qtimes2, rounddown), vec_splat_u16(1));
++     /* clamp */
++     const vector signed short dclamp_P1 = vec_max((vector signed short)zero, finald);
++     const vector signed short dclamp_P = vec_min(dclamp_P1, q);
++     const vector signed short dclamp_N1 = vec_min((vector signed short)zero, finald);
++     const vector signed short dclamp_N = vec_max(dclamp_N1, q);
++
++     const vector signed short dclampedfinal = vec_sel(dclamp_N,
++                                                       dclamp_P,
++                                                       vec_cmpgt(q, (vector signed short)zero));
++     const vector signed short dornotd = vec_sel((vector signed short)zero,
++                                                 dclampedfinal,
++                                                 vec_cmplt(absmE, vqp));
++     /* add/subtract to l4 and l5 */
++     const vector signed short vb4minusd = vec_sub(vb4, dornotd);
++     const vector signed short vb5plusd  = vec_add(vb5, dornotd);
++     /* finally, stores */
++     const vector unsigned char st4 = vec_packsu(vb4minusd, (vector signed short)zero);
++     const vector unsigned char st5 = vec_packsu(vb5plusd,  (vector signed short)zero);
++
++     const vector signed char neg1 = vec_splat_s8(-1);
++     const vector unsigned char permHH = (const vector unsigned char){0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07,
++                                                                      0x18, 0x19, 0x1A, 0x1B, 0x1C, 0x1D, 0x1E, 0x1F};
++
++#define STORE(i)                                                \
++{    const vector unsigned char perms##i =                      \
++         vec_lvsr(i * stride, src2);                            \
++     const vector unsigned char vg##i =                         \
++         vec_perm(st##i, vbT##i, permHH);                       \
++     const vector unsigned char mask##i =                       \
++         vec_perm((vector unsigned char)zero, (vector unsigned char)neg1, perms##i); \
++     const vector unsigned char vg2##i =                        \
++         vec_perm(vg##i, vg##i, perms##i);                      \
++     const vector unsigned char svA##i =                        \
++         vec_sel(vbA##i, vg2##i, mask##i);                      \
++     const vector unsigned char svB##i =                        \
++         vec_sel(vg2##i, vbB##i, mask##i);                      \
++     vec_st(svA##i, i * stride, src2);                          \
++     vec_st(svB##i, i * stride + 16, src2);}
++
++     STORE(4)
++     STORE(5)
++}
++
++static inline void dering_altivec(uint8_t src[], int stride, PPContext *c, int leftborder, int rightborder, int topborder) {
++    const vector signed int vsint32_8 = vec_splat_s32(8);
++    const vector unsigned int vuint32_4 = vec_splat_u32(4);
++    const vector signed char neg1 = vec_splat_s8(-1);
++
++    const vector unsigned char permA1 = (vector unsigned char)
++        {0x00, 0x01, 0x02, 0x10, 0x11, 0x12, 0x1F, 0x1F,
++         0x1F, 0x1F, 0x1F, 0x1F, 0x1F, 0x1F, 0x1F, 0x1F};
++    const vector unsigned char permA2 = (vector unsigned char)
++        {0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x10, 0x11,
++         0x12, 0x1F, 0x1F, 0x1F, 0x1F, 0x1F, 0x1F, 0x1F};
++    const vector unsigned char permA1inc = (vector unsigned char)
++        {0x01, 0x01, 0x01, 0x01, 0x01, 0x01, 0x00, 0x00,
++         0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00};
++    const vector unsigned char permA2inc = (vector unsigned char)
++        {0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x01, 0x01,
++         0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00};
++    const vector unsigned char magic = (vector unsigned char)
++        {0x01, 0x02, 0x01, 0x02, 0x04, 0x02, 0x01, 0x02,
++         0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00};
++    const vector unsigned char extractPerm = (vector unsigned char)
++        {0x10, 0x10, 0x10, 0x01, 0x10, 0x10, 0x10, 0x01,
++         0x10, 0x10, 0x10, 0x01, 0x10, 0x10, 0x10, 0x01};
++    const vector unsigned char extractPermInc = (vector unsigned char)
++        {0x00, 0x00, 0x00, 0x01, 0x00, 0x00, 0x00, 0x01,
++         0x00, 0x00, 0x00, 0x01, 0x00, 0x00, 0x00, 0x01};
++    const vector unsigned char identity = vec_lvsl(0,(unsigned char *)0);
++    const vector unsigned char tenRight = (vector unsigned char)
++        {0x00, 0x10, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
++         0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00};
++    const vector unsigned char eightLeft = (vector unsigned char)
++        {0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
++         0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x08};
++
++    /*
++    this code makes no assumption on src or stride.
++    One could remove the recomputation of the perm
++    vector by assuming (stride % 16) == 0, unfortunately
++    this is not always true. Quite a lot of load/stores
++    can be removed by assuming proper alignment of
++    src & stride :-(
++    */
++    uint8_t *srcCopy = src;
++    DECLARE_ALIGNED(16, uint8_t, dt)[16] = { DERING_THRESHOLD };
++    const vector signed int zero = vec_splat_s32(0);
++    vector unsigned char v_dt = vec_splat(vec_ld(0, dt), 0);
++
++    if (topborder)
++        return;
++
++#define LOAD_LINE(i)                                                  \
++    const vector unsigned char perm##i =                              \
++        vec_lvsl(i * stride, srcCopy);                                \
++    vector unsigned char sA##i = vec_ld(i * stride, srcCopy);         \
++    vector unsigned char sB##i = vec_ld(i * stride + 16, srcCopy);    \
++    vector unsigned char src##i = vec_perm(sA##i, sB##i, perm##i)
++
++    LOAD_LINE(0);
++    LOAD_LINE(1);
++    LOAD_LINE(2);
++    LOAD_LINE(3);
++    LOAD_LINE(4);
++    LOAD_LINE(5);
++    LOAD_LINE(6);
++    LOAD_LINE(7);
++    LOAD_LINE(8);
++    LOAD_LINE(9);
++#undef LOAD_LINE
++
++    vector unsigned char v_avg;
++    DECLARE_ALIGNED(16, signed int, S)[8];
++    DECLARE_ALIGNED(16, int, tQP2)[4] = { c->QP/2 + 1 };
++    vector signed int vQP2 = vec_ld(0, tQP2);
++    vQP2 = vec_splat(vQP2, 0);
++
++    {
++    const vector unsigned char trunc_perm = (vector unsigned char)
++        {0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08,
++         0x11, 0x12, 0x13, 0x14, 0x15, 0x16, 0x17, 0x18};
++    const vector unsigned char trunc_src12 = vec_perm(src1, src2, trunc_perm);
++    const vector unsigned char trunc_src34 = vec_perm(src3, src4, trunc_perm);
++    const vector unsigned char trunc_src56 = vec_perm(src5, src6, trunc_perm);
++    const vector unsigned char trunc_src78 = vec_perm(src7, src8, trunc_perm);
++
++#define EXTRACT(op) do {                                                \
++    const vector unsigned char s_1   = vec_##op(trunc_src12, trunc_src34); \
++    const vector unsigned char s_2   = vec_##op(trunc_src56, trunc_src78); \
++    const vector unsigned char s_6   = vec_##op(s_1, s_2);     \
++    const vector unsigned char s_8h  = vec_mergeh(s_6, s_6);   \
++    const vector unsigned char s_8l  = vec_mergel(s_6, s_6);   \
++    const vector unsigned char s_9   = vec_##op(s_8h, s_8l);   \
++    const vector unsigned char s_9h  = vec_mergeh(s_9, s_9);   \
++    const vector unsigned char s_9l  = vec_mergel(s_9, s_9);   \
++    const vector unsigned char s_10  = vec_##op(s_9h, s_9l);   \
++    const vector unsigned char s_10h = vec_mergeh(s_10, s_10); \
++    const vector unsigned char s_10l = vec_mergel(s_10, s_10); \
++    const vector unsigned char s_11  = vec_##op(s_10h, s_10l); \
++    const vector unsigned char s_11h = vec_mergeh(s_11, s_11); \
++    const vector unsigned char s_11l = vec_mergel(s_11, s_11); \
++    v_##op = vec_##op(s_11h, s_11l);                           \
++} while (0)
++
++    vector unsigned char v_min;
++    vector unsigned char v_max;
++    EXTRACT(min);
++    EXTRACT(max);
++#undef EXTRACT
++
++    if (vec_all_lt(vec_sub(v_max, v_min), v_dt))
++        return;
++
++    v_avg = vec_avg(v_min, v_max);
++    }
++
++    {
++    const vector unsigned short mask1 = (vector unsigned short)
++                                        {0x0001, 0x0002, 0x0004, 0x0008,
++                                         0x0010, 0x0020, 0x0040, 0x0080};
++    const vector unsigned short mask2 = (vector unsigned short)
++                                        {0x0100, 0x0200, 0x0000, 0x0000,
++                                         0x0000, 0x0000, 0x0000, 0x0000};
++
++    const vector unsigned int vuint32_16 = vec_sl(vec_splat_u32(1), vec_splat_u32(4));
++    const vector unsigned int vuint32_1 = vec_splat_u32(1);
++
++    vector signed int sumA2;
++    vector signed int sumB2;
++    vector signed int sum0, sum1, sum2, sum3, sum4;
++    vector signed int sum5, sum6, sum7, sum8, sum9;
++
++#define COMPARE(i)                                                      \
++    do {                                                                \
++        const vector unsigned char cmp =                                \
++            (vector unsigned char)vec_cmpgt(src##i, v_avg);             \
++        const vector unsigned short cmpHi =                             \
++            (vector unsigned short)vec_mergeh(cmp, cmp);                \
++        const vector unsigned short cmpLi =                             \
++            (vector unsigned short)vec_mergel(cmp, cmp);                \
++        const vector signed short cmpHf =                               \
++            (vector signed short)vec_and(cmpHi, mask1);                 \
++        const vector signed short cmpLf =                               \
++            (vector signed short)vec_and(cmpLi, mask2);                 \
++        const vector signed int sump = vec_sum4s(cmpHf, zero);          \
++        const vector signed int sumq = vec_sum4s(cmpLf, sump);          \
++        sum##i  = vec_sums(sumq, zero);                                 \
++    } while (0)
++
++    COMPARE(0);
++    COMPARE(1);
++    COMPARE(2);
++    COMPARE(3);
++    COMPARE(4);
++    COMPARE(5);
++    COMPARE(6);
++    COMPARE(7);
++    COMPARE(8);
++    COMPARE(9);
++#undef COMPARE
++
++    {
++    const vector signed int sump02 = vec_mergel(sum0, sum2);
++    const vector signed int sump13 = vec_mergel(sum1, sum3);
++    const vector signed int sumA = vec_mergel(sump02, sump13);
++
++    const vector signed int sump46 = vec_mergel(sum4, sum6);
++    const vector signed int sump57 = vec_mergel(sum5, sum7);
++    const vector signed int sumB = vec_mergel(sump46, sump57);
++
++    const vector signed int sump8A = vec_mergel(sum8, zero);
++    const vector signed int sump9B = vec_mergel(sum9, zero);
++    const vector signed int sumC = vec_mergel(sump8A, sump9B);
++
++    const vector signed int tA = vec_sl(vec_nor(zero, sumA), vuint32_16);
++    const vector signed int tB = vec_sl(vec_nor(zero, sumB), vuint32_16);
++    const vector signed int tC = vec_sl(vec_nor(zero, sumC), vuint32_16);
++    const vector signed int t2A = vec_or(sumA, tA);
++    const vector signed int t2B = vec_or(sumB, tB);
++    const vector signed int t2C = vec_or(sumC, tC);
++    const vector signed int t3A = vec_and(vec_sra(t2A, vuint32_1),
++                                          vec_sl(t2A, vuint32_1));
++    const vector signed int t3B = vec_and(vec_sra(t2B, vuint32_1),
++                                          vec_sl(t2B, vuint32_1));
++    const vector signed int t3C = vec_and(vec_sra(t2C, vuint32_1),
++                                          vec_sl(t2C, vuint32_1));
++    const vector signed int yA = vec_and(t2A, t3A);
++    const vector signed int yB = vec_and(t2B, t3B);
++    const vector signed int yC = vec_and(t2C, t3C);
++
++    const vector unsigned char strangeperm1 = vec_lvsl(4, (unsigned char*)0);
++    const vector unsigned char strangeperm2 = vec_lvsl(8, (unsigned char*)0);
++    const vector signed int sumAd4 = vec_perm(yA, yB, strangeperm1);
++    const vector signed int sumAd8 = vec_perm(yA, yB, strangeperm2);
++    const vector signed int sumBd4 = vec_perm(yB, yC, strangeperm1);
++    const vector signed int sumBd8 = vec_perm(yB, yC, strangeperm2);
++    const vector signed int sumAp = vec_and(yA,
++                                            vec_and(sumAd4,sumAd8));
++    const vector signed int sumBp = vec_and(yB,
++                                            vec_and(sumBd4,sumBd8));
++    sumA2 = vec_or(sumAp,
++                   vec_sra(sumAp,
++                           vuint32_16));
++    sumB2  = vec_or(sumBp,
++                    vec_sra(sumBp,
++                            vuint32_16));
++    }
++    vec_st(sumA2, 0, S);
++    vec_st(sumB2, 16, S);
++    }
++
++    /* I'm not sure the following is actually faster
++       than straight, unvectorized C code :-( */
++
++#define F_INIT()                                       \
++    vector unsigned char tenRightM = tenRight;         \
++    vector unsigned char permA1M = permA1;             \
++    vector unsigned char permA2M = permA2;             \
++    vector unsigned char extractPermM = extractPerm
++
++#define F2(i, j, k, l)                                                  \
++    if (S[i] & (1 << (l+1))) {                                          \
++        const vector unsigned char a_A = vec_perm(src##i, src##j, permA1M); \
++        const vector unsigned char a_B = vec_perm(a_A, src##k, permA2M); \
++        const vector signed int a_sump =                                \
++            (vector signed int)vec_msum(a_B, magic, (vector unsigned int)zero);\
++        vector signed int F = vec_sr(vec_sums(a_sump, vsint32_8), vuint32_4); \
++        const vector signed int p =                                     \
++            (vector signed int)vec_perm(src##j, (vector unsigned char)zero, \
++                                        extractPermM);                  \
++        const vector signed int sum  = vec_add(p, vQP2);                \
++        const vector signed int diff = vec_sub(p, vQP2);                \
++        vector signed int newpm;                                        \
++        vector unsigned char newpm2, mask;                              \
++        F = vec_splat(F, 3);                                            \
++        if (vec_all_lt(sum, F))                                         \
++            newpm = sum;                                                \
++        else if (vec_all_gt(diff, F))                                   \
++            newpm = diff;                                               \
++        else newpm = F;                                                 \
++        newpm2 = vec_splat((vector unsigned char)newpm, 15);            \
++        mask = vec_add(identity, tenRightM);                            \
++        src##j = vec_perm(src##j, newpm2, mask);                        \
++    }                                                                   \
++    permA1M = vec_add(permA1M, permA1inc);                              \
++    permA2M = vec_add(permA2M, permA2inc);                              \
++    tenRightM = vec_sro(tenRightM, eightLeft);                          \
++    extractPermM = vec_add(extractPermM, extractPermInc)
++
++#define ITER(i, j, k) do {                      \
++    F_INIT();                                   \
++    F2(i, j, k, 0);                             \
++    F2(i, j, k, 1);                             \
++    F2(i, j, k, 2);                             \
++    F2(i, j, k, 3);                             \
++    F2(i, j, k, 4);                             \
++    F2(i, j, k, 5);                             \
++    F2(i, j, k, 6);                             \
++    F2(i, j, k, 7);                             \
++} while (0)
++
++    ITER(0, 1, 2);
++    ITER(1, 2, 3);
++    ITER(2, 3, 4);
++    ITER(3, 4, 5);
++    ITER(4, 5, 6);
++    ITER(5, 6, 7);
++    ITER(6, 7, 8);
++    ITER(7, 8, 9);
++
++#define STORE_LINE(i) do {                              \
++    const vector unsigned char permST =                 \
++        vec_lvsr(i * stride, srcCopy);                  \
++    const vector unsigned char maskST =                 \
++        vec_perm((vector unsigned char)zero,            \
++                 (vector unsigned char)neg1, permST);   \
++    src##i = vec_perm(src##i ,src##i, permST);          \
++    sA##i= vec_sel(sA##i, src##i, maskST);              \
++    sB##i= vec_sel(src##i, sB##i, maskST);              \
++    vec_st(sA##i, i * stride, srcCopy);                 \
++    vec_st(sB##i, i * stride + 16, srcCopy);            \
++} while (0)
++
++    STORE_LINE(1);
++    STORE_LINE(2);
++    STORE_LINE(3);
++    STORE_LINE(4);
++    STORE_LINE(5);
++    STORE_LINE(6);
++    STORE_LINE(7);
++    STORE_LINE(8);
++
++#undef STORE_LINE
++#undef ITER
++#undef F2
++}
++
++#define doHorizLowPass_altivec(a...) doHorizLowPass_C(a)
++#define doHorizDefFilter_altivec(a...) doHorizDefFilter_C(a)
++#define do_a_deblock_altivec(a...) do_a_deblock_C(a)
++
++static inline void tempNoiseReducer_altivec(uint8_t *src, int stride,
++                                            uint8_t *tempBlurred, uint32_t *tempBlurredPast, int *maxNoise)
++{
++    const vector signed char neg1 = vec_splat_s8(-1);
++    const vector unsigned char permHH = (const vector unsigned char){0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07,
++                                                                     0x18, 0x19, 0x1A, 0x1B, 0x1C, 0x1D, 0x1E, 0x1F};
++
++    const vector signed int zero = vec_splat_s32(0);
++    const vector signed short vsint16_1 = vec_splat_s16(1);
++    vector signed int v_dp = zero;
++    vector signed int v_sysdp = zero;
++    int d, sysd, i;
++
++#define LOAD_LINE(src, i)                                               \
++    register int j##src##i = i * stride;                                \
++    vector unsigned char perm##src##i = vec_lvsl(j##src##i, src);       \
++    const vector unsigned char v_##src##A1##i = vec_ld(j##src##i, src); \
++    const vector unsigned char v_##src##A2##i = vec_ld(j##src##i + 16, src); \
++    const vector unsigned char v_##src##A##i =                          \
++        vec_perm(v_##src##A1##i, v_##src##A2##i, perm##src##i);         \
++    vector signed short v_##src##Ass##i =                               \
++        (vector signed short)vec_mergeh((vector signed char)zero,       \
++                                        (vector signed char)v_##src##A##i)
++
++    LOAD_LINE(src, 0);
++    LOAD_LINE(src, 1);
++    LOAD_LINE(src, 2);
++    LOAD_LINE(src, 3);
++    LOAD_LINE(src, 4);
++    LOAD_LINE(src, 5);
++    LOAD_LINE(src, 6);
++    LOAD_LINE(src, 7);
++
++    LOAD_LINE(tempBlurred, 0);
++    LOAD_LINE(tempBlurred, 1);
++    LOAD_LINE(tempBlurred, 2);
++    LOAD_LINE(tempBlurred, 3);
++    LOAD_LINE(tempBlurred, 4);
++    LOAD_LINE(tempBlurred, 5);
++    LOAD_LINE(tempBlurred, 6);
++    LOAD_LINE(tempBlurred, 7);
++#undef LOAD_LINE
++
++#define ACCUMULATE_DIFFS(i) do {                                \
++        vector signed short v_d = vec_sub(v_tempBlurredAss##i,  \
++                                          v_srcAss##i);         \
++        v_dp = vec_msums(v_d, v_d, v_dp);                       \
++        v_sysdp = vec_msums(v_d, vsint16_1, v_sysdp);           \
++    } while (0)
++
++    ACCUMULATE_DIFFS(0);
++    ACCUMULATE_DIFFS(1);
++    ACCUMULATE_DIFFS(2);
++    ACCUMULATE_DIFFS(3);
++    ACCUMULATE_DIFFS(4);
++    ACCUMULATE_DIFFS(5);
++    ACCUMULATE_DIFFS(6);
++    ACCUMULATE_DIFFS(7);
++#undef ACCUMULATE_DIFFS
++
++    tempBlurredPast[127]= maxNoise[0];
++    tempBlurredPast[128]= maxNoise[1];
++    tempBlurredPast[129]= maxNoise[2];
++
++    v_dp = vec_sums(v_dp, zero);
++    v_sysdp = vec_sums(v_sysdp, zero);
++
++    v_dp = vec_splat(v_dp, 3);
++    v_sysdp = vec_splat(v_sysdp, 3);
++
++    vec_ste(v_dp, 0, &d);
++    vec_ste(v_sysdp, 0, &sysd);
++
++    i = d;
++    d = (4*d
++         +(*(tempBlurredPast-256))
++         +(*(tempBlurredPast-1))+ (*(tempBlurredPast+1))
++         +(*(tempBlurredPast+256))
++         +4)>>3;
++
++    *tempBlurredPast=i;
++
++    if (d > maxNoise[1]) {
++        if (d < maxNoise[2]) {
++#define OP(i) v_tempBlurredAss##i = vec_avg(v_tempBlurredAss##i, v_srcAss##i);
++
++            OP(0);
++            OP(1);
++            OP(2);
++            OP(3);
++            OP(4);
++            OP(5);
++            OP(6);
++            OP(7);
++#undef OP
++        } else {
++#define OP(i) v_tempBlurredAss##i = v_srcAss##i;
++
++            OP(0);
++            OP(1);
++            OP(2);
++            OP(3);
++            OP(4);
++            OP(5);
++            OP(6);
++            OP(7);
++#undef OP
++        }
++    } else {
++        if (d < maxNoise[0]) {
++            const vector signed short vsint16_7 = vec_splat_s16(7);
++            const vector signed short vsint16_4 = vec_splat_s16(4);
++            const vector unsigned short vuint16_3 = vec_splat_u16(3);
++
++#define OP(i) do {                                                      \
++            const vector signed short v_temp =                          \
++                vec_mladd(v_tempBlurredAss##i, vsint16_7, v_srcAss##i); \
++            const vector signed short v_temp2 = vec_add(v_temp, vsint16_4); \
++            v_tempBlurredAss##i = vec_sr(v_temp2, vuint16_3);           \
++        } while (0)
++
++            OP(0);
++            OP(1);
++            OP(2);
++            OP(3);
++            OP(4);
++            OP(5);
++            OP(6);
++            OP(7);
++#undef OP
++        } else {
++            const vector signed short vsint16_3 = vec_splat_s16(3);
++            const vector signed short vsint16_2 = vec_splat_s16(2);
++
++#define OP(i) do {                                              \
++            const vector signed short v_temp =                  \
++                vec_mladd(v_tempBlurredAss##i, vsint16_3, v_srcAss##i); \
++            const vector signed short v_temp2 = vec_add(v_temp, vsint16_2); \
++            v_tempBlurredAss##i =                                       \
++                vec_sr(v_temp2, (vector unsigned short)vsint16_2);      \
++        } while (0)
++
++            OP(0);
++            OP(1);
++            OP(2);
++            OP(3);
++            OP(4);
++            OP(5);
++            OP(6);
++            OP(7);
++#undef OP
++        }
++    }
++
++#define PACK_AND_STORE(src, i) do {                                      \
++    const vector unsigned char perms = vec_lvsr(i * stride, src);        \
++    const vector unsigned char vf =                                      \
++        vec_packsu(v_tempBlurredAss##1, (vector signed short)zero);     \
++    const vector unsigned char vg = vec_perm(vf, v_##src##A##i, permHH); \
++    const vector unsigned char mask =                                    \
++        vec_perm((vector unsigned char)zero, (vector unsigned char)neg1, perms); \
++    const vector unsigned char vg2 = vec_perm(vg, vg, perms);            \
++    const vector unsigned char svA = vec_sel(v_##src##A1##i, vg2, mask); \
++    const vector unsigned char svB = vec_sel(vg2, v_##src##A2##i, mask); \
++    vec_st(svA, i * stride, src);                                        \
++    vec_st(svB, i * stride + 16, src);                                   \
++} while (0)
++
++    PACK_AND_STORE(src, 0);
++    PACK_AND_STORE(src, 1);
++    PACK_AND_STORE(src, 2);
++    PACK_AND_STORE(src, 3);
++    PACK_AND_STORE(src, 4);
++    PACK_AND_STORE(src, 5);
++    PACK_AND_STORE(src, 6);
++    PACK_AND_STORE(src, 7);
++    PACK_AND_STORE(tempBlurred, 0);
++    PACK_AND_STORE(tempBlurred, 1);
++    PACK_AND_STORE(tempBlurred, 2);
++    PACK_AND_STORE(tempBlurred, 3);
++    PACK_AND_STORE(tempBlurred, 4);
++    PACK_AND_STORE(tempBlurred, 5);
++    PACK_AND_STORE(tempBlurred, 6);
++    PACK_AND_STORE(tempBlurred, 7);
++#undef PACK_AND_STORE
++}
++
++static inline void transpose_16x8_char_toPackedAlign_altivec(unsigned char* dst, unsigned char* src, int stride) {
++    const vector unsigned char zero = vec_splat_u8(0);
++
++#define LOAD_DOUBLE_LINE(i, j)                                          \
++    vector unsigned char perm1##i = vec_lvsl(i * stride, src);          \
++    vector unsigned char perm2##i = vec_lvsl(j * stride, src);          \
++    vector unsigned char srcA##i = vec_ld(i * stride, src);             \
++    vector unsigned char srcB##i = vec_ld(i * stride + 16, src);        \
++    vector unsigned char srcC##i = vec_ld(j * stride, src);             \
++    vector unsigned char srcD##i = vec_ld(j * stride+ 16, src);         \
++    vector unsigned char src##i = vec_perm(srcA##i, srcB##i, perm1##i); \
++    vector unsigned char src##j = vec_perm(srcC##i, srcD##i, perm2##i)
++
++    LOAD_DOUBLE_LINE(0, 1);
++    LOAD_DOUBLE_LINE(2, 3);
++    LOAD_DOUBLE_LINE(4, 5);
++    LOAD_DOUBLE_LINE(6, 7);
++#undef LOAD_DOUBLE_LINE
++
++    vector unsigned char tempA = vec_mergeh(src0, zero);
++    vector unsigned char tempB = vec_mergel(src0, zero);
++    vector unsigned char tempC = vec_mergeh(src1, zero);
++    vector unsigned char tempD = vec_mergel(src1, zero);
++    vector unsigned char tempE = vec_mergeh(src2, zero);
++    vector unsigned char tempF = vec_mergel(src2, zero);
++    vector unsigned char tempG = vec_mergeh(src3, zero);
++    vector unsigned char tempH = vec_mergel(src3, zero);
++    vector unsigned char tempI = vec_mergeh(src4, zero);
++    vector unsigned char tempJ = vec_mergel(src4, zero);
++    vector unsigned char tempK = vec_mergeh(src5, zero);
++    vector unsigned char tempL = vec_mergel(src5, zero);
++    vector unsigned char tempM = vec_mergeh(src6, zero);
++    vector unsigned char tempN = vec_mergel(src6, zero);
++    vector unsigned char tempO = vec_mergeh(src7, zero);
++    vector unsigned char tempP = vec_mergel(src7, zero);
++
++    vector unsigned char temp0  = vec_mergeh(tempA, tempI);
++    vector unsigned char temp1  = vec_mergel(tempA, tempI);
++    vector unsigned char temp2  = vec_mergeh(tempB, tempJ);
++    vector unsigned char temp3  = vec_mergel(tempB, tempJ);
++    vector unsigned char temp4  = vec_mergeh(tempC, tempK);
++    vector unsigned char temp5  = vec_mergel(tempC, tempK);
++    vector unsigned char temp6  = vec_mergeh(tempD, tempL);
++    vector unsigned char temp7  = vec_mergel(tempD, tempL);
++    vector unsigned char temp8  = vec_mergeh(tempE, tempM);
++    vector unsigned char temp9  = vec_mergel(tempE, tempM);
++    vector unsigned char temp10 = vec_mergeh(tempF, tempN);
++    vector unsigned char temp11 = vec_mergel(tempF, tempN);
++    vector unsigned char temp12 = vec_mergeh(tempG, tempO);
++    vector unsigned char temp13 = vec_mergel(tempG, tempO);
++    vector unsigned char temp14 = vec_mergeh(tempH, tempP);
++    vector unsigned char temp15 = vec_mergel(tempH, tempP);
++
++    tempA = vec_mergeh(temp0, temp8);
++    tempB = vec_mergel(temp0, temp8);
++    tempC = vec_mergeh(temp1, temp9);
++    tempD = vec_mergel(temp1, temp9);
++    tempE = vec_mergeh(temp2, temp10);
++    tempF = vec_mergel(temp2, temp10);
++    tempG = vec_mergeh(temp3, temp11);
++    tempH = vec_mergel(temp3, temp11);
++    tempI = vec_mergeh(temp4, temp12);
++    tempJ = vec_mergel(temp4, temp12);
++    tempK = vec_mergeh(temp5, temp13);
++    tempL = vec_mergel(temp5, temp13);
++    tempM = vec_mergeh(temp6, temp14);
++    tempN = vec_mergel(temp6, temp14);
++    tempO = vec_mergeh(temp7, temp15);
++    tempP = vec_mergel(temp7, temp15);
++
++    temp0  = vec_mergeh(tempA, tempI);
++    temp1  = vec_mergel(tempA, tempI);
++    temp2  = vec_mergeh(tempB, tempJ);
++    temp3  = vec_mergel(tempB, tempJ);
++    temp4  = vec_mergeh(tempC, tempK);
++    temp5  = vec_mergel(tempC, tempK);
++    temp6  = vec_mergeh(tempD, tempL);
++    temp7  = vec_mergel(tempD, tempL);
++    temp8  = vec_mergeh(tempE, tempM);
++    temp9  = vec_mergel(tempE, tempM);
++    temp10 = vec_mergeh(tempF, tempN);
++    temp11 = vec_mergel(tempF, tempN);
++    temp12 = vec_mergeh(tempG, tempO);
++    temp13 = vec_mergel(tempG, tempO);
++    temp14 = vec_mergeh(tempH, tempP);
++    temp15 = vec_mergel(tempH, tempP);
++
++    vec_st(temp0,    0, dst);
++    vec_st(temp1,   16, dst);
++    vec_st(temp2,   32, dst);
++    vec_st(temp3,   48, dst);
++    vec_st(temp4,   64, dst);
++    vec_st(temp5,   80, dst);
++    vec_st(temp6,   96, dst);
++    vec_st(temp7,  112, dst);
++    vec_st(temp8,  128, dst);
++    vec_st(temp9,  144, dst);
++    vec_st(temp10, 160, dst);
++    vec_st(temp11, 176, dst);
++    vec_st(temp12, 192, dst);
++    vec_st(temp13, 208, dst);
++    vec_st(temp14, 224, dst);
++    vec_st(temp15, 240, dst);
++}
++
++static inline void transpose_8x16_char_fromPackedAlign_altivec(unsigned char* dst, unsigned char* src, int stride) {
++    const vector unsigned char zero = vec_splat_u8(0);
++    const vector signed   char neg1 = vec_splat_s8(-1);
++
++#define LOAD_DOUBLE_LINE(i, j)                                  \
++    vector unsigned char src##i = vec_ld(i * 16, src);            \
++    vector unsigned char src##j = vec_ld(j * 16, src)
++
++    LOAD_DOUBLE_LINE(0, 1);
++    LOAD_DOUBLE_LINE(2, 3);
++    LOAD_DOUBLE_LINE(4, 5);
++    LOAD_DOUBLE_LINE(6, 7);
++    LOAD_DOUBLE_LINE(8, 9);
++    LOAD_DOUBLE_LINE(10, 11);
++    LOAD_DOUBLE_LINE(12, 13);
++    LOAD_DOUBLE_LINE(14, 15);
++#undef LOAD_DOUBLE_LINE
++
++    vector unsigned char tempA = vec_mergeh(src0, src8);
++    vector unsigned char tempB;
++    vector unsigned char tempC = vec_mergeh(src1, src9);
++    vector unsigned char tempD;
++    vector unsigned char tempE = vec_mergeh(src2, src10);
++    vector unsigned char tempG = vec_mergeh(src3, src11);
++    vector unsigned char tempI = vec_mergeh(src4, src12);
++    vector unsigned char tempJ;
++    vector unsigned char tempK = vec_mergeh(src5, src13);
++    vector unsigned char tempL;
++    vector unsigned char tempM = vec_mergeh(src6, src14);
++    vector unsigned char tempO = vec_mergeh(src7, src15);
++
++    vector unsigned char temp0 = vec_mergeh(tempA, tempI);
++    vector unsigned char temp1 = vec_mergel(tempA, tempI);
++    vector unsigned char temp2;
++    vector unsigned char temp3;
++    vector unsigned char temp4 = vec_mergeh(tempC, tempK);
++    vector unsigned char temp5 = vec_mergel(tempC, tempK);
++    vector unsigned char temp6;
++    vector unsigned char temp7;
++    vector unsigned char temp8 = vec_mergeh(tempE, tempM);
++    vector unsigned char temp9 = vec_mergel(tempE, tempM);
++    vector unsigned char temp12 = vec_mergeh(tempG, tempO);
++    vector unsigned char temp13 = vec_mergel(tempG, tempO);
++
++    tempA = vec_mergeh(temp0, temp8);
++    tempB = vec_mergel(temp0, temp8);
++    tempC = vec_mergeh(temp1, temp9);
++    tempD = vec_mergel(temp1, temp9);
++    tempI = vec_mergeh(temp4, temp12);
++    tempJ = vec_mergel(temp4, temp12);
++    tempK = vec_mergeh(temp5, temp13);
++    tempL = vec_mergel(temp5, temp13);
++
++    temp0 = vec_mergeh(tempA, tempI);
++    temp1 = vec_mergel(tempA, tempI);
++    temp2 = vec_mergeh(tempB, tempJ);
++    temp3 = vec_mergel(tempB, tempJ);
++    temp4 = vec_mergeh(tempC, tempK);
++    temp5 = vec_mergel(tempC, tempK);
++    temp6 = vec_mergeh(tempD, tempL);
++    temp7 = vec_mergel(tempD, tempL);
++
++
++#define STORE_DOUBLE_LINE(i, j) do {                                    \
++    vector unsigned char dstAi = vec_ld(i * stride, dst);               \
++    vector unsigned char dstBi = vec_ld(i * stride + 16, dst);          \
++    vector unsigned char dstAj = vec_ld(j * stride, dst);               \
++    vector unsigned char dstBj = vec_ld(j * stride+ 16, dst);           \
++    vector unsigned char aligni = vec_lvsr(i * stride, dst);            \
++    vector unsigned char alignj = vec_lvsr(j * stride, dst);            \
++    vector unsigned char maski =                                        \
++        vec_perm(zero, (vector unsigned char)neg1, aligni);             \
++    vector unsigned char maskj =                                        \
++        vec_perm(zero, (vector unsigned char)neg1, alignj);             \
++    vector unsigned char dstRi = vec_perm(temp##i, temp##i, aligni);    \
++    vector unsigned char dstRj = vec_perm(temp##j, temp##j, alignj);    \
++    vector unsigned char dstAFi = vec_sel(dstAi, dstRi, maski);         \
++    vector unsigned char dstBFi = vec_sel(dstRi, dstBi, maski);         \
++    vector unsigned char dstAFj = vec_sel(dstAj, dstRj, maskj);         \
++    vector unsigned char dstBFj = vec_sel(dstRj, dstBj, maskj);         \
++    vec_st(dstAFi, i * stride, dst);                                    \
++    vec_st(dstBFi, i * stride + 16, dst);                               \
++    vec_st(dstAFj, j * stride, dst);                                    \
++    vec_st(dstBFj, j * stride + 16, dst);                               \
++} while (0)
++
++    STORE_DOUBLE_LINE(0,1);
++    STORE_DOUBLE_LINE(2,3);
++    STORE_DOUBLE_LINE(4,5);
++    STORE_DOUBLE_LINE(6,7);
++}
+diff --git a/libpostproc/postprocess_internal.h b/libpostproc/postprocess_internal.h
+new file mode 100644
+index 0000000000000..5d1aee362ea60
+--- /dev/null
++++ b/libpostproc/postprocess_internal.h
+@@ -0,0 +1,185 @@
++/*
++ * Copyright (C) 2001-2002 Michael Niedermayer (michaelni@gmx.at)
++ *
++ * This file is part of FFmpeg.
++ *
++ * FFmpeg is free software; you can redistribute it and/or modify
++ * it under the terms of the GNU General Public License as published by
++ * the Free Software Foundation; either version 2 of the License, or
++ * (at your option) any later version.
++ *
++ * FFmpeg is distributed in the hope that it will be useful,
++ * but WITHOUT ANY WARRANTY; without even the implied warranty of
++ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
++ * GNU General Public License for more details.
++ *
++ * You should have received a copy of the GNU General Public License
++ * along with FFmpeg; if not, write to the Free Software
++ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
++ */
++
++/**
++ * @file
++ * internal API header.
++ */
++
++#ifndef POSTPROC_POSTPROCESS_INTERNAL_H
++#define POSTPROC_POSTPROCESS_INTERNAL_H
++
++#include <string.h>
++#include "libavutil/avutil.h"
++#include "libavutil/intmath.h"
++#include "libavutil/log.h"
++#include "libavutil/mem_internal.h"
++#include "postprocess.h"
++
++#define V_DEBLOCK       0x01
++#define H_DEBLOCK       0x02
++#define DERING          0x04
++#define LEVEL_FIX       0x08 ///< Brightness & Contrast
++
++#define LUM_V_DEBLOCK   V_DEBLOCK               //   1
++#define LUM_H_DEBLOCK   H_DEBLOCK               //   2
++#define CHROM_V_DEBLOCK (V_DEBLOCK<<4)          //  16
++#define CHROM_H_DEBLOCK (H_DEBLOCK<<4)          //  32
++#define LUM_DERING      DERING                  //   4
++#define CHROM_DERING    (DERING<<4)             //  64
++#define LUM_LEVEL_FIX   LEVEL_FIX               //   8
++#define CHROM_LEVEL_FIX (LEVEL_FIX<<4)          // 128 (not implemented yet)
++
++// Experimental vertical filters
++#define V_X1_FILTER     0x0200                  // 512
++#define V_A_DEBLOCK     0x0400
++
++// Experimental horizontal filters
++#define H_X1_FILTER     0x2000                  // 8192
++#define H_A_DEBLOCK     0x4000
++
++/// select between full y range (255-0) or standard one (234-16)
++#define FULL_Y_RANGE    0x8000                  // 32768
++
++//Deinterlacing Filters
++#define LINEAR_IPOL_DEINT_FILTER        0x10000 // 65536
++#define LINEAR_BLEND_DEINT_FILTER       0x20000 // 131072
++#define CUBIC_BLEND_DEINT_FILTER        0x8000  // (not implemented yet)
++#define CUBIC_IPOL_DEINT_FILTER         0x40000 // 262144
++#define MEDIAN_DEINT_FILTER             0x80000 // 524288
++#define FFMPEG_DEINT_FILTER             0x400000
++#define LOWPASS5_DEINT_FILTER           0x800000
++
++#define TEMP_NOISE_FILTER               0x100000
++#define FORCE_QUANT                     0x200000
++#define BITEXACT                        0x1000000
++#define VISUALIZE                       0x2000000
++
++//use if you want a faster postprocessing code
++//cannot differentiate between chroma & luma filters (both on or both off)
++//obviously the -pp option on the command line has no effect except turning the here selected
++//filters on
++//#define COMPILE_TIME_MODE 0x77
++
++/**
++ * Postprocessing filter.
++ */
++struct PPFilter{
++    const char *shortName;
++    const char *longName;
++    int chromDefault;       ///< is chrominance filtering on by default if this filter is manually activated
++    int minLumQuality;      ///< minimum quality to turn luminance filtering on
++    int minChromQuality;    ///< minimum quality to turn chrominance filtering on
++    int mask;               ///< Bitmask to turn this filter on
++};
++
++/**
++ * Postprocessing mode.
++ */
++typedef struct PPMode{
++    int lumMode;                    ///< activates filters for luminance
++    int chromMode;                  ///< activates filters for chrominance
++    int error;                      ///< non zero on error
++
++    int minAllowedY;                ///< for brightness correction
++    int maxAllowedY;                ///< for brightness correction
++    AVRational maxClippedThreshold; ///< amount of "black" you are willing to lose to get a brightness-corrected picture
++
++    int maxTmpNoise[3];             ///< for Temporal Noise Reducing filter (Maximal sum of abs differences)
++
++    int baseDcDiff;
++    int flatnessThreshold;
++
++    int forcedQuant;                ///< quantizer if FORCE_QUANT is used
++} PPMode;
++
++/**
++ * postprocess context.
++ */
++typedef struct PPContext{
++    /**
++     * info on struct for av_log
++     */
++    const AVClass *av_class;
++
++    uint8_t *tempBlocks; ///<used for the horizontal code
++
++    /**
++     * luma histogram.
++     * we need 64bit here otherwise we'll going to have a problem
++     * after watching a black picture for 5 hours
++     */
++    uint64_t *yHistogram;
++
++    DECLARE_ALIGNED(8, uint64_t, packedYOffset);
++    DECLARE_ALIGNED(8, uint64_t, packedYScale);
++
++    /** Temporal noise reducing buffers */
++    uint8_t *tempBlurred[3];
++    int32_t *tempBlurredPast[3];
++
++    /** Temporary buffers for handling the last row(s) */
++    uint8_t *tempDst;
++    uint8_t *tempSrc;
++
++    uint8_t *deintTemp;
++
++    DECLARE_ALIGNED(8, uint64_t, pQPb);
++    DECLARE_ALIGNED(8, uint64_t, pQPb2);
++
++    DECLARE_ALIGNED(32, uint64_t, pQPb_block)[4];
++    DECLARE_ALIGNED(32, uint64_t, pQPb2_block)[4];
++
++    DECLARE_ALIGNED(32, uint64_t, mmxDcOffset)[64];
++    DECLARE_ALIGNED(32, uint64_t, mmxDcThreshold)[64];
++
++    int8_t *stdQPTable;       ///< used to fix MPEG2 style qscale
++    int8_t *nonBQPTable;
++    int8_t *forcedQPTable;
++
++    int QP;
++    int nonBQP;
++
++    DECLARE_ALIGNED(32, int, QP_block)[4];
++    DECLARE_ALIGNED(32, int, nonBQP_block)[4];
++
++    int frameNum;
++
++    int cpuCaps;
++
++    int qpStride; ///<size of qp buffers (needed to realloc them if needed)
++    int stride;   ///<size of some buffers (needed to realloc them if needed)
++
++    int hChromaSubSample;
++    int vChromaSubSample;
++
++    PPMode ppMode;
++} PPContext;
++
++
++static inline void linecpy(void *dest, const void *src, int lines, int stride) {
++    if (stride > 0) {
++        memcpy(dest, src, lines*stride);
++    } else {
++        memcpy((uint8_t*)dest+(lines-1)*stride, (const uint8_t*)src+(lines-1)*stride, -lines*stride);
++    }
++}
++
++#endif /* POSTPROC_POSTPROCESS_INTERNAL_H */
+diff --git a/libpostproc/postprocess_template.c b/libpostproc/postprocess_template.c
+new file mode 100644
+index 0000000000000..3dfe701b5dce5
+--- /dev/null
++++ b/libpostproc/postprocess_template.c
+@@ -0,0 +1,3293 @@
++/*
++ * Copyright (C) 2001-2002 Michael Niedermayer (michaelni@gmx.at)
++ *
++ * This file is part of FFmpeg.
++ *
++ * FFmpeg is free software; you can redistribute it and/or modify
++ * it under the terms of the GNU General Public License as published by
++ * the Free Software Foundation; either version 2 of the License, or
++ * (at your option) any later version.
++ *
++ * FFmpeg is distributed in the hope that it will be useful,
++ * but WITHOUT ANY WARRANTY; without even the implied warranty of
++ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
++ * GNU General Public License for more details.
++ *
++ * You should have received a copy of the GNU General Public License
++ * along with FFmpeg; if not, write to the Free Software
++ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
++ */
++
++/**
++ * @file
++ * mmx/mmx2/sse2 postprocess code.
++ */
++#include "config.h"
++
++#include "libavutil/mem_internal.h"
++#if ARCH_X86
++#include "libavutil/x86/asm.h"
++#endif
++
++/* A single TEMPLATE_PP_* should be defined (to 1) when this template is
++ * included. The following macros will define its dependencies to 1 as well
++ * (like MMX2 depending on MMX), and will define to 0 all the others. Every
++ * TEMPLATE_PP_* need to be undef at the end. */
++
++#ifdef TEMPLATE_PP_C
++#   define RENAME(a) a ## _C
++#else
++#   define TEMPLATE_PP_C 0
++#endif
++
++#ifdef TEMPLATE_PP_ALTIVEC
++#   define RENAME(a) a ## _altivec
++#else
++#   define TEMPLATE_PP_ALTIVEC 0
++#endif
++
++#ifdef TEMPLATE_PP_MMX
++#   define RENAME(a) a ## _MMX
++#else
++#   define TEMPLATE_PP_MMX 0
++#endif
++
++#ifdef TEMPLATE_PP_MMXEXT
++#   undef  TEMPLATE_PP_MMX
++#   define TEMPLATE_PP_MMX 1
++#   define RENAME(a) a ## _MMX2
++#else
++#   define TEMPLATE_PP_MMXEXT 0
++#endif
++
++#ifdef TEMPLATE_PP_SSE2
++#   undef  TEMPLATE_PP_MMX
++#   define TEMPLATE_PP_MMX 1
++#   undef  TEMPLATE_PP_MMXEXT
++#   define TEMPLATE_PP_MMXEXT 1
++#   define RENAME(a) a ## _SSE2
++#else
++#   define TEMPLATE_PP_SSE2 0
++#endif
++
++#undef REAL_PAVGB
++#undef PAVGB
++#undef PMINUB
++#undef PMAXUB
++
++#if   TEMPLATE_PP_MMXEXT
++#define REAL_PAVGB(a,b) "pavgb " #a ", " #b " \n\t"
++#endif
++#define PAVGB(a,b)  REAL_PAVGB(a,b)
++
++#if   TEMPLATE_PP_MMXEXT
++#define PMINUB(a,b,t) "pminub " #a ", " #b " \n\t"
++#endif
++
++#if   TEMPLATE_PP_MMXEXT
++#define PMAXUB(a,b) "pmaxub " #a ", " #b " \n\t"
++#endif
++
++//FIXME? |255-0| = 1 (should not be a problem ...)
++#if TEMPLATE_PP_MMXEXT
++/**
++ * Check if the middle 8x8 Block in the given 8x16 block is flat
++ */
++static inline int RENAME(vertClassify)(const uint8_t src[], int stride, PPContext *c){
++    int numEq= 0, dcOk;
++    src+= stride*4; // src points to begin of the 8x8 Block
++    __asm__ volatile(
++        "movq %0, %%mm7                         \n\t"
++        "movq %1, %%mm6                         \n\t"
++        : : "m" (c->mmxDcOffset[c->nonBQP]),  "m" (c->mmxDcThreshold[c->nonBQP])
++        );
++
++    __asm__ volatile(
++        "lea (%2, %3), %%"FF_REG_a"             \n\t"
++//      0       1       2       3       4       5       6       7       8       9
++//      %1      eax     eax+%2  eax+2%2 %1+4%2  ecx     ecx+%2  ecx+2%2 %1+8%2  ecx+4%2
++
++        "movq (%2), %%mm0                       \n\t"
++        "movq (%%"FF_REG_a"), %%mm1             \n\t"
++        "movq %%mm0, %%mm3                      \n\t"
++        "movq %%mm0, %%mm4                      \n\t"
++        PMAXUB(%%mm1, %%mm4)
++        PMINUB(%%mm1, %%mm3, %%mm5)
++        "psubb %%mm1, %%mm0                     \n\t" // mm0 = difference
++        "paddb %%mm7, %%mm0                     \n\t"
++        "pcmpgtb %%mm6, %%mm0                   \n\t"
++
++        "movq (%%"FF_REG_a",%3), %%mm2          \n\t"
++        PMAXUB(%%mm2, %%mm4)
++        PMINUB(%%mm2, %%mm3, %%mm5)
++        "psubb %%mm2, %%mm1                     \n\t"
++        "paddb %%mm7, %%mm1                     \n\t"
++        "pcmpgtb %%mm6, %%mm1                   \n\t"
++        "paddb %%mm1, %%mm0                     \n\t"
++
++        "movq (%%"FF_REG_a", %3, 2), %%mm1      \n\t"
++        PMAXUB(%%mm1, %%mm4)
++        PMINUB(%%mm1, %%mm3, %%mm5)
++        "psubb %%mm1, %%mm2                     \n\t"
++        "paddb %%mm7, %%mm2                     \n\t"
++        "pcmpgtb %%mm6, %%mm2                   \n\t"
++        "paddb %%mm2, %%mm0                     \n\t"
++
++        "lea (%%"FF_REG_a", %3, 4), %%"FF_REG_a"\n\t"
++
++        "movq (%2, %3, 4), %%mm2                \n\t"
++        PMAXUB(%%mm2, %%mm4)
++        PMINUB(%%mm2, %%mm3, %%mm5)
++        "psubb %%mm2, %%mm1                     \n\t"
++        "paddb %%mm7, %%mm1                     \n\t"
++        "pcmpgtb %%mm6, %%mm1                   \n\t"
++        "paddb %%mm1, %%mm0                     \n\t"
++
++        "movq (%%"FF_REG_a"), %%mm1             \n\t"
++        PMAXUB(%%mm1, %%mm4)
++        PMINUB(%%mm1, %%mm3, %%mm5)
++        "psubb %%mm1, %%mm2                     \n\t"
++        "paddb %%mm7, %%mm2                     \n\t"
++        "pcmpgtb %%mm6, %%mm2                   \n\t"
++        "paddb %%mm2, %%mm0                     \n\t"
++
++        "movq (%%"FF_REG_a", %3), %%mm2         \n\t"
++        PMAXUB(%%mm2, %%mm4)
++        PMINUB(%%mm2, %%mm3, %%mm5)
++        "psubb %%mm2, %%mm1                     \n\t"
++        "paddb %%mm7, %%mm1                     \n\t"
++        "pcmpgtb %%mm6, %%mm1                   \n\t"
++        "paddb %%mm1, %%mm0                     \n\t"
++
++        "movq (%%"FF_REG_a", %3, 2), %%mm1      \n\t"
++        PMAXUB(%%mm1, %%mm4)
++        PMINUB(%%mm1, %%mm3, %%mm5)
++        "psubb %%mm1, %%mm2                     \n\t"
++        "paddb %%mm7, %%mm2                     \n\t"
++        "pcmpgtb %%mm6, %%mm2                   \n\t"
++        "paddb %%mm2, %%mm0                     \n\t"
++        "psubusb %%mm3, %%mm4                   \n\t"
++
++        "                                       \n\t"
++        "pxor %%mm7, %%mm7                      \n\t"
++        "psadbw %%mm7, %%mm0                    \n\t"
++        "movq %4, %%mm7                         \n\t" // QP,..., QP
++        "paddusb %%mm7, %%mm7                   \n\t" // 2QP ... 2QP
++        "psubusb %%mm7, %%mm4                   \n\t" // Diff <= 2QP -> 0
++        "packssdw %%mm4, %%mm4                  \n\t"
++        "movd %%mm0, %0                         \n\t"
++        "movd %%mm4, %1                         \n\t"
++
++        : "=r" (numEq), "=r" (dcOk)
++        : "r" (src), "r" ((x86_reg)stride), "m" (c->pQPb)
++        : "%"FF_REG_a
++        );
++
++    numEq= (-numEq) &0xFF;
++    if(numEq > c->ppMode.flatnessThreshold){
++        if(dcOk) return 0;
++        else     return 1;
++    }else{
++        return 2;
++    }
++}
++#endif //TEMPLATE_PP_MMXEXT
++
++/**
++ * Do a vertical low pass filter on the 8x16 block (only write to the 8x8 block in the middle)
++ * using the 9-Tap Filter (1,1,2,2,4,2,2,1,1)/16
++ */
++#if !TEMPLATE_PP_ALTIVEC
++static inline void RENAME(doVertLowPass)(uint8_t *src, int stride, PPContext *c)
++{
++#if TEMPLATE_PP_MMXEXT
++    src+= stride*3;
++    __asm__ volatile(        //"movv %0 %1 %2\n\t"
++        "movq %2, %%mm0                         \n\t"  // QP,..., QP
++        "pxor %%mm4, %%mm4                      \n\t"
++
++        "movq (%0), %%mm6                       \n\t"
++        "movq (%0, %1), %%mm5                   \n\t"
++        "movq %%mm5, %%mm1                      \n\t"
++        "movq %%mm6, %%mm2                      \n\t"
++        "psubusb %%mm6, %%mm5                   \n\t"
++        "psubusb %%mm1, %%mm2                   \n\t"
++        "por %%mm5, %%mm2                       \n\t" // ABS Diff of lines
++        "psubusb %%mm0, %%mm2                   \n\t" // diff <= QP -> 0
++        "pcmpeqb %%mm4, %%mm2                   \n\t" // diff <= QP -> FF
++
++        "pand %%mm2, %%mm6                      \n\t"
++        "pandn %%mm1, %%mm2                     \n\t"
++        "por %%mm2, %%mm6                       \n\t"// First Line to Filter
++
++        "movq (%0, %1, 8), %%mm5                \n\t"
++        "lea (%0, %1, 4), %%"FF_REG_a"          \n\t"
++        "lea (%0, %1, 8), %%"FF_REG_c"          \n\t"
++        "sub %1, %%"FF_REG_c"                   \n\t"
++        "add %1, %0                             \n\t" // %0 points to line 1 not 0
++        "movq (%0, %1, 8), %%mm7                \n\t"
++        "movq %%mm5, %%mm1                      \n\t"
++        "movq %%mm7, %%mm2                      \n\t"
++        "psubusb %%mm7, %%mm5                   \n\t"
++        "psubusb %%mm1, %%mm2                   \n\t"
++        "por %%mm5, %%mm2                       \n\t" // ABS Diff of lines
++        "psubusb %%mm0, %%mm2                   \n\t" // diff <= QP -> 0
++        "pcmpeqb %%mm4, %%mm2                   \n\t" // diff <= QP -> FF
++
++        "pand %%mm2, %%mm7                      \n\t"
++        "pandn %%mm1, %%mm2                     \n\t"
++        "por %%mm2, %%mm7                       \n\t" // First Line to Filter
++
++
++        //      1       2       3       4       5       6       7       8
++        //      %0      %0+%1   %0+2%1  eax     %0+4%1  eax+2%1 ecx     eax+4%1
++        // 6 4 2 2 1 1
++        // 6 4 4 2
++        // 6 8 2
++
++        "movq (%0, %1), %%mm0                   \n\t" //  1
++        "movq %%mm0, %%mm1                      \n\t" //  1
++        PAVGB(%%mm6, %%mm0)                           //1 1        /2
++        PAVGB(%%mm6, %%mm0)                           //3 1        /4
++
++        "movq (%0, %1, 4), %%mm2                \n\t" //     1
++        "movq %%mm2, %%mm5                      \n\t" //     1
++        PAVGB((%%FF_REGa), %%mm2)                     //    11        /2
++        PAVGB((%0, %1, 2), %%mm2)                     //   211        /4
++        "movq %%mm2, %%mm3                      \n\t" //   211        /4
++        "movq (%0), %%mm4                       \n\t" // 1
++        PAVGB(%%mm4, %%mm3)                           // 4 211        /8
++        PAVGB(%%mm0, %%mm3)                           //642211        /16
++        "movq %%mm3, (%0)                       \n\t" // X
++        // mm1=2 mm2=3(211) mm4=1 mm5=5 mm6=0 mm7=9
++        "movq %%mm1, %%mm0                      \n\t" //  1
++        PAVGB(%%mm6, %%mm0)                           //1 1        /2
++        "movq %%mm4, %%mm3                      \n\t" // 1
++        PAVGB((%0,%1,2), %%mm3)                       // 1 1        /2
++        PAVGB((%%FF_REGa,%1,2), %%mm5)                //     11        /2
++        PAVGB((%%FF_REGa), %%mm5)                     //    211 /4
++        PAVGB(%%mm5, %%mm3)                           // 2 2211 /8
++        PAVGB(%%mm0, %%mm3)                           //4242211 /16
++        "movq %%mm3, (%0,%1)                    \n\t" //  X
++        // mm1=2 mm2=3(211) mm4=1 mm5=4(211) mm6=0 mm7=9
++        PAVGB(%%mm4, %%mm6)                                   //11        /2
++        "movq (%%"FF_REG_c"), %%mm0             \n\t" //       1
++        PAVGB((%%FF_REGa, %1, 2), %%mm0)              //      11/2
++        "movq %%mm0, %%mm3                      \n\t" //      11/2
++        PAVGB(%%mm1, %%mm0)                           //  2   11/4
++        PAVGB(%%mm6, %%mm0)                           //222   11/8
++        PAVGB(%%mm2, %%mm0)                           //22242211/16
++        "movq (%0, %1, 2), %%mm2                \n\t" //   1
++        "movq %%mm0, (%0, %1, 2)                \n\t" //   X
++        // mm1=2 mm2=3 mm3=6(11) mm4=1 mm5=4(211) mm6=0(11) mm7=9
++        "movq (%%"FF_REG_a", %1, 4), %%mm0      \n\t" //        1
++        PAVGB((%%FF_REGc), %%mm0)                     //       11        /2
++        PAVGB(%%mm0, %%mm6)                           //11     11        /4
++        PAVGB(%%mm1, %%mm4)                           // 11                /2
++        PAVGB(%%mm2, %%mm1)                           //  11                /2
++        PAVGB(%%mm1, %%mm6)                           //1122   11        /8
++        PAVGB(%%mm5, %%mm6)                           //112242211        /16
++        "movq (%%"FF_REG_a"), %%mm5             \n\t" //    1
++        "movq %%mm6, (%%"FF_REG_a")             \n\t" //    X
++        // mm0=7(11) mm1=2(11) mm2=3 mm3=6(11) mm4=1(11) mm5=4 mm7=9
++        "movq (%%"FF_REG_a", %1, 4), %%mm6      \n\t" //        1
++        PAVGB(%%mm7, %%mm6)                           //        11        /2
++        PAVGB(%%mm4, %%mm6)                           // 11     11        /4
++        PAVGB(%%mm3, %%mm6)                           // 11   2211        /8
++        PAVGB(%%mm5, %%mm2)                           //   11                /2
++        "movq (%0, %1, 4), %%mm4                \n\t" //     1
++        PAVGB(%%mm4, %%mm2)                           //   112                /4
++        PAVGB(%%mm2, %%mm6)                           // 112242211        /16
++        "movq %%mm6, (%0, %1, 4)                \n\t" //     X
++        // mm0=7(11) mm1=2(11) mm2=3(112) mm3=6(11) mm4=5 mm5=4 mm7=9
++        PAVGB(%%mm7, %%mm1)                           //  11     2        /4
++        PAVGB(%%mm4, %%mm5)                           //    11                /2
++        PAVGB(%%mm5, %%mm0)                           //    11 11        /4
++        "movq (%%"FF_REG_a", %1, 2), %%mm6      \n\t" //      1
++        PAVGB(%%mm6, %%mm1)                           //  11  4  2        /8
++        PAVGB(%%mm0, %%mm1)                           //  11224222        /16
++        "movq %%mm1, (%%"FF_REG_a", %1, 2)      \n\t" //      X
++        // mm2=3(112) mm3=6(11) mm4=5 mm5=4(11) mm6=6 mm7=9
++        PAVGB((%%FF_REGc), %%mm2)                     //   112 4        /8
++        "movq (%%"FF_REG_a", %1, 4), %%mm0      \n\t" //        1
++        PAVGB(%%mm0, %%mm6)                           //      1 1        /2
++        PAVGB(%%mm7, %%mm6)                           //      1 12        /4
++        PAVGB(%%mm2, %%mm6)                           //   1122424        /4
++        "movq %%mm6, (%%"FF_REG_c")             \n\t" //       X
++        // mm0=8 mm3=6(11) mm4=5 mm5=4(11) mm7=9
++        PAVGB(%%mm7, %%mm5)                           //    11   2        /4
++        PAVGB(%%mm7, %%mm5)                           //    11   6        /8
++
++        PAVGB(%%mm3, %%mm0)                           //      112        /4
++        PAVGB(%%mm0, %%mm5)                           //    112246        /16
++        "movq %%mm5, (%%"FF_REG_a", %1, 4)      \n\t" //        X
++        "sub %1, %0                             \n\t"
++
++        :
++        : "r" (src), "r" ((x86_reg)stride), "m" (c->pQPb)
++        : "%"FF_REG_a, "%"FF_REG_c
++    );
++#else //TEMPLATE_PP_MMXEXT
++    const int l1= stride;
++    const int l2= stride + l1;
++    const int l3= stride + l2;
++    const int l4= stride + l3;
++    const int l5= stride + l4;
++    const int l6= stride + l5;
++    const int l7= stride + l6;
++    const int l8= stride + l7;
++    const int l9= stride + l8;
++    int x;
++    src+= stride*3;
++    for(x=0; x<BLOCK_SIZE; x++){
++        const int first= FFABS(src[0] - src[l1]) < c->QP ? src[0] : src[l1];
++        const int last= FFABS(src[l8] - src[l9]) < c->QP ? src[l9] : src[l8];
++
++        int sums[10];
++        sums[0] = 4*first + src[l1] + src[l2] + src[l3] + 4;
++        sums[1] = sums[0] - first  + src[l4];
++        sums[2] = sums[1] - first  + src[l5];
++        sums[3] = sums[2] - first  + src[l6];
++        sums[4] = sums[3] - first  + src[l7];
++        sums[5] = sums[4] - src[l1] + src[l8];
++        sums[6] = sums[5] - src[l2] + last;
++        sums[7] = sums[6] - src[l3] + last;
++        sums[8] = sums[7] - src[l4] + last;
++        sums[9] = sums[8] - src[l5] + last;
++
++        src[l1]= (sums[0] + sums[2] + 2*src[l1])>>4;
++        src[l2]= (sums[1] + sums[3] + 2*src[l2])>>4;
++        src[l3]= (sums[2] + sums[4] + 2*src[l3])>>4;
++        src[l4]= (sums[3] + sums[5] + 2*src[l4])>>4;
++        src[l5]= (sums[4] + sums[6] + 2*src[l5])>>4;
++        src[l6]= (sums[5] + sums[7] + 2*src[l6])>>4;
++        src[l7]= (sums[6] + sums[8] + 2*src[l7])>>4;
++        src[l8]= (sums[7] + sums[9] + 2*src[l8])>>4;
++
++        src++;
++    }
++#endif //TEMPLATE_PP_MMXEXT
++}
++#endif //TEMPLATE_PP_ALTIVEC
++
++/**
++ * Experimental Filter 1
++ * will not damage linear gradients
++ * Flat blocks should look like they were passed through the (1,1,2,2,4,2,2,1,1) 9-Tap filter
++ * can only smooth blocks at the expected locations (it cannot smooth them if they did move)
++ * MMX2 version does correct clipping C version does not
++ */
++static inline void RENAME(vertX1Filter)(uint8_t *src, int stride, PPContext *co)
++{
++#if TEMPLATE_PP_MMXEXT
++    src+= stride*3;
++
++    __asm__ volatile(
++        "pxor %%mm7, %%mm7                      \n\t" // 0
++        "lea (%0, %1), %%"FF_REG_a"             \n\t"
++        "lea (%%"FF_REG_a", %1, 4), %%"FF_REG_c"\n\t"
++//      0       1       2       3       4       5       6       7       8       9
++//      %0      eax     eax+%1  eax+2%1 %0+4%1  ecx     ecx+%1  ecx+2%1 %0+8%1  ecx+4%1
++        "movq (%%"FF_REG_a", %1, 2), %%mm0      \n\t" // line 3
++        "movq (%0, %1, 4), %%mm1                \n\t" // line 4
++        "movq %%mm1, %%mm2                      \n\t" // line 4
++        "psubusb %%mm0, %%mm1                   \n\t"
++        "psubusb %%mm2, %%mm0                   \n\t"
++        "por %%mm1, %%mm0                       \n\t" // |l2 - l3|
++        "movq (%%"FF_REG_c"), %%mm3             \n\t" // line 5
++        "movq (%%"FF_REG_c", %1), %%mm4         \n\t" // line 6
++        "movq %%mm3, %%mm5                      \n\t" // line 5
++        "psubusb %%mm4, %%mm3                   \n\t"
++        "psubusb %%mm5, %%mm4                   \n\t"
++        "por %%mm4, %%mm3                       \n\t" // |l5 - l6|
++        PAVGB(%%mm3, %%mm0)                           // (|l2 - l3| + |l5 - l6|)/2
++        "movq %%mm2, %%mm1                      \n\t" // line 4
++        "psubusb %%mm5, %%mm2                   \n\t"
++        "movq %%mm2, %%mm4                      \n\t"
++        "pcmpeqb %%mm7, %%mm2                   \n\t" // (l4 - l5) <= 0 ? -1 : 0
++        "psubusb %%mm1, %%mm5                   \n\t"
++        "por %%mm5, %%mm4                       \n\t" // |l4 - l5|
++        "psubusb %%mm0, %%mm4                   \n\t" //d = MAX(0, |l4-l5| - (|l2-l3| + |l5-l6|)/2)
++        "movq %%mm4, %%mm3                      \n\t" // d
++        "movq %2, %%mm0                         \n\t"
++        "paddusb %%mm0, %%mm0                   \n\t"
++        "psubusb %%mm0, %%mm4                   \n\t"
++        "pcmpeqb %%mm7, %%mm4                   \n\t" // d <= QP ? -1 : 0
++        "psubusb "MANGLE(b01)", %%mm3           \n\t"
++        "pand %%mm4, %%mm3                      \n\t" // d <= QP ? d : 0
++
++        PAVGB(%%mm7, %%mm3)                           // d/2
++        "movq %%mm3, %%mm1                      \n\t" // d/2
++        PAVGB(%%mm7, %%mm3)                           // d/4
++        PAVGB(%%mm1, %%mm3)                           // 3*d/8
++
++        "movq (%0, %1, 4), %%mm0                \n\t" // line 4
++        "pxor %%mm2, %%mm0                      \n\t" //(l4 - l5) <= 0 ? -l4-1 : l4
++        "psubusb %%mm3, %%mm0                   \n\t"
++        "pxor %%mm2, %%mm0                      \n\t"
++        "movq %%mm0, (%0, %1, 4)                \n\t" // line 4
++
++        "movq (%%"FF_REG_c"), %%mm0             \n\t" // line 5
++        "pxor %%mm2, %%mm0                      \n\t" //(l4 - l5) <= 0 ? -l5-1 : l5
++        "paddusb %%mm3, %%mm0                   \n\t"
++        "pxor %%mm2, %%mm0                      \n\t"
++        "movq %%mm0, (%%"FF_REG_c")             \n\t" // line 5
++
++        PAVGB(%%mm7, %%mm1)                           // d/4
++
++        "movq (%%"FF_REG_a", %1, 2), %%mm0      \n\t" // line 3
++        "pxor %%mm2, %%mm0                      \n\t" //(l4 - l5) <= 0 ? -l4-1 : l4
++        "psubusb %%mm1, %%mm0                   \n\t"
++        "pxor %%mm2, %%mm0                      \n\t"
++        "movq %%mm0, (%%"FF_REG_a", %1, 2)      \n\t" // line 3
++
++        "movq (%%"FF_REG_c", %1), %%mm0         \n\t" // line 6
++        "pxor %%mm2, %%mm0                      \n\t" //(l4 - l5) <= 0 ? -l5-1 : l5
++        "paddusb %%mm1, %%mm0                   \n\t"
++        "pxor %%mm2, %%mm0                      \n\t"
++        "movq %%mm0, (%%"FF_REG_c", %1)         \n\t" // line 6
++
++        PAVGB(%%mm7, %%mm1)                           // d/8
++
++        "movq (%%"FF_REG_a", %1), %%mm0         \n\t" // line 2
++        "pxor %%mm2, %%mm0                      \n\t" //(l4 - l5) <= 0 ? -l2-1 : l2
++        "psubusb %%mm1, %%mm0                   \n\t"
++        "pxor %%mm2, %%mm0                      \n\t"
++        "movq %%mm0, (%%"FF_REG_a", %1)         \n\t" // line 2
++
++        "movq (%%"FF_REG_c", %1, 2), %%mm0      \n\t" // line 7
++        "pxor %%mm2, %%mm0                      \n\t" //(l4 - l5) <= 0 ? -l7-1 : l7
++        "paddusb %%mm1, %%mm0                   \n\t"
++        "pxor %%mm2, %%mm0                      \n\t"
++        "movq %%mm0, (%%"FF_REG_c", %1, 2)      \n\t" // line 7
++
++        :
++        : "r" (src), "r" ((x86_reg)stride), "m" (co->pQPb)
++          NAMED_CONSTRAINTS_ADD(b01)
++        : "%"FF_REG_a, "%"FF_REG_c
++    );
++#else //TEMPLATE_PP_MMXEXT
++
++    const int l1= stride;
++    const int l2= stride + l1;
++    const int l3= stride + l2;
++    const int l4= stride + l3;
++    const int l5= stride + l4;
++    const int l6= stride + l5;
++    const int l7= stride + l6;
++//    const int l8= stride + l7;
++//    const int l9= stride + l8;
++    int x;
++
++    src+= stride*3;
++    for(x=0; x<BLOCK_SIZE; x++){
++        int a= src[l3] - src[l4];
++        int b= src[l4] - src[l5];
++        int c= src[l5] - src[l6];
++
++        int d= FFABS(b) - ((FFABS(a) + FFABS(c))>>1);
++        d= FFMAX(d, 0);
++
++        if(d < co->QP*2){
++            int v = d * FFSIGN(-b);
++
++            src[l2] +=v>>3;
++            src[l3] +=v>>2;
++            src[l4] +=(3*v)>>3;
++            src[l5] -=(3*v)>>3;
++            src[l6] -=v>>2;
++            src[l7] -=v>>3;
++        }
++        src++;
++    }
++#endif //TEMPLATE_PP_MMXEXT
++}
++
++#if !TEMPLATE_PP_ALTIVEC
++static inline void RENAME(doVertDefFilter)(uint8_t src[], int stride, PPContext *c)
++{
++#if TEMPLATE_PP_MMXEXT
++/*
++    uint8_t tmp[16];
++    const int l1= stride;
++    const int l2= stride + l1;
++    const int l3= stride + l2;
++    const int l4= (int)tmp - (int)src - stride*3;
++    const int l5= (int)tmp - (int)src - stride*3 + 8;
++    const int l6= stride*3 + l3;
++    const int l7= stride + l6;
++    const int l8= stride + l7;
++
++    memcpy(tmp, src+stride*7, 8);
++    memcpy(tmp+8, src+stride*8, 8);
++*/
++    src+= stride*4;
++    __asm__ volatile(
++
++#if 0 //slightly more accurate and slightly slower
++        "pxor %%mm7, %%mm7                      \n\t" // 0
++        "lea (%0, %1), %%"FF_REG_a"             \n\t"
++        "lea (%%"FF_REG_a", %1, 4), %%"FF_REG_c"\n\t"
++//      0       1       2       3       4       5       6       7
++//      %0      %0+%1   %0+2%1  eax+2%1 %0+4%1  eax+4%1 ecx+%1  ecx+2%1
++//      %0      eax     eax+%1  eax+2%1 %0+4%1  ecx     ecx+%1  ecx+2%1
++
++
++        "movq (%0, %1, 2), %%mm0                \n\t" // l2
++        "movq (%0), %%mm1                       \n\t" // l0
++        "movq %%mm0, %%mm2                      \n\t" // l2
++        PAVGB(%%mm7, %%mm0)                           // ~l2/2
++        PAVGB(%%mm1, %%mm0)                           // ~(l2 + 2l0)/4
++        PAVGB(%%mm2, %%mm0)                           // ~(5l2 + 2l0)/8
++
++        "movq (%%"FF_REG_a"), %%mm1             \n\t" // l1
++        "movq (%%"FF_REG_a", %1, 2), %%mm3      \n\t" // l3
++        "movq %%mm1, %%mm4                      \n\t" // l1
++        PAVGB(%%mm7, %%mm1)                           // ~l1/2
++        PAVGB(%%mm3, %%mm1)                           // ~(l1 + 2l3)/4
++        PAVGB(%%mm4, %%mm1)                           // ~(5l1 + 2l3)/8
++
++        "movq %%mm0, %%mm4                      \n\t" // ~(5l2 + 2l0)/8
++        "psubusb %%mm1, %%mm0                   \n\t"
++        "psubusb %%mm4, %%mm1                   \n\t"
++        "por %%mm0, %%mm1                       \n\t" // ~|2l0 - 5l1 + 5l2 - 2l3|/8
++// mm1= |lenergy|, mm2= l2, mm3= l3, mm7=0
++
++        "movq (%0, %1, 4), %%mm0                \n\t" // l4
++        "movq %%mm0, %%mm4                      \n\t" // l4
++        PAVGB(%%mm7, %%mm0)                           // ~l4/2
++        PAVGB(%%mm2, %%mm0)                           // ~(l4 + 2l2)/4
++        PAVGB(%%mm4, %%mm0)                           // ~(5l4 + 2l2)/8
++
++        "movq (%%"FF_REG_c"), %%mm2             \n\t" // l5
++        "movq %%mm3, %%mm5                      \n\t" // l3
++        PAVGB(%%mm7, %%mm3)                           // ~l3/2
++        PAVGB(%%mm2, %%mm3)                           // ~(l3 + 2l5)/4
++        PAVGB(%%mm5, %%mm3)                           // ~(5l3 + 2l5)/8
++
++        "movq %%mm0, %%mm6                      \n\t" // ~(5l4 + 2l2)/8
++        "psubusb %%mm3, %%mm0                   \n\t"
++        "psubusb %%mm6, %%mm3                   \n\t"
++        "por %%mm0, %%mm3                       \n\t" // ~|2l2 - 5l3 + 5l4 - 2l5|/8
++        "pcmpeqb %%mm7, %%mm0                   \n\t" // SIGN(2l2 - 5l3 + 5l4 - 2l5)
++// mm0= SIGN(menergy), mm1= |lenergy|, mm2= l5, mm3= |menergy|, mm4=l4, mm5= l3, mm7=0
++
++        "movq (%%"FF_REG_c", %1), %%mm6         \n\t" // l6
++        "movq %%mm6, %%mm5                      \n\t" // l6
++        PAVGB(%%mm7, %%mm6)                           // ~l6/2
++        PAVGB(%%mm4, %%mm6)                           // ~(l6 + 2l4)/4
++        PAVGB(%%mm5, %%mm6)                           // ~(5l6 + 2l4)/8
++
++        "movq (%%"FF_REG_c", %1, 2), %%mm5      \n\t" // l7
++        "movq %%mm2, %%mm4                      \n\t" // l5
++        PAVGB(%%mm7, %%mm2)                           // ~l5/2
++        PAVGB(%%mm5, %%mm2)                           // ~(l5 + 2l7)/4
++        PAVGB(%%mm4, %%mm2)                           // ~(5l5 + 2l7)/8
++
++        "movq %%mm6, %%mm4                      \n\t" // ~(5l6 + 2l4)/8
++        "psubusb %%mm2, %%mm6                   \n\t"
++        "psubusb %%mm4, %%mm2                   \n\t"
++        "por %%mm6, %%mm2                       \n\t" // ~|2l4 - 5l5 + 5l6 - 2l7|/8
++// mm0= SIGN(menergy), mm1= |lenergy|/8, mm2= |renergy|/8, mm3= |menergy|/8, mm7=0
++
++
++        PMINUB(%%mm2, %%mm1, %%mm4)                   // MIN(|lenergy|,|renergy|)/8
++        "movq %2, %%mm4                         \n\t" // QP //FIXME QP+1 ?
++        "paddusb "MANGLE(b01)", %%mm4           \n\t"
++        "pcmpgtb %%mm3, %%mm4                   \n\t" // |menergy|/8 < QP
++        "psubusb %%mm1, %%mm3                   \n\t" // d=|menergy|/8-MIN(|lenergy|,|renergy|)/8
++        "pand %%mm4, %%mm3                      \n\t"
++
++        "movq %%mm3, %%mm1                      \n\t"
++//        "psubusb "MANGLE(b01)", %%mm3           \n\t"
++        PAVGB(%%mm7, %%mm3)
++        PAVGB(%%mm7, %%mm3)
++        "paddusb %%mm1, %%mm3                   \n\t"
++//        "paddusb "MANGLE(b01)", %%mm3           \n\t"
++
++        "movq (%%"FF_REG_a", %1, 2), %%mm6      \n\t" //l3
++        "movq (%0, %1, 4), %%mm5                \n\t" //l4
++        "movq (%0, %1, 4), %%mm4                \n\t" //l4
++        "psubusb %%mm6, %%mm5                   \n\t"
++        "psubusb %%mm4, %%mm6                   \n\t"
++        "por %%mm6, %%mm5                       \n\t" // |l3-l4|
++        "pcmpeqb %%mm7, %%mm6                   \n\t" // SIGN(l3-l4)
++        "pxor %%mm6, %%mm0                      \n\t"
++        "pand %%mm0, %%mm3                      \n\t"
++        PMINUB(%%mm5, %%mm3, %%mm0)
++
++        "psubusb "MANGLE(b01)", %%mm3           \n\t"
++        PAVGB(%%mm7, %%mm3)
++
++        "movq (%%"FF_REG_a", %1, 2), %%mm0      \n\t"
++        "movq (%0, %1, 4), %%mm2                \n\t"
++        "pxor %%mm6, %%mm0                      \n\t"
++        "pxor %%mm6, %%mm2                      \n\t"
++        "psubb %%mm3, %%mm0                     \n\t"
++        "paddb %%mm3, %%mm2                     \n\t"
++        "pxor %%mm6, %%mm0                      \n\t"
++        "pxor %%mm6, %%mm2                      \n\t"
++        "movq %%mm0, (%%"FF_REG_a", %1, 2)      \n\t"
++        "movq %%mm2, (%0, %1, 4)                \n\t"
++#endif //0
++
++        "lea (%0, %1), %%"FF_REG_a"             \n\t"
++        "pcmpeqb %%mm6, %%mm6                   \n\t" // -1
++//      0       1       2       3       4       5       6       7
++//      %0      %0+%1   %0+2%1  eax+2%1 %0+4%1  eax+4%1 ecx+%1  ecx+2%1
++//      %0      eax     eax+%1  eax+2%1 %0+4%1  ecx     ecx+%1  ecx+2%1
++
++
++        "movq (%%"FF_REG_a", %1, 2), %%mm1      \n\t" // l3
++        "movq (%0, %1, 4), %%mm0                \n\t" // l4
++        "pxor %%mm6, %%mm1                      \n\t" // -l3-1
++        PAVGB(%%mm1, %%mm0)                           // -q+128 = (l4-l3+256)/2
++// mm1=-l3-1, mm0=128-q
++
++        "movq (%%"FF_REG_a", %1, 4), %%mm2      \n\t" // l5
++        "movq (%%"FF_REG_a", %1), %%mm3         \n\t" // l2
++        "pxor %%mm6, %%mm2                      \n\t" // -l5-1
++        "movq %%mm2, %%mm5                      \n\t" // -l5-1
++        "movq "MANGLE(b80)", %%mm4              \n\t" // 128
++        "lea (%%"FF_REG_a", %1, 4), %%"FF_REG_c"\n\t"
++        PAVGB(%%mm3, %%mm2)                           // (l2-l5+256)/2
++        PAVGB(%%mm0, %%mm4)                           // ~(l4-l3)/4 + 128
++        PAVGB(%%mm2, %%mm4)                           // ~(l2-l5)/4 +(l4-l3)/8 + 128
++        PAVGB(%%mm0, %%mm4)                           // ~(l2-l5)/8 +5(l4-l3)/16 + 128
++// mm1=-l3-1, mm0=128-q, mm3=l2, mm4=menergy/16 + 128, mm5= -l5-1
++
++        "movq (%%"FF_REG_a"), %%mm2             \n\t" // l1
++        "pxor %%mm6, %%mm2                      \n\t" // -l1-1
++        PAVGB(%%mm3, %%mm2)                           // (l2-l1+256)/2
++        PAVGB((%0), %%mm1)                            // (l0-l3+256)/2
++        "movq "MANGLE(b80)", %%mm3              \n\t" // 128
++        PAVGB(%%mm2, %%mm3)                           // ~(l2-l1)/4 + 128
++        PAVGB(%%mm1, %%mm3)                           // ~(l0-l3)/4 +(l2-l1)/8 + 128
++        PAVGB(%%mm2, %%mm3)                           // ~(l0-l3)/8 +5(l2-l1)/16 + 128
++// mm0=128-q, mm3=lenergy/16 + 128, mm4= menergy/16 + 128, mm5= -l5-1
++
++        PAVGB((%%FF_REGc, %1), %%mm5)                 // (l6-l5+256)/2
++        "movq (%%"FF_REG_c", %1, 2), %%mm1      \n\t" // l7
++        "pxor %%mm6, %%mm1                      \n\t" // -l7-1
++        PAVGB((%0, %1, 4), %%mm1)                     // (l4-l7+256)/2
++        "movq "MANGLE(b80)", %%mm2              \n\t" // 128
++        PAVGB(%%mm5, %%mm2)                           // ~(l6-l5)/4 + 128
++        PAVGB(%%mm1, %%mm2)                           // ~(l4-l7)/4 +(l6-l5)/8 + 128
++        PAVGB(%%mm5, %%mm2)                           // ~(l4-l7)/8 +5(l6-l5)/16 + 128
++// mm0=128-q, mm2=renergy/16 + 128, mm3=lenergy/16 + 128, mm4= menergy/16 + 128
++
++        "movq "MANGLE(b00)", %%mm1              \n\t" // 0
++        "movq "MANGLE(b00)", %%mm5              \n\t" // 0
++        "psubb %%mm2, %%mm1                     \n\t" // 128 - renergy/16
++        "psubb %%mm3, %%mm5                     \n\t" // 128 - lenergy/16
++        PMAXUB(%%mm1, %%mm2)                          // 128 + |renergy/16|
++        PMAXUB(%%mm5, %%mm3)                          // 128 + |lenergy/16|
++        PMINUB(%%mm2, %%mm3, %%mm1)                   // 128 + MIN(|lenergy|,|renergy|)/16
++
++// mm0=128-q, mm3=128 + MIN(|lenergy|,|renergy|)/16, mm4= menergy/16 + 128
++
++        "movq "MANGLE(b00)", %%mm7              \n\t" // 0
++        "movq %2, %%mm2                         \n\t" // QP
++        PAVGB(%%mm6, %%mm2)                           // 128 + QP/2
++        "psubb %%mm6, %%mm2                     \n\t"
++
++        "movq %%mm4, %%mm1                      \n\t"
++        "pcmpgtb %%mm7, %%mm1                   \n\t" // SIGN(menergy)
++        "pxor %%mm1, %%mm4                      \n\t"
++        "psubb %%mm1, %%mm4                     \n\t" // 128 + |menergy|/16
++        "pcmpgtb %%mm4, %%mm2                   \n\t" // |menergy|/16 < QP/2
++        "psubusb %%mm3, %%mm4                   \n\t" //d=|menergy|/16 - MIN(|lenergy|,|renergy|)/16
++// mm0=128-q, mm1= SIGN(menergy), mm2= |menergy|/16 < QP/2, mm4= d/16
++
++        "movq %%mm4, %%mm3                      \n\t" // d
++        "psubusb "MANGLE(b01)", %%mm4           \n\t"
++        PAVGB(%%mm7, %%mm4)                           // d/32
++        PAVGB(%%mm7, %%mm4)                           // (d + 32)/64
++        "paddb %%mm3, %%mm4                     \n\t" // 5d/64
++        "pand %%mm2, %%mm4                      \n\t"
++
++        "movq "MANGLE(b80)", %%mm5              \n\t" // 128
++        "psubb %%mm0, %%mm5                     \n\t" // q
++        "paddsb %%mm6, %%mm5                    \n\t" // fix bad rounding
++        "pcmpgtb %%mm5, %%mm7                   \n\t" // SIGN(q)
++        "pxor %%mm7, %%mm5                      \n\t"
++
++        PMINUB(%%mm5, %%mm4, %%mm3)                   // MIN(|q|, 5d/64)
++        "pxor %%mm1, %%mm7                      \n\t" // SIGN(d*q)
++
++        "pand %%mm7, %%mm4                      \n\t"
++        "movq (%%"FF_REG_a", %1, 2), %%mm0      \n\t"
++        "movq (%0, %1, 4), %%mm2                \n\t"
++        "pxor %%mm1, %%mm0                      \n\t"
++        "pxor %%mm1, %%mm2                      \n\t"
++        "paddb %%mm4, %%mm0                     \n\t"
++        "psubb %%mm4, %%mm2                     \n\t"
++        "pxor %%mm1, %%mm0                      \n\t"
++        "pxor %%mm1, %%mm2                      \n\t"
++        "movq %%mm0, (%%"FF_REG_a", %1, 2)      \n\t"
++        "movq %%mm2, (%0, %1, 4)                \n\t"
++
++        :
++        : "r" (src), "r" ((x86_reg)stride), "m" (c->pQPb)
++          NAMED_CONSTRAINTS_ADD(b80,b00,b01)
++        : "%"FF_REG_a, "%"FF_REG_c
++    );
++
++/*
++    {
++    int x;
++    src-= stride;
++    for(x=0; x<BLOCK_SIZE; x++){
++        const int middleEnergy= 5*(src[l5] - src[l4]) + 2*(src[l3] - src[l6]);
++        if(FFABS(middleEnergy)< 8*QP){
++            const int q=(src[l4] - src[l5])/2;
++            const int leftEnergy=  5*(src[l3] - src[l2]) + 2*(src[l1] - src[l4]);
++            const int rightEnergy= 5*(src[l7] - src[l6]) + 2*(src[l5] - src[l8]);
++
++            int d= FFABS(middleEnergy) - FFMIN( FFABS(leftEnergy), FFABS(rightEnergy) );
++            d= FFMAX(d, 0);
++
++            d= (5*d + 32) >> 6;
++            d*= FFSIGN(-middleEnergy);
++
++            if(q>0){
++                d= d<0 ? 0 : d;
++                d= d>q ? q : d;
++            }else{
++                d= d>0 ? 0 : d;
++                d= d<q ? q : d;
++            }
++
++            src[l4]-= d;
++            src[l5]+= d;
++        }
++        src++;
++    }
++    src-=8;
++    for(x=0; x<8; x++){
++        int y;
++        for(y=4; y<6; y++){
++            int d= src[x+y*stride] - tmp[x+(y-4)*8];
++            int ad= FFABS(d);
++            static int max=0;
++            static int sum=0;
++            static int num=0;
++            static int bias=0;
++
++            if(max<ad) max=ad;
++            sum+= ad>3 ? 1 : 0;
++            if(ad>3){
++                src[0] = src[7] = src[stride*7] = src[(stride+1)*7]=255;
++            }
++            if(y==4) bias+=d;
++            num++;
++            if(num%1000000 == 0){
++                av_log(c, AV_LOG_INFO, " %d %d %d %d\n", num, sum, max, bias);
++            }
++        }
++    }
++}
++*/
++#else //TEMPLATE_PP_MMXEXT
++    const int l1= stride;
++    const int l2= stride + l1;
++    const int l3= stride + l2;
++    const int l4= stride + l3;
++    const int l5= stride + l4;
++    const int l6= stride + l5;
++    const int l7= stride + l6;
++    const int l8= stride + l7;
++//    const int l9= stride + l8;
++    int x;
++    src+= stride*3;
++    for(x=0; x<BLOCK_SIZE; x++){
++        const int middleEnergy= 5*(src[l5] - src[l4]) + 2*(src[l3] - src[l6]);
++        if(FFABS(middleEnergy) < 8*c->QP){
++            const int q=(src[l4] - src[l5])/2;
++            const int leftEnergy=  5*(src[l3] - src[l2]) + 2*(src[l1] - src[l4]);
++            const int rightEnergy= 5*(src[l7] - src[l6]) + 2*(src[l5] - src[l8]);
++
++            int d= FFABS(middleEnergy) - FFMIN( FFABS(leftEnergy), FFABS(rightEnergy) );
++            d= FFMAX(d, 0);
++
++            d= (5*d + 32) >> 6;
++            d*= FFSIGN(-middleEnergy);
++
++            if(q>0){
++                d = FFMAX(d, 0);
++                d = FFMIN(d, q);
++            }else{
++                d = FFMIN(d, 0);
++                d = FFMAX(d, q);
++            }
++
++            src[l4]-= d;
++            src[l5]+= d;
++        }
++        src++;
++    }
++#endif //TEMPLATE_PP_MMXEXT
++}
++#endif //TEMPLATE_PP_ALTIVEC
++
++#if !TEMPLATE_PP_ALTIVEC
++static inline void RENAME(dering)(uint8_t src[], int stride, PPContext *c, int leftborder, int rightborder, int topborder)
++{
++#if TEMPLATE_PP_MMXEXT && HAVE_7REGS
++    if (topborder)
++        return;
++    DECLARE_ALIGNED(8, uint64_t, tmp)[3];
++    __asm__ volatile(
++        "pxor %%mm6, %%mm6                      \n\t"
++        "pcmpeqb %%mm7, %%mm7                   \n\t"
++        "movq %2, %%mm0                         \n\t"
++        "punpcklbw %%mm6, %%mm0                 \n\t"
++        "psrlw $1, %%mm0                        \n\t"
++        "psubw %%mm7, %%mm0                     \n\t"
++        "packuswb %%mm0, %%mm0                  \n\t"
++        "movq %%mm0, %3                         \n\t"
++
++        "lea (%0, %1), %%"FF_REG_a"             \n\t"
++        "lea (%%"FF_REG_a", %1, 4), %%"FF_REG_d"\n\t"
++
++//        0        1        2        3        4        5        6        7        8        9
++//        %0        eax        eax+%1        eax+2%1        %0+4%1        edx        edx+%1        edx+2%1        %0+8%1        edx+4%1
++
++#undef REAL_FIND_MIN_MAX
++#undef FIND_MIN_MAX
++#define REAL_FIND_MIN_MAX(addr)\
++        "movq " #addr ", %%mm0                  \n\t"\
++        "pminub %%mm0, %%mm7                    \n\t"\
++        "pmaxub %%mm0, %%mm6                    \n\t"
++#define FIND_MIN_MAX(addr)  REAL_FIND_MIN_MAX(addr)
++
++FIND_MIN_MAX((%%FF_REGa))
++FIND_MIN_MAX((%%FF_REGa, %1))
++FIND_MIN_MAX((%%FF_REGa, %1, 2))
++FIND_MIN_MAX((%0, %1, 4))
++FIND_MIN_MAX((%%FF_REGd))
++FIND_MIN_MAX((%%FF_REGd, %1))
++FIND_MIN_MAX((%%FF_REGd, %1, 2))
++FIND_MIN_MAX((%0, %1, 8))
++
++        "movq %%mm7, %%mm4                      \n\t"
++        "psrlq $8, %%mm7                        \n\t"
++        "pminub %%mm4, %%mm7                    \n\t" // min of pixels
++        "pshufw $0xF9, %%mm7, %%mm4             \n\t"
++        "pminub %%mm4, %%mm7                    \n\t" // min of pixels
++        "pshufw $0xFE, %%mm7, %%mm4             \n\t"
++        "pminub %%mm4, %%mm7                    \n\t"
++
++
++        "movq %%mm6, %%mm4                      \n\t"
++        "psrlq $8, %%mm6                        \n\t"
++        "pmaxub %%mm4, %%mm6                    \n\t" // max of pixels
++        "pshufw $0xF9, %%mm6, %%mm4             \n\t"
++        "pmaxub %%mm4, %%mm6                    \n\t"
++        "pshufw $0xFE, %%mm6, %%mm4             \n\t"
++        "pmaxub %%mm4, %%mm6                    \n\t"
++        "movq %%mm6, %%mm0                      \n\t" // max
++        "psubb %%mm7, %%mm6                     \n\t" // max - min
++        "push %%"FF_REG_a"                      \n\t"
++        "movd %%mm6, %%eax                      \n\t"
++        "cmpb $"AV_STRINGIFY(DERING_THRESHOLD)", %%al   \n\t"
++        "pop %%"FF_REG_a"                       \n\t"
++        " jb 1f                                 \n\t"
++        PAVGB(%%mm0, %%mm7)                           // a=(max + min)/2
++        "punpcklbw %%mm7, %%mm7                 \n\t"
++        "punpcklbw %%mm7, %%mm7                 \n\t"
++        "punpcklbw %%mm7, %%mm7                 \n\t"
++        "movq %%mm7, (%4)                       \n\t"
++
++        "movq (%0), %%mm0                       \n\t" // L10
++        "movq %%mm0, %%mm1                      \n\t" // L10
++        "movq %%mm0, %%mm2                      \n\t" // L10
++        "psllq $8, %%mm1                        \n\t"
++        "psrlq $8, %%mm2                        \n\t"
++        "movd -4(%0), %%mm3                     \n\t"
++        "movd 8(%0), %%mm4                      \n\t"
++        "psrlq $24, %%mm3                       \n\t"
++        "psllq $56, %%mm4                       \n\t"
++        "por %%mm3, %%mm1                       \n\t" // L00
++        "por %%mm4, %%mm2                       \n\t" // L20
++        "movq %%mm1, %%mm3                      \n\t" // L00
++        PAVGB(%%mm2, %%mm1)                           // (L20 + L00)/2
++        PAVGB(%%mm0, %%mm1)                           // (L20 + L00 + 2L10)/4
++        "psubusb %%mm7, %%mm0                   \n\t"
++        "psubusb %%mm7, %%mm2                   \n\t"
++        "psubusb %%mm7, %%mm3                   \n\t"
++        "pcmpeqb "MANGLE(b00)", %%mm0           \n\t" // L10 > a ? 0 : -1
++        "pcmpeqb "MANGLE(b00)", %%mm2           \n\t" // L20 > a ? 0 : -1
++        "pcmpeqb "MANGLE(b00)", %%mm3           \n\t" // L00 > a ? 0 : -1
++        "paddb %%mm2, %%mm0                     \n\t"
++        "paddb %%mm3, %%mm0                     \n\t"
++
++        "movq (%%"FF_REG_a"), %%mm2             \n\t" // L11
++        "movq %%mm2, %%mm3                      \n\t" // L11
++        "movq %%mm2, %%mm4                      \n\t" // L11
++        "psllq $8, %%mm3                        \n\t"
++        "psrlq $8, %%mm4                        \n\t"
++        "movd -4(%%"FF_REG_a"), %%mm5           \n\t"
++        "movd 8(%%"FF_REG_a"), %%mm6            \n\t"
++        "psrlq $24, %%mm5                       \n\t"
++        "psllq $56, %%mm6                       \n\t"
++        "por %%mm5, %%mm3                       \n\t" // L01
++        "por %%mm6, %%mm4                       \n\t" // L21
++        "movq %%mm3, %%mm5                      \n\t" // L01
++        PAVGB(%%mm4, %%mm3)                           // (L21 + L01)/2
++        PAVGB(%%mm2, %%mm3)                           // (L21 + L01 + 2L11)/4
++        "psubusb %%mm7, %%mm2                   \n\t"
++        "psubusb %%mm7, %%mm4                   \n\t"
++        "psubusb %%mm7, %%mm5                   \n\t"
++        "pcmpeqb "MANGLE(b00)", %%mm2           \n\t" // L11 > a ? 0 : -1
++        "pcmpeqb "MANGLE(b00)", %%mm4           \n\t" // L21 > a ? 0 : -1
++        "pcmpeqb "MANGLE(b00)", %%mm5           \n\t" // L01 > a ? 0 : -1
++        "paddb %%mm4, %%mm2                     \n\t"
++        "paddb %%mm5, %%mm2                     \n\t"
++// 0, 2, 3, 1
++#define REAL_DERING_CORE(dst,src,ppsx,psx,sx,pplx,plx,lx,t0,t1) \
++        "movq " #src ", " #sx "                 \n\t" /* src[0] */\
++        "movq " #sx ", " #lx "                  \n\t" /* src[0] */\
++        "movq " #sx ", " #t0 "                  \n\t" /* src[0] */\
++        "psllq $8, " #lx "                      \n\t"\
++        "psrlq $8, " #t0 "                      \n\t"\
++        "movd -4" #src ", " #t1 "               \n\t"\
++        "psrlq $24, " #t1 "                     \n\t"\
++        "por " #t1 ", " #lx "                   \n\t" /* src[-1] */\
++        "movd 8" #src ", " #t1 "                \n\t"\
++        "psllq $56, " #t1 "                     \n\t"\
++        "por " #t1 ", " #t0 "                   \n\t" /* src[+1] */\
++        "movq " #lx ", " #t1 "                  \n\t" /* src[-1] */\
++        PAVGB(t0, lx)                                 /* (src[-1] + src[+1])/2 */\
++        PAVGB(sx, lx)                                 /* (src[-1] + 2src[0] + src[+1])/4 */\
++        PAVGB(lx, pplx)                                     \
++        "movq " #lx ", 8(%4)                    \n\t"\
++        "movq (%4), " #lx "                     \n\t"\
++        "psubusb " #lx ", " #t1 "               \n\t"\
++        "psubusb " #lx ", " #t0 "               \n\t"\
++        "psubusb " #lx ", " #sx "               \n\t"\
++        "movq "MANGLE(b00)", " #lx "            \n\t"\
++        "pcmpeqb " #lx ", " #t1 "               \n\t" /* src[-1] > a ? 0 : -1*/\
++        "pcmpeqb " #lx ", " #t0 "               \n\t" /* src[+1] > a ? 0 : -1*/\
++        "pcmpeqb " #lx ", " #sx "               \n\t" /* src[0]  > a ? 0 : -1*/\
++        "paddb " #t1 ", " #t0 "                 \n\t"\
++        "paddb " #t0 ", " #sx "                 \n\t"\
++\
++        PAVGB(plx, pplx)                              /* filtered */\
++        "movq " #dst ", " #t0 "                 \n\t" /* dst */\
++        "movq " #t0 ", " #t1 "                  \n\t" /* dst */\
++        "psubusb %3, " #t0 "                    \n\t"\
++        "paddusb %3, " #t1 "                    \n\t"\
++        PMAXUB(t0, pplx)\
++        PMINUB(t1, pplx, t0)\
++        "paddb " #sx ", " #ppsx "               \n\t"\
++        "paddb " #psx ", " #ppsx "              \n\t"\
++        "pand "MANGLE(b08)", " #ppsx "          \n\t"\
++        "pcmpeqb " #lx ", " #ppsx "             \n\t"\
++        "pand " #ppsx ", " #pplx "              \n\t"\
++        "pandn " #dst ", " #ppsx "              \n\t"\
++        "por " #pplx ", " #ppsx "               \n\t"\
++        "movq " #ppsx ", " #dst "               \n\t"\
++        "movq 8(%4), " #lx "                    \n\t"
++
++#define DERING_CORE(dst,src,ppsx,psx,sx,pplx,plx,lx,t0,t1) \
++   REAL_DERING_CORE(dst,src,ppsx,psx,sx,pplx,plx,lx,t0,t1)
++/*
++0000000
++1111111
++
++1111110
++1111101
++1111100
++1111011
++1111010
++1111001
++
++1111000
++1110111
++
++*/
++//DERING_CORE(dst             ,src               ,ppsx ,psx  ,sx   ,pplx ,plx  ,lx   ,t0   ,t1)
++DERING_CORE((%%FF_REGa)       ,(%%FF_REGa, %1)   ,%%mm0,%%mm2,%%mm4,%%mm1,%%mm3,%%mm5,%%mm6,%%mm7)
++DERING_CORE((%%FF_REGa, %1)   ,(%%FF_REGa, %1, 2),%%mm2,%%mm4,%%mm0,%%mm3,%%mm5,%%mm1,%%mm6,%%mm7)
++DERING_CORE((%%FF_REGa, %1, 2),(%0, %1, 4)       ,%%mm4,%%mm0,%%mm2,%%mm5,%%mm1,%%mm3,%%mm6,%%mm7)
++DERING_CORE((%0, %1, 4)       ,(%%FF_REGd)       ,%%mm0,%%mm2,%%mm4,%%mm1,%%mm3,%%mm5,%%mm6,%%mm7)
++DERING_CORE((%%FF_REGd)       ,(%%FF_REGd, %1)   ,%%mm2,%%mm4,%%mm0,%%mm3,%%mm5,%%mm1,%%mm6,%%mm7)
++DERING_CORE((%%FF_REGd, %1)   ,(%%FF_REGd, %1, 2),%%mm4,%%mm0,%%mm2,%%mm5,%%mm1,%%mm3,%%mm6,%%mm7)
++DERING_CORE((%%FF_REGd, %1, 2),(%0, %1, 8)       ,%%mm0,%%mm2,%%mm4,%%mm1,%%mm3,%%mm5,%%mm6,%%mm7)
++DERING_CORE((%0, %1, 8)       ,(%%FF_REGd, %1, 4),%%mm2,%%mm4,%%mm0,%%mm3,%%mm5,%%mm1,%%mm6,%%mm7)
++
++        "1:                        \n\t"
++        : : "r" (src), "r" ((x86_reg)stride), "m" (c->pQPb), "m"(c->pQPb2), "q"(tmp)
++          NAMED_CONSTRAINTS_ADD(b00,b08)
++        : "%"FF_REG_a, "%"FF_REG_d
++    );
++#else // HAVE_7REGS && TEMPLATE_PP_MMXEXT
++    int y;
++    int min=255;
++    int max=0;
++    int avg;
++    uint8_t *p;
++    int s[10];
++    const int QP2= c->QP/2 + 1;
++
++    src --;
++    for(y=1; y<9; y++){
++        int x;
++        p= src + stride*y;
++        for(x=1; x<9; x++){
++            p++;
++            if(*p > max) max= *p;
++            if(*p < min) min= *p;
++        }
++    }
++    avg= (min + max + 1)>>1;
++
++    if (max - min < DERING_THRESHOLD) return;
++
++    s[0] = 0;
++    for(y=topborder; y<10; y++){
++        int t = 0;
++
++        if(!leftborder && src[stride*y + 0] > avg) t+= 1;
++        if(src[stride*y + 1] > avg) t+= 2;
++        if(src[stride*y + 2] > avg) t+= 4;
++        if(src[stride*y + 3] > avg) t+= 8;
++        if(src[stride*y + 4] > avg) t+= 16;
++        if(src[stride*y + 5] > avg) t+= 32;
++        if(src[stride*y + 6] > avg) t+= 64;
++        if(src[stride*y + 7] > avg) t+= 128;
++        if(src[stride*y + 8] > avg) t+= 256;
++        if(!rightborder && src[stride*y + 9] > avg) t+= 512;
++
++        t |= (~t)<<16;
++        t &= (t<<1) & (t>>1);
++        s[y] = t;
++    }
++
++    for(y=1; y<9; y++){
++        int t = s[y-1] & s[y] & s[y+1];
++        t|= t>>16;
++        s[y-1]= t;
++    }
++
++    for(y=1; y<9; y++){
++        int x;
++        int t = s[y-1];
++
++        p= src + stride*y + leftborder;
++        for(x=1+leftborder; x<9-rightborder; x++){
++            p++;
++            if(t & (1<<x)){
++                int f= (*(p-stride-1)) + 2*(*(p-stride)) + (*(p-stride+1))
++                      +2*(*(p     -1)) + 4*(*p         ) + 2*(*(p     +1))
++                      +(*(p+stride-1)) + 2*(*(p+stride)) + (*(p+stride+1));
++                f= (f + 8)>>4;
++
++#ifdef DEBUG_DERING_THRESHOLD
++                    __asm__ volatile("emms\n\t":);
++                    {
++                    static uint64_t numPixels=0;
++                    if(x!=1 && x!=8 && y!=1 && y!=8) numPixels++;
++//                    if((max-min)<20 || (max-min)*QP<200)
++//                    if((max-min)*QP < 500)
++//                    if(max-min<QP/2)
++                    if(max-min < 20){
++                        static int numSkipped=0;
++                        static int errorSum=0;
++                        static int worstQP=0;
++                        static int worstRange=0;
++                        static int worstDiff=0;
++                        int diff= (f - *p);
++                        int absDiff= FFABS(diff);
++                        int error= diff*diff;
++
++                        if(x==1 || x==8 || y==1 || y==8) continue;
++
++                        numSkipped++;
++                        if(absDiff > worstDiff){
++                            worstDiff= absDiff;
++                            worstQP= QP;
++                            worstRange= max-min;
++                        }
++                        errorSum+= error;
++
++                        if(1024LL*1024LL*1024LL % numSkipped == 0){
++                            av_log(c, AV_LOG_INFO, "sum:%1.3f, skip:%d, wQP:%d, "
++                                   "wRange:%d, wDiff:%d, relSkip:%1.3f\n",
++                                   (float)errorSum/numSkipped, numSkipped, worstQP, worstRange,
++                                   worstDiff, (float)numSkipped/numPixels);
++                        }
++                    }
++                    }
++#endif
++                    if     (*p + QP2 < f) *p= *p + QP2;
++                    else if(*p - QP2 > f) *p= *p - QP2;
++                    else *p=f;
++            }
++        }
++    }
++#ifdef DEBUG_DERING_THRESHOLD
++    if(max-min < 20){
++        for(y=1; y<9; y++){
++            int x;
++            int t = 0;
++            p= src + stride*y;
++            for(x=1; x<9; x++){
++                p++;
++                *p = FFMIN(*p + 20, 255);
++            }
++        }
++//        src[0] = src[7]=src[stride*7]=src[stride*7 + 7]=255;
++    }
++#endif
++#endif //TEMPLATE_PP_MMXEXT
++}
++#endif //TEMPLATE_PP_ALTIVEC
++
++/**
++ * Deinterlace the given block by linearly interpolating every second line.
++ * will be called for every 8x8 block and can read & write from line 4-15
++ * lines 0-3 have been passed through the deblock / dering filters already, but can be read, too.
++ * lines 4-12 will be read into the deblocking filter and should be deinterlaced
++ */
++static inline void RENAME(deInterlaceInterpolateLinear)(uint8_t src[], int stride)
++{
++#if TEMPLATE_PP_MMXEXT
++    src+= 4*stride;
++    __asm__ volatile(
++        "lea (%0, %1), %%"FF_REG_a"             \n\t"
++        "lea (%%"FF_REG_a", %1, 4), %%"FF_REG_c"\n\t"
++//      0       1       2       3       4       5       6       7       8       9
++//      %0      eax     eax+%1  eax+2%1 %0+4%1  ecx     ecx+%1  ecx+2%1 %0+8%1  ecx+4%1
++
++        "movq (%0), %%mm0                       \n\t"
++        "movq (%%"FF_REG_a", %1), %%mm1         \n\t"
++        PAVGB(%%mm1, %%mm0)
++        "movq %%mm0, (%%"FF_REG_a")             \n\t"
++        "movq (%0, %1, 4), %%mm0                \n\t"
++        PAVGB(%%mm0, %%mm1)
++        "movq %%mm1, (%%"FF_REG_a", %1, 2)      \n\t"
++        "movq (%%"FF_REG_c", %1), %%mm1         \n\t"
++        PAVGB(%%mm1, %%mm0)
++        "movq %%mm0, (%%"FF_REG_c")             \n\t"
++        "movq (%0, %1, 8), %%mm0                \n\t"
++        PAVGB(%%mm0, %%mm1)
++        "movq %%mm1, (%%"FF_REG_c", %1, 2)      \n\t"
++
++        : : "r" (src), "r" ((x86_reg)stride)
++        : "%"FF_REG_a, "%"FF_REG_c
++    );
++#else
++    int a, b, x;
++    src+= 4*stride;
++
++    for(x=0; x<2; x++){
++        a= *(uint32_t*)&src[stride*0];
++        b= *(uint32_t*)&src[stride*2];
++        *(uint32_t*)&src[stride*1]= (a|b) - (((a^b)&0xFEFEFEFEUL)>>1);
++        a= *(uint32_t*)&src[stride*4];
++        *(uint32_t*)&src[stride*3]= (a|b) - (((a^b)&0xFEFEFEFEUL)>>1);
++        b= *(uint32_t*)&src[stride*6];
++        *(uint32_t*)&src[stride*5]= (a|b) - (((a^b)&0xFEFEFEFEUL)>>1);
++        a= *(uint32_t*)&src[stride*8];
++        *(uint32_t*)&src[stride*7]= (a|b) - (((a^b)&0xFEFEFEFEUL)>>1);
++        src += 4;
++    }
++#endif
++}
++
++/**
++ * Deinterlace the given block by cubic interpolating every second line.
++ * will be called for every 8x8 block and can read & write from line 4-15
++ * lines 0-3 have been passed through the deblock / dering filters already, but can be read, too.
++ * lines 4-12 will be read into the deblocking filter and should be deinterlaced
++ * this filter will read lines 3-15 and write 7-13
++ */
++static inline void RENAME(deInterlaceInterpolateCubic)(uint8_t src[], int stride)
++{
++#if TEMPLATE_PP_SSE2
++    src+= stride*3;
++    __asm__ volatile(
++        "lea (%0, %1), %%"FF_REG_a"             \n\t"
++        "lea (%%"FF_REG_a", %1, 4), %%"FF_REG_d"\n\t"
++        "lea (%%"FF_REG_d", %1, 4), %%"FF_REG_c"\n\t"
++        "add %1, %%"FF_REG_c"                   \n\t"
++        "pxor %%xmm7, %%xmm7                    \n\t"
++#define REAL_DEINT_CUBIC(a,b,c,d,e)\
++        "movq " #a ", %%xmm0                    \n\t"\
++        "movq " #b ", %%xmm1                    \n\t"\
++        "movq " #d ", %%xmm2                    \n\t"\
++        "movq " #e ", %%xmm3                    \n\t"\
++        "pavgb %%xmm2, %%xmm1                   \n\t"\
++        "pavgb %%xmm3, %%xmm0                   \n\t"\
++        "punpcklbw %%xmm7, %%xmm0               \n\t"\
++        "punpcklbw %%xmm7, %%xmm1               \n\t"\
++        "psubw %%xmm1, %%xmm0                   \n\t"\
++        "psraw $3, %%xmm0                       \n\t"\
++        "psubw %%xmm0, %%xmm1                   \n\t"\
++        "packuswb %%xmm1, %%xmm1                \n\t"\
++        "movlps %%xmm1, " #c "                  \n\t"
++#define DEINT_CUBIC(a,b,c,d,e)  REAL_DEINT_CUBIC(a,b,c,d,e)
++
++DEINT_CUBIC((%0)           , (%%FF_REGa, %1), (%%FF_REGa, %1, 2), (%0, %1, 4)    , (%%FF_REGd, %1))
++DEINT_CUBIC((%%FF_REGa, %1), (%0, %1, 4)    , (%%FF_REGd)       , (%%FF_REGd, %1), (%0, %1, 8))
++DEINT_CUBIC((%0, %1, 4)    , (%%FF_REGd, %1), (%%FF_REGd, %1, 2), (%0, %1, 8)    , (%%FF_REGc))
++DEINT_CUBIC((%%FF_REGd, %1), (%0, %1, 8)    , (%%FF_REGd, %1, 4), (%%FF_REGc)    , (%%FF_REGc, %1, 2))
++
++        : : "r" (src), "r" ((x86_reg)stride)
++        :
++        XMM_CLOBBERS("%xmm0", "%xmm1", "%xmm2", "%xmm3", "%xmm7",)
++        "%"FF_REG_a, "%"FF_REG_d, "%"FF_REG_c
++    );
++#undef REAL_DEINT_CUBIC
++#else //TEMPLATE_PP_SSE2
++    int x;
++    src+= stride*3;
++    for(x=0; x<8; x++){
++        src[stride*3] = av_clip_uint8((-src[0]        + 9*src[stride*2] + 9*src[stride*4] - src[stride*6])>>4);
++        src[stride*5] = av_clip_uint8((-src[stride*2] + 9*src[stride*4] + 9*src[stride*6] - src[stride*8])>>4);
++        src[stride*7] = av_clip_uint8((-src[stride*4] + 9*src[stride*6] + 9*src[stride*8] - src[stride*10])>>4);
++        src[stride*9] = av_clip_uint8((-src[stride*6] + 9*src[stride*8] + 9*src[stride*10] - src[stride*12])>>4);
++        src++;
++    }
++#endif //TEMPLATE_PP_SSE2
++}
++
++/**
++ * Deinterlace the given block by filtering every second line with a (-1 4 2 4 -1) filter.
++ * will be called for every 8x8 block and can read & write from line 4-15
++ * lines 0-3 have been passed through the deblock / dering filters already, but can be read, too.
++ * lines 4-12 will be read into the deblocking filter and should be deinterlaced
++ * this filter will read lines 4-13 and write 5-11
++ */
++static inline void RENAME(deInterlaceFF)(uint8_t src[], int stride, uint8_t *tmp)
++{
++#if TEMPLATE_PP_MMXEXT
++    src+= stride*4;
++    __asm__ volatile(
++        "lea (%0, %1), %%"FF_REG_a"             \n\t"
++        "lea (%%"FF_REG_a", %1, 4), %%"FF_REG_d"\n\t"
++        "pxor %%mm7, %%mm7                      \n\t"
++        "movq (%2), %%mm0                       \n\t"
++//      0       1       2       3       4       5       6       7       8       9       10
++//      %0      eax     eax+%1  eax+2%1 %0+4%1  edx     edx+%1  edx+2%1 %0+8%1  edx+4%1 ecx
++
++#define REAL_DEINT_FF(a,b,c,d)\
++        "movq " #a ", %%mm1                     \n\t"\
++        "movq " #b ", %%mm2                     \n\t"\
++        "movq " #c ", %%mm3                     \n\t"\
++        "movq " #d ", %%mm4                     \n\t"\
++        PAVGB(%%mm3, %%mm1)                          \
++        PAVGB(%%mm4, %%mm0)                          \
++        "movq %%mm0, %%mm3                      \n\t"\
++        "punpcklbw %%mm7, %%mm0                 \n\t"\
++        "punpckhbw %%mm7, %%mm3                 \n\t"\
++        "movq %%mm1, %%mm4                      \n\t"\
++        "punpcklbw %%mm7, %%mm1                 \n\t"\
++        "punpckhbw %%mm7, %%mm4                 \n\t"\
++        "psllw $2, %%mm1                        \n\t"\
++        "psllw $2, %%mm4                        \n\t"\
++        "psubw %%mm0, %%mm1                     \n\t"\
++        "psubw %%mm3, %%mm4                     \n\t"\
++        "movq %%mm2, %%mm5                      \n\t"\
++        "movq %%mm2, %%mm0                      \n\t"\
++        "punpcklbw %%mm7, %%mm2                 \n\t"\
++        "punpckhbw %%mm7, %%mm5                 \n\t"\
++        "paddw %%mm2, %%mm1                     \n\t"\
++        "paddw %%mm5, %%mm4                     \n\t"\
++        "psraw $2, %%mm1                        \n\t"\
++        "psraw $2, %%mm4                        \n\t"\
++        "packuswb %%mm4, %%mm1                  \n\t"\
++        "movq %%mm1, " #b "                     \n\t"\
++
++#define DEINT_FF(a,b,c,d)  REAL_DEINT_FF(a,b,c,d)
++
++DEINT_FF((%0)           , (%%FF_REGa)       , (%%FF_REGa, %1), (%%FF_REGa, %1, 2))
++DEINT_FF((%%FF_REGa, %1), (%%FF_REGa, %1, 2), (%0, %1, 4)    , (%%FF_REGd)       )
++DEINT_FF((%0, %1, 4)    , (%%FF_REGd)       , (%%FF_REGd, %1), (%%FF_REGd, %1, 2))
++DEINT_FF((%%FF_REGd, %1), (%%FF_REGd, %1, 2), (%0, %1, 8)    , (%%FF_REGd, %1, 4))
++
++        "movq %%mm0, (%2)                       \n\t"
++        : : "r" (src), "r" ((x86_reg)stride), "r"(tmp)
++        : "%"FF_REG_a, "%"FF_REG_d
++    );
++#else //TEMPLATE_PP_MMXEXT
++    int x;
++    src+= stride*4;
++    for(x=0; x<8; x++){
++        int t1= tmp[x];
++        int t2= src[stride*1];
++
++        src[stride*1]= av_clip_uint8((-t1 + 4*src[stride*0] + 2*t2 + 4*src[stride*2] - src[stride*3] + 4)>>3);
++        t1= src[stride*4];
++        src[stride*3]= av_clip_uint8((-t2 + 4*src[stride*2] + 2*t1 + 4*src[stride*4] - src[stride*5] + 4)>>3);
++        t2= src[stride*6];
++        src[stride*5]= av_clip_uint8((-t1 + 4*src[stride*4] + 2*t2 + 4*src[stride*6] - src[stride*7] + 4)>>3);
++        t1= src[stride*8];
++        src[stride*7]= av_clip_uint8((-t2 + 4*src[stride*6] + 2*t1 + 4*src[stride*8] - src[stride*9] + 4)>>3);
++        tmp[x]= t1;
++
++        src++;
++    }
++#endif //TEMPLATE_PP_MMXEXT
++}
++
++/**
++ * Deinterlace the given block by filtering every line with a (-1 2 6 2 -1) filter.
++ * will be called for every 8x8 block and can read & write from line 4-15
++ * lines 0-3 have been passed through the deblock / dering filters already, but can be read, too.
++ * lines 4-12 will be read into the deblocking filter and should be deinterlaced
++ * this filter will read lines 4-13 and write 4-11
++ */
++static inline void RENAME(deInterlaceL5)(uint8_t src[], int stride, uint8_t *tmp, uint8_t *tmp2)
++{
++#if TEMPLATE_PP_MMXEXT && HAVE_6REGS
++    src+= stride*4;
++    __asm__ volatile(
++        "lea (%0, %1), %%"FF_REG_a"             \n\t"
++        "lea (%%"FF_REG_a", %1, 4), %%"FF_REG_d"\n\t"
++        "pxor %%mm7, %%mm7                      \n\t"
++        "movq (%2), %%mm0                       \n\t"
++        "movq (%3), %%mm1                       \n\t"
++//      0       1       2       3       4       5       6       7       8       9       10
++//      %0      eax     eax+%1  eax+2%1 %0+4%1  edx     edx+%1  edx+2%1 %0+8%1  edx+4%1 ecx
++
++#define REAL_DEINT_L5(t1,t2,a,b,c)\
++        "movq " #a ", %%mm2                     \n\t"\
++        "movq " #b ", %%mm3                     \n\t"\
++        "movq " #c ", %%mm4                     \n\t"\
++        PAVGB(t2, %%mm3)                             \
++        PAVGB(t1, %%mm4)                             \
++        "movq %%mm2, %%mm5                      \n\t"\
++        "movq %%mm2, " #t1 "                    \n\t"\
++        "punpcklbw %%mm7, %%mm2                 \n\t"\
++        "punpckhbw %%mm7, %%mm5                 \n\t"\
++        "movq %%mm2, %%mm6                      \n\t"\
++        "paddw %%mm2, %%mm2                     \n\t"\
++        "paddw %%mm6, %%mm2                     \n\t"\
++        "movq %%mm5, %%mm6                      \n\t"\
++        "paddw %%mm5, %%mm5                     \n\t"\
++        "paddw %%mm6, %%mm5                     \n\t"\
++        "movq %%mm3, %%mm6                      \n\t"\
++        "punpcklbw %%mm7, %%mm3                 \n\t"\
++        "punpckhbw %%mm7, %%mm6                 \n\t"\
++        "paddw %%mm3, %%mm3                     \n\t"\
++        "paddw %%mm6, %%mm6                     \n\t"\
++        "paddw %%mm3, %%mm2                     \n\t"\
++        "paddw %%mm6, %%mm5                     \n\t"\
++        "movq %%mm4, %%mm6                      \n\t"\
++        "punpcklbw %%mm7, %%mm4                 \n\t"\
++        "punpckhbw %%mm7, %%mm6                 \n\t"\
++        "psubw %%mm4, %%mm2                     \n\t"\
++        "psubw %%mm6, %%mm5                     \n\t"\
++        "psraw $2, %%mm2                        \n\t"\
++        "psraw $2, %%mm5                        \n\t"\
++        "packuswb %%mm5, %%mm2                  \n\t"\
++        "movq %%mm2, " #a "                     \n\t"\
++
++#define DEINT_L5(t1,t2,a,b,c)  REAL_DEINT_L5(t1,t2,a,b,c)
++
++DEINT_L5(%%mm0, %%mm1, (%0)              , (%%FF_REGa)       , (%%FF_REGa, %1)   )
++DEINT_L5(%%mm1, %%mm0, (%%FF_REGa)       , (%%FF_REGa, %1)   , (%%FF_REGa, %1, 2))
++DEINT_L5(%%mm0, %%mm1, (%%FF_REGa, %1)   , (%%FF_REGa, %1, 2), (%0, %1, 4)   )
++DEINT_L5(%%mm1, %%mm0, (%%FF_REGa, %1, 2), (%0, %1, 4)       , (%%FF_REGd)       )
++DEINT_L5(%%mm0, %%mm1, (%0, %1, 4)       , (%%FF_REGd)       , (%%FF_REGd, %1)   )
++DEINT_L5(%%mm1, %%mm0, (%%FF_REGd)       , (%%FF_REGd, %1)   , (%%FF_REGd, %1, 2))
++DEINT_L5(%%mm0, %%mm1, (%%FF_REGd, %1)   , (%%FF_REGd, %1, 2), (%0, %1, 8)   )
++DEINT_L5(%%mm1, %%mm0, (%%FF_REGd, %1, 2), (%0, %1, 8)       , (%%FF_REGd, %1, 4))
++
++        "movq %%mm0, (%2)                       \n\t"
++        "movq %%mm1, (%3)                       \n\t"
++        : : "r" (src), "r" ((x86_reg)stride), "r"(tmp), "r"(tmp2)
++        : "%"FF_REG_a, "%"FF_REG_d
++    );
++#else //TEMPLATE_PP_MMXEXT && HAVE_6REGS
++    int x;
++    src+= stride*4;
++    for(x=0; x<8; x++){
++        int t1= tmp[x];
++        int t2= tmp2[x];
++        int t3= src[0];
++
++        src[stride*0]= av_clip_uint8((-(t1 + src[stride*2]) + 2*(t2 + src[stride*1]) + 6*t3 + 4)>>3);
++        t1= src[stride*1];
++        src[stride*1]= av_clip_uint8((-(t2 + src[stride*3]) + 2*(t3 + src[stride*2]) + 6*t1 + 4)>>3);
++        t2= src[stride*2];
++        src[stride*2]= av_clip_uint8((-(t3 + src[stride*4]) + 2*(t1 + src[stride*3]) + 6*t2 + 4)>>3);
++        t3= src[stride*3];
++        src[stride*3]= av_clip_uint8((-(t1 + src[stride*5]) + 2*(t2 + src[stride*4]) + 6*t3 + 4)>>3);
++        t1= src[stride*4];
++        src[stride*4]= av_clip_uint8((-(t2 + src[stride*6]) + 2*(t3 + src[stride*5]) + 6*t1 + 4)>>3);
++        t2= src[stride*5];
++        src[stride*5]= av_clip_uint8((-(t3 + src[stride*7]) + 2*(t1 + src[stride*6]) + 6*t2 + 4)>>3);
++        t3= src[stride*6];
++        src[stride*6]= av_clip_uint8((-(t1 + src[stride*8]) + 2*(t2 + src[stride*7]) + 6*t3 + 4)>>3);
++        t1= src[stride*7];
++        src[stride*7]= av_clip_uint8((-(t2 + src[stride*9]) + 2*(t3 + src[stride*8]) + 6*t1 + 4)>>3);
++
++        tmp[x]= t3;
++        tmp2[x]= t1;
++
++        src++;
++    }
++#endif // TEMPLATE_PP_MMXEXT && HAVE_6REGS
++}
++
++/**
++ * Deinterlace the given block by filtering all lines with a (1 2 1) filter.
++ * will be called for every 8x8 block and can read & write from line 4-15
++ * lines 0-3 have been passed through the deblock / dering filters already, but can be read, too.
++ * lines 4-12 will be read into the deblocking filter and should be deinterlaced
++ * this filter will read lines 4-13 and write 4-11
++ */
++static inline void RENAME(deInterlaceBlendLinear)(uint8_t src[], int stride, uint8_t *tmp)
++{
++#if TEMPLATE_PP_MMXEXT
++    src+= 4*stride;
++    __asm__ volatile(
++        "lea (%0, %1), %%"FF_REG_a"             \n\t"
++        "lea (%%"FF_REG_a", %1, 4), %%"FF_REG_d"\n\t"
++//      0       1       2       3       4       5       6       7       8       9
++//      %0      eax     eax+%1  eax+2%1 %0+4%1  edx     edx+%1  edx+2%1 %0+8%1  edx+4%1
++
++        "movq (%2), %%mm0                       \n\t" // L0
++        "movq (%%"FF_REG_a"), %%mm1             \n\t" // L2
++        PAVGB(%%mm1, %%mm0)                           // L0+L2
++        "movq (%0), %%mm2                       \n\t" // L1
++        PAVGB(%%mm2, %%mm0)
++        "movq %%mm0, (%0)                       \n\t"
++        "movq (%%"FF_REG_a", %1), %%mm0         \n\t" // L3
++        PAVGB(%%mm0, %%mm2)                           // L1+L3
++        PAVGB(%%mm1, %%mm2)                           // 2L2 + L1 + L3
++        "movq %%mm2, (%%"FF_REG_a")             \n\t"
++        "movq (%%"FF_REG_a", %1, 2), %%mm2      \n\t" // L4
++        PAVGB(%%mm2, %%mm1)                           // L2+L4
++        PAVGB(%%mm0, %%mm1)                           // 2L3 + L2 + L4
++        "movq %%mm1, (%%"FF_REG_a", %1)         \n\t"
++        "movq (%0, %1, 4), %%mm1                \n\t" // L5
++        PAVGB(%%mm1, %%mm0)                           // L3+L5
++        PAVGB(%%mm2, %%mm0)                           // 2L4 + L3 + L5
++        "movq %%mm0, (%%"FF_REG_a", %1, 2)      \n\t"
++        "movq (%%"FF_REG_d"), %%mm0             \n\t" // L6
++        PAVGB(%%mm0, %%mm2)                           // L4+L6
++        PAVGB(%%mm1, %%mm2)                           // 2L5 + L4 + L6
++        "movq %%mm2, (%0, %1, 4)                \n\t"
++        "movq (%%"FF_REG_d", %1), %%mm2         \n\t" // L7
++        PAVGB(%%mm2, %%mm1)                           // L5+L7
++        PAVGB(%%mm0, %%mm1)                           // 2L6 + L5 + L7
++        "movq %%mm1, (%%"FF_REG_d")             \n\t"
++        "movq (%%"FF_REG_d", %1, 2), %%mm1      \n\t" // L8
++        PAVGB(%%mm1, %%mm0)                           // L6+L8
++        PAVGB(%%mm2, %%mm0)                           // 2L7 + L6 + L8
++        "movq %%mm0, (%%"FF_REG_d", %1)         \n\t"
++        "movq (%0, %1, 8), %%mm0                \n\t" // L9
++        PAVGB(%%mm0, %%mm2)                           // L7+L9
++        PAVGB(%%mm1, %%mm2)                           // 2L8 + L7 + L9
++        "movq %%mm2, (%%"FF_REG_d", %1, 2)      \n\t"
++        "movq %%mm1, (%2)                       \n\t"
++
++        : : "r" (src), "r" ((x86_reg)stride), "r" (tmp)
++        : "%"FF_REG_a, "%"FF_REG_d
++    );
++#else //TEMPLATE_PP_MMXEXT
++    int a, b, c, x;
++    src+= 4*stride;
++
++    for(x=0; x<2; x++){
++        a= *(uint32_t*)&tmp[stride*0];
++        b= *(uint32_t*)&src[stride*0];
++        c= *(uint32_t*)&src[stride*1];
++        a= (a&c) + (((a^c)&0xFEFEFEFEUL)>>1);
++        *(uint32_t*)&src[stride*0]= (a|b) - (((a^b)&0xFEFEFEFEUL)>>1);
++
++        a= *(uint32_t*)&src[stride*2];
++        b= (a&b) + (((a^b)&0xFEFEFEFEUL)>>1);
++        *(uint32_t*)&src[stride*1]= (c|b) - (((c^b)&0xFEFEFEFEUL)>>1);
++
++        b= *(uint32_t*)&src[stride*3];
++        c= (b&c) + (((b^c)&0xFEFEFEFEUL)>>1);
++        *(uint32_t*)&src[stride*2]= (c|a) - (((c^a)&0xFEFEFEFEUL)>>1);
++
++        c= *(uint32_t*)&src[stride*4];
++        a= (a&c) + (((a^c)&0xFEFEFEFEUL)>>1);
++        *(uint32_t*)&src[stride*3]= (a|b) - (((a^b)&0xFEFEFEFEUL)>>1);
++
++        a= *(uint32_t*)&src[stride*5];
++        b= (a&b) + (((a^b)&0xFEFEFEFEUL)>>1);
++        *(uint32_t*)&src[stride*4]= (c|b) - (((c^b)&0xFEFEFEFEUL)>>1);
++
++        b= *(uint32_t*)&src[stride*6];
++        c= (b&c) + (((b^c)&0xFEFEFEFEUL)>>1);
++        *(uint32_t*)&src[stride*5]= (c|a) - (((c^a)&0xFEFEFEFEUL)>>1);
++
++        c= *(uint32_t*)&src[stride*7];
++        a= (a&c) + (((a^c)&0xFEFEFEFEUL)>>1);
++        *(uint32_t*)&src[stride*6]= (a|b) - (((a^b)&0xFEFEFEFEUL)>>1);
++
++        a= *(uint32_t*)&src[stride*8];
++        b= (a&b) + (((a^b)&0xFEFEFEFEUL)>>1);
++        *(uint32_t*)&src[stride*7]= (c|b) - (((c^b)&0xFEFEFEFEUL)>>1);
++
++        *(uint32_t*)&tmp[stride*0]= c;
++        src += 4;
++        tmp += 4;
++    }
++#endif //TEMPLATE_PP_MMXEXT
++}
++
++/**
++ * Deinterlace the given block by applying a median filter to every second line.
++ * will be called for every 8x8 block and can read & write from line 4-15,
++ * lines 0-3 have been passed through the deblock / dering filters already, but can be read, too.
++ * lines 4-12 will be read into the deblocking filter and should be deinterlaced
++ */
++static inline void RENAME(deInterlaceMedian)(uint8_t src[], int stride)
++{
++#if TEMPLATE_PP_MMXEXT
++    src+= 4*stride;
++    __asm__ volatile(
++        "lea (%0, %1), %%"FF_REG_a"             \n\t"
++        "lea (%%"FF_REG_a", %1, 4), %%"FF_REG_d"\n\t"
++//      0       1       2       3       4       5       6       7       8       9
++//      %0      eax     eax+%1  eax+2%1 %0+4%1  edx     edx+%1  edx+2%1 %0+8%1  edx+4%1
++
++        "movq (%0), %%mm0                       \n\t"
++        "movq (%%"FF_REG_a", %1), %%mm2         \n\t"
++        "movq (%%"FF_REG_a"), %%mm1             \n\t"
++        "movq %%mm0, %%mm3                      \n\t"
++        "pmaxub %%mm1, %%mm0                    \n\t"
++        "pminub %%mm3, %%mm1                    \n\t"
++        "pmaxub %%mm2, %%mm1                    \n\t"
++        "pminub %%mm1, %%mm0                    \n\t"
++        "movq %%mm0, (%%"FF_REG_a")             \n\t"
++
++        "movq (%0, %1, 4), %%mm0                \n\t"
++        "movq (%%"FF_REG_a", %1, 2), %%mm1      \n\t"
++        "movq %%mm2, %%mm3                      \n\t"
++        "pmaxub %%mm1, %%mm2                    \n\t"
++        "pminub %%mm3, %%mm1                    \n\t"
++        "pmaxub %%mm0, %%mm1                    \n\t"
++        "pminub %%mm1, %%mm2                    \n\t"
++        "movq %%mm2, (%%"FF_REG_a", %1, 2)      \n\t"
++
++        "movq (%%"FF_REG_d"), %%mm2             \n\t"
++        "movq (%%"FF_REG_d", %1), %%mm1         \n\t"
++        "movq %%mm2, %%mm3                      \n\t"
++        "pmaxub %%mm0, %%mm2                    \n\t"
++        "pminub %%mm3, %%mm0                    \n\t"
++        "pmaxub %%mm1, %%mm0                    \n\t"
++        "pminub %%mm0, %%mm2                    \n\t"
++        "movq %%mm2, (%%"FF_REG_d")             \n\t"
++
++        "movq (%%"FF_REG_d", %1, 2), %%mm2      \n\t"
++        "movq (%0, %1, 8), %%mm0                \n\t"
++        "movq %%mm2, %%mm3                      \n\t"
++        "pmaxub %%mm0, %%mm2                    \n\t"
++        "pminub %%mm3, %%mm0                    \n\t"
++        "pmaxub %%mm1, %%mm0                    \n\t"
++        "pminub %%mm0, %%mm2                    \n\t"
++        "movq %%mm2, (%%"FF_REG_d", %1, 2)      \n\t"
++
++
++        : : "r" (src), "r" ((x86_reg)stride)
++        : "%"FF_REG_a, "%"FF_REG_d
++    );
++
++#else //TEMPLATE_PP_MMX
++    int x, y;
++    src+= 4*stride;
++    // FIXME - there should be a way to do a few columns in parallel like w/mmx
++    for(x=0; x<8; x++){
++        uint8_t *colsrc = src;
++        for (y=0; y<4; y++){
++            int a, b, c, d, e, f;
++            a = colsrc[0       ];
++            b = colsrc[stride  ];
++            c = colsrc[stride*2];
++            d = (a-b)>>31;
++            e = (b-c)>>31;
++            f = (c-a)>>31;
++            colsrc[stride  ] = (a|(d^f)) & (b|(d^e)) & (c|(e^f));
++            colsrc += stride*2;
++        }
++        src++;
++    }
++#endif //TEMPLATE_PP_MMX
++}
++
++#if TEMPLATE_PP_MMX
++/**
++ * Transpose and shift the given 8x8 Block into dst1 and dst2.
++ */
++static inline void RENAME(transpose1)(uint8_t *dst1, uint8_t *dst2, const uint8_t *src, int srcStride)
++{
++    __asm__(
++        "lea (%0, %1), %%"FF_REG_a"             \n\t"
++//      0       1       2       3       4       5       6       7       8       9
++//      %0      eax     eax+%1  eax+2%1 %0+4%1  edx     edx+%1  edx+2%1 %0+8%1  edx+4%1
++        "movq (%0), %%mm0                       \n\t" // 12345678
++        "movq (%%"FF_REG_a"), %%mm1             \n\t" // abcdefgh
++        "movq %%mm0, %%mm2                      \n\t" // 12345678
++        "punpcklbw %%mm1, %%mm0                 \n\t" // 1a2b3c4d
++        "punpckhbw %%mm1, %%mm2                 \n\t" // 5e6f7g8h
++
++        "movq (%%"FF_REG_a", %1), %%mm1         \n\t"
++        "movq (%%"FF_REG_a", %1, 2), %%mm3      \n\t"
++        "movq %%mm1, %%mm4                      \n\t"
++        "punpcklbw %%mm3, %%mm1                 \n\t"
++        "punpckhbw %%mm3, %%mm4                 \n\t"
++
++        "movq %%mm0, %%mm3                      \n\t"
++        "punpcklwd %%mm1, %%mm0                 \n\t"
++        "punpckhwd %%mm1, %%mm3                 \n\t"
++        "movq %%mm2, %%mm1                      \n\t"
++        "punpcklwd %%mm4, %%mm2                 \n\t"
++        "punpckhwd %%mm4, %%mm1                 \n\t"
++
++        "movd %%mm0, 128(%2)                    \n\t"
++        "psrlq $32, %%mm0                       \n\t"
++        "movd %%mm0, 144(%2)                    \n\t"
++        "movd %%mm3, 160(%2)                    \n\t"
++        "psrlq $32, %%mm3                       \n\t"
++        "movd %%mm3, 176(%2)                    \n\t"
++        "movd %%mm3, 48(%3)                     \n\t"
++        "movd %%mm2, 192(%2)                    \n\t"
++        "movd %%mm2, 64(%3)                     \n\t"
++        "psrlq $32, %%mm2                       \n\t"
++        "movd %%mm2, 80(%3)                     \n\t"
++        "movd %%mm1, 96(%3)                     \n\t"
++        "psrlq $32, %%mm1                       \n\t"
++        "movd %%mm1, 112(%3)                    \n\t"
++
++        "lea (%%"FF_REG_a", %1, 4), %%"FF_REG_a"\n\t"
++
++        "movq (%0, %1, 4), %%mm0                \n\t" // 12345678
++        "movq (%%"FF_REG_a"), %%mm1             \n\t" // abcdefgh
++        "movq %%mm0, %%mm2                      \n\t" // 12345678
++        "punpcklbw %%mm1, %%mm0                 \n\t" // 1a2b3c4d
++        "punpckhbw %%mm1, %%mm2                 \n\t" // 5e6f7g8h
++
++        "movq (%%"FF_REG_a", %1), %%mm1         \n\t"
++        "movq (%%"FF_REG_a", %1, 2), %%mm3      \n\t"
++        "movq %%mm1, %%mm4                      \n\t"
++        "punpcklbw %%mm3, %%mm1                 \n\t"
++        "punpckhbw %%mm3, %%mm4                 \n\t"
++
++        "movq %%mm0, %%mm3                      \n\t"
++        "punpcklwd %%mm1, %%mm0                 \n\t"
++        "punpckhwd %%mm1, %%mm3                 \n\t"
++        "movq %%mm2, %%mm1                      \n\t"
++        "punpcklwd %%mm4, %%mm2                 \n\t"
++        "punpckhwd %%mm4, %%mm1                 \n\t"
++
++        "movd %%mm0, 132(%2)                    \n\t"
++        "psrlq $32, %%mm0                       \n\t"
++        "movd %%mm0, 148(%2)                    \n\t"
++        "movd %%mm3, 164(%2)                    \n\t"
++        "psrlq $32, %%mm3                       \n\t"
++        "movd %%mm3, 180(%2)                    \n\t"
++        "movd %%mm3, 52(%3)                     \n\t"
++        "movd %%mm2, 196(%2)                    \n\t"
++        "movd %%mm2, 68(%3)                     \n\t"
++        "psrlq $32, %%mm2                       \n\t"
++        "movd %%mm2, 84(%3)                     \n\t"
++        "movd %%mm1, 100(%3)                    \n\t"
++        "psrlq $32, %%mm1                       \n\t"
++        "movd %%mm1, 116(%3)                    \n\t"
++
++
++        :: "r" (src), "r" ((x86_reg)srcStride), "r" (dst1), "r" (dst2)
++        : "%"FF_REG_a
++    );
++}
++
++/**
++ * Transpose the given 8x8 block.
++ */
++static inline void RENAME(transpose2)(uint8_t *dst, int dstStride, const uint8_t *src)
++{
++    __asm__(
++        "lea (%0, %1), %%"FF_REG_a"             \n\t"
++        "lea (%%"FF_REG_a",%1,4), %%"FF_REG_d"  \n\t"
++//      0       1       2       3       4       5       6       7       8       9
++//      %0      eax     eax+%1  eax+2%1 %0+4%1  edx     edx+%1  edx+2%1 %0+8%1  edx+4%1
++        "movq (%2), %%mm0                       \n\t" // 12345678
++        "movq 16(%2), %%mm1                     \n\t" // abcdefgh
++        "movq %%mm0, %%mm2                      \n\t" // 12345678
++        "punpcklbw %%mm1, %%mm0                 \n\t" // 1a2b3c4d
++        "punpckhbw %%mm1, %%mm2                 \n\t" // 5e6f7g8h
++
++        "movq 32(%2), %%mm1                     \n\t"
++        "movq 48(%2), %%mm3                     \n\t"
++        "movq %%mm1, %%mm4                      \n\t"
++        "punpcklbw %%mm3, %%mm1                 \n\t"
++        "punpckhbw %%mm3, %%mm4                 \n\t"
++
++        "movq %%mm0, %%mm3                      \n\t"
++        "punpcklwd %%mm1, %%mm0                 \n\t"
++        "punpckhwd %%mm1, %%mm3                 \n\t"
++        "movq %%mm2, %%mm1                      \n\t"
++        "punpcklwd %%mm4, %%mm2                 \n\t"
++        "punpckhwd %%mm4, %%mm1                 \n\t"
++
++        "movd %%mm0, (%0)                       \n\t"
++        "psrlq $32, %%mm0                       \n\t"
++        "movd %%mm0, (%%"FF_REG_a")             \n\t"
++        "movd %%mm3, (%%"FF_REG_a", %1)         \n\t"
++        "psrlq $32, %%mm3                       \n\t"
++        "movd %%mm3, (%%"FF_REG_a", %1, 2)      \n\t"
++        "movd %%mm2, (%0, %1, 4)                \n\t"
++        "psrlq $32, %%mm2                       \n\t"
++        "movd %%mm2, (%%"FF_REG_d")             \n\t"
++        "movd %%mm1, (%%"FF_REG_d", %1)         \n\t"
++        "psrlq $32, %%mm1                       \n\t"
++        "movd %%mm1, (%%"FF_REG_d", %1, 2)      \n\t"
++
++
++        "movq 64(%2), %%mm0                     \n\t" // 12345678
++        "movq 80(%2), %%mm1                     \n\t" // abcdefgh
++        "movq %%mm0, %%mm2                      \n\t" // 12345678
++        "punpcklbw %%mm1, %%mm0                 \n\t" // 1a2b3c4d
++        "punpckhbw %%mm1, %%mm2                 \n\t" // 5e6f7g8h
++
++        "movq 96(%2), %%mm1                     \n\t"
++        "movq 112(%2), %%mm3                    \n\t"
++        "movq %%mm1, %%mm4                      \n\t"
++        "punpcklbw %%mm3, %%mm1                 \n\t"
++        "punpckhbw %%mm3, %%mm4                 \n\t"
++
++        "movq %%mm0, %%mm3                      \n\t"
++        "punpcklwd %%mm1, %%mm0                 \n\t"
++        "punpckhwd %%mm1, %%mm3                 \n\t"
++        "movq %%mm2, %%mm1                      \n\t"
++        "punpcklwd %%mm4, %%mm2                 \n\t"
++        "punpckhwd %%mm4, %%mm1                 \n\t"
++
++        "movd %%mm0, 4(%0)                      \n\t"
++        "psrlq $32, %%mm0                       \n\t"
++        "movd %%mm0, 4(%%"FF_REG_a")            \n\t"
++        "movd %%mm3, 4(%%"FF_REG_a", %1)        \n\t"
++        "psrlq $32, %%mm3                       \n\t"
++        "movd %%mm3, 4(%%"FF_REG_a", %1, 2)     \n\t"
++        "movd %%mm2, 4(%0, %1, 4)               \n\t"
++        "psrlq $32, %%mm2                       \n\t"
++        "movd %%mm2, 4(%%"FF_REG_d")            \n\t"
++        "movd %%mm1, 4(%%"FF_REG_d", %1)        \n\t"
++        "psrlq $32, %%mm1                       \n\t"
++        "movd %%mm1, 4(%%"FF_REG_d", %1, 2)     \n\t"
++
++        :: "r" (dst), "r" ((x86_reg)dstStride), "r" (src)
++        : "%"FF_REG_a, "%"FF_REG_d
++    );
++}
++#endif //TEMPLATE_PP_MMX
++//static long test=0;
++
++#if !TEMPLATE_PP_ALTIVEC
++static inline void RENAME(tempNoiseReducer)(uint8_t *src, int stride,
++                                    uint8_t *tempBlurred, uint32_t *tempBlurredPast, const int *maxNoise)
++{
++    // to save a register (FIXME do this outside of the loops)
++    tempBlurredPast[127]= maxNoise[0];
++    tempBlurredPast[128]= maxNoise[1];
++    tempBlurredPast[129]= maxNoise[2];
++
++#define FAST_L2_DIFF
++//#define L1_DIFF //u should change the thresholds too if u try that one
++#if TEMPLATE_PP_MMXEXT && HAVE_6REGS
++    __asm__ volatile(
++        "lea (%2, %2, 2), %%"FF_REG_a"          \n\t" // 3*stride
++        "lea (%2, %2, 4), %%"FF_REG_d"          \n\t" // 5*stride
++        "lea (%%"FF_REG_d", %2, 2), %%"FF_REG_c"\n\t" // 7*stride
++//      0       1       2       3       4       5       6       7       8       9
++//      %x      %x+%2   %x+2%2  %x+eax  %x+4%2  %x+edx  %x+2eax %x+ecx  %x+8%2
++//FIXME reorder?
++#ifdef L1_DIFF //needs mmx2
++        "movq (%0), %%mm0                       \n\t" // L0
++        "psadbw (%1), %%mm0                     \n\t" // |L0-R0|
++        "movq (%0, %2), %%mm1                   \n\t" // L1
++        "psadbw (%1, %2), %%mm1                 \n\t" // |L1-R1|
++        "movq (%0, %2, 2), %%mm2                \n\t" // L2
++        "psadbw (%1, %2, 2), %%mm2              \n\t" // |L2-R2|
++        "movq (%0, %%"FF_REG_a"), %%mm3         \n\t" // L3
++        "psadbw (%1, %%"FF_REG_a"), %%mm3       \n\t" // |L3-R3|
++
++        "movq (%0, %2, 4), %%mm4                \n\t" // L4
++        "paddw %%mm1, %%mm0                     \n\t"
++        "psadbw (%1, %2, 4), %%mm4              \n\t" // |L4-R4|
++        "movq (%0, %%"FF_REG_d"), %%mm5         \n\t" // L5
++        "paddw %%mm2, %%mm0                     \n\t"
++        "psadbw (%1, %%"FF_REG_d"), %%mm5       \n\t" // |L5-R5|
++        "movq (%0, %%"FF_REG_a", 2), %%mm6      \n\t" // L6
++        "paddw %%mm3, %%mm0                     \n\t"
++        "psadbw (%1, %%"FF_REG_a", 2), %%mm6    \n\t" // |L6-R6|
++        "movq (%0, %%"FF_REG_c"), %%mm7         \n\t" // L7
++        "paddw %%mm4, %%mm0                     \n\t"
++        "psadbw (%1, %%"FF_REG_c"), %%mm7       \n\t" // |L7-R7|
++        "paddw %%mm5, %%mm6                     \n\t"
++        "paddw %%mm7, %%mm6                     \n\t"
++        "paddw %%mm6, %%mm0                     \n\t"
++#else //L1_DIFF
++#if defined (FAST_L2_DIFF)
++        "pcmpeqb %%mm7, %%mm7                   \n\t"
++        "movq "MANGLE(b80)", %%mm6              \n\t"
++        "pxor %%mm0, %%mm0                      \n\t"
++#define REAL_L2_DIFF_CORE(a, b)\
++        "movq " #a ", %%mm5                     \n\t"\
++        "movq " #b ", %%mm2                     \n\t"\
++        "pxor %%mm7, %%mm2                      \n\t"\
++        PAVGB(%%mm2, %%mm5)\
++        "paddb %%mm6, %%mm5                     \n\t"\
++        "movq %%mm5, %%mm2                      \n\t"\
++        "psllw $8, %%mm5                        \n\t"\
++        "pmaddwd %%mm5, %%mm5                   \n\t"\
++        "pmaddwd %%mm2, %%mm2                   \n\t"\
++        "paddd %%mm2, %%mm5                     \n\t"\
++        "psrld $14, %%mm5                       \n\t"\
++        "paddd %%mm5, %%mm0                     \n\t"
++
++#else //defined (FAST_L2_DIFF)
++        "pxor %%mm7, %%mm7                      \n\t"
++        "pxor %%mm0, %%mm0                      \n\t"
++#define REAL_L2_DIFF_CORE(a, b)\
++        "movq " #a ", %%mm5                     \n\t"\
++        "movq " #b ", %%mm2                     \n\t"\
++        "movq %%mm5, %%mm1                      \n\t"\
++        "movq %%mm2, %%mm3                      \n\t"\
++        "punpcklbw %%mm7, %%mm5                 \n\t"\
++        "punpckhbw %%mm7, %%mm1                 \n\t"\
++        "punpcklbw %%mm7, %%mm2                 \n\t"\
++        "punpckhbw %%mm7, %%mm3                 \n\t"\
++        "psubw %%mm2, %%mm5                     \n\t"\
++        "psubw %%mm3, %%mm1                     \n\t"\
++        "pmaddwd %%mm5, %%mm5                   \n\t"\
++        "pmaddwd %%mm1, %%mm1                   \n\t"\
++        "paddd %%mm1, %%mm5                     \n\t"\
++        "paddd %%mm5, %%mm0                     \n\t"
++
++#endif //defined (FAST_L2_DIFF)
++
++#define L2_DIFF_CORE(a, b)  REAL_L2_DIFF_CORE(a, b)
++
++L2_DIFF_CORE((%0)             , (%1))
++L2_DIFF_CORE((%0, %2)         , (%1, %2))
++L2_DIFF_CORE((%0, %2, 2)      , (%1, %2, 2))
++L2_DIFF_CORE((%0, %%FF_REGa)  , (%1, %%FF_REGa))
++L2_DIFF_CORE((%0, %2, 4)      , (%1, %2, 4))
++L2_DIFF_CORE((%0, %%FF_REGd)  , (%1, %%FF_REGd))
++L2_DIFF_CORE((%0, %%FF_REGa,2), (%1, %%FF_REGa,2))
++L2_DIFF_CORE((%0, %%FF_REGc)  , (%1, %%FF_REGc))
++
++#endif //L1_DIFF
++
++        "movq %%mm0, %%mm4                      \n\t"
++        "psrlq $32, %%mm0                       \n\t"
++        "paddd %%mm0, %%mm4                     \n\t"
++        "movd %%mm4, %%ecx                      \n\t"
++        "shll $2, %%ecx                         \n\t"
++        "mov %3, %%"FF_REG_d"                   \n\t"
++        "addl -4(%%"FF_REG_d"), %%ecx           \n\t"
++        "addl 4(%%"FF_REG_d"), %%ecx            \n\t"
++        "addl -1024(%%"FF_REG_d"), %%ecx        \n\t"
++        "addl $4, %%ecx                         \n\t"
++        "addl 1024(%%"FF_REG_d"), %%ecx         \n\t"
++        "shrl $3, %%ecx                         \n\t"
++        "movl %%ecx, (%%"FF_REG_d")             \n\t"
++
++//        "mov %3, %%"FF_REG_c"                   \n\t"
++//        "mov %%"FF_REG_c", test                 \n\t"
++//        "jmp 4f                                 \n\t"
++        "cmpl 512(%%"FF_REG_d"), %%ecx          \n\t"
++        " jb 2f                                 \n\t"
++        "cmpl 516(%%"FF_REG_d"), %%ecx          \n\t"
++        " jb 1f                                 \n\t"
++
++        "lea (%%"FF_REG_a", %2, 2), %%"FF_REG_d"\n\t" // 5*stride
++        "lea (%%"FF_REG_d", %2, 2), %%"FF_REG_c"\n\t" // 7*stride
++        "movq (%0), %%mm0                       \n\t" // L0
++        "movq (%0, %2), %%mm1                   \n\t" // L1
++        "movq (%0, %2, 2), %%mm2                \n\t" // L2
++        "movq (%0, %%"FF_REG_a"), %%mm3         \n\t" // L3
++        "movq (%0, %2, 4), %%mm4                \n\t" // L4
++        "movq (%0, %%"FF_REG_d"), %%mm5         \n\t" // L5
++        "movq (%0, %%"FF_REG_a", 2), %%mm6      \n\t" // L6
++        "movq (%0, %%"FF_REG_c"), %%mm7         \n\t" // L7
++        "movq %%mm0, (%1)                       \n\t" // L0
++        "movq %%mm1, (%1, %2)                   \n\t" // L1
++        "movq %%mm2, (%1, %2, 2)                \n\t" // L2
++        "movq %%mm3, (%1, %%"FF_REG_a")         \n\t" // L3
++        "movq %%mm4, (%1, %2, 4)                \n\t" // L4
++        "movq %%mm5, (%1, %%"FF_REG_d")         \n\t" // L5
++        "movq %%mm6, (%1, %%"FF_REG_a", 2)      \n\t" // L6
++        "movq %%mm7, (%1, %%"FF_REG_c")         \n\t" // L7
++        "jmp 4f                                 \n\t"
++
++        "1:                                     \n\t"
++        "lea (%%"FF_REG_a", %2, 2), %%"FF_REG_d"\n\t" // 5*stride
++        "lea (%%"FF_REG_d", %2, 2), %%"FF_REG_c"\n\t" // 7*stride
++        "movq (%0), %%mm0                       \n\t" // L0
++        PAVGB((%1), %%mm0)                            // L0
++        "movq (%0, %2), %%mm1                   \n\t" // L1
++        PAVGB((%1, %2), %%mm1)                        // L1
++        "movq (%0, %2, 2), %%mm2                \n\t" // L2
++        PAVGB((%1, %2, 2), %%mm2)                     // L2
++        "movq (%0, %%"FF_REG_a"), %%mm3         \n\t" // L3
++        PAVGB((%1, %%FF_REGa), %%mm3)                 // L3
++        "movq (%0, %2, 4), %%mm4                \n\t" // L4
++        PAVGB((%1, %2, 4), %%mm4)                     // L4
++        "movq (%0, %%"FF_REG_d"), %%mm5         \n\t" // L5
++        PAVGB((%1, %%FF_REGd), %%mm5)                 // L5
++        "movq (%0, %%"FF_REG_a", 2), %%mm6      \n\t" // L6
++        PAVGB((%1, %%FF_REGa, 2), %%mm6)              // L6
++        "movq (%0, %%"FF_REG_c"), %%mm7         \n\t" // L7
++        PAVGB((%1, %%FF_REGc), %%mm7)                 // L7
++        "movq %%mm0, (%1)                       \n\t" // R0
++        "movq %%mm1, (%1, %2)                   \n\t" // R1
++        "movq %%mm2, (%1, %2, 2)                \n\t" // R2
++        "movq %%mm3, (%1, %%"FF_REG_a")         \n\t" // R3
++        "movq %%mm4, (%1, %2, 4)                \n\t" // R4
++        "movq %%mm5, (%1, %%"FF_REG_d")         \n\t" // R5
++        "movq %%mm6, (%1, %%"FF_REG_a", 2)      \n\t" // R6
++        "movq %%mm7, (%1, %%"FF_REG_c")         \n\t" // R7
++        "movq %%mm0, (%0)                       \n\t" // L0
++        "movq %%mm1, (%0, %2)                   \n\t" // L1
++        "movq %%mm2, (%0, %2, 2)                \n\t" // L2
++        "movq %%mm3, (%0, %%"FF_REG_a")         \n\t" // L3
++        "movq %%mm4, (%0, %2, 4)                \n\t" // L4
++        "movq %%mm5, (%0, %%"FF_REG_d")         \n\t" // L5
++        "movq %%mm6, (%0, %%"FF_REG_a", 2)      \n\t" // L6
++        "movq %%mm7, (%0, %%"FF_REG_c")         \n\t" // L7
++        "jmp 4f                                 \n\t"
++
++        "2:                                     \n\t"
++        "cmpl 508(%%"FF_REG_d"), %%ecx          \n\t"
++        " jb 3f                                 \n\t"
++
++        "lea (%%"FF_REG_a", %2, 2), %%"FF_REG_d"\n\t" // 5*stride
++        "lea (%%"FF_REG_d", %2, 2), %%"FF_REG_c"\n\t" // 7*stride
++        "movq (%0), %%mm0                       \n\t" // L0
++        "movq (%0, %2), %%mm1                   \n\t" // L1
++        "movq (%0, %2, 2), %%mm2                \n\t" // L2
++        "movq (%0, %%"FF_REG_a"), %%mm3         \n\t" // L3
++        "movq (%1), %%mm4                       \n\t" // R0
++        "movq (%1, %2), %%mm5                   \n\t" // R1
++        "movq (%1, %2, 2), %%mm6                \n\t" // R2
++        "movq (%1, %%"FF_REG_a"), %%mm7         \n\t" // R3
++        PAVGB(%%mm4, %%mm0)
++        PAVGB(%%mm5, %%mm1)
++        PAVGB(%%mm6, %%mm2)
++        PAVGB(%%mm7, %%mm3)
++        PAVGB(%%mm4, %%mm0)
++        PAVGB(%%mm5, %%mm1)
++        PAVGB(%%mm6, %%mm2)
++        PAVGB(%%mm7, %%mm3)
++        "movq %%mm0, (%1)                       \n\t" // R0
++        "movq %%mm1, (%1, %2)                   \n\t" // R1
++        "movq %%mm2, (%1, %2, 2)                \n\t" // R2
++        "movq %%mm3, (%1, %%"FF_REG_a")         \n\t" // R3
++        "movq %%mm0, (%0)                       \n\t" // L0
++        "movq %%mm1, (%0, %2)                   \n\t" // L1
++        "movq %%mm2, (%0, %2, 2)                \n\t" // L2
++        "movq %%mm3, (%0, %%"FF_REG_a")         \n\t" // L3
++
++        "movq (%0, %2, 4), %%mm0                \n\t" // L4
++        "movq (%0, %%"FF_REG_d"), %%mm1         \n\t" // L5
++        "movq (%0, %%"FF_REG_a", 2), %%mm2      \n\t" // L6
++        "movq (%0, %%"FF_REG_c"), %%mm3         \n\t" // L7
++        "movq (%1, %2, 4), %%mm4                \n\t" // R4
++        "movq (%1, %%"FF_REG_d"), %%mm5         \n\t" // R5
++        "movq (%1, %%"FF_REG_a", 2), %%mm6      \n\t" // R6
++        "movq (%1, %%"FF_REG_c"), %%mm7         \n\t" // R7
++        PAVGB(%%mm4, %%mm0)
++        PAVGB(%%mm5, %%mm1)
++        PAVGB(%%mm6, %%mm2)
++        PAVGB(%%mm7, %%mm3)
++        PAVGB(%%mm4, %%mm0)
++        PAVGB(%%mm5, %%mm1)
++        PAVGB(%%mm6, %%mm2)
++        PAVGB(%%mm7, %%mm3)
++        "movq %%mm0, (%1, %2, 4)                \n\t" // R4
++        "movq %%mm1, (%1, %%"FF_REG_d")         \n\t" // R5
++        "movq %%mm2, (%1, %%"FF_REG_a", 2)      \n\t" // R6
++        "movq %%mm3, (%1, %%"FF_REG_c")         \n\t" // R7
++        "movq %%mm0, (%0, %2, 4)                \n\t" // L4
++        "movq %%mm1, (%0, %%"FF_REG_d")         \n\t" // L5
++        "movq %%mm2, (%0, %%"FF_REG_a", 2)      \n\t" // L6
++        "movq %%mm3, (%0, %%"FF_REG_c")         \n\t" // L7
++        "jmp 4f                                 \n\t"
++
++        "3:                                     \n\t"
++        "lea (%%"FF_REG_a", %2, 2), %%"FF_REG_d"\n\t" // 5*stride
++        "lea (%%"FF_REG_d", %2, 2), %%"FF_REG_c"\n\t" // 7*stride
++        "movq (%0), %%mm0                       \n\t" // L0
++        "movq (%0, %2), %%mm1                   \n\t" // L1
++        "movq (%0, %2, 2), %%mm2                \n\t" // L2
++        "movq (%0, %%"FF_REG_a"), %%mm3         \n\t" // L3
++        "movq (%1), %%mm4                       \n\t" // R0
++        "movq (%1, %2), %%mm5                   \n\t" // R1
++        "movq (%1, %2, 2), %%mm6                \n\t" // R2
++        "movq (%1, %%"FF_REG_a"), %%mm7         \n\t" // R3
++        PAVGB(%%mm4, %%mm0)
++        PAVGB(%%mm5, %%mm1)
++        PAVGB(%%mm6, %%mm2)
++        PAVGB(%%mm7, %%mm3)
++        PAVGB(%%mm4, %%mm0)
++        PAVGB(%%mm5, %%mm1)
++        PAVGB(%%mm6, %%mm2)
++        PAVGB(%%mm7, %%mm3)
++        PAVGB(%%mm4, %%mm0)
++        PAVGB(%%mm5, %%mm1)
++        PAVGB(%%mm6, %%mm2)
++        PAVGB(%%mm7, %%mm3)
++        "movq %%mm0, (%1)                       \n\t" // R0
++        "movq %%mm1, (%1, %2)                   \n\t" // R1
++        "movq %%mm2, (%1, %2, 2)                \n\t" // R2
++        "movq %%mm3, (%1, %%"FF_REG_a")         \n\t" // R3
++        "movq %%mm0, (%0)                       \n\t" // L0
++        "movq %%mm1, (%0, %2)                   \n\t" // L1
++        "movq %%mm2, (%0, %2, 2)                \n\t" // L2
++        "movq %%mm3, (%0, %%"FF_REG_a")         \n\t" // L3
++
++        "movq (%0, %2, 4), %%mm0                \n\t" // L4
++        "movq (%0, %%"FF_REG_d"), %%mm1         \n\t" // L5
++        "movq (%0, %%"FF_REG_a", 2), %%mm2      \n\t" // L6
++        "movq (%0, %%"FF_REG_c"), %%mm3         \n\t" // L7
++        "movq (%1, %2, 4), %%mm4                \n\t" // R4
++        "movq (%1, %%"FF_REG_d"), %%mm5         \n\t" // R5
++        "movq (%1, %%"FF_REG_a", 2), %%mm6      \n\t" // R6
++        "movq (%1, %%"FF_REG_c"), %%mm7         \n\t" // R7
++        PAVGB(%%mm4, %%mm0)
++        PAVGB(%%mm5, %%mm1)
++        PAVGB(%%mm6, %%mm2)
++        PAVGB(%%mm7, %%mm3)
++        PAVGB(%%mm4, %%mm0)
++        PAVGB(%%mm5, %%mm1)
++        PAVGB(%%mm6, %%mm2)
++        PAVGB(%%mm7, %%mm3)
++        PAVGB(%%mm4, %%mm0)
++        PAVGB(%%mm5, %%mm1)
++        PAVGB(%%mm6, %%mm2)
++        PAVGB(%%mm7, %%mm3)
++        "movq %%mm0, (%1, %2, 4)                \n\t" // R4
++        "movq %%mm1, (%1, %%"FF_REG_d")         \n\t" // R5
++        "movq %%mm2, (%1, %%"FF_REG_a", 2)      \n\t" // R6
++        "movq %%mm3, (%1, %%"FF_REG_c")         \n\t" // R7
++        "movq %%mm0, (%0, %2, 4)                \n\t" // L4
++        "movq %%mm1, (%0, %%"FF_REG_d")         \n\t" // L5
++        "movq %%mm2, (%0, %%"FF_REG_a", 2)      \n\t" // L6
++        "movq %%mm3, (%0, %%"FF_REG_c")         \n\t" // L7
++
++        "4:                                     \n\t"
++
++        :: "r" (src), "r" (tempBlurred), "r"((x86_reg)stride), "m" (tempBlurredPast)
++          NAMED_CONSTRAINTS_ADD(b80)
++        : "%"FF_REG_a, "%"FF_REG_d, "%"FF_REG_c, "memory"
++    );
++#else //TEMPLATE_PP_MMXEXT && HAVE_6REGS
++{
++    int y;
++    int d=0;
++//    int sysd=0;
++    int i;
++
++    for(y=0; y<8; y++){
++        int x;
++        for(x=0; x<8; x++){
++            int ref= tempBlurred[ x + y*stride ];
++            int cur= src[ x + y*stride ];
++            int d1=ref - cur;
++//            if(x==0 || x==7) d1+= d1>>1;
++//            if(y==0 || y==7) d1+= d1>>1;
++//            d+= FFABS(d1);
++            d+= d1*d1;
++//            sysd+= d1;
++        }
++    }
++    i=d;
++    d=  (
++        4*d
++        +(*(tempBlurredPast-256))
++        +(*(tempBlurredPast-1))+ (*(tempBlurredPast+1))
++        +(*(tempBlurredPast+256))
++        +4)>>3;
++    *tempBlurredPast=i;
++//    ((*tempBlurredPast)*3 + d + 2)>>2;
++
++/*
++Switch between
++ 1  0  0  0  0  0  0  (0)
++64 32 16  8  4  2  1  (1)
++64 48 36 27 20 15 11 (33) (approx)
++64 56 49 43 37 33 29 (200) (approx)
++*/
++    if(d > maxNoise[1]){
++        if(d < maxNoise[2]){
++            for(y=0; y<8; y++){
++                int x;
++                for(x=0; x<8; x++){
++                    int ref= tempBlurred[ x + y*stride ];
++                    int cur= src[ x + y*stride ];
++                    tempBlurred[ x + y*stride ]=
++                    src[ x + y*stride ]=
++                        (ref + cur + 1)>>1;
++                }
++            }
++        }else{
++            for(y=0; y<8; y++){
++                int x;
++                for(x=0; x<8; x++){
++                    tempBlurred[ x + y*stride ]= src[ x + y*stride ];
++                }
++            }
++        }
++    }else{
++        if(d < maxNoise[0]){
++            for(y=0; y<8; y++){
++                int x;
++                for(x=0; x<8; x++){
++                    int ref= tempBlurred[ x + y*stride ];
++                    int cur= src[ x + y*stride ];
++                    tempBlurred[ x + y*stride ]=
++                    src[ x + y*stride ]=
++                        (ref*7 + cur + 4)>>3;
++                }
++            }
++        }else{
++            for(y=0; y<8; y++){
++                int x;
++                for(x=0; x<8; x++){
++                    int ref= tempBlurred[ x + y*stride ];
++                    int cur= src[ x + y*stride ];
++                    tempBlurred[ x + y*stride ]=
++                    src[ x + y*stride ]=
++                        (ref*3 + cur + 2)>>2;
++                }
++            }
++        }
++    }
++}
++#endif //TEMPLATE_PP_MMXEXT && HAVE_6REGS
++}
++#endif //TEMPLATE_PP_ALTIVEC
++
++#if TEMPLATE_PP_MMXEXT
++/**
++ * accurate deblock filter
++ */
++static av_always_inline void RENAME(do_a_deblock)(uint8_t *src, int step, int stride, const PPContext *c, int mode){
++    int64_t dc_mask, eq_mask, both_masks;
++    int64_t sums[10*8*2];
++    src+= step*3; // src points to begin of the 8x8 Block
++
++    __asm__ volatile(
++        "movq %0, %%mm7                         \n\t"
++        "movq %1, %%mm6                         \n\t"
++        : : "m" (c->mmxDcOffset[c->nonBQP]),  "m" (c->mmxDcThreshold[c->nonBQP])
++        );
++
++    __asm__ volatile(
++        "lea (%2, %3), %%"FF_REG_a"             \n\t"
++//      0       1       2       3       4       5       6       7       8       9
++//      %1      eax     eax+%2  eax+2%2 %1+4%2  ecx     ecx+%2  ecx+2%2 %1+8%2  ecx+4%2
++
++        "movq (%2), %%mm0                       \n\t"
++        "movq (%%"FF_REG_a"), %%mm1             \n\t"
++        "movq %%mm1, %%mm3                      \n\t"
++        "movq %%mm1, %%mm4                      \n\t"
++        "psubb %%mm1, %%mm0                     \n\t" // mm0 = difference
++        "paddb %%mm7, %%mm0                     \n\t"
++        "pcmpgtb %%mm6, %%mm0                   \n\t"
++
++        "movq (%%"FF_REG_a",%3), %%mm2          \n\t"
++        PMAXUB(%%mm2, %%mm4)
++        PMINUB(%%mm2, %%mm3, %%mm5)
++        "psubb %%mm2, %%mm1                     \n\t"
++        "paddb %%mm7, %%mm1                     \n\t"
++        "pcmpgtb %%mm6, %%mm1                   \n\t"
++        "paddb %%mm1, %%mm0                     \n\t"
++
++        "movq (%%"FF_REG_a", %3, 2), %%mm1      \n\t"
++        PMAXUB(%%mm1, %%mm4)
++        PMINUB(%%mm1, %%mm3, %%mm5)
++        "psubb %%mm1, %%mm2                     \n\t"
++        "paddb %%mm7, %%mm2                     \n\t"
++        "pcmpgtb %%mm6, %%mm2                   \n\t"
++        "paddb %%mm2, %%mm0                     \n\t"
++
++        "lea (%%"FF_REG_a", %3, 4), %%"FF_REG_a"\n\t"
++
++        "movq (%2, %3, 4), %%mm2                \n\t"
++        PMAXUB(%%mm2, %%mm4)
++        PMINUB(%%mm2, %%mm3, %%mm5)
++        "psubb %%mm2, %%mm1                     \n\t"
++        "paddb %%mm7, %%mm1                     \n\t"
++        "pcmpgtb %%mm6, %%mm1                   \n\t"
++        "paddb %%mm1, %%mm0                     \n\t"
++
++        "movq (%%"FF_REG_a"), %%mm1             \n\t"
++        PMAXUB(%%mm1, %%mm4)
++        PMINUB(%%mm1, %%mm3, %%mm5)
++        "psubb %%mm1, %%mm2                     \n\t"
++        "paddb %%mm7, %%mm2                     \n\t"
++        "pcmpgtb %%mm6, %%mm2                   \n\t"
++        "paddb %%mm2, %%mm0                     \n\t"
++
++        "movq (%%"FF_REG_a", %3), %%mm2         \n\t"
++        PMAXUB(%%mm2, %%mm4)
++        PMINUB(%%mm2, %%mm3, %%mm5)
++        "psubb %%mm2, %%mm1                     \n\t"
++        "paddb %%mm7, %%mm1                     \n\t"
++        "pcmpgtb %%mm6, %%mm1                   \n\t"
++        "paddb %%mm1, %%mm0                     \n\t"
++
++        "movq (%%"FF_REG_a", %3, 2), %%mm1      \n\t"
++        PMAXUB(%%mm1, %%mm4)
++        PMINUB(%%mm1, %%mm3, %%mm5)
++        "psubb %%mm1, %%mm2                     \n\t"
++        "paddb %%mm7, %%mm2                     \n\t"
++        "pcmpgtb %%mm6, %%mm2                   \n\t"
++        "paddb %%mm2, %%mm0                     \n\t"
++
++        "movq (%2, %3, 8), %%mm2                \n\t"
++        PMAXUB(%%mm2, %%mm4)
++        PMINUB(%%mm2, %%mm3, %%mm5)
++        "psubb %%mm2, %%mm1                     \n\t"
++        "paddb %%mm7, %%mm1                     \n\t"
++        "pcmpgtb %%mm6, %%mm1                   \n\t"
++        "paddb %%mm1, %%mm0                     \n\t"
++
++        "movq (%%"FF_REG_a", %3, 4), %%mm1      \n\t"
++        "psubb %%mm1, %%mm2                     \n\t"
++        "paddb %%mm7, %%mm2                     \n\t"
++        "pcmpgtb %%mm6, %%mm2                   \n\t"
++        "paddb %%mm2, %%mm0                     \n\t"
++        "psubusb %%mm3, %%mm4                   \n\t"
++
++        "pxor %%mm6, %%mm6                      \n\t"
++        "movq %4, %%mm7                         \n\t" // QP,..., QP
++        "paddusb %%mm7, %%mm7                   \n\t" // 2QP ... 2QP
++        "psubusb %%mm4, %%mm7                   \n\t" // Diff >=2QP -> 0
++        "pcmpeqb %%mm6, %%mm7                   \n\t" // Diff < 2QP -> 0
++        "pcmpeqb %%mm6, %%mm7                   \n\t" // Diff < 2QP -> 0
++        "movq %%mm7, %1                         \n\t"
++
++        "movq %5, %%mm7                         \n\t"
++        "punpcklbw %%mm7, %%mm7                 \n\t"
++        "punpcklbw %%mm7, %%mm7                 \n\t"
++        "punpcklbw %%mm7, %%mm7                 \n\t"
++        "psubb %%mm0, %%mm6                     \n\t"
++        "pcmpgtb %%mm7, %%mm6                   \n\t"
++        "movq %%mm6, %0                         \n\t"
++
++        : "=m" (eq_mask), "=m" (dc_mask)
++        : "r" (src), "r" ((x86_reg)step), "m" (c->pQPb), "m"(c->ppMode.flatnessThreshold)
++        : "%"FF_REG_a
++    );
++
++    both_masks = dc_mask & eq_mask;
++
++    if(both_masks){
++        x86_reg offset= -8*step;
++        int64_t *temp_sums= sums;
++
++        __asm__ volatile(
++            "movq %2, %%mm0                         \n\t"  // QP,..., QP
++            "pxor %%mm4, %%mm4                      \n\t"
++
++            "movq (%0), %%mm6                       \n\t"
++            "movq (%0, %1), %%mm5                   \n\t"
++            "movq %%mm5, %%mm1                      \n\t"
++            "movq %%mm6, %%mm2                      \n\t"
++            "psubusb %%mm6, %%mm5                   \n\t"
++            "psubusb %%mm1, %%mm2                   \n\t"
++            "por %%mm5, %%mm2                       \n\t" // ABS Diff of lines
++            "psubusb %%mm2, %%mm0                   \n\t" // diff >= QP -> 0
++            "pcmpeqb %%mm4, %%mm0                   \n\t" // diff >= QP -> FF
++
++            "pxor %%mm6, %%mm1                      \n\t"
++            "pand %%mm0, %%mm1                      \n\t"
++            "pxor %%mm1, %%mm6                      \n\t"
++            // 0:QP  6:First
++
++            "movq (%0, %1, 8), %%mm5                \n\t"
++            "add %1, %0                             \n\t" // %0 points to line 1 not 0
++            "movq (%0, %1, 8), %%mm7                \n\t"
++            "movq %%mm5, %%mm1                      \n\t"
++            "movq %%mm7, %%mm2                      \n\t"
++            "psubusb %%mm7, %%mm5                   \n\t"
++            "psubusb %%mm1, %%mm2                   \n\t"
++            "por %%mm5, %%mm2                       \n\t" // ABS Diff of lines
++            "movq %2, %%mm0                         \n\t"  // QP,..., QP
++            "psubusb %%mm2, %%mm0                   \n\t" // diff >= QP -> 0
++            "pcmpeqb %%mm4, %%mm0                   \n\t" // diff >= QP -> FF
++
++            "pxor %%mm7, %%mm1                      \n\t"
++            "pand %%mm0, %%mm1                      \n\t"
++            "pxor %%mm1, %%mm7                      \n\t"
++
++            "movq %%mm6, %%mm5                      \n\t"
++            "punpckhbw %%mm4, %%mm6                 \n\t"
++            "punpcklbw %%mm4, %%mm5                 \n\t"
++            // 4:0 5/6:First 7:Last
++
++            "movq %%mm5, %%mm0                      \n\t"
++            "movq %%mm6, %%mm1                      \n\t"
++            "psllw $2, %%mm0                        \n\t"
++            "psllw $2, %%mm1                        \n\t"
++            "paddw "MANGLE(w04)", %%mm0             \n\t"
++            "paddw "MANGLE(w04)", %%mm1             \n\t"
++
++#define NEXT\
++            "movq (%0), %%mm2                       \n\t"\
++            "movq (%0), %%mm3                       \n\t"\
++            "add %1, %0                             \n\t"\
++            "punpcklbw %%mm4, %%mm2                 \n\t"\
++            "punpckhbw %%mm4, %%mm3                 \n\t"\
++            "paddw %%mm2, %%mm0                     \n\t"\
++            "paddw %%mm3, %%mm1                     \n\t"
++
++#define PREV\
++            "movq (%0), %%mm2                       \n\t"\
++            "movq (%0), %%mm3                       \n\t"\
++            "add %1, %0                             \n\t"\
++            "punpcklbw %%mm4, %%mm2                 \n\t"\
++            "punpckhbw %%mm4, %%mm3                 \n\t"\
++            "psubw %%mm2, %%mm0                     \n\t"\
++            "psubw %%mm3, %%mm1                     \n\t"
++
++
++            NEXT //0
++            NEXT //1
++            NEXT //2
++            "movq %%mm0, (%3)                       \n\t"
++            "movq %%mm1, 8(%3)                      \n\t"
++
++            NEXT //3
++            "psubw %%mm5, %%mm0                     \n\t"
++            "psubw %%mm6, %%mm1                     \n\t"
++            "movq %%mm0, 16(%3)                     \n\t"
++            "movq %%mm1, 24(%3)                     \n\t"
++
++            NEXT //4
++            "psubw %%mm5, %%mm0                     \n\t"
++            "psubw %%mm6, %%mm1                     \n\t"
++            "movq %%mm0, 32(%3)                     \n\t"
++            "movq %%mm1, 40(%3)                     \n\t"
++
++            NEXT //5
++            "psubw %%mm5, %%mm0                     \n\t"
++            "psubw %%mm6, %%mm1                     \n\t"
++            "movq %%mm0, 48(%3)                     \n\t"
++            "movq %%mm1, 56(%3)                     \n\t"
++
++            NEXT //6
++            "psubw %%mm5, %%mm0                     \n\t"
++            "psubw %%mm6, %%mm1                     \n\t"
++            "movq %%mm0, 64(%3)                     \n\t"
++            "movq %%mm1, 72(%3)                     \n\t"
++
++            "movq %%mm7, %%mm6                      \n\t"
++            "punpckhbw %%mm4, %%mm7                 \n\t"
++            "punpcklbw %%mm4, %%mm6                 \n\t"
++
++            NEXT //7
++            "mov %4, %0                             \n\t"
++            "add %1, %0                             \n\t"
++            PREV //0
++            "movq %%mm0, 80(%3)                     \n\t"
++            "movq %%mm1, 88(%3)                     \n\t"
++
++            PREV //1
++            "paddw %%mm6, %%mm0                     \n\t"
++            "paddw %%mm7, %%mm1                     \n\t"
++            "movq %%mm0, 96(%3)                     \n\t"
++            "movq %%mm1, 104(%3)                    \n\t"
++
++            PREV //2
++            "paddw %%mm6, %%mm0                     \n\t"
++            "paddw %%mm7, %%mm1                     \n\t"
++            "movq %%mm0, 112(%3)                    \n\t"
++            "movq %%mm1, 120(%3)                    \n\t"
++
++            PREV //3
++            "paddw %%mm6, %%mm0                     \n\t"
++            "paddw %%mm7, %%mm1                     \n\t"
++            "movq %%mm0, 128(%3)                    \n\t"
++            "movq %%mm1, 136(%3)                    \n\t"
++
++            PREV //4
++            "paddw %%mm6, %%mm0                     \n\t"
++            "paddw %%mm7, %%mm1                     \n\t"
++            "movq %%mm0, 144(%3)                    \n\t"
++            "movq %%mm1, 152(%3)                    \n\t"
++
++            "mov %4, %0                             \n\t" //FIXME
++
++            : "+&r"(src)
++            : "r" ((x86_reg)step), "m" (c->pQPb), "r"(sums), "g"(src)
++              NAMED_CONSTRAINTS_ADD(w04)
++        );
++
++        src+= step; // src points to begin of the 8x8 Block
++
++        __asm__ volatile(
++            "movq %4, %%mm6                         \n\t"
++            "pcmpeqb %%mm5, %%mm5                   \n\t"
++            "pxor %%mm6, %%mm5                      \n\t"
++            "pxor %%mm7, %%mm7                      \n\t"
++
++            "1:                                     \n\t"
++            "movq (%1), %%mm0                       \n\t"
++            "movq 8(%1), %%mm1                      \n\t"
++            "paddw 32(%1), %%mm0                    \n\t"
++            "paddw 40(%1), %%mm1                    \n\t"
++            "movq (%0, %3), %%mm2                   \n\t"
++            "movq %%mm2, %%mm3                      \n\t"
++            "movq %%mm2, %%mm4                      \n\t"
++            "punpcklbw %%mm7, %%mm2                 \n\t"
++            "punpckhbw %%mm7, %%mm3                 \n\t"
++            "paddw %%mm2, %%mm0                     \n\t"
++            "paddw %%mm3, %%mm1                     \n\t"
++            "paddw %%mm2, %%mm0                     \n\t"
++            "paddw %%mm3, %%mm1                     \n\t"
++            "psrlw $4, %%mm0                        \n\t"
++            "psrlw $4, %%mm1                        \n\t"
++            "packuswb %%mm1, %%mm0                  \n\t"
++            "pand %%mm6, %%mm0                      \n\t"
++            "pand %%mm5, %%mm4                      \n\t"
++            "por %%mm4, %%mm0                       \n\t"
++            "movq %%mm0, (%0, %3)                   \n\t"
++            "add $16, %1                            \n\t"
++            "add %2, %0                             \n\t"
++            " js 1b                                 \n\t"
++
++            : "+r"(offset), "+r"(temp_sums)
++            : "r" ((x86_reg)step), "r"(src - offset), "m"(both_masks)
++        );
++    }else
++        src+= step; // src points to begin of the 8x8 Block
++
++    if(eq_mask != -1LL){
++        uint8_t *temp_src= src;
++        DECLARE_ALIGNED(8, uint64_t, tmp)[4]; // make space for 4 8-byte vars
++        __asm__ volatile(
++            "pxor %%mm7, %%mm7                      \n\t"
++//      0       1       2       3       4       5       6       7       8       9
++//      %0      eax     eax+%1  eax+2%1 %0+4%1  ecx     ecx+%1  ecx+2%1 %1+8%1  ecx+4%1
++
++            "movq (%0), %%mm0                       \n\t"
++            "movq %%mm0, %%mm1                      \n\t"
++            "punpcklbw %%mm7, %%mm0                 \n\t" // low part of line 0
++            "punpckhbw %%mm7, %%mm1                 \n\t" // high part of line 0
++
++            "movq (%0, %1), %%mm2                   \n\t"
++            "lea (%0, %1, 2), %%"FF_REG_a"          \n\t"
++            "movq %%mm2, %%mm3                      \n\t"
++            "punpcklbw %%mm7, %%mm2                 \n\t" // low part of line 1
++            "punpckhbw %%mm7, %%mm3                 \n\t" // high part of line 1
++
++            "movq (%%"FF_REG_a"), %%mm4             \n\t"
++            "movq %%mm4, %%mm5                      \n\t"
++            "punpcklbw %%mm7, %%mm4                 \n\t" // low part of line 2
++            "punpckhbw %%mm7, %%mm5                 \n\t" // high part of line 2
++
++            "paddw %%mm0, %%mm0                     \n\t" // 2L0
++            "paddw %%mm1, %%mm1                     \n\t" // 2H0
++            "psubw %%mm4, %%mm2                     \n\t" // L1 - L2
++            "psubw %%mm5, %%mm3                     \n\t" // H1 - H2
++            "psubw %%mm2, %%mm0                     \n\t" // 2L0 - L1 + L2
++            "psubw %%mm3, %%mm1                     \n\t" // 2H0 - H1 + H2
++
++            "psllw $2, %%mm2                        \n\t" // 4L1 - 4L2
++            "psllw $2, %%mm3                        \n\t" // 4H1 - 4H2
++            "psubw %%mm2, %%mm0                     \n\t" // 2L0 - 5L1 + 5L2
++            "psubw %%mm3, %%mm1                     \n\t" // 2H0 - 5H1 + 5H2
++
++            "movq (%%"FF_REG_a", %1), %%mm2         \n\t"
++            "movq %%mm2, %%mm3                      \n\t"
++            "punpcklbw %%mm7, %%mm2                 \n\t" // L3
++            "punpckhbw %%mm7, %%mm3                 \n\t" // H3
++
++            "psubw %%mm2, %%mm0                     \n\t" // 2L0 - 5L1 + 5L2 - L3
++            "psubw %%mm3, %%mm1                     \n\t" // 2H0 - 5H1 + 5H2 - H3
++            "psubw %%mm2, %%mm0                     \n\t" // 2L0 - 5L1 + 5L2 - 2L3
++            "psubw %%mm3, %%mm1                     \n\t" // 2H0 - 5H1 + 5H2 - 2H3
++            "movq %%mm0, (%4)                       \n\t" // 2L0 - 5L1 + 5L2 - 2L3
++            "movq %%mm1, 8(%4)                      \n\t" // 2H0 - 5H1 + 5H2 - 2H3
++
++            "movq (%%"FF_REG_a", %1, 2), %%mm0      \n\t"
++            "movq %%mm0, %%mm1                      \n\t"
++            "punpcklbw %%mm7, %%mm0                 \n\t" // L4
++            "punpckhbw %%mm7, %%mm1                 \n\t" // H4
++
++            "psubw %%mm0, %%mm2                     \n\t" // L3 - L4
++            "psubw %%mm1, %%mm3                     \n\t" // H3 - H4
++            "movq %%mm2, 16(%4)                     \n\t" // L3 - L4
++            "movq %%mm3, 24(%4)                     \n\t" // H3 - H4
++            "paddw %%mm4, %%mm4                     \n\t" // 2L2
++            "paddw %%mm5, %%mm5                     \n\t" // 2H2
++            "psubw %%mm2, %%mm4                     \n\t" // 2L2 - L3 + L4
++            "psubw %%mm3, %%mm5                     \n\t" // 2H2 - H3 + H4
++
++            "lea (%%"FF_REG_a", %1), %0             \n\t"
++            "psllw $2, %%mm2                        \n\t" // 4L3 - 4L4
++            "psllw $2, %%mm3                        \n\t" // 4H3 - 4H4
++            "psubw %%mm2, %%mm4                     \n\t" // 2L2 - 5L3 + 5L4
++            "psubw %%mm3, %%mm5                     \n\t" // 2H2 - 5H3 + 5H4
++//50 opcodes so far
++            "movq (%0, %1, 2), %%mm2                \n\t"
++            "movq %%mm2, %%mm3                      \n\t"
++            "punpcklbw %%mm7, %%mm2                 \n\t" // L5
++            "punpckhbw %%mm7, %%mm3                 \n\t" // H5
++            "psubw %%mm2, %%mm4                     \n\t" // 2L2 - 5L3 + 5L4 - L5
++            "psubw %%mm3, %%mm5                     \n\t" // 2H2 - 5H3 + 5H4 - H5
++            "psubw %%mm2, %%mm4                     \n\t" // 2L2 - 5L3 + 5L4 - 2L5
++            "psubw %%mm3, %%mm5                     \n\t" // 2H2 - 5H3 + 5H4 - 2H5
++
++            "movq (%%"FF_REG_a", %1, 4), %%mm6      \n\t"
++            "punpcklbw %%mm7, %%mm6                 \n\t" // L6
++            "psubw %%mm6, %%mm2                     \n\t" // L5 - L6
++            "movq (%%"FF_REG_a", %1, 4), %%mm6      \n\t"
++            "punpckhbw %%mm7, %%mm6                 \n\t" // H6
++            "psubw %%mm6, %%mm3                     \n\t" // H5 - H6
++
++            "paddw %%mm0, %%mm0                     \n\t" // 2L4
++            "paddw %%mm1, %%mm1                     \n\t" // 2H4
++            "psubw %%mm2, %%mm0                     \n\t" // 2L4 - L5 + L6
++            "psubw %%mm3, %%mm1                     \n\t" // 2H4 - H5 + H6
++
++            "psllw $2, %%mm2                        \n\t" // 4L5 - 4L6
++            "psllw $2, %%mm3                        \n\t" // 4H5 - 4H6
++            "psubw %%mm2, %%mm0                     \n\t" // 2L4 - 5L5 + 5L6
++            "psubw %%mm3, %%mm1                     \n\t" // 2H4 - 5H5 + 5H6
++
++            "movq (%0, %1, 4), %%mm2                \n\t"
++            "movq %%mm2, %%mm3                      \n\t"
++            "punpcklbw %%mm7, %%mm2                 \n\t" // L7
++            "punpckhbw %%mm7, %%mm3                 \n\t" // H7
++
++            "paddw %%mm2, %%mm2                     \n\t" // 2L7
++            "paddw %%mm3, %%mm3                     \n\t" // 2H7
++            "psubw %%mm2, %%mm0                     \n\t" // 2L4 - 5L5 + 5L6 - 2L7
++            "psubw %%mm3, %%mm1                     \n\t" // 2H4 - 5H5 + 5H6 - 2H7
++
++            "movq (%4), %%mm2                       \n\t" // 2L0 - 5L1 + 5L2 - 2L3
++            "movq 8(%4), %%mm3                      \n\t" // 2H0 - 5H1 + 5H2 - 2H3
++
++            "movq %%mm7, %%mm6                      \n\t" // 0
++            "psubw %%mm0, %%mm6                     \n\t"
++            "pmaxsw %%mm6, %%mm0                    \n\t" // |2L4 - 5L5 + 5L6 - 2L7|
++            "movq %%mm7, %%mm6                      \n\t" // 0
++            "psubw %%mm1, %%mm6                     \n\t"
++            "pmaxsw %%mm6, %%mm1                    \n\t" // |2H4 - 5H5 + 5H6 - 2H7|
++            "movq %%mm7, %%mm6                      \n\t" // 0
++            "psubw %%mm2, %%mm6                     \n\t"
++            "pmaxsw %%mm6, %%mm2                    \n\t" // |2L0 - 5L1 + 5L2 - 2L3|
++            "movq %%mm7, %%mm6                      \n\t" // 0
++            "psubw %%mm3, %%mm6                     \n\t"
++            "pmaxsw %%mm6, %%mm3                    \n\t" // |2H0 - 5H1 + 5H2 - 2H3|
++
++            "pminsw %%mm2, %%mm0                    \n\t"
++            "pminsw %%mm3, %%mm1                    \n\t"
++
++            "movd %2, %%mm2                         \n\t" // QP
++            "punpcklbw %%mm7, %%mm2                 \n\t"
++
++            "movq %%mm7, %%mm6                      \n\t" // 0
++            "pcmpgtw %%mm4, %%mm6                   \n\t" // sign(2L2 - 5L3 + 5L4 - 2L5)
++            "pxor %%mm6, %%mm4                      \n\t"
++            "psubw %%mm6, %%mm4                     \n\t" // |2L2 - 5L3 + 5L4 - 2L5|
++            "pcmpgtw %%mm5, %%mm7                   \n\t" // sign(2H2 - 5H3 + 5H4 - 2H5)
++            "pxor %%mm7, %%mm5                      \n\t"
++            "psubw %%mm7, %%mm5                     \n\t" // |2H2 - 5H3 + 5H4 - 2H5|
++// 100 opcodes
++            "psllw $3, %%mm2                        \n\t" // 8QP
++            "movq %%mm2, %%mm3                      \n\t" // 8QP
++            "pcmpgtw %%mm4, %%mm2                   \n\t"
++            "pcmpgtw %%mm5, %%mm3                   \n\t"
++            "pand %%mm2, %%mm4                      \n\t"
++            "pand %%mm3, %%mm5                      \n\t"
++
++
++            "psubusw %%mm0, %%mm4                   \n\t" // hd
++            "psubusw %%mm1, %%mm5                   \n\t" // ld
++
++
++            "movq "MANGLE(w05)", %%mm2              \n\t" // 5
++            "pmullw %%mm2, %%mm4                    \n\t"
++            "pmullw %%mm2, %%mm5                    \n\t"
++            "movq "MANGLE(w20)", %%mm2              \n\t" // 32
++            "paddw %%mm2, %%mm4                     \n\t"
++            "paddw %%mm2, %%mm5                     \n\t"
++            "psrlw $6, %%mm4                        \n\t"
++            "psrlw $6, %%mm5                        \n\t"
++
++            "movq 16(%4), %%mm0                     \n\t" // L3 - L4
++            "movq 24(%4), %%mm1                     \n\t" // H3 - H4
++
++            "pxor %%mm2, %%mm2                      \n\t"
++            "pxor %%mm3, %%mm3                      \n\t"
++
++            "pcmpgtw %%mm0, %%mm2                   \n\t" // sign (L3-L4)
++            "pcmpgtw %%mm1, %%mm3                   \n\t" // sign (H3-H4)
++            "pxor %%mm2, %%mm0                      \n\t"
++            "pxor %%mm3, %%mm1                      \n\t"
++            "psubw %%mm2, %%mm0                     \n\t" // |L3-L4|
++            "psubw %%mm3, %%mm1                     \n\t" // |H3-H4|
++            "psrlw $1, %%mm0                        \n\t" // |L3 - L4|/2
++            "psrlw $1, %%mm1                        \n\t" // |H3 - H4|/2
++
++            "pxor %%mm6, %%mm2                      \n\t"
++            "pxor %%mm7, %%mm3                      \n\t"
++            "pand %%mm2, %%mm4                      \n\t"
++            "pand %%mm3, %%mm5                      \n\t"
++
++            "pminsw %%mm0, %%mm4                    \n\t"
++            "pminsw %%mm1, %%mm5                    \n\t"
++            "pxor %%mm6, %%mm4                      \n\t"
++            "pxor %%mm7, %%mm5                      \n\t"
++            "psubw %%mm6, %%mm4                     \n\t"
++            "psubw %%mm7, %%mm5                     \n\t"
++            "packsswb %%mm5, %%mm4                  \n\t"
++            "movq %3, %%mm1                         \n\t"
++            "pandn %%mm4, %%mm1                     \n\t"
++            "movq (%0), %%mm0                       \n\t"
++            "paddb   %%mm1, %%mm0                   \n\t"
++            "movq %%mm0, (%0)                       \n\t"
++            "movq (%0, %1), %%mm0                   \n\t"
++            "psubb %%mm1, %%mm0                     \n\t"
++            "movq %%mm0, (%0, %1)                   \n\t"
++
++            : "+r" (temp_src)
++            : "r" ((x86_reg)step), "m" (c->pQPb), "m"(eq_mask), "r"(tmp)
++              NAMED_CONSTRAINTS_ADD(w05,w20)
++            : "%"FF_REG_a
++        );
++    }
++}
++#endif //TEMPLATE_PP_MMX
++
++static void RENAME(postProcess)(const uint8_t src[], int srcStride, uint8_t dst[], int dstStride, int width, int height,
++                                const int8_t QPs[], int QPStride, int isColor, PPContext *c);
++
++/**
++ * Copy a block from src to dst and fixes the blacklevel.
++ * levelFix == 0 -> do not touch the brightness & contrast
++ */
++#undef REAL_SCALED_CPY
++#undef SCALED_CPY
++
++static inline void RENAME(blockCopy)(uint8_t dst[], int dstStride, const uint8_t src[], int srcStride,
++                                     int levelFix, int64_t *packedOffsetAndScale)
++{
++    if(levelFix){
++#if TEMPLATE_PP_MMXEXT && HAVE_6REGS
++    __asm__ volatile(
++        "movq (%%"FF_REG_a"), %%mm2     \n\t" // packedYOffset
++        "movq 8(%%"FF_REG_a"), %%mm3    \n\t" // packedYScale
++        "lea (%2,%4), %%"FF_REG_a"      \n\t"
++        "lea (%3,%5), %%"FF_REG_d"      \n\t"
++        "pxor %%mm4, %%mm4              \n\t"
++#define REAL_SCALED_CPY(src1, src2, dst1, dst2)                                                \
++        "movq " #src1 ", %%mm0          \n\t"\
++        "movq " #src1 ", %%mm5          \n\t"\
++        "movq " #src2 ", %%mm1          \n\t"\
++        "movq " #src2 ", %%mm6          \n\t"\
++        "punpcklbw %%mm0, %%mm0         \n\t"\
++        "punpckhbw %%mm5, %%mm5         \n\t"\
++        "punpcklbw %%mm1, %%mm1         \n\t"\
++        "punpckhbw %%mm6, %%mm6         \n\t"\
++        "pmulhuw %%mm3, %%mm0           \n\t"\
++        "pmulhuw %%mm3, %%mm5           \n\t"\
++        "pmulhuw %%mm3, %%mm1           \n\t"\
++        "pmulhuw %%mm3, %%mm6           \n\t"\
++        "psubw %%mm2, %%mm0             \n\t"\
++        "psubw %%mm2, %%mm5             \n\t"\
++        "psubw %%mm2, %%mm1             \n\t"\
++        "psubw %%mm2, %%mm6             \n\t"\
++        "packuswb %%mm5, %%mm0          \n\t"\
++        "packuswb %%mm6, %%mm1          \n\t"\
++        "movq %%mm0, " #dst1 "          \n\t"\
++        "movq %%mm1, " #dst2 "          \n\t"\
++
++#define SCALED_CPY(src1, src2, dst1, dst2)\
++   REAL_SCALED_CPY(src1, src2, dst1, dst2)
++
++SCALED_CPY((%2)       , (%2, %4)      , (%3)       , (%3, %5))
++SCALED_CPY((%2, %4, 2), (%%FF_REGa, %4, 2), (%3, %5, 2), (%%FF_REGd, %5, 2))
++SCALED_CPY((%2, %4, 4), (%%FF_REGa, %4, 4), (%3, %5, 4), (%%FF_REGd, %5, 4))
++        "lea (%%"FF_REG_a",%4,4), %%"FF_REG_a"        \n\t"
++        "lea (%%"FF_REG_d",%5,4), %%"FF_REG_d"        \n\t"
++SCALED_CPY((%%FF_REGa, %4), (%%FF_REGa, %4, 2), (%%FF_REGd, %5), (%%FF_REGd, %5, 2))
++
++
++        : "=&a" (packedOffsetAndScale)
++        : "0" (packedOffsetAndScale),
++        "r"(src),
++        "r"(dst),
++        "r" ((x86_reg)srcStride),
++        "r" ((x86_reg)dstStride)
++        : "%"FF_REG_d
++    );
++#else //TEMPLATE_PP_MMX && HAVE_6REGS
++    for (int i = 0; i < 8; i++)
++        memcpy( &(dst[dstStride*i]),
++                &(src[srcStride*i]), BLOCK_SIZE);
++#endif //TEMPLATE_PP_MMX && HAVE_6REGS
++    }else{
++#if TEMPLATE_PP_MMX && HAVE_6REGS
++    __asm__ volatile(
++        "lea (%0,%2), %%"FF_REG_a"      \n\t"
++        "lea (%1,%3), %%"FF_REG_d"      \n\t"
++
++#define REAL_SIMPLE_CPY(src1, src2, dst1, dst2)                              \
++        "movq " #src1 ", %%mm0          \n\t"\
++        "movq " #src2 ", %%mm1          \n\t"\
++        "movq %%mm0, " #dst1 "          \n\t"\
++        "movq %%mm1, " #dst2 "          \n\t"\
++
++#define SIMPLE_CPY(src1, src2, dst1, dst2)\
++   REAL_SIMPLE_CPY(src1, src2, dst1, dst2)
++
++SIMPLE_CPY((%0)       , (%0, %2)          , (%1)       , (%1, %3))
++SIMPLE_CPY((%0, %2, 2), (%%FF_REGa, %2, 2), (%1, %3, 2), (%%FF_REGd, %3, 2))
++SIMPLE_CPY((%0, %2, 4), (%%FF_REGa, %2, 4), (%1, %3, 4), (%%FF_REGd, %3, 4))
++        "lea (%%"FF_REG_a",%2,4), %%"FF_REG_a"        \n\t"
++        "lea (%%"FF_REG_d",%3,4), %%"FF_REG_d"        \n\t"
++SIMPLE_CPY((%%FF_REGa, %2), (%%FF_REGa, %2, 2), (%%FF_REGd, %3), (%%FF_REGd, %3, 2))
++
++        : : "r" (src),
++        "r" (dst),
++        "r" ((x86_reg)srcStride),
++        "r" ((x86_reg)dstStride)
++        : "%"FF_REG_a, "%"FF_REG_d
++    );
++#else //TEMPLATE_PP_MMX && HAVE_6REGS
++    for (int i = 0; i < 8; i++)
++        memcpy( &(dst[dstStride*i]),
++                &(src[srcStride*i]), BLOCK_SIZE);
++#endif //TEMPLATE_PP_MMX && HAVE_6REGS
++    }
++}
++
++/**
++ * Duplicate the given 8 src pixels ? times upward
++ */
++static inline void RENAME(duplicate)(uint8_t src[], int stride)
++{
++#if TEMPLATE_PP_MMX
++    __asm__ volatile(
++        "movq (%0), %%mm0               \n\t"
++        "movq %%mm0, (%0, %1, 4)        \n\t"
++        "add %1, %0                     \n\t"
++        "movq %%mm0, (%0)               \n\t"
++        "movq %%mm0, (%0, %1)           \n\t"
++        "movq %%mm0, (%0, %1, 2)        \n\t"
++        "movq %%mm0, (%0, %1, 4)        \n\t"
++        : "+r" (src)
++        : "r" ((x86_reg)-stride)
++    );
++#else
++    int i;
++    uint8_t *p=src;
++    for(i=0; i<5; i++){
++        p-= stride;
++        memcpy(p, src, 8);
++    }
++#endif
++}
++
++#if ARCH_X86 && TEMPLATE_PP_MMXEXT
++static inline void RENAME(prefetchnta)(const void *p)
++{
++    __asm__ volatile(   "prefetchnta (%0)\n\t"
++        : : "r" (p)
++    );
++}
++
++static inline void RENAME(prefetcht0)(const void *p)
++{
++    __asm__ volatile(   "prefetcht0 (%0)\n\t"
++        : : "r" (p)
++    );
++}
++
++static inline void RENAME(prefetcht1)(const void *p)
++{
++    __asm__ volatile(   "prefetcht1 (%0)\n\t"
++        : : "r" (p)
++    );
++}
++
++static inline void RENAME(prefetcht2)(const void *p)
++{
++    __asm__ volatile(   "prefetcht2 (%0)\n\t"
++        : : "r" (p)
++    );
++}
++#elif !ARCH_X86 && AV_GCC_VERSION_AT_LEAST(3,2)
++static inline void RENAME(prefetchnta)(const void *p)
++{
++    __builtin_prefetch(p,0,0);
++}
++static inline void RENAME(prefetcht0)(const void *p)
++{
++    __builtin_prefetch(p,0,1);
++}
++static inline void RENAME(prefetcht1)(const void *p)
++{
++    __builtin_prefetch(p,0,2);
++}
++static inline void RENAME(prefetcht2)(const void *p)
++{
++    __builtin_prefetch(p,0,3);
++}
++#else
++static inline void RENAME(prefetchnta)(const void *p)
++{
++    return;
++}
++static inline void RENAME(prefetcht0)(const void *p)
++{
++    return;
++}
++static inline void RENAME(prefetcht1)(const void *p)
++{
++    return;
++}
++static inline void RENAME(prefetcht2)(const void *p)
++{
++    return;
++}
++#endif
++/**
++ * Filter array of bytes (Y or U or V values)
++ */
++static void RENAME(postProcess)(const uint8_t src[], int srcStride, uint8_t dst[], int dstStride, int width, int height,
++                                const int8_t QPs[], int QPStride, int isColor, PPContext *c)
++{
++    int x,y;
++#ifdef TEMPLATE_PP_TIME_MODE
++    const int mode= TEMPLATE_PP_TIME_MODE;
++#else
++    const int mode = isColor ? c->ppMode.chromMode : c->ppMode.lumMode;
++#endif
++    int black=0, white=255; // blackest black and whitest white in the picture
++    int QPCorrecture= 256*256;
++
++    int copyAhead;
++#if TEMPLATE_PP_MMX
++    int i;
++#endif
++
++    const int qpHShift = isColor ? 4 - c->hChromaSubSample : 4;
++    const int qpVShift = isColor ? 4 - c->vChromaSubSample : 4;
++
++    //FIXME remove
++    uint64_t * const yHistogram= c->yHistogram;
++    uint8_t * const tempSrc =  srcStride > 0 ? c->tempSrc : c->tempSrc - 23*srcStride;
++    uint8_t * const tempDst = (dstStride > 0 ? c->tempDst : c->tempDst - 23*dstStride) + 32;
++    //const int mbWidth= isColor ? (width+7)>>3 : (width+15)>>4;
++
++    if (mode & VISUALIZE){
++        if(!(mode & (V_A_DEBLOCK | H_A_DEBLOCK)) || TEMPLATE_PP_MMX) {
++            av_log(c, AV_LOG_WARNING, "Visualization is currently only supported with the accurate deblock filter without SIMD\n");
++        }
++    }
++
++#if TEMPLATE_PP_MMX
++    for(i=0; i<57; i++){
++        int offset = ((i * c->ppMode.baseDcDiff) >> 8) + 1;
++        int threshold= offset*2 + 1;
++        c->mmxDcOffset[i]     = 0x7F - offset;
++        c->mmxDcThreshold[i]  = 0x7F - threshold;
++        c->mmxDcOffset[i]    *= 0x0101010101010101LL;
++        c->mmxDcThreshold[i] *= 0x0101010101010101LL;
++    }
++#endif
++
++    if(mode & CUBIC_IPOL_DEINT_FILTER) copyAhead=16;
++    else if(   (mode & LINEAR_BLEND_DEINT_FILTER)
++            || (mode & FFMPEG_DEINT_FILTER)
++            || (mode & LOWPASS5_DEINT_FILTER)) copyAhead=14;
++    else if(   (mode & V_DEBLOCK)
++            || (mode & LINEAR_IPOL_DEINT_FILTER)
++            || (mode & MEDIAN_DEINT_FILTER)
++            || (mode & V_A_DEBLOCK)) copyAhead=13;
++    else if(mode & V_X1_FILTER) copyAhead=11;
++//    else if(mode & V_RK1_FILTER) copyAhead=10;
++    else if(mode & DERING) copyAhead=9;
++    else copyAhead=8;
++
++    copyAhead-= 8;
++
++    if(!isColor){
++        uint64_t sum= 0;
++        int i;
++        uint64_t maxClipped;
++        uint64_t clipped;
++        AVRational scale;
++
++        c->frameNum++;
++        // first frame is fscked so we ignore it
++        if (c->frameNum == 1)
++            yHistogram[0] = width * (uint64_t)height/64*15/256;
++
++        for(i=0; i<256; i++){
++            sum+= yHistogram[i];
++        }
++
++        /* We always get a completely black picture first. */
++        maxClipped = av_rescale(sum, c->ppMode.maxClippedThreshold.num,
++                                     c->ppMode.maxClippedThreshold.den);
++
++        clipped= sum;
++        for(black=255; black>0; black--){
++            if(clipped < maxClipped) break;
++            clipped-= yHistogram[black];
++        }
++
++        clipped= sum;
++        for(white=0; white<256; white++){
++            if(clipped < maxClipped) break;
++            clipped-= yHistogram[white];
++        }
++
++        scale = (AVRational){c->ppMode.maxAllowedY - c->ppMode.minAllowedY, white - black};
++
++#if TEMPLATE_PP_MMXEXT
++        c->packedYScale  = (uint16_t)av_rescale(scale.num, 256, scale.den);
++        c->packedYOffset = (((black*c->packedYScale)>>8) - c->ppMode.minAllowedY) & 0xFFFF;
++#else
++        c->packedYScale  = (uint16_t)av_rescale(scale.num, 1024, scale.den);
++        c->packedYOffset = (black - c->ppMode.minAllowedY) & 0xFFFF;
++#endif
++
++        c->packedYOffset |= c->packedYOffset<<32;
++        c->packedYOffset |= c->packedYOffset<<16;
++
++        c->packedYScale |= c->packedYScale<<32;
++        c->packedYScale |= c->packedYScale<<16;
++
++        if(mode & LEVEL_FIX)        QPCorrecture= (int)av_rescale(scale.num, 256*256, scale.den);
++        else                        QPCorrecture= 256*256;
++    }else{
++        c->packedYScale  = 0x0100010001000100LL;
++        c->packedYOffset = 0;
++        QPCorrecture= 256*256;
++    }
++
++    /* copy & deinterlace first row of blocks */
++    y=-BLOCK_SIZE;
++    {
++        const uint8_t *srcBlock= &(src[y*srcStride]);
++        uint8_t *dstBlock= tempDst + dstStride;
++
++        // From this point on it is guaranteed that we can read and write 16 lines downward
++        // finish 1 block before the next otherwise we might have a problem
++        // with the L1 Cache of the P4 ... or only a few blocks at a time or something
++        for(x=0; x<width; x+=BLOCK_SIZE){
++            RENAME(prefetchnta)(srcBlock + (((x>>2)&6) + copyAhead)*srcStride + 32);
++            RENAME(prefetchnta)(srcBlock + (((x>>2)&6) + copyAhead+1)*srcStride + 32);
++            RENAME(prefetcht0)(dstBlock + (((x>>2)&6) + copyAhead)*dstStride + 32);
++            RENAME(prefetcht0)(dstBlock + (((x>>2)&6) + copyAhead+1)*dstStride + 32);
++
++            RENAME(blockCopy)(dstBlock + dstStride*8, dstStride,
++                              srcBlock + srcStride*8, srcStride, mode & LEVEL_FIX, &c->packedYOffset);
++
++            RENAME(duplicate)(dstBlock + dstStride*8, dstStride);
++
++            if(mode & LINEAR_IPOL_DEINT_FILTER)
++                RENAME(deInterlaceInterpolateLinear)(dstBlock, dstStride);
++            else if(mode & LINEAR_BLEND_DEINT_FILTER)
++                RENAME(deInterlaceBlendLinear)(dstBlock, dstStride, c->deintTemp + x);
++            else if(mode & MEDIAN_DEINT_FILTER)
++                RENAME(deInterlaceMedian)(dstBlock, dstStride);
++            else if(mode & CUBIC_IPOL_DEINT_FILTER)
++                RENAME(deInterlaceInterpolateCubic)(dstBlock, dstStride);
++            else if(mode & FFMPEG_DEINT_FILTER)
++                RENAME(deInterlaceFF)(dstBlock, dstStride, c->deintTemp + x);
++            else if(mode & LOWPASS5_DEINT_FILTER)
++                RENAME(deInterlaceL5)(dstBlock, dstStride, c->deintTemp + x, c->deintTemp + width + x);
++/*          else if(mode & CUBIC_BLEND_DEINT_FILTER)
++                RENAME(deInterlaceBlendCubic)(dstBlock, dstStride);
++*/
++            dstBlock+=8;
++            srcBlock+=8;
++        }
++        if(width==FFABS(dstStride))
++            linecpy(dst, tempDst + 9*dstStride, copyAhead, dstStride);
++        else{
++            int i;
++            for(i=0; i<copyAhead; i++){
++                memcpy(dst + i*dstStride, tempDst + (9+i)*dstStride, width);
++            }
++        }
++    }
++
++    for(y=0; y<height; y+=BLOCK_SIZE){
++        //1% speedup if these are here instead of the inner loop
++        const uint8_t *srcBlock= &(src[y*srcStride]);
++        uint8_t *dstBlock= &(dst[y*dstStride]);
++#if TEMPLATE_PP_MMX
++        uint8_t *tempBlock1 = c->tempBlocks;
++        uint8_t *tempBlock2 = c->tempBlocks + 8;
++#endif
++        const int8_t *QPptr= &QPs[(y>>qpVShift)*QPStride];
++        int8_t *nonBQPptr = &c->nonBQPTable[(y>>qpVShift)*FFABS(QPStride)];
++        int QP=0, nonBQP=0;
++        /* can we mess with a 8x16 block from srcBlock/dstBlock downwards and 1 line upwards
++           if not than use a temporary buffer */
++        if(y+15 >= height){
++            int i;
++            /* copy from line (copyAhead) to (copyAhead+7) of src, these will be copied with
++               blockcopy to dst later */
++            linecpy(tempSrc + srcStride*copyAhead, srcBlock + srcStride*copyAhead,
++                    FFMAX(height-y-copyAhead, 0), srcStride);
++
++            /* duplicate last line of src to fill the void up to line (copyAhead+7) */
++            for(i=FFMAX(height-y, 8); i<copyAhead+8; i++)
++                    memcpy(tempSrc + srcStride*i, src + srcStride*(height-1), FFABS(srcStride));
++
++            /* copy up to (copyAhead+1) lines of dst (line -1 to (copyAhead-1))*/
++            linecpy(tempDst, dstBlock - dstStride, FFMIN(height-y+1, copyAhead+1), dstStride);
++
++            /* duplicate last line of dst to fill the void up to line (copyAhead) */
++            for(i=height-y+1; i<=copyAhead; i++)
++                    memcpy(tempDst + dstStride*i, dst + dstStride*(height-1), FFABS(dstStride));
++
++            dstBlock= tempDst + dstStride;
++            srcBlock= tempSrc;
++        }
++
++        // From this point on it is guaranteed that we can read and write 16 lines downward
++        // finish 1 block before the next otherwise we might have a problem
++        // with the L1 Cache of the P4 ... or only a few blocks at a time or something
++        for(x=0; x<width; ){
++            int startx = x;
++            int endx = FFMIN(width, x+32);
++            uint8_t *dstBlockStart = dstBlock;
++            const uint8_t *srcBlockStart = srcBlock;
++            int qp_index = 0;
++            for(qp_index=0; qp_index < (endx-startx)/BLOCK_SIZE; qp_index++){
++                QP = QPptr[(x+qp_index*BLOCK_SIZE)>>qpHShift];
++                nonBQP = nonBQPptr[(x+qp_index*BLOCK_SIZE)>>qpHShift];
++            if(!isColor){
++                QP= (QP* QPCorrecture + 256*128)>>16;
++                nonBQP= (nonBQP* QPCorrecture + 256*128)>>16;
++                yHistogram[(srcBlock+qp_index*8)[srcStride*12 + 4]]++;
++            }
++            c->QP_block[qp_index] = QP;
++            c->nonBQP_block[qp_index] = nonBQP;
++#if TEMPLATE_PP_MMX
++            __asm__ volatile(
++                "movd %1, %%mm7         \n\t"
++                "packuswb %%mm7, %%mm7  \n\t" // 0, 0, 0, QP, 0, 0, 0, QP
++                "packuswb %%mm7, %%mm7  \n\t" // 0,QP, 0, QP, 0,QP, 0, QP
++                "packuswb %%mm7, %%mm7  \n\t" // QP,..., QP
++                "movq %%mm7, %0         \n\t"
++                : "=m" (c->pQPb_block[qp_index])
++                : "r" (QP)
++            );
++#endif
++            }
++          for(; x < endx; x+=BLOCK_SIZE){
++            RENAME(prefetchnta)(srcBlock + (((x>>2)&6) + copyAhead)*srcStride + 32);
++            RENAME(prefetchnta)(srcBlock + (((x>>2)&6) + copyAhead+1)*srcStride + 32);
++            RENAME(prefetcht0)(dstBlock + (((x>>2)&6) + copyAhead)*dstStride + 32);
++            RENAME(prefetcht0)(dstBlock + (((x>>2)&6) + copyAhead+1)*dstStride + 32);
++
++            RENAME(blockCopy)(dstBlock + dstStride*copyAhead, dstStride,
++                              srcBlock + srcStride*copyAhead, srcStride, mode & LEVEL_FIX, &c->packedYOffset);
++
++            if(mode & LINEAR_IPOL_DEINT_FILTER)
++                RENAME(deInterlaceInterpolateLinear)(dstBlock, dstStride);
++            else if(mode & LINEAR_BLEND_DEINT_FILTER)
++                RENAME(deInterlaceBlendLinear)(dstBlock, dstStride, c->deintTemp + x);
++            else if(mode & MEDIAN_DEINT_FILTER)
++                RENAME(deInterlaceMedian)(dstBlock, dstStride);
++            else if(mode & CUBIC_IPOL_DEINT_FILTER)
++                RENAME(deInterlaceInterpolateCubic)(dstBlock, dstStride);
++            else if(mode & FFMPEG_DEINT_FILTER)
++                RENAME(deInterlaceFF)(dstBlock, dstStride, c->deintTemp + x);
++            else if(mode & LOWPASS5_DEINT_FILTER)
++                RENAME(deInterlaceL5)(dstBlock, dstStride, c->deintTemp + x, c->deintTemp + width + x);
++/*          else if(mode & CUBIC_BLEND_DEINT_FILTER)
++                RENAME(deInterlaceBlendCubic)(dstBlock, dstStride);
++*/
++            dstBlock+=8;
++            srcBlock+=8;
++          }
++
++          dstBlock = dstBlockStart;
++          srcBlock = srcBlockStart;
++
++          for(x = startx, qp_index = 0; x < endx; x+=BLOCK_SIZE, qp_index++){
++            const int stride= dstStride;
++            //temporary while changing QP stuff to make things continue to work
++            //eventually QP,nonBQP,etc will be arrays and this will be unnecessary
++            c->QP     = c->QP_block[qp_index];
++            c->nonBQP = c->nonBQP_block[qp_index];
++            c->pQPb   = c->pQPb_block[qp_index];
++            c->pQPb2  = c->pQPb2_block[qp_index];
++
++            /* only deblock if we have 2 blocks */
++            if(y + 8 < height){
++                if(mode & V_X1_FILTER)
++                    RENAME(vertX1Filter)(dstBlock, stride, c);
++                else if(mode & V_DEBLOCK){
++                    const int t = RENAME(vertClassify)(dstBlock, stride, c);
++
++                    if(t==1)
++                        RENAME(doVertLowPass)(dstBlock, stride, c);
++                    else if(t==2)
++                        RENAME(doVertDefFilter)(dstBlock, stride, c);
++                }else if(mode & V_A_DEBLOCK){
++                    RENAME(do_a_deblock)(dstBlock, stride, 1, c, mode);
++                }
++            }
++
++            dstBlock+=8;
++            srcBlock+=8;
++          }
++
++          dstBlock = dstBlockStart;
++          srcBlock = srcBlockStart;
++
++          for(x = startx, qp_index=0; x < endx; x+=BLOCK_SIZE, qp_index++){
++            const int stride= dstStride;
++            c->QP     = c->QP_block[qp_index];
++            c->nonBQP = c->nonBQP_block[qp_index];
++            c->pQPb   = c->pQPb_block[qp_index];
++            c->pQPb2  = c->pQPb2_block[qp_index];
++#if TEMPLATE_PP_MMX
++            RENAME(transpose1)(tempBlock1, tempBlock2, dstBlock, dstStride);
++#endif
++            /* check if we have a previous block to deblock it with dstBlock */
++            if(x - 8 >= 0){
++#if TEMPLATE_PP_MMX
++                if(mode & H_X1_FILTER)
++                        RENAME(vertX1Filter)(tempBlock1, 16, c);
++                else if(mode & H_DEBLOCK){
++                    const int t= RENAME(vertClassify)(tempBlock1, 16, c);
++                    if(t==1)
++                        RENAME(doVertLowPass)(tempBlock1, 16, c);
++                    else if(t==2)
++                        RENAME(doVertDefFilter)(tempBlock1, 16, c);
++                }else if(mode & H_A_DEBLOCK){
++                        RENAME(do_a_deblock)(tempBlock1, 16, 1, c, mode);
++                }
++
++                RENAME(transpose2)(dstBlock-4, dstStride, tempBlock1 + 4*16);
++
++#else
++                if(mode & H_X1_FILTER)
++                    horizX1Filter(dstBlock-4, stride, c->QP);
++                else if(mode & H_DEBLOCK){
++#if TEMPLATE_PP_ALTIVEC
++                    DECLARE_ALIGNED(16, unsigned char, tempBlock)[272];
++                    int t;
++                    transpose_16x8_char_toPackedAlign_altivec(tempBlock, dstBlock - (4 + 1), stride);
++
++                    t = vertClassify_altivec(tempBlock-48, 16, c);
++                    if(t==1) {
++                        doVertLowPass_altivec(tempBlock-48, 16, c);
++                        transpose_8x16_char_fromPackedAlign_altivec(dstBlock - (4 + 1), tempBlock, stride);
++                    }
++                    else if(t==2) {
++                        doVertDefFilter_altivec(tempBlock-48, 16, c);
++                        transpose_8x16_char_fromPackedAlign_altivec(dstBlock - (4 + 1), tempBlock, stride);
++                    }
++#else
++                    const int t= RENAME(horizClassify)(dstBlock-4, stride, c);
++
++                    if(t==1)
++                        RENAME(doHorizLowPass)(dstBlock-4, stride, c);
++                    else if(t==2)
++                        RENAME(doHorizDefFilter)(dstBlock-4, stride, c);
++#endif
++                }else if(mode & H_A_DEBLOCK){
++                    RENAME(do_a_deblock)(dstBlock-8, 1, stride, c, mode);
++                }
++#endif //TEMPLATE_PP_MMX
++                if(mode & DERING){
++                    RENAME(dering)(dstBlock - stride - 8, stride, c, x<=8, 0, y<=0);
++                }
++
++                if(mode & TEMP_NOISE_FILTER)
++                {
++                    RENAME(tempNoiseReducer)(dstBlock-8, stride,
++                            c->tempBlurred[isColor] + y*dstStride + x,
++                            c->tempBlurredPast[isColor] + (y>>3)*256 + (x>>3) + 256,
++                            c->ppMode.maxTmpNoise);
++                }
++            }
++
++            dstBlock+=8;
++            srcBlock+=8;
++
++#if TEMPLATE_PP_MMX
++            FFSWAP(uint8_t *, tempBlock1, tempBlock2);
++#endif
++          }
++        }
++
++        if(mode & DERING){
++            RENAME(dering)(dstBlock - dstStride - 8, dstStride, c, x<=8, 1, y<=0);
++        }
++
++        if((mode & TEMP_NOISE_FILTER)){
++            RENAME(tempNoiseReducer)(dstBlock-8, dstStride,
++                    c->tempBlurred[isColor] + y*dstStride + x,
++                    c->tempBlurredPast[isColor] + (y>>3)*256 + (x>>3) + 256,
++                    c->ppMode.maxTmpNoise);
++        }
++
++        /* did we use a tmp buffer for the last lines*/
++        if(y+15 >= height){
++            uint8_t *dstBlock= &(dst[y*dstStride]);
++            if(width==FFABS(dstStride))
++                linecpy(dstBlock, tempDst + dstStride, height-y, dstStride);
++            else{
++                int i;
++                for(i=0; i<height-y; i++){
++                    memcpy(dstBlock + i*dstStride, tempDst + (i+1)*dstStride, width);
++                }
++            }
++        }
++    }
++#if TEMPLATE_PP_MMX
++    __asm__ volatile("emms");
++#endif
++
++#ifdef DEBUG_BRIGHTNESS
++    if(!isColor){
++        int max=1;
++        int i;
++        for(i=0; i<256; i++)
++            if(yHistogram[i] > max) max=yHistogram[i];
++
++        for(i=1; i<256; i++){
++            int x;
++            int start=yHistogram[i-1]/(max/256+1);
++            int end=yHistogram[i]/(max/256+1);
++            int inc= end > start ? 1 : -1;
++            for(x=start; x!=end+inc; x+=inc)
++                dst[ i*dstStride + x]+=128;
++        }
++
++        for(i=0; i<100; i+=2){
++            dst[ (white)*dstStride + i]+=128;
++            dst[ (black)*dstStride + i]+=128;
++        }
++    }
++#endif
++}
++
++#undef RENAME
++#undef TEMPLATE_PP_C
++#undef TEMPLATE_PP_ALTIVEC
++#undef TEMPLATE_PP_MMX
++#undef TEMPLATE_PP_MMXEXT
++#undef TEMPLATE_PP_SSE2
+diff --git a/libpostproc/postprocres.rc b/libpostproc/postprocres.rc
+new file mode 100644
+index 0000000000000..e6104ac88bfea
+--- /dev/null
++++ b/libpostproc/postprocres.rc
+@@ -0,0 +1,55 @@
++/*
++ * Windows resource file for libpostproc
++ *
++ * Copyright (C) 2012 James Almer
++ * Copyright (C) 2013 Tiancheng "Timothy" Gu
++ *
++ * This file is part of FFmpeg.
++ *
++ * FFmpeg is free software; you can redistribute it and/or
++ * modify it under the terms of the GNU Lesser General Public
++ * License as published by the Free Software Foundation; either
++ * version 2.1 of the License, or (at your option) any later version.
++ *
++ * FFmpeg is distributed in the hope that it will be useful,
++ * but WITHOUT ANY WARRANTY; without even the implied warranty of
++ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
++ * Lesser General Public License for more details.
++ *
++ * You should have received a copy of the GNU Lesser General Public
++ * License along with FFmpeg; if not, write to the Free Software
++ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
++ */
++
++#include <windows.h>
++#include "libpostproc/version.h"
++#include "libavutil/ffversion.h"
++#include "config.h"
++
++1 VERSIONINFO
++FILEVERSION     LIBPOSTPROC_VERSION_MAJOR, LIBPOSTPROC_VERSION_MINOR, LIBPOSTPROC_VERSION_MICRO, 0
++PRODUCTVERSION  LIBPOSTPROC_VERSION_MAJOR, LIBPOSTPROC_VERSION_MINOR, LIBPOSTPROC_VERSION_MICRO, 0
++FILEFLAGSMASK   VS_FFI_FILEFLAGSMASK
++FILEOS          VOS_NT_WINDOWS32
++FILETYPE        VFT_DLL
++{
++    BLOCK "StringFileInfo"
++    {
++        BLOCK "040904B0"
++        {
++            VALUE "CompanyName",      "FFmpeg Project"
++            VALUE "FileDescription",  "FFmpeg postprocessing library"
++            VALUE "FileVersion",      AV_STRINGIFY(LIBPOSTPROC_VERSION)
++            VALUE "InternalName",     "libpostproc"
++            VALUE "LegalCopyright",   "Copyright (C) 2000-" AV_STRINGIFY(CONFIG_THIS_YEAR) " FFmpeg Project"
++            VALUE "OriginalFilename", "postproc" BUILDSUF "-" AV_STRINGIFY(LIBPOSTPROC_VERSION_MAJOR) SLIBSUF
++            VALUE "ProductName",      "FFmpeg"
++            VALUE "ProductVersion",   FFMPEG_VERSION
++        }
++    }
++
++    BLOCK "VarFileInfo"
++    {
++        VALUE "Translation", 0x0409, 0x04B0
++    }
++}
+diff --git a/libpostproc/tests/.gitignore b/libpostproc/tests/.gitignore
+new file mode 100644
+index 0000000000000..60dc67fa74f13
+--- /dev/null
++++ b/libpostproc/tests/.gitignore
+@@ -0,0 +1,3 @@
++/blocktest
++/stripetest
++/temptest
+diff --git a/libpostproc/tests/blocktest.c b/libpostproc/tests/blocktest.c
+new file mode 100644
+index 0000000000000..e91fb0b569461
+--- /dev/null
++++ b/libpostproc/tests/blocktest.c
+@@ -0,0 +1,113 @@
++/*
++ * Copyright (c) 2025 Michael Niedermayer
++ *
++ * This file is part of FFmpeg.
++ *
++ * FFmpeg is free software; you can redistribute it and/or
++ * modify it under the terms of the GNU Lesser General Public
++ * License as published by the Free Software Foundation; either
++ * version 2.1 of the License, or (at your option) any later version.
++ *
++ * FFmpeg is distributed in the hope that it will be useful,
++ * but WITHOUT ANY WARRANTY; without even the implied warranty of
++ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
++ * Lesser General Public License for more details.
++ *
++ * You should have received a copy of the GNU Lesser General Public
++ * License along with FFmpeg; if not, write to the Free Software
++ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
++ */
++
++#include "libavutil/frame.h"
++#include "libavutil/adler32.h"
++#include "libpostproc/postprocess.h"
++#include "test_utils.h"
++
++typedef const uint8_t *cuint8;
++
++static void blocks(AVFrame *frame, int blocksize, int mul)
++{
++    for(int y=0; y<frame->height; y++) {
++        for(int x=0; x<frame->width; x++) {
++            frame->data[0][x + y*frame->linesize[0]] = x/blocksize*mul + y/blocksize*mul;
++        }
++    }
++    for(int y=0; y<(frame->height+1)/2; y++) {
++        for(int x=0; x<(frame->width+1)/2; x++) {
++            frame->data[1][x + y*frame->linesize[1]] = x/blocksize*mul + y/blocksize*mul;
++            frame->data[2][x + y*frame->linesize[2]] = x/blocksize * (y/blocksize)*mul;
++        }
++    }
++}
++
++static int64_t test(int width, int height, const char * filter_string, int blocksize, int flags, int pict_type, int quality) {
++    AVFrame *in  = av_frame_alloc();
++    AVFrame *out = av_frame_alloc();
++    pp_context *context = pp_get_context(width, height, flags);
++    pp_mode *mode = pp_get_mode_by_name_and_quality(filter_string, quality);
++    int64_t ret;
++#define  QP_STRIDE (352/16)
++    int8_t qp[QP_STRIDE * 352/16];
++
++    if (!in || !out || !context || !mode) {
++        ret = AVERROR(ENOMEM);
++        goto end;
++    }
++
++    in-> width = out->width  = width;
++    in->height = out->height = height;
++    in->format = out->format = AV_PIX_FMT_YUV420P;
++
++    ret = av_frame_get_buffer(in, 0);
++    if (ret < 0)
++        goto end;
++
++    ret = av_frame_get_buffer(out, 0);
++    if (ret < 0)
++        goto end;
++
++    blocks(in, blocksize, 11);
++
++    for(int i= 0; i<sizeof(qp); i++)
++        qp[i] = i % 31;
++
++    pp_postprocess( (cuint8[]){in->data[0], in->data[1], in->data[2]}, in->linesize,
++                   out->data, out->linesize,
++                   width, height, qp, QP_STRIDE,
++                   mode, context, pict_type);
++
++    ret = ff_chksum(out);
++end:
++    av_frame_free(&in);
++    av_frame_free(&out);
++    pp_free_context(context);
++    pp_free_mode(mode);
++
++    return ret;
++}
++
++int main(int argc, char **argv) {
++    const char *teststrings[] = {
++        "be,de",
++        "be,h1,v1",
++        "be,ha,va",
++        "be,al,de",
++        "be,vi,de",
++        "be,vi,ha,va",
++    };
++
++    for (int w=16; w< 352; w=w*3-16) {
++        for (int h=16; h< 352; h=h*5-16) {
++            for (int b=1; b<17; b*=2) {
++                for (int c=0; c<6; c++) {
++                    for (int q=0; q<17; q = 2*q+1) {
++                        int64_t ret = test(w, h, teststrings[c], b, PP_FORMAT_420, 0, q);
++                        printf("blocktest %dx%d %s b:%d q:%d result %"PRIX64"\n", w, h, teststrings[c], b, q, ret);
++                    }
++                }
++            }
++        }
++    }
++
++    return 0;
++}
+diff --git a/libpostproc/tests/stripetest.c b/libpostproc/tests/stripetest.c
+new file mode 100644
+index 0000000000000..def7aa3756303
+--- /dev/null
++++ b/libpostproc/tests/stripetest.c
+@@ -0,0 +1,115 @@
++/*
++ * Copyright (c) 2025 Michael Niedermayer
++ *
++ * This file is part of FFmpeg.
++ *
++ * FFmpeg is free software; you can redistribute it and/or
++ * modify it under the terms of the GNU Lesser General Public
++ * License as published by the Free Software Foundation; either
++ * version 2.1 of the License, or (at your option) any later version.
++ *
++ * FFmpeg is distributed in the hope that it will be useful,
++ * but WITHOUT ANY WARRANTY; without even the implied warranty of
++ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
++ * Lesser General Public License for more details.
++ *
++ * You should have received a copy of the GNU Lesser General Public
++ * License along with FFmpeg; if not, write to the Free Software
++ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
++ */
++
++#include "libavutil/frame.h"
++#include "libavutil/adler32.h"
++#include "libpostproc/postprocess.h"
++#include "test_utils.h"
++
++typedef const uint8_t *cuint8;
++
++static void strips(AVFrame *frame, int mul)
++{
++    for(int y=0; y<frame->height; y++) {
++        for(int x=0; x<frame->width; x++) {
++            if (y&1) {
++                frame->data[0][x + y*frame->linesize[0]] = x*x + y*mul;
++            } else {
++                frame->data[0][x + y*frame->linesize[0]] = (y-x)*(y-x);
++            }
++        }
++    }
++    for(int y=0; y<(frame->height+1)/2; y++) {
++        for(int x=0; x<(frame->width+1)/2; x++) {
++            if (y&1) {
++                frame->data[1][x + y*frame->linesize[1]] = x + y + mul;
++                frame->data[2][x + y*frame->linesize[2]] = mul*x - y*x;
++            } else {
++                frame->data[1][x + y*frame->linesize[1]] = (x - y)/(mul+1);
++                frame->data[2][x + y*frame->linesize[2]] = (y + x)/(mul+1);
++            }
++        }
++    }
++}
++
++static int64_t test(int width, int height, const char *testname, int mul, int flags, int pict_type, int quality) {
++    AVFrame *in  = av_frame_alloc();
++    AVFrame *out = av_frame_alloc();
++    pp_context *context = pp_get_context(width, height, flags);
++    pp_mode *mode = pp_get_mode_by_name_and_quality(testname, quality);
++    int64_t ret;
++
++    if (!in || !out || !context || !mode) {
++        ret = AVERROR(ENOMEM);
++        goto end;
++    }
++
++    in-> width = out->width  = width;
++    in->height = out->height = height;
++    in->format = out->format = AV_PIX_FMT_YUV420P;
++
++    ret = av_frame_get_buffer(in, 0);
++    if (ret < 0)
++        goto end;
++
++    ret = av_frame_get_buffer(out, 0);
++    if (ret < 0)
++        goto end;
++
++    strips(in, mul);
++
++    pp_postprocess( (cuint8[]){in->data[0], in->data[1], in->data[2]}, in->linesize,
++                   out->data, out->linesize,
++                   width, height, NULL, 0,
++                   mode, context, pict_type);
++
++    ret = ff_chksum(out);
++end:
++    av_frame_free(&in);
++    av_frame_free(&out);
++    pp_free_context(context);
++    pp_free_mode(mode);
++
++    return ret;
++}
++
++int main(int argc, char **argv) {
++    const char *teststrings[] = {
++        "be,lb",
++        "be,li",
++        "be,ci",
++        "be,md",
++        "be,fd",
++        "be,l5",
++    };
++
++    for (int w=16; w< 352; w=w*3-16) {
++        for (int h=16; h< 352; h=h*5-16) {
++            for (int b=0; b<6; b++) {
++                for (int m=0; m<17; m = 2*m+1) {
++                    int64_t ret = test(w, h, teststrings[b], m, PP_FORMAT_420, 0, 11);
++                    printf("striptest %dx%d T:%s m:%d result %"PRIX64"\n", w, h, teststrings[b], m, ret);
++                }
++            }
++        }
++    }
++
++    return 0;
++}
+diff --git a/libpostproc/tests/temptest.c b/libpostproc/tests/temptest.c
+new file mode 100644
+index 0000000000000..26414a1ce3a7b
+--- /dev/null
++++ b/libpostproc/tests/temptest.c
+@@ -0,0 +1,106 @@
++/*
++ * Copyright (c) 2025 Michael Niedermayer
++ *
++ * This file is part of FFmpeg.
++ *
++ * FFmpeg is free software; you can redistribute it and/or
++ * modify it under the terms of the GNU Lesser General Public
++ * License as published by the Free Software Foundation; either
++ * version 2.1 of the License, or (at your option) any later version.
++ *
++ * FFmpeg is distributed in the hope that it will be useful,
++ * but WITHOUT ANY WARRANTY; without even the implied warranty of
++ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
++ * Lesser General Public License for more details.
++ *
++ * You should have received a copy of the GNU Lesser General Public
++ * License along with FFmpeg; if not, write to the Free Software
++ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
++ */
++
++#include "libavutil/frame.h"
++#include "libavutil/adler32.h"
++#include "libpostproc/postprocess.h"
++#include "test_utils.h"
++
++typedef const uint8_t *cuint8;
++
++static void stuff(AVFrame *frame, unsigned *state, int mul)
++{
++    for(int y=0; y<frame->height; y++) {
++        for(int x=0; x<frame->width; x++) {
++            *state= *state*1664525+1013904223;
++            frame->data[0][x + y*frame->linesize[0]] = x*x + (y-x)*mul + ((((x+y)&0xFF)* (int64_t)(*state))>>32);
++        }
++    }
++    for(int y=0; y<(frame->height+1)/2; y++) {
++        for(int x=0; x<(frame->width+1)/2; x++) {
++            *state= *state*1664525+1013904223;
++            frame->data[1][x + y*frame->linesize[1]] = x + y + ((mul*(int64_t)(*state))>>32);
++            frame->data[2][x + y*frame->linesize[2]] = mul*x - ((y*x*(int64_t)(*state))>>32);
++        }
++    }
++}
++
++static int64_t test(int width, int height, const char *testname, int mul, int flags, int pict_type, int quality) {
++    AVFrame *in  = av_frame_alloc();
++    AVFrame *out = av_frame_alloc();
++    pp_context *context = pp_get_context(width, height, flags);
++    pp_mode *mode = pp_get_mode_by_name_and_quality(testname, quality);
++    int64_t ret;
++
++    if (!in || !out || !context || !mode) {
++        ret = AVERROR(ENOMEM);
++        goto end;
++    }
++
++    in-> width = out->width  = width;
++    in->height = out->height = height;
++    in->format = out->format = AV_PIX_FMT_YUV420P;
++
++    ret = av_frame_get_buffer(in, 0);
++    if (ret < 0)
++        goto end;
++
++    ret = av_frame_get_buffer(out, 0);
++    if (ret < 0)
++        goto end;
++
++    unsigned state = mul;
++    for(int f=0; f<10; f++) {
++        stuff(in, &state, mul);
++
++        pp_postprocess( (cuint8[]){in->data[0], in->data[1], in->data[2]}, in->linesize,
++                    out->data, out->linesize,
++                    width, height, NULL, 0,
++                    mode, context, pict_type);
++
++        ret += ff_chksum(out);
++        ret *= 1664525U;
++    }
++end:
++    av_frame_free(&in);
++    av_frame_free(&out);
++    pp_free_context(context);
++    pp_free_mode(mode);
++
++    return ret;
++}
++
++int main(int argc, char **argv) {
++
++    for(int a=0; a<600000; a= 17*a+1) {
++        for(int b=a; b<600000; b= 17*b+1) {
++            for(int c=b; c<600000; c= 17*c+1) {
++                for (int m=0; m<128; m = 3*m+1) {
++                    char buf[100];
++                    snprintf(buf, sizeof(buf), "be,tn:%d:%d:%d", a, b, c);
++                    int64_t ret = test(352, 288, buf, m, PP_FORMAT_420, 0, 11);
++                    printf("temptest %d %d %d %d result %"PRIX64"\n", a,b,c,m, ret);
++                }
++            }
++        }
++    }
++
++    return 0;
++}
+diff --git a/libpostproc/tests/test_utils.c b/libpostproc/tests/test_utils.c
+new file mode 100644
+index 0000000000000..f1642c0c81f68
+--- /dev/null
++++ b/libpostproc/tests/test_utils.c
+@@ -0,0 +1,38 @@
++/*
++ * Copyright (c) 2025 Michael Niedermayer
++ *
++ * This file is part of FFmpeg.
++ *
++ * FFmpeg is free software; you can redistribute it and/or
++ * modify it under the terms of the GNU Lesser General Public
++ * License as published by the Free Software Foundation; either
++ * version 2.1 of the License, or (at your option) any later version.
++ *
++ * FFmpeg is distributed in the hope that it will be useful,
++ * but WITHOUT ANY WARRANTY; without even the implied warranty of
++ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
++ * Lesser General Public License for more details.
++ *
++ * You should have received a copy of the GNU Lesser General Public
++ * License along with FFmpeg; if not, write to the Free Software
++ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
++ */
++
++#include "libavutil/frame.h"
++#include "libavutil/adler32.h"
++#include "test_utils.h"
++
++int64_t ff_chksum(AVFrame *f)
++{
++    AVAdler a = 123;
++
++    for(int y=0; y<f->height; y++) {
++        a = av_adler32_update(a, &f->data[0][y*f->linesize[0]], f->width);
++    }
++    for(int y=0; y<(f->height+1)/2; y++) {
++        a = av_adler32_update(a, &f->data[1][y*f->linesize[1]], (f->width+1)/2);
++        a = av_adler32_update(a, &f->data[2][y*f->linesize[2]], (f->width+1)/2);
++    }
++
++    return a;
++}
+diff --git a/libpostproc/tests/test_utils.h b/libpostproc/tests/test_utils.h
+new file mode 100644
+index 0000000000000..d73ea6cab84cb
+--- /dev/null
++++ b/libpostproc/tests/test_utils.h
+@@ -0,0 +1,27 @@
++/*
++ * Copyright (c) 2025 Michael Niedermayer
++ *
++ * This file is part of FFmpeg.
++ *
++ * FFmpeg is free software; you can redistribute it and/or
++ * modify it under the terms of the GNU Lesser General Public
++ * License as published by the Free Software Foundation; either
++ * version 2.1 of the License, or (at your option) any later version.
++ *
++ * FFmpeg is distributed in the hope that it will be useful,
++ * but WITHOUT ANY WARRANTY; without even the implied warranty of
++ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
++ * Lesser General Public License for more details.
++ *
++ * You should have received a copy of the GNU Lesser General Public
++ * License along with FFmpeg; if not, write to the Free Software
++ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
++ */
++
++
++#ifndef POSTPROC_TESTS_TEST_UTILS_H
++#define POSTPROC_TESTS_TEST_UTILS_H
++
++int64_t ff_chksum(AVFrame *f);
++
++#endif /* POSTPROC_TESTS_TEST_UTILS_H */
+diff --git a/libpostproc/version.c b/libpostproc/version.c
+new file mode 100644
+index 0000000000000..304abe08e6ac2
+--- /dev/null
++++ b/libpostproc/version.c
+@@ -0,0 +1,45 @@
++/*
++ * Version functions.
++ *
++ * This file is part of FFmpeg.
++ *
++ * FFmpeg is free software; you can redistribute it and/or
++ * modify it under the terms of the GNU Lesser General Public
++ * License as published by the Free Software Foundation; either
++ * version 2.1 of the License, or (at your option) any later version.
++ *
++ * FFmpeg is distributed in the hope that it will be useful,
++ * but WITHOUT ANY WARRANTY; without even the implied warranty of
++ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
++ * Lesser General Public License for more details.
++ *
++ * You should have received a copy of the GNU Lesser General Public
++ * License along with FFmpeg; if not, write to the Free Software
++ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
++ */
++
++#include <assert.h>
++
++#include "config.h"
++#include "postprocess.h"
++#include "version.h"
++
++#include "libavutil/ffversion.h"
++const char postproc_ffversion[] = "FFmpeg version " FFMPEG_VERSION;
++
++unsigned postproc_version(void)
++{
++    static_assert(LIBPOSTPROC_VERSION_MICRO >= 100, "micro version starts at 100");
++    return LIBPOSTPROC_VERSION_INT;
++}
++
++const char *postproc_configuration(void)
++{
++    return FFMPEG_CONFIGURATION;
++}
++
++const char *postproc_license(void)
++{
++#define LICENSE_PREFIX "libpostproc license: "
++    return &LICENSE_PREFIX FFMPEG_LICENSE[sizeof(LICENSE_PREFIX) - 1];
++}
+diff --git a/libpostproc/version.h b/libpostproc/version.h
+new file mode 100644
+index 0000000000000..111f075536906
+--- /dev/null
++++ b/libpostproc/version.h
+@@ -0,0 +1,48 @@
++/*
++ * Version macros.
++ *
++ * This file is part of FFmpeg.
++ *
++ * FFmpeg is free software; you can redistribute it and/or
++ * modify it under the terms of the GNU Lesser General Public
++ * License as published by the Free Software Foundation; either
++ * version 2.1 of the License, or (at your option) any later version.
++ *
++ * FFmpeg is distributed in the hope that it will be useful,
++ * but WITHOUT ANY WARRANTY; without even the implied warranty of
++ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
++ * Lesser General Public License for more details.
++ *
++ * You should have received a copy of the GNU Lesser General Public
++ * License along with FFmpeg; if not, write to the Free Software
++ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
++ */
++
++#ifndef POSTPROC_VERSION_H
++#define POSTPROC_VERSION_H
++
++/**
++ * @file
++ * Libpostproc version macros
++ */
++
++#include "libavutil/version.h"
++
++#include "version_major.h"
++
++#define LIBPOSTPROC_VERSION_MINOR   1
++#define LIBPOSTPROC_VERSION_MICRO 100
++
++#define LIBPOSTPROC_VERSION_INT AV_VERSION_INT(LIBPOSTPROC_VERSION_MAJOR, \
++                                               LIBPOSTPROC_VERSION_MINOR, \
++                                               LIBPOSTPROC_VERSION_MICRO)
++#define LIBPOSTPROC_VERSION     AV_VERSION(LIBPOSTPROC_VERSION_MAJOR, \
++                                           LIBPOSTPROC_VERSION_MINOR, \
++                                           LIBPOSTPROC_VERSION_MICRO)
++#define LIBPOSTPROC_BUILD       LIBPOSTPROC_VERSION_INT
++
++#define LIBPOSTPROC_IDENT       "postproc" AV_STRINGIFY(LIBPOSTPROC_VERSION)
++
++#define PP_AMD_3DNOW               (LIBPOSTPROC_VERSION_MAJOR < 60)
++
++#endif /* POSTPROC_VERSION_H */
+diff --git a/libpostproc/version_major.h b/libpostproc/version_major.h
+new file mode 100644
+index 0000000000000..b9946912db383
+--- /dev/null
++++ b/libpostproc/version_major.h
+@@ -0,0 +1,33 @@
++/*
++ * Version macros.
++ *
++ * This file is part of FFmpeg.
++ *
++ * FFmpeg is free software; you can redistribute it and/or
++ * modify it under the terms of the GNU Lesser General Public
++ * License as published by the Free Software Foundation; either
++ * version 2.1 of the License, or (at your option) any later version.
++ *
++ * FFmpeg is distributed in the hope that it will be useful,
++ * but WITHOUT ANY WARRANTY; without even the implied warranty of
++ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
++ * Lesser General Public License for more details.
++ *
++ * You should have received a copy of the GNU Lesser General Public
++ * License along with FFmpeg; if not, write to the Free Software
++ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
++ */
++
++#ifndef POSTPROC_VERSION_MAJOR_H
++#define POSTPROC_VERSION_MAJOR_H
++
++/**
++ * @file
++ * Libpostproc version macros
++ */
++
++#define LIBPOSTPROC_VERSION_MAJOR  59
++
++#define FF_API_PP_AMD_3DNOW      (LIBPOSTPROC_VERSION_MAJOR < 60)
++
++#endif /* POSTPROC_VERSION_MAJOR_H */
+diff --git a/tests/Makefile b/tests/Makefile
+index 505d7f9c6d6d4..c2043310207f8 100644
+--- a/tests/Makefile
++++ b/tests/Makefile
+@@ -208,6 +208,7 @@ include $(SRC_PATH)/tests/fate/libavformat.mak
+ include $(SRC_PATH)/tests/fate/libavutil.mak
+ include $(SRC_PATH)/tests/fate/libswresample.mak
+ include $(SRC_PATH)/tests/fate/libswscale.mak
++include $(SRC_PATH)/tests/fate/libpostproc.mak
+ include $(SRC_PATH)/tests/fate/lossless-audio.mak
+ include $(SRC_PATH)/tests/fate/lossless-video.mak
+ include $(SRC_PATH)/tests/fate/matroska.mak
+diff --git a/tests/fate/filter-video.mak b/tests/fate/filter-video.mak
+index df8a9327506c2..2ae7aed88dab3 100644
+--- a/tests/fate/filter-video.mak
++++ b/tests/fate/filter-video.mak
+@@ -533,6 +533,19 @@ fate-filter-idet: CMD = framecrc -flags bitexact -idct simple -i $(SRC) -vf idet
+ FATE_FILTER_VSYNTH_VIDEO_FILTER-$(CONFIG_PAD_FILTER) += fate-filter-pad
+ fate-filter-pad: CMD = video_filter "pad=iw*1.5:ih*1.5:iw*0.3:ih*0.2"
+ 
++fate-filter-pp1: CMD = video_filter "pp=fq|4/be/hb/vb/tn/l5/al"
++fate-filter-pp2: CMD = video_filter "qp=2*(x+y),pp=be/h1/v1/lb"
++fate-filter-pp3: CMD = video_filter "qp=2*(x+y),pp=be/ha|128|7/va/li"
++fate-filter-pp4: CMD = video_filter "pp=be/ci"
++fate-filter-pp5: CMD = video_filter "pp=md"
++fate-filter-pp6: CMD = video_filter "pp=be/fd"
++
++FATE_FILTER_VSYNTH_VIDEO_FILTER-$(CONFIG_PP_FILTER) += $(addprefix fate-filter-, pp1 pp4 pp5 pp6)
++FATE_FILTER_VSYNTH_VIDEO_FILTER-$(call ALLYES, PP_FILTER QP_FILTER) += fate-filter-pp2 fate-filter-pp3
++
++FATE_FILTER_VSYNTH1_MPEG4_QPRD-$(call FILTERDEMDEC, PP, AVI, MPEG4) += pp
++fate-filter-pp:  CMD = framecrc -flags bitexact -export_side_data venc_params -idct simple -i $(TARGET_PATH)/tests/data/fate/vsynth1-mpeg4-qprd.avi -frames:v 5 -flags +bitexact -vf "pp=be/hb/vb/tn/l5/al"
++
+ FATE_FILTER_VSYNTH1_MPEG4_QPRD-$(call FILTERDEMDEC, PP7, AVI, MPEG4) += pp7
+ fate-filter-pp7: CMD = framecrc -flags bitexact -export_side_data venc_params -idct simple -i $(TARGET_PATH)/tests/data/fate/vsynth1-mpeg4-qprd.avi -frames:v 5 -flags +bitexact -vf "pp7"
+ 
+@@ -550,6 +563,9 @@ FATE_FILTER_VSYNTH-yes += $(FATE_FILTER_VSYNTH1_MPEG4_QPRD)
+ $(FATE_FILTER_VSYNTH1_MPEG4_QPRD): fate-vsynth1-mpeg4-qprd
+ fate-vsynth1-mpeg4-qprd: KEEP_FILES ?= 1
+ 
++FATE_FILTER_VSYNTH_VIDEO_FILTER-$(call ALLYES, QP_FILTER PP_FILTER) += fate-filter-qp
++fate-filter-qp: CMD = video_filter "qp=34,pp=be/hb/vb/tn/l5/al"
++
+ FATE_FILTER_VSYNTH-$(call FILTERDEMDEC, SELECT, IMAGE2, PGM) += fate-filter-select
+ fate-filter-select: CMD = framecrc -flags bitexact -idct simple -i $(SRC) -vf "select=not(eq(mod(n\,2)\,0)+eq(mod(n\,3)\,0))" -frames:v 25 -flags +bitexact
+ 
+diff --git a/tests/fate/libpostproc.mak b/tests/fate/libpostproc.mak
+new file mode 100644
+index 0000000000000..07fb3dcd07b2c
+--- /dev/null
++++ b/tests/fate/libpostproc.mak
+@@ -0,0 +1,14 @@
++FATE_LIBPOSTPROC += fate-blocktest
++fate-blocktest: libpostproc/tests/blocktest$(EXESUF)
++fate-blocktest: CMD = run libpostproc/tests/blocktest$(EXESUF)
++
++FATE_LIBPOSTPROC += fate-stripetest
++fate-stripetest: libpostproc/tests/stripetest$(EXESUF)
++fate-stripetest: CMD = run libpostproc/tests/stripetest$(EXESUF)
++
++FATE_LIBPOSTPROC += fate-temptest
++fate-temptest: libpostproc/tests/temptest$(EXESUF)
++fate-temptest: CMD = run libpostproc/tests/temptest$(EXESUF)
++
++FATE-$(CONFIG_POSTPROC) += $(FATE_LIBPOSTPROC)
++fate-libpostproc: $(FATE_LIBPOSTPROC)
+diff --git a/tests/ref/fate/blocktest b/tests/ref/fate/blocktest
+new file mode 100644
+index 0000000000000..38cf195c95a9b
+--- /dev/null
++++ b/tests/ref/fate/blocktest
+@@ -0,0 +1,1800 @@
++blocktest 16x16 be,de b:1 q:0 result 67B4B06B
++blocktest 16x16 be,de b:1 q:1 result 67B4B06B
++blocktest 16x16 be,de b:1 q:3 result 67B4B06B
++blocktest 16x16 be,de b:1 q:7 result 62C1B05E
++blocktest 16x16 be,de b:1 q:15 result 62C1B05E
++blocktest 16x16 be,h1,v1 b:1 q:0 result 67B4B06B
++blocktest 16x16 be,h1,v1 b:1 q:1 result 67B4B06B
++blocktest 16x16 be,h1,v1 b:1 q:3 result 67B4B06B
++blocktest 16x16 be,h1,v1 b:1 q:7 result 67B4B06B
++blocktest 16x16 be,h1,v1 b:1 q:15 result 67B4B06B
++blocktest 16x16 be,ha,va b:1 q:0 result 67B4B06B
++blocktest 16x16 be,ha,va b:1 q:1 result 67B4B06B
++blocktest 16x16 be,ha,va b:1 q:3 result 67B4B06B
++blocktest 16x16 be,ha,va b:1 q:7 result 67B4B06B
++blocktest 16x16 be,ha,va b:1 q:15 result 67B4B06B
++blocktest 16x16 be,al,de b:1 q:0 result 67B4B06B
++blocktest 16x16 be,al,de b:1 q:1 result 67B4B06B
++blocktest 16x16 be,al,de b:1 q:3 result 67B4B06B
++blocktest 16x16 be,al,de b:1 q:7 result 62C1B05E
++blocktest 16x16 be,al,de b:1 q:15 result 62C1B05E
++blocktest 16x16 be,vi,de b:1 q:0 result 67B4B06B
++blocktest 16x16 be,vi,de b:1 q:1 result 67B4B06B
++blocktest 16x16 be,vi,de b:1 q:3 result 67B4B06B
++blocktest 16x16 be,vi,de b:1 q:7 result 62C1B05E
++blocktest 16x16 be,vi,de b:1 q:15 result 62C1B05E
++blocktest 16x16 be,vi,ha,va b:1 q:0 result 67B4B06B
++blocktest 16x16 be,vi,ha,va b:1 q:1 result 67B4B06B
++blocktest 16x16 be,vi,ha,va b:1 q:3 result 67B4B06B
++blocktest 16x16 be,vi,ha,va b:1 q:7 result 67B4B06B
++blocktest 16x16 be,vi,ha,va b:1 q:15 result 67B4B06B
++blocktest 16x16 be,de b:2 q:0 result BF005BEB
++blocktest 16x16 be,de b:2 q:1 result BF005BEB
++blocktest 16x16 be,de b:2 q:3 result BF005BEB
++blocktest 16x16 be,de b:2 q:7 result BE6E5BEB
++blocktest 16x16 be,de b:2 q:15 result BE6E5BEB
++blocktest 16x16 be,h1,v1 b:2 q:0 result BF005BEB
++blocktest 16x16 be,h1,v1 b:2 q:1 result BF005BEB
++blocktest 16x16 be,h1,v1 b:2 q:3 result BF005BEB
++blocktest 16x16 be,h1,v1 b:2 q:7 result BF005BEB
++blocktest 16x16 be,h1,v1 b:2 q:15 result BF005BEB
++blocktest 16x16 be,ha,va b:2 q:0 result BF005BEB
++blocktest 16x16 be,ha,va b:2 q:1 result BF005BEB
++blocktest 16x16 be,ha,va b:2 q:3 result BF005BEB
++blocktest 16x16 be,ha,va b:2 q:7 result BF005BEB
++blocktest 16x16 be,ha,va b:2 q:15 result BF005BEB
++blocktest 16x16 be,al,de b:2 q:0 result BF005BEB
++blocktest 16x16 be,al,de b:2 q:1 result BF005BEB
++blocktest 16x16 be,al,de b:2 q:3 result BF005BEB
++blocktest 16x16 be,al,de b:2 q:7 result BE6E5BEB
++blocktest 16x16 be,al,de b:2 q:15 result BE6E5BEB
++blocktest 16x16 be,vi,de b:2 q:0 result BF005BEB
++blocktest 16x16 be,vi,de b:2 q:1 result BF005BEB
++blocktest 16x16 be,vi,de b:2 q:3 result BF005BEB
++blocktest 16x16 be,vi,de b:2 q:7 result BE6E5BEB
++blocktest 16x16 be,vi,de b:2 q:15 result BE6E5BEB
++blocktest 16x16 be,vi,ha,va b:2 q:0 result BF005BEB
++blocktest 16x16 be,vi,ha,va b:2 q:1 result BF005BEB
++blocktest 16x16 be,vi,ha,va b:2 q:3 result BF005BEB
++blocktest 16x16 be,vi,ha,va b:2 q:7 result BF005BEB
++blocktest 16x16 be,vi,ha,va b:2 q:15 result BF005BEB
++blocktest 16x16 be,de b:4 q:0 result C39A24EB
++blocktest 16x16 be,de b:4 q:1 result C39A24EB
++blocktest 16x16 be,de b:4 q:3 result C39A24EB
++blocktest 16x16 be,de b:4 q:7 result B85024DF
++blocktest 16x16 be,de b:4 q:15 result B85024DF
++blocktest 16x16 be,h1,v1 b:4 q:0 result C39A24EB
++blocktest 16x16 be,h1,v1 b:4 q:1 result C39A24EB
++blocktest 16x16 be,h1,v1 b:4 q:3 result C39A24EB
++blocktest 16x16 be,h1,v1 b:4 q:7 result C39A24EB
++blocktest 16x16 be,h1,v1 b:4 q:15 result C39A24EB
++blocktest 16x16 be,ha,va b:4 q:0 result C39A24EB
++blocktest 16x16 be,ha,va b:4 q:1 result C39A24EB
++blocktest 16x16 be,ha,va b:4 q:3 result C39A24EB
++blocktest 16x16 be,ha,va b:4 q:7 result C39A24EB
++blocktest 16x16 be,ha,va b:4 q:15 result C39A24EB
++blocktest 16x16 be,al,de b:4 q:0 result C39A24EB
++blocktest 16x16 be,al,de b:4 q:1 result C39A24EB
++blocktest 16x16 be,al,de b:4 q:3 result C39A24EB
++blocktest 16x16 be,al,de b:4 q:7 result B85024DF
++blocktest 16x16 be,al,de b:4 q:15 result B85024DF
++blocktest 16x16 be,vi,de b:4 q:0 result C39A24EB
++blocktest 16x16 be,vi,de b:4 q:1 result C39A24EB
++blocktest 16x16 be,vi,de b:4 q:3 result C39A24EB
++blocktest 16x16 be,vi,de b:4 q:7 result B85024DF
++blocktest 16x16 be,vi,de b:4 q:15 result B85024DF
++blocktest 16x16 be,vi,ha,va b:4 q:0 result C39A24EB
++blocktest 16x16 be,vi,ha,va b:4 q:1 result C39A24EB
++blocktest 16x16 be,vi,ha,va b:4 q:3 result C39A24EB
++blocktest 16x16 be,vi,ha,va b:4 q:7 result C39A24EB
++blocktest 16x16 be,vi,ha,va b:4 q:15 result C39A24EB
++blocktest 16x16 be,de b:8 q:0 result 48960B7B
++blocktest 16x16 be,de b:8 q:1 result 48960B7B
++blocktest 16x16 be,de b:8 q:3 result 48960B7B
++blocktest 16x16 be,de b:8 q:7 result 48960B7B
++blocktest 16x16 be,de b:8 q:15 result 48960B7B
++blocktest 16x16 be,h1,v1 b:8 q:0 result 48960B7B
++blocktest 16x16 be,h1,v1 b:8 q:1 result 48960B7B
++blocktest 16x16 be,h1,v1 b:8 q:3 result 48960B7B
++blocktest 16x16 be,h1,v1 b:8 q:7 result 48960B7B
++blocktest 16x16 be,h1,v1 b:8 q:15 result 48960B7B
++blocktest 16x16 be,ha,va b:8 q:0 result 48960B7B
++blocktest 16x16 be,ha,va b:8 q:1 result 48960B7B
++blocktest 16x16 be,ha,va b:8 q:3 result 48960B7B
++blocktest 16x16 be,ha,va b:8 q:7 result 48960B7B
++blocktest 16x16 be,ha,va b:8 q:15 result 48960B7B
++blocktest 16x16 be,al,de b:8 q:0 result 48960B7B
++blocktest 16x16 be,al,de b:8 q:1 result 48960B7B
++blocktest 16x16 be,al,de b:8 q:3 result 48960B7B
++blocktest 16x16 be,al,de b:8 q:7 result 48960B7B
++blocktest 16x16 be,al,de b:8 q:15 result 48960B7B
++blocktest 16x16 be,vi,de b:8 q:0 result 48960B7B
++blocktest 16x16 be,vi,de b:8 q:1 result 48960B7B
++blocktest 16x16 be,vi,de b:8 q:3 result 48960B7B
++blocktest 16x16 be,vi,de b:8 q:7 result 48960B7B
++blocktest 16x16 be,vi,de b:8 q:15 result 48960B7B
++blocktest 16x16 be,vi,ha,va b:8 q:0 result 48960B7B
++blocktest 16x16 be,vi,ha,va b:8 q:1 result 48960B7B
++blocktest 16x16 be,vi,ha,va b:8 q:3 result 48960B7B
++blocktest 16x16 be,vi,ha,va b:8 q:7 result 48960B7B
++blocktest 16x16 be,vi,ha,va b:8 q:15 result 48960B7B
++blocktest 16x16 be,de b:16 q:0 result B880007B
++blocktest 16x16 be,de b:16 q:1 result B880007B
++blocktest 16x16 be,de b:16 q:3 result B880007B
++blocktest 16x16 be,de b:16 q:7 result B880007B
++blocktest 16x16 be,de b:16 q:15 result B880007B
++blocktest 16x16 be,h1,v1 b:16 q:0 result B880007B
++blocktest 16x16 be,h1,v1 b:16 q:1 result B880007B
++blocktest 16x16 be,h1,v1 b:16 q:3 result B880007B
++blocktest 16x16 be,h1,v1 b:16 q:7 result B880007B
++blocktest 16x16 be,h1,v1 b:16 q:15 result B880007B
++blocktest 16x16 be,ha,va b:16 q:0 result B880007B
++blocktest 16x16 be,ha,va b:16 q:1 result B880007B
++blocktest 16x16 be,ha,va b:16 q:3 result B880007B
++blocktest 16x16 be,ha,va b:16 q:7 result B880007B
++blocktest 16x16 be,ha,va b:16 q:15 result B880007B
++blocktest 16x16 be,al,de b:16 q:0 result B880007B
++blocktest 16x16 be,al,de b:16 q:1 result B880007B
++blocktest 16x16 be,al,de b:16 q:3 result B880007B
++blocktest 16x16 be,al,de b:16 q:7 result B880007B
++blocktest 16x16 be,al,de b:16 q:15 result B880007B
++blocktest 16x16 be,vi,de b:16 q:0 result B880007B
++blocktest 16x16 be,vi,de b:16 q:1 result B880007B
++blocktest 16x16 be,vi,de b:16 q:3 result B880007B
++blocktest 16x16 be,vi,de b:16 q:7 result B880007B
++blocktest 16x16 be,vi,de b:16 q:15 result B880007B
++blocktest 16x16 be,vi,ha,va b:16 q:0 result B880007B
++blocktest 16x16 be,vi,ha,va b:16 q:1 result B880007B
++blocktest 16x16 be,vi,ha,va b:16 q:3 result B880007B
++blocktest 16x16 be,vi,ha,va b:16 q:7 result B880007B
++blocktest 16x16 be,vi,ha,va b:16 q:15 result B880007B
++blocktest 16x64 be,de b:1 q:0 result 841FE459
++blocktest 16x64 be,de b:1 q:1 result 841FE459
++blocktest 16x64 be,de b:1 q:3 result 841FE459
++blocktest 16x64 be,de b:1 q:7 result 4081E42C
++blocktest 16x64 be,de b:1 q:15 result 4081E42C
++blocktest 16x64 be,h1,v1 b:1 q:0 result 841FE459
++blocktest 16x64 be,h1,v1 b:1 q:1 result 841FE459
++blocktest 16x64 be,h1,v1 b:1 q:3 result 841FE459
++blocktest 16x64 be,h1,v1 b:1 q:7 result 841FE459
++blocktest 16x64 be,h1,v1 b:1 q:15 result 841FE459
++blocktest 16x64 be,ha,va b:1 q:0 result 841FE459
++blocktest 16x64 be,ha,va b:1 q:1 result 841FE459
++blocktest 16x64 be,ha,va b:1 q:3 result 841FE459
++blocktest 16x64 be,ha,va b:1 q:7 result 841FE459
++blocktest 16x64 be,ha,va b:1 q:15 result 841FE459
++blocktest 16x64 be,al,de b:1 q:0 result 841FE459
++blocktest 16x64 be,al,de b:1 q:1 result 841FE459
++blocktest 16x64 be,al,de b:1 q:3 result 841FE459
++blocktest 16x64 be,al,de b:1 q:7 result 56DDE437
++blocktest 16x64 be,al,de b:1 q:15 result 56DDE437
++blocktest 16x64 be,vi,de b:1 q:0 result 841FE459
++blocktest 16x64 be,vi,de b:1 q:1 result 841FE459
++blocktest 16x64 be,vi,de b:1 q:3 result 841FE459
++blocktest 16x64 be,vi,de b:1 q:7 result 4081E42C
++blocktest 16x64 be,vi,de b:1 q:15 result 4081E42C
++blocktest 16x64 be,vi,ha,va b:1 q:0 result 841FE459
++blocktest 16x64 be,vi,ha,va b:1 q:1 result 841FE459
++blocktest 16x64 be,vi,ha,va b:1 q:3 result 841FE459
++blocktest 16x64 be,vi,ha,va b:1 q:7 result 841FE459
++blocktest 16x64 be,vi,ha,va b:1 q:15 result 841FE459
++blocktest 16x64 be,de b:2 q:0 result D1A38359
++blocktest 16x64 be,de b:2 q:1 result D1A38359
++blocktest 16x64 be,de b:2 q:3 result D1A38359
++blocktest 16x64 be,de b:2 q:7 result 9EE48356
++blocktest 16x64 be,de b:2 q:15 result 9EE48356
++blocktest 16x64 be,h1,v1 b:2 q:0 result 20D28359
++blocktest 16x64 be,h1,v1 b:2 q:1 result 20D28359
++blocktest 16x64 be,h1,v1 b:2 q:3 result 20D28359
++blocktest 16x64 be,h1,v1 b:2 q:7 result 20D28359
++blocktest 16x64 be,h1,v1 b:2 q:15 result 20D28359
++blocktest 16x64 be,ha,va b:2 q:0 result D1A38359
++blocktest 16x64 be,ha,va b:2 q:1 result D1A38359
++blocktest 16x64 be,ha,va b:2 q:3 result D1A38359
++blocktest 16x64 be,ha,va b:2 q:7 result D1A38359
++blocktest 16x64 be,ha,va b:2 q:15 result D1A38359
++blocktest 16x64 be,al,de b:2 q:0 result D1A38359
++blocktest 16x64 be,al,de b:2 q:1 result D1A38359
++blocktest 16x64 be,al,de b:2 q:3 result D1A38359
++blocktest 16x64 be,al,de b:2 q:7 result C11B8363
++blocktest 16x64 be,al,de b:2 q:15 result C11B8363
++blocktest 16x64 be,vi,de b:2 q:0 result D1A38359
++blocktest 16x64 be,vi,de b:2 q:1 result D1A38359
++blocktest 16x64 be,vi,de b:2 q:3 result D1A38359
++blocktest 16x64 be,vi,de b:2 q:7 result 9EE48356
++blocktest 16x64 be,vi,de b:2 q:15 result 9EE48356
++blocktest 16x64 be,vi,ha,va b:2 q:0 result D1A38359
++blocktest 16x64 be,vi,ha,va b:2 q:1 result D1A38359
++blocktest 16x64 be,vi,ha,va b:2 q:3 result D1A38359
++blocktest 16x64 be,vi,ha,va b:2 q:7 result D1A38359
++blocktest 16x64 be,vi,ha,va b:2 q:15 result D1A38359
++blocktest 16x64 be,de b:4 q:0 result 46DDCBCA
++blocktest 16x64 be,de b:4 q:1 result 445DCBCA
++blocktest 16x64 be,de b:4 q:3 result FD34CC5A
++blocktest 16x64 be,de b:4 q:7 result 540BCC13
++blocktest 16x64 be,de b:4 q:15 result 540BCC13
++blocktest 16x64 be,h1,v1 b:4 q:0 result 9B3DCBCA
++blocktest 16x64 be,h1,v1 b:4 q:1 result 9B3DCBCA
++blocktest 16x64 be,h1,v1 b:4 q:3 result 9B3DCBCA
++blocktest 16x64 be,h1,v1 b:4 q:7 result 9B3DCBCA
++blocktest 16x64 be,h1,v1 b:4 q:15 result 9B3DCBCA
++blocktest 16x64 be,ha,va b:4 q:0 result 57BDCBCA
++blocktest 16x64 be,ha,va b:4 q:1 result 57BDCBCA
++blocktest 16x64 be,ha,va b:4 q:3 result 57BDCBCA
++blocktest 16x64 be,ha,va b:4 q:7 result 57BDCBCA
++blocktest 16x64 be,ha,va b:4 q:15 result 57BDCBCA
++blocktest 16x64 be,al,de b:4 q:0 result 46DDCBCA
++blocktest 16x64 be,al,de b:4 q:1 result 472DCBCA
++blocktest 16x64 be,al,de b:4 q:3 result B586CB9A
++blocktest 16x64 be,al,de b:4 q:7 result 2701CB5D
++blocktest 16x64 be,al,de b:4 q:15 result 2701CB5D
++blocktest 16x64 be,vi,de b:4 q:0 result 46DDCBCA
++blocktest 16x64 be,vi,de b:4 q:1 result 445DCBCA
++blocktest 16x64 be,vi,de b:4 q:3 result FD34CC5A
++blocktest 16x64 be,vi,de b:4 q:7 result 540BCC13
++blocktest 16x64 be,vi,de b:4 q:15 result 540BCC13
++blocktest 16x64 be,vi,ha,va b:4 q:0 result 92CECBCA
++blocktest 16x64 be,vi,ha,va b:4 q:1 result 92CECBCA
++blocktest 16x64 be,vi,ha,va b:4 q:3 result 92CECBCA
++blocktest 16x64 be,vi,ha,va b:4 q:7 result 92CECBCA
++blocktest 16x64 be,vi,ha,va b:4 q:15 result 92CECBCA
++blocktest 16x64 be,de b:8 q:0 result 6F77C0FB
++blocktest 16x64 be,de b:8 q:1 result 7297C0FB
++blocktest 16x64 be,de b:8 q:3 result 23FFC0CB
++blocktest 16x64 be,de b:8 q:7 result 371BC0C3
++blocktest 16x64 be,de b:8 q:15 result 371BC0C3
++blocktest 16x64 be,h1,v1 b:8 q:0 result BC57C0FB
++blocktest 16x64 be,h1,v1 b:8 q:1 result BC57C0FB
++blocktest 16x64 be,h1,v1 b:8 q:3 result BC57C0FB
++blocktest 16x64 be,h1,v1 b:8 q:7 result BC57C0FB
++blocktest 16x64 be,h1,v1 b:8 q:15 result BC57C0FB
++blocktest 16x64 be,ha,va b:8 q:0 result 7ED7C0FB
++blocktest 16x64 be,ha,va b:8 q:1 result 7ED7C0FB
++blocktest 16x64 be,ha,va b:8 q:3 result 7ED7C0FB
++blocktest 16x64 be,ha,va b:8 q:7 result 7ED7C0FB
++blocktest 16x64 be,ha,va b:8 q:15 result 7ED7C0FB
++blocktest 16x64 be,al,de b:8 q:0 result 6F77C0FB
++blocktest 16x64 be,al,de b:8 q:1 result 7297C0FB
++blocktest 16x64 be,al,de b:8 q:3 result 23FFC0CB
++blocktest 16x64 be,al,de b:8 q:7 result 371BC0C3
++blocktest 16x64 be,al,de b:8 q:15 result 371BC0C3
++blocktest 16x64 be,vi,de b:8 q:0 result 6F77C0FB
++blocktest 16x64 be,vi,de b:8 q:1 result 7297C0FB
++blocktest 16x64 be,vi,de b:8 q:3 result 23FFC0CB
++blocktest 16x64 be,vi,de b:8 q:7 result 371BC0C3
++blocktest 16x64 be,vi,de b:8 q:15 result 371BC0C3
++blocktest 16x64 be,vi,ha,va b:8 q:0 result 41E9C2C5
++blocktest 16x64 be,vi,ha,va b:8 q:1 result 41E9C2C5
++blocktest 16x64 be,vi,ha,va b:8 q:3 result 41E9C2C5
++blocktest 16x64 be,vi,ha,va b:8 q:7 result 41E9C2C5
++blocktest 16x64 be,vi,ha,va b:8 q:15 result 41E9C2C5
++blocktest 16x64 be,de b:16 q:0 result E84A47FB
++blocktest 16x64 be,de b:16 q:1 result E84A47FB
++blocktest 16x64 be,de b:16 q:3 result 1A5947FB
++blocktest 16x64 be,de b:16 q:7 result 26D947FB
++blocktest 16x64 be,de b:16 q:15 result 26D947FB
++blocktest 16x64 be,h1,v1 b:16 q:0 result DD947FB
++blocktest 16x64 be,h1,v1 b:16 q:1 result DD947FB
++blocktest 16x64 be,h1,v1 b:16 q:3 result DD947FB
++blocktest 16x64 be,h1,v1 b:16 q:7 result DD947FB
++blocktest 16x64 be,h1,v1 b:16 q:15 result DD947FB
++blocktest 16x64 be,ha,va b:16 q:0 result EFCA47FB
++blocktest 16x64 be,ha,va b:16 q:1 result EFCA47FB
++blocktest 16x64 be,ha,va b:16 q:3 result EFCA47FB
++blocktest 16x64 be,ha,va b:16 q:7 result EFCA47FB
++blocktest 16x64 be,ha,va b:16 q:15 result EFCA47FB
++blocktest 16x64 be,al,de b:16 q:0 result E84A47FB
++blocktest 16x64 be,al,de b:16 q:1 result E84A47FB
++blocktest 16x64 be,al,de b:16 q:3 result 1A5947FB
++blocktest 16x64 be,al,de b:16 q:7 result 26D947FB
++blocktest 16x64 be,al,de b:16 q:15 result 26D947FB
++blocktest 16x64 be,vi,de b:16 q:0 result E84A47FB
++blocktest 16x64 be,vi,de b:16 q:1 result E84A47FB
++blocktest 16x64 be,vi,de b:16 q:3 result 1A5947FB
++blocktest 16x64 be,vi,de b:16 q:7 result 26D947FB
++blocktest 16x64 be,vi,de b:16 q:15 result 26D947FB
++blocktest 16x64 be,vi,ha,va b:16 q:0 result D5BA4AEB
++blocktest 16x64 be,vi,ha,va b:16 q:1 result D5BA4AEB
++blocktest 16x64 be,vi,ha,va b:16 q:3 result D5BA4AEB
++blocktest 16x64 be,vi,ha,va b:16 q:7 result D5BA4AEB
++blocktest 16x64 be,vi,ha,va b:16 q:15 result D5BA4AEB
++blocktest 16x304 be,de b:1 q:0 result F252DA0E
++blocktest 16x304 be,de b:1 q:1 result F252DA0E
++blocktest 16x304 be,de b:1 q:3 result F252DA0E
++blocktest 16x304 be,de b:1 q:7 result D3C0D9E4
++blocktest 16x304 be,de b:1 q:15 result D3C0D9E4
++blocktest 16x304 be,h1,v1 b:1 q:0 result F252DA0E
++blocktest 16x304 be,h1,v1 b:1 q:1 result F252DA0E
++blocktest 16x304 be,h1,v1 b:1 q:3 result F252DA0E
++blocktest 16x304 be,h1,v1 b:1 q:7 result F252DA0E
++blocktest 16x304 be,h1,v1 b:1 q:15 result F252DA0E
++blocktest 16x304 be,ha,va b:1 q:0 result F252DA0E
++blocktest 16x304 be,ha,va b:1 q:1 result F252DA0E
++blocktest 16x304 be,ha,va b:1 q:3 result F252DA0E
++blocktest 16x304 be,ha,va b:1 q:7 result F252DA0E
++blocktest 16x304 be,ha,va b:1 q:15 result F252DA0E
++blocktest 16x304 be,al,de b:1 q:0 result F252DA0E
++blocktest 16x304 be,al,de b:1 q:1 result F252DA0E
++blocktest 16x304 be,al,de b:1 q:3 result F252DA0E
++blocktest 16x304 be,al,de b:1 q:7 result D3C0D9E4
++blocktest 16x304 be,al,de b:1 q:15 result D3C0D9E4
++blocktest 16x304 be,vi,de b:1 q:0 result F252DA0E
++blocktest 16x304 be,vi,de b:1 q:1 result F252DA0E
++blocktest 16x304 be,vi,de b:1 q:3 result F252DA0E
++blocktest 16x304 be,vi,de b:1 q:7 result D3C0D9E4
++blocktest 16x304 be,vi,de b:1 q:15 result D3C0D9E4
++blocktest 16x304 be,vi,ha,va b:1 q:0 result F252DA0E
++blocktest 16x304 be,vi,ha,va b:1 q:1 result F252DA0E
++blocktest 16x304 be,vi,ha,va b:1 q:3 result F252DA0E
++blocktest 16x304 be,vi,ha,va b:1 q:7 result F252DA0E
++blocktest 16x304 be,vi,ha,va b:1 q:15 result F252DA0E
++blocktest 16x304 be,de b:2 q:0 result CFDF510E
++blocktest 16x304 be,de b:2 q:1 result CFDF510E
++blocktest 16x304 be,de b:2 q:3 result CFDF510E
++blocktest 16x304 be,de b:2 q:7 result E5625190
++blocktest 16x304 be,de b:2 q:15 result E5625190
++blocktest 16x304 be,h1,v1 b:2 q:0 result 9DD24D0E
++blocktest 16x304 be,h1,v1 b:2 q:1 result 9DD24D0E
++blocktest 16x304 be,h1,v1 b:2 q:3 result 9DD24D0E
++blocktest 16x304 be,h1,v1 b:2 q:7 result 9DD24D0E
++blocktest 16x304 be,h1,v1 b:2 q:15 result 9DD24D0E
++blocktest 16x304 be,ha,va b:2 q:0 result CFDF510E
++blocktest 16x304 be,ha,va b:2 q:1 result CFDF510E
++blocktest 16x304 be,ha,va b:2 q:3 result CFDF510E
++blocktest 16x304 be,ha,va b:2 q:7 result CFDF510E
++blocktest 16x304 be,ha,va b:2 q:15 result CFDF510E
++blocktest 16x304 be,al,de b:2 q:0 result CFDF510E
++blocktest 16x304 be,al,de b:2 q:1 result CFDF510E
++blocktest 16x304 be,al,de b:2 q:3 result CFDF510E
++blocktest 16x304 be,al,de b:2 q:7 result 6281518C
++blocktest 16x304 be,al,de b:2 q:15 result 6281518C
++blocktest 16x304 be,vi,de b:2 q:0 result CFDF510E
++blocktest 16x304 be,vi,de b:2 q:1 result CFDF510E
++blocktest 16x304 be,vi,de b:2 q:3 result CFDF510E
++blocktest 16x304 be,vi,de b:2 q:7 result E5625190
++blocktest 16x304 be,vi,de b:2 q:15 result E5625190
++blocktest 16x304 be,vi,ha,va b:2 q:0 result CFDF510E
++blocktest 16x304 be,vi,ha,va b:2 q:1 result CFDF510E
++blocktest 16x304 be,vi,ha,va b:2 q:3 result CFDF510E
++blocktest 16x304 be,vi,ha,va b:2 q:7 result CFDF510E
++blocktest 16x304 be,vi,ha,va b:2 q:15 result CFDF510E
++blocktest 16x304 be,de b:4 q:0 result 4B30C3F
++blocktest 16x304 be,de b:4 q:1 result 1B480C3F
++blocktest 16x304 be,de b:4 q:3 result 34840E77
++blocktest 16x304 be,de b:4 q:7 result B02B0D83
++blocktest 16x304 be,de b:4 q:15 result B02B0D83
++blocktest 16x304 be,h1,v1 b:4 q:0 result 49A20C3F
++blocktest 16x304 be,h1,v1 b:4 q:1 result 49A20C3F
++blocktest 16x304 be,h1,v1 b:4 q:3 result 49A20C3F
++blocktest 16x304 be,h1,v1 b:4 q:7 result 49A20C3F
++blocktest 16x304 be,h1,v1 b:4 q:15 result 49A20C3F
++blocktest 16x304 be,ha,va b:4 q:0 result 79680C3F
++blocktest 16x304 be,ha,va b:4 q:1 result 79680C3F
++blocktest 16x304 be,ha,va b:4 q:3 result 79680C3F
++blocktest 16x304 be,ha,va b:4 q:7 result 79680C3F
++blocktest 16x304 be,ha,va b:4 q:15 result 79680C3F
++blocktest 16x304 be,al,de b:4 q:0 result 4B30C3F
++blocktest 16x304 be,al,de b:4 q:1 result 20E80C3F
++blocktest 16x304 be,al,de b:4 q:3 result 23750CF7
++blocktest 16x304 be,al,de b:4 q:7 result 4B970C0B
++blocktest 16x304 be,al,de b:4 q:15 result 4B970C0B
++blocktest 16x304 be,vi,de b:4 q:0 result 4B30C3F
++blocktest 16x304 be,vi,de b:4 q:1 result 1B480C3F
++blocktest 16x304 be,vi,de b:4 q:3 result 34840E77
++blocktest 16x304 be,vi,de b:4 q:7 result B02B0D83
++blocktest 16x304 be,vi,de b:4 q:15 result B02B0D83
++blocktest 16x304 be,vi,ha,va b:4 q:0 result 4FC80C50
++blocktest 16x304 be,vi,ha,va b:4 q:1 result 4FC80C50
++blocktest 16x304 be,vi,ha,va b:4 q:3 result 4FC80C50
++blocktest 16x304 be,vi,ha,va b:4 q:7 result 4FC80C50
++blocktest 16x304 be,vi,ha,va b:4 q:15 result 4FC80C50
++blocktest 16x304 be,de b:8 q:0 result 6CD11A51
++blocktest 16x304 be,de b:8 q:1 result 83791A51
++blocktest 16x304 be,de b:8 q:3 result F7B518E0
++blocktest 16x304 be,de b:8 q:7 result 25E91888
++blocktest 16x304 be,de b:8 q:15 result 25E91888
++blocktest 16x304 be,h1,v1 b:8 q:0 result 849F1A51
++blocktest 16x304 be,h1,v1 b:8 q:1 result 849F1A51
++blocktest 16x304 be,h1,v1 b:8 q:3 result 849F1A51
++blocktest 16x304 be,h1,v1 b:8 q:7 result 849F1A51
++blocktest 16x304 be,h1,v1 b:8 q:15 result 849F1A51
++blocktest 16x304 be,ha,va b:8 q:0 result D8871A51
++blocktest 16x304 be,ha,va b:8 q:1 result D8871A51
++blocktest 16x304 be,ha,va b:8 q:3 result D8871A51
++blocktest 16x304 be,ha,va b:8 q:7 result D8871A51
++blocktest 16x304 be,ha,va b:8 q:15 result D8871A51
++blocktest 16x304 be,al,de b:8 q:0 result 6CD11A51
++blocktest 16x304 be,al,de b:8 q:1 result 83791A51
++blocktest 16x304 be,al,de b:8 q:3 result F7B518E0
++blocktest 16x304 be,al,de b:8 q:7 result 25E91888
++blocktest 16x304 be,al,de b:8 q:15 result 25E91888
++blocktest 16x304 be,vi,de b:8 q:0 result 6CD11A51
++blocktest 16x304 be,vi,de b:8 q:1 result 83791A51
++blocktest 16x304 be,vi,de b:8 q:3 result F7B518E0
++blocktest 16x304 be,vi,de b:8 q:7 result 25E91888
++blocktest 16x304 be,vi,de b:8 q:15 result 25E91888
++blocktest 16x304 be,vi,ha,va b:8 q:0 result C2FD1D43
++blocktest 16x304 be,vi,ha,va b:8 q:1 result C2FD1D43
++blocktest 16x304 be,vi,ha,va b:8 q:3 result C2FD1D43
++blocktest 16x304 be,vi,ha,va b:8 q:7 result C2FD1D43
++blocktest 16x304 be,vi,ha,va b:8 q:15 result C2FD1D43
++blocktest 16x304 be,de b:16 q:0 result 5FBD38B3
++blocktest 16x304 be,de b:16 q:1 result 5FBD38B3
++blocktest 16x304 be,de b:16 q:3 result BDCC38B3
++blocktest 16x304 be,de b:16 q:7 result 155B38B3
++blocktest 16x304 be,de b:16 q:15 result 155B38B3
++blocktest 16x304 be,h1,v1 b:16 q:0 result 664C38B3
++blocktest 16x304 be,h1,v1 b:16 q:1 result 664C38B3
++blocktest 16x304 be,h1,v1 b:16 q:3 result 664C38B3
++blocktest 16x304 be,h1,v1 b:16 q:7 result 664C38B3
++blocktest 16x304 be,h1,v1 b:16 q:15 result 664C38B3
++blocktest 16x304 be,ha,va b:16 q:0 result 943D38B3
++blocktest 16x304 be,ha,va b:16 q:1 result 943D38B3
++blocktest 16x304 be,ha,va b:16 q:3 result 943D38B3
++blocktest 16x304 be,ha,va b:16 q:7 result 943D38B3
++blocktest 16x304 be,ha,va b:16 q:15 result 943D38B3
++blocktest 16x304 be,al,de b:16 q:0 result 5FBD38B3
++blocktest 16x304 be,al,de b:16 q:1 result 5FBD38B3
++blocktest 16x304 be,al,de b:16 q:3 result BDCC38B3
++blocktest 16x304 be,al,de b:16 q:7 result 155B38B3
++blocktest 16x304 be,al,de b:16 q:15 result 155B38B3
++blocktest 16x304 be,vi,de b:16 q:0 result 5FBD38B3
++blocktest 16x304 be,vi,de b:16 q:1 result 5FBD38B3
++blocktest 16x304 be,vi,de b:16 q:3 result BDCC38B3
++blocktest 16x304 be,vi,de b:16 q:7 result 155B38B3
++blocktest 16x304 be,vi,de b:16 q:15 result 155B38B3
++blocktest 16x304 be,vi,ha,va b:16 q:0 result 94123BF3
++blocktest 16x304 be,vi,ha,va b:16 q:1 result 94123BF3
++blocktest 16x304 be,vi,ha,va b:16 q:3 result 94123BF3
++blocktest 16x304 be,vi,ha,va b:16 q:7 result 94123BF3
++blocktest 16x304 be,vi,ha,va b:16 q:15 result 94123BF3
++blocktest 32x16 be,de b:1 q:0 result 461C6D6A
++blocktest 32x16 be,de b:1 q:1 result 461C6D6A
++blocktest 32x16 be,de b:1 q:3 result 461C6D6A
++blocktest 32x16 be,de b:1 q:7 result 311C6D4E
++blocktest 32x16 be,de b:1 q:15 result 311C6D4E
++blocktest 32x16 be,h1,v1 b:1 q:0 result 461C6D6A
++blocktest 32x16 be,h1,v1 b:1 q:1 result 461C6D6A
++blocktest 32x16 be,h1,v1 b:1 q:3 result 461C6D6A
++blocktest 32x16 be,h1,v1 b:1 q:7 result 461C6D6A
++blocktest 32x16 be,h1,v1 b:1 q:15 result 461C6D6A
++blocktest 32x16 be,ha,va b:1 q:0 result 461C6D6A
++blocktest 32x16 be,ha,va b:1 q:1 result 461C6D6A
++blocktest 32x16 be,ha,va b:1 q:3 result 461C6D6A
++blocktest 32x16 be,ha,va b:1 q:7 result 461C6D6A
++blocktest 32x16 be,ha,va b:1 q:15 result 461C6D6A
++blocktest 32x16 be,al,de b:1 q:0 result 461C6D6A
++blocktest 32x16 be,al,de b:1 q:1 result 461C6D6A
++blocktest 32x16 be,al,de b:1 q:3 result 461C6D6A
++blocktest 32x16 be,al,de b:1 q:7 result 311C6D4E
++blocktest 32x16 be,al,de b:1 q:15 result 311C6D4E
++blocktest 32x16 be,vi,de b:1 q:0 result 461C6D6A
++blocktest 32x16 be,vi,de b:1 q:1 result 461C6D6A
++blocktest 32x16 be,vi,de b:1 q:3 result 461C6D6A
++blocktest 32x16 be,vi,de b:1 q:7 result 311C6D4E
++blocktest 32x16 be,vi,de b:1 q:15 result 311C6D4E
++blocktest 32x16 be,vi,ha,va b:1 q:0 result 461C6D6A
++blocktest 32x16 be,vi,ha,va b:1 q:1 result 461C6D6A
++blocktest 32x16 be,vi,ha,va b:1 q:3 result 461C6D6A
++blocktest 32x16 be,vi,ha,va b:1 q:7 result 461C6D6A
++blocktest 32x16 be,vi,ha,va b:1 q:15 result 461C6D6A
++blocktest 32x16 be,de b:2 q:0 result 73872AEA
++blocktest 32x16 be,de b:2 q:1 result 73872AEA
++blocktest 32x16 be,de b:2 q:3 result 73872AEA
++blocktest 32x16 be,de b:2 q:7 result 6B622AE4
++blocktest 32x16 be,de b:2 q:15 result 6B622AE4
++blocktest 32x16 be,h1,v1 b:2 q:0 result 73872AEA
++blocktest 32x16 be,h1,v1 b:2 q:1 result 73872AEA
++blocktest 32x16 be,h1,v1 b:2 q:3 result 73872AEA
++blocktest 32x16 be,h1,v1 b:2 q:7 result 73872AEA
++blocktest 32x16 be,h1,v1 b:2 q:15 result 73872AEA
++blocktest 32x16 be,ha,va b:2 q:0 result 73872AEA
++blocktest 32x16 be,ha,va b:2 q:1 result 73872AEA
++blocktest 32x16 be,ha,va b:2 q:3 result 73872AEA
++blocktest 32x16 be,ha,va b:2 q:7 result 73872AEA
++blocktest 32x16 be,ha,va b:2 q:15 result 73872AEA
++blocktest 32x16 be,al,de b:2 q:0 result 73872AEA
++blocktest 32x16 be,al,de b:2 q:1 result 73872AEA
++blocktest 32x16 be,al,de b:2 q:3 result 73872AEA
++blocktest 32x16 be,al,de b:2 q:7 result 6B622AE4
++blocktest 32x16 be,al,de b:2 q:15 result 6B622AE4
++blocktest 32x16 be,vi,de b:2 q:0 result 73872AEA
++blocktest 32x16 be,vi,de b:2 q:1 result 73872AEA
++blocktest 32x16 be,vi,de b:2 q:3 result 73872AEA
++blocktest 32x16 be,vi,de b:2 q:7 result 6B622AE4
++blocktest 32x16 be,vi,de b:2 q:15 result 6B622AE4
++blocktest 32x16 be,vi,ha,va b:2 q:0 result 73872AEA
++blocktest 32x16 be,vi,ha,va b:2 q:1 result 73872AEA
++blocktest 32x16 be,vi,ha,va b:2 q:3 result 73872AEA
++blocktest 32x16 be,vi,ha,va b:2 q:7 result 73872AEA
++blocktest 32x16 be,vi,ha,va b:2 q:15 result 73872AEA
++blocktest 32x16 be,de b:4 q:0 result 13BC7D9B
++blocktest 32x16 be,de b:4 q:1 result 13BC7D9B
++blocktest 32x16 be,de b:4 q:3 result 13BC7D9B
++blocktest 32x16 be,de b:4 q:7 result D7BD7D7A
++blocktest 32x16 be,de b:4 q:15 result D7BD7D7A
++blocktest 32x16 be,h1,v1 b:4 q:0 result 13BC7D9B
++blocktest 32x16 be,h1,v1 b:4 q:1 result 13BC7D9B
++blocktest 32x16 be,h1,v1 b:4 q:3 result 13BC7D9B
++blocktest 32x16 be,h1,v1 b:4 q:7 result 13BC7D9B
++blocktest 32x16 be,h1,v1 b:4 q:15 result 13BC7D9B
++blocktest 32x16 be,ha,va b:4 q:0 result 13BC7D9B
++blocktest 32x16 be,ha,va b:4 q:1 result 13BC7D9B
++blocktest 32x16 be,ha,va b:4 q:3 result 13BC7D9B
++blocktest 32x16 be,ha,va b:4 q:7 result 13BC7D9B
++blocktest 32x16 be,ha,va b:4 q:15 result 13BC7D9B
++blocktest 32x16 be,al,de b:4 q:0 result 13BC7D9B
++blocktest 32x16 be,al,de b:4 q:1 result 13BC7D9B
++blocktest 32x16 be,al,de b:4 q:3 result 13BC7D9B
++blocktest 32x16 be,al,de b:4 q:7 result D7BD7D7A
++blocktest 32x16 be,al,de b:4 q:15 result D7BD7D7A
++blocktest 32x16 be,vi,de b:4 q:0 result 13BC7D9B
++blocktest 32x16 be,vi,de b:4 q:1 result 13BC7D9B
++blocktest 32x16 be,vi,de b:4 q:3 result 13BC7D9B
++blocktest 32x16 be,vi,de b:4 q:7 result D7BD7D7A
++blocktest 32x16 be,vi,de b:4 q:15 result D7BD7D7A
++blocktest 32x16 be,vi,ha,va b:4 q:0 result 13BC7D9B
++blocktest 32x16 be,vi,ha,va b:4 q:1 result 13BC7D9B
++blocktest 32x16 be,vi,ha,va b:4 q:3 result 13BC7D9B
++blocktest 32x16 be,vi,ha,va b:4 q:7 result 13BC7D9B
++blocktest 32x16 be,vi,ha,va b:4 q:15 result 13BC7D9B
++blocktest 32x16 be,de b:8 q:0 result 9C4C2F3B
++blocktest 32x16 be,de b:8 q:1 result 9C4C2F3B
++blocktest 32x16 be,de b:8 q:3 result 9C4C2F3B
++blocktest 32x16 be,de b:8 q:7 result 9C4C2F3B
++blocktest 32x16 be,de b:8 q:15 result 9C4C2F3B
++blocktest 32x16 be,h1,v1 b:8 q:0 result 9C4C2F3B
++blocktest 32x16 be,h1,v1 b:8 q:1 result 9C4C2F3B
++blocktest 32x16 be,h1,v1 b:8 q:3 result 9C4C2F3B
++blocktest 32x16 be,h1,v1 b:8 q:7 result 9C4C2F3B
++blocktest 32x16 be,h1,v1 b:8 q:15 result 9C4C2F3B
++blocktest 32x16 be,ha,va b:8 q:0 result 9C4C2F3B
++blocktest 32x16 be,ha,va b:8 q:1 result 9C4C2F3B
++blocktest 32x16 be,ha,va b:8 q:3 result 9C4C2F3B
++blocktest 32x16 be,ha,va b:8 q:7 result 9C4C2F3B
++blocktest 32x16 be,ha,va b:8 q:15 result 9C4C2F3B
++blocktest 32x16 be,al,de b:8 q:0 result 9C4C2F3B
++blocktest 32x16 be,al,de b:8 q:1 result 9C4C2F3B
++blocktest 32x16 be,al,de b:8 q:3 result 9C4C2F3B
++blocktest 32x16 be,al,de b:8 q:7 result 9C4C2F3B
++blocktest 32x16 be,al,de b:8 q:15 result 9C4C2F3B
++blocktest 32x16 be,vi,de b:8 q:0 result 9C4C2F3B
++blocktest 32x16 be,vi,de b:8 q:1 result 9C4C2F3B
++blocktest 32x16 be,vi,de b:8 q:3 result 9C4C2F3B
++blocktest 32x16 be,vi,de b:8 q:7 result 9C4C2F3B
++blocktest 32x16 be,vi,de b:8 q:15 result 9C4C2F3B
++blocktest 32x16 be,vi,ha,va b:8 q:0 result 9C4C2F3B
++blocktest 32x16 be,vi,ha,va b:8 q:1 result 9C4C2F3B
++blocktest 32x16 be,vi,ha,va b:8 q:3 result 9C4C2F3B
++blocktest 32x16 be,vi,ha,va b:8 q:7 result 9C4C2F3B
++blocktest 32x16 be,vi,ha,va b:8 q:15 result 9C4C2F3B
++blocktest 32x16 be,de b:16 q:0 result 1FD90B7B
++blocktest 32x16 be,de b:16 q:1 result 1FD90B7B
++blocktest 32x16 be,de b:16 q:3 result 1FD90B7B
++blocktest 32x16 be,de b:16 q:7 result 1FD90B7B
++blocktest 32x16 be,de b:16 q:15 result 1FD90B7B
++blocktest 32x16 be,h1,v1 b:16 q:0 result 1FD90B7B
++blocktest 32x16 be,h1,v1 b:16 q:1 result 1FD90B7B
++blocktest 32x16 be,h1,v1 b:16 q:3 result 1FD90B7B
++blocktest 32x16 be,h1,v1 b:16 q:7 result 1FD90B7B
++blocktest 32x16 be,h1,v1 b:16 q:15 result 1FD90B7B
++blocktest 32x16 be,ha,va b:16 q:0 result 1FD90B7B
++blocktest 32x16 be,ha,va b:16 q:1 result 1FD90B7B
++blocktest 32x16 be,ha,va b:16 q:3 result 1FD90B7B
++blocktest 32x16 be,ha,va b:16 q:7 result 1FD90B7B
++blocktest 32x16 be,ha,va b:16 q:15 result 1FD90B7B
++blocktest 32x16 be,al,de b:16 q:0 result 1FD90B7B
++blocktest 32x16 be,al,de b:16 q:1 result 1FD90B7B
++blocktest 32x16 be,al,de b:16 q:3 result 1FD90B7B
++blocktest 32x16 be,al,de b:16 q:7 result 1FD90B7B
++blocktest 32x16 be,al,de b:16 q:15 result 1FD90B7B
++blocktest 32x16 be,vi,de b:16 q:0 result 1FD90B7B
++blocktest 32x16 be,vi,de b:16 q:1 result 1FD90B7B
++blocktest 32x16 be,vi,de b:16 q:3 result 1FD90B7B
++blocktest 32x16 be,vi,de b:16 q:7 result 1FD90B7B
++blocktest 32x16 be,vi,de b:16 q:15 result 1FD90B7B
++blocktest 32x16 be,vi,ha,va b:16 q:0 result 1FD90B7B
++blocktest 32x16 be,vi,ha,va b:16 q:1 result 1FD90B7B
++blocktest 32x16 be,vi,ha,va b:16 q:3 result 1FD90B7B
++blocktest 32x16 be,vi,ha,va b:16 q:7 result 1FD90B7B
++blocktest 32x16 be,vi,ha,va b:16 q:15 result 1FD90B7B
++blocktest 32x64 be,de b:1 q:0 result 1816E246
++blocktest 32x64 be,de b:1 q:1 result 1816E246
++blocktest 32x64 be,de b:1 q:3 result 1816E246
++blocktest 32x64 be,de b:1 q:7 result FD1AE1E6
++blocktest 32x64 be,de b:1 q:15 result FD1AE1E6
++blocktest 32x64 be,h1,v1 b:1 q:0 result 1A76E246
++blocktest 32x64 be,h1,v1 b:1 q:1 result 1A76E246
++blocktest 32x64 be,h1,v1 b:1 q:3 result 1A76E246
++blocktest 32x64 be,h1,v1 b:1 q:7 result 1A76E246
++blocktest 32x64 be,h1,v1 b:1 q:15 result 1A76E246
++blocktest 32x64 be,ha,va b:1 q:0 result 1816E246
++blocktest 32x64 be,ha,va b:1 q:1 result 1816E246
++blocktest 32x64 be,ha,va b:1 q:3 result 1816E246
++blocktest 32x64 be,ha,va b:1 q:7 result 1816E246
++blocktest 32x64 be,ha,va b:1 q:15 result 1816E246
++blocktest 32x64 be,al,de b:1 q:0 result 1816E246
++blocktest 32x64 be,al,de b:1 q:1 result 1816E246
++blocktest 32x64 be,al,de b:1 q:3 result 1816E246
++blocktest 32x64 be,al,de b:1 q:7 result 11BAE1EB
++blocktest 32x64 be,al,de b:1 q:15 result 11BAE1EB
++blocktest 32x64 be,vi,de b:1 q:0 result 1816E246
++blocktest 32x64 be,vi,de b:1 q:1 result 1816E246
++blocktest 32x64 be,vi,de b:1 q:3 result 1816E246
++blocktest 32x64 be,vi,de b:1 q:7 result FD1AE1E6
++blocktest 32x64 be,vi,de b:1 q:15 result FD1AE1E6
++blocktest 32x64 be,vi,ha,va b:1 q:0 result 1816E246
++blocktest 32x64 be,vi,ha,va b:1 q:1 result 1816E246
++blocktest 32x64 be,vi,ha,va b:1 q:3 result 1816E246
++blocktest 32x64 be,vi,ha,va b:1 q:7 result 1816E246
++blocktest 32x64 be,vi,ha,va b:1 q:15 result 1816E246
++blocktest 32x64 be,de b:2 q:0 result 2ED7B446
++blocktest 32x64 be,de b:2 q:1 result 2ED7B446
++blocktest 32x64 be,de b:2 q:3 result 2ED7B446
++blocktest 32x64 be,de b:2 q:7 result 19F3B421
++blocktest 32x64 be,de b:2 q:15 result 19F3B421
++blocktest 32x64 be,h1,v1 b:2 q:0 result 6E26B446
++blocktest 32x64 be,h1,v1 b:2 q:1 result 6E26B446
++blocktest 32x64 be,h1,v1 b:2 q:3 result 6E26B446
++blocktest 32x64 be,h1,v1 b:2 q:7 result 6E26B446
++blocktest 32x64 be,h1,v1 b:2 q:15 result 6E26B446
++blocktest 32x64 be,ha,va b:2 q:0 result 2ED7B446
++blocktest 32x64 be,ha,va b:2 q:1 result 2ED7B446
++blocktest 32x64 be,ha,va b:2 q:3 result 2ED7B446
++blocktest 32x64 be,ha,va b:2 q:7 result 2ED7B446
++blocktest 32x64 be,ha,va b:2 q:15 result 2ED7B446
++blocktest 32x64 be,al,de b:2 q:0 result 2ED7B446
++blocktest 32x64 be,al,de b:2 q:1 result 2ED7B446
++blocktest 32x64 be,al,de b:2 q:3 result 2ED7B446
++blocktest 32x64 be,al,de b:2 q:7 result 1698B420
++blocktest 32x64 be,al,de b:2 q:15 result 1698B420
++blocktest 32x64 be,vi,de b:2 q:0 result 2ED7B446
++blocktest 32x64 be,vi,de b:2 q:1 result 2ED7B446
++blocktest 32x64 be,vi,de b:2 q:3 result 2ED7B446
++blocktest 32x64 be,vi,de b:2 q:7 result 19F3B421
++blocktest 32x64 be,vi,de b:2 q:15 result 19F3B421
++blocktest 32x64 be,vi,ha,va b:2 q:0 result 2ED7B446
++blocktest 32x64 be,vi,ha,va b:2 q:1 result 2ED7B446
++blocktest 32x64 be,vi,ha,va b:2 q:3 result 2ED7B446
++blocktest 32x64 be,vi,ha,va b:2 q:7 result 2ED7B446
++blocktest 32x64 be,vi,ha,va b:2 q:15 result 2ED7B446
++blocktest 32x64 be,de b:4 q:0 result 6B4AA37
++blocktest 32x64 be,de b:4 q:1 result FE3FAAF7
++blocktest 32x64 be,de b:4 q:3 result E050AC17
++blocktest 32x64 be,de b:4 q:7 result B92AAB2E
++blocktest 32x64 be,de b:4 q:15 result B92AAB2E
++blocktest 32x64 be,h1,v1 b:4 q:0 result 85D7AA37
++blocktest 32x64 be,h1,v1 b:4 q:1 result 85D7AA37
++blocktest 32x64 be,h1,v1 b:4 q:3 result 85D7AA37
++blocktest 32x64 be,h1,v1 b:4 q:7 result 85D7AA37
++blocktest 32x64 be,h1,v1 b:4 q:15 result 85D7AA37
++blocktest 32x64 be,ha,va b:4 q:0 result 5AACAA37
++blocktest 32x64 be,ha,va b:4 q:1 result 5AACAA37
++blocktest 32x64 be,ha,va b:4 q:3 result 5AACAA37
++blocktest 32x64 be,ha,va b:4 q:7 result 5AACAA37
++blocktest 32x64 be,ha,va b:4 q:15 result 5AACAA37
++blocktest 32x64 be,al,de b:4 q:0 result 6B4AA37
++blocktest 32x64 be,al,de b:4 q:1 result A27CAB57
++blocktest 32x64 be,al,de b:4 q:3 result 1634ABBE
++blocktest 32x64 be,al,de b:4 q:7 result D5E4AACD
++blocktest 32x64 be,al,de b:4 q:15 result D5E4AACD
++blocktest 32x64 be,vi,de b:4 q:0 result 6B4AA37
++blocktest 32x64 be,vi,de b:4 q:1 result FE3FAAF7
++blocktest 32x64 be,vi,de b:4 q:3 result E050AC17
++blocktest 32x64 be,vi,de b:4 q:7 result B92AAB2E
++blocktest 32x64 be,vi,de b:4 q:15 result B92AAB2E
++blocktest 32x64 be,vi,ha,va b:4 q:0 result CDACAA2E
++blocktest 32x64 be,vi,ha,va b:4 q:1 result CDACAA2E
++blocktest 32x64 be,vi,ha,va b:4 q:3 result CDACAA2E
++blocktest 32x64 be,vi,ha,va b:4 q:7 result CDACAA2E
++blocktest 32x64 be,vi,ha,va b:4 q:15 result CDACAA2E
++blocktest 32x64 be,de b:8 q:0 result 345AF50A
++blocktest 32x64 be,de b:8 q:1 result 3D9CF4CA
++blocktest 32x64 be,de b:8 q:3 result 12EDF472
++blocktest 32x64 be,de b:8 q:7 result 8A7DF45A
++blocktest 32x64 be,de b:8 q:15 result 8A7DF45A
++blocktest 32x64 be,h1,v1 b:8 q:0 result 857BF50A
++blocktest 32x64 be,h1,v1 b:8 q:1 result 857BF50A
++blocktest 32x64 be,h1,v1 b:8 q:3 result 857BF50A
++blocktest 32x64 be,h1,v1 b:8 q:7 result 857BF50A
++blocktest 32x64 be,h1,v1 b:8 q:15 result 857BF50A
++blocktest 32x64 be,ha,va b:8 q:0 result 7E5EF50A
++blocktest 32x64 be,ha,va b:8 q:1 result 7E5EF50A
++blocktest 32x64 be,ha,va b:8 q:3 result 7E5EF50A
++blocktest 32x64 be,ha,va b:8 q:7 result 7E5EF50A
++blocktest 32x64 be,ha,va b:8 q:15 result 7E5EF50A
++blocktest 32x64 be,al,de b:8 q:0 result 345AF50A
++blocktest 32x64 be,al,de b:8 q:1 result 3D9CF4CA
++blocktest 32x64 be,al,de b:8 q:3 result 12EDF472
++blocktest 32x64 be,al,de b:8 q:7 result 8A7DF45A
++blocktest 32x64 be,al,de b:8 q:15 result 8A7DF45A
++blocktest 32x64 be,vi,de b:8 q:0 result 345AF50A
++blocktest 32x64 be,vi,de b:8 q:1 result 3D9CF4CA
++blocktest 32x64 be,vi,de b:8 q:3 result 12EDF472
++blocktest 32x64 be,vi,de b:8 q:7 result 8A7DF45A
++blocktest 32x64 be,vi,de b:8 q:15 result 8A7DF45A
++blocktest 32x64 be,vi,ha,va b:8 q:0 result 83DCFAE4
++blocktest 32x64 be,vi,ha,va b:8 q:1 result 83DCFAE4
++blocktest 32x64 be,vi,ha,va b:8 q:3 result 83DCFAE4
++blocktest 32x64 be,vi,ha,va b:8 q:7 result 83DCFAE4
++blocktest 32x64 be,vi,ha,va b:8 q:15 result 83DCFAE4
++blocktest 32x64 be,de b:16 q:0 result 600CBB7B
++blocktest 32x64 be,de b:16 q:1 result 632CBB7B
++blocktest 32x64 be,de b:16 q:3 result 2B3BBB7B
++blocktest 32x64 be,de b:16 q:7 result 5D3BBB7B
++blocktest 32x64 be,de b:16 q:15 result 5D3BBB7B
++blocktest 32x64 be,h1,v1 b:16 q:0 result F7ECBB7B
++blocktest 32x64 be,h1,v1 b:16 q:1 result F7ECBB7B
++blocktest 32x64 be,h1,v1 b:16 q:3 result F7ECBB7B
++blocktest 32x64 be,h1,v1 b:16 q:7 result F7ECBB7B
++blocktest 32x64 be,h1,v1 b:16 q:15 result F7ECBB7B
++blocktest 32x64 be,ha,va b:16 q:0 result 7E9CBB7B
++blocktest 32x64 be,ha,va b:16 q:1 result 7E9CBB7B
++blocktest 32x64 be,ha,va b:16 q:3 result 7E9CBB7B
++blocktest 32x64 be,ha,va b:16 q:7 result 7E9CBB7B
++blocktest 32x64 be,ha,va b:16 q:15 result 7E9CBB7B
++blocktest 32x64 be,al,de b:16 q:0 result 600CBB7B
++blocktest 32x64 be,al,de b:16 q:1 result 632CBB7B
++blocktest 32x64 be,al,de b:16 q:3 result 2B3BBB7B
++blocktest 32x64 be,al,de b:16 q:7 result 5D3BBB7B
++blocktest 32x64 be,al,de b:16 q:15 result 5D3BBB7B
++blocktest 32x64 be,vi,de b:16 q:0 result 600CBB7B
++blocktest 32x64 be,vi,de b:16 q:1 result 632CBB7B
++blocktest 32x64 be,vi,de b:16 q:3 result 2B3BBB7B
++blocktest 32x64 be,vi,de b:16 q:7 result 5D3BBB7B
++blocktest 32x64 be,vi,de b:16 q:15 result 5D3BBB7B
++blocktest 32x64 be,vi,ha,va b:16 q:0 result BEB6C1D2
++blocktest 32x64 be,vi,ha,va b:16 q:1 result BEB6C1D2
++blocktest 32x64 be,vi,ha,va b:16 q:3 result BEB6C1D2
++blocktest 32x64 be,vi,ha,va b:16 q:7 result BEB6C1D2
++blocktest 32x64 be,vi,ha,va b:16 q:15 result BEB6C1D2
++blocktest 32x304 be,de b:1 q:0 result FE2813BF
++blocktest 32x304 be,de b:1 q:1 result FE2813BF
++blocktest 32x304 be,de b:1 q:3 result FE2813BF
++blocktest 32x304 be,de b:1 q:7 result D7F3135F
++blocktest 32x304 be,de b:1 q:15 result D7F3135F
++blocktest 32x304 be,h1,v1 b:1 q:0 result D6A414BF
++blocktest 32x304 be,h1,v1 b:1 q:1 result D6A414BF
++blocktest 32x304 be,h1,v1 b:1 q:3 result D6A414BF
++blocktest 32x304 be,h1,v1 b:1 q:7 result D6A414BF
++blocktest 32x304 be,h1,v1 b:1 q:15 result D6A414BF
++blocktest 32x304 be,ha,va b:1 q:0 result FE2813BF
++blocktest 32x304 be,ha,va b:1 q:1 result FE2813BF
++blocktest 32x304 be,ha,va b:1 q:3 result FE2813BF
++blocktest 32x304 be,ha,va b:1 q:7 result FE2813BF
++blocktest 32x304 be,ha,va b:1 q:15 result FE2813BF
++blocktest 32x304 be,al,de b:1 q:0 result FE2813BF
++blocktest 32x304 be,al,de b:1 q:1 result FE2813BF
++blocktest 32x304 be,al,de b:1 q:3 result FE2813BF
++blocktest 32x304 be,al,de b:1 q:7 result D7F3135F
++blocktest 32x304 be,al,de b:1 q:15 result D7F3135F
++blocktest 32x304 be,vi,de b:1 q:0 result FE2813BF
++blocktest 32x304 be,vi,de b:1 q:1 result FE2813BF
++blocktest 32x304 be,vi,de b:1 q:3 result FE2813BF
++blocktest 32x304 be,vi,de b:1 q:7 result D7F3135F
++blocktest 32x304 be,vi,de b:1 q:15 result D7F3135F
++blocktest 32x304 be,vi,ha,va b:1 q:0 result FE2813BF
++blocktest 32x304 be,vi,ha,va b:1 q:1 result FE2813BF
++blocktest 32x304 be,vi,ha,va b:1 q:3 result FE2813BF
++blocktest 32x304 be,vi,ha,va b:1 q:7 result FE2813BF
++blocktest 32x304 be,vi,ha,va b:1 q:15 result FE2813BF
++blocktest 32x304 be,de b:2 q:0 result 99FEA830
++blocktest 32x304 be,de b:2 q:1 result 99FEA830
++blocktest 32x304 be,de b:2 q:3 result 99FEA830
++blocktest 32x304 be,de b:2 q:7 result 8781A8E5
++blocktest 32x304 be,de b:2 q:15 result 8781A8E5
++blocktest 32x304 be,h1,v1 b:2 q:0 result B124A230
++blocktest 32x304 be,h1,v1 b:2 q:1 result B124A230
++blocktest 32x304 be,h1,v1 b:2 q:3 result B124A230
++blocktest 32x304 be,h1,v1 b:2 q:7 result B124A230
++blocktest 32x304 be,h1,v1 b:2 q:15 result B124A230
++blocktest 32x304 be,ha,va b:2 q:0 result 99FEA830
++blocktest 32x304 be,ha,va b:2 q:1 result 99FEA830
++blocktest 32x304 be,ha,va b:2 q:3 result 99FEA830
++blocktest 32x304 be,ha,va b:2 q:7 result 99FEA830
++blocktest 32x304 be,ha,va b:2 q:15 result 99FEA830
++blocktest 32x304 be,al,de b:2 q:0 result 99FEA830
++blocktest 32x304 be,al,de b:2 q:1 result 99FEA830
++blocktest 32x304 be,al,de b:2 q:3 result 99FEA830
++blocktest 32x304 be,al,de b:2 q:7 result 24D4A8E9
++blocktest 32x304 be,al,de b:2 q:15 result 24D4A8E9
++blocktest 32x304 be,vi,de b:2 q:0 result 99FEA830
++blocktest 32x304 be,vi,de b:2 q:1 result 99FEA830
++blocktest 32x304 be,vi,de b:2 q:3 result 99FEA830
++blocktest 32x304 be,vi,de b:2 q:7 result 8781A8E5
++blocktest 32x304 be,vi,de b:2 q:15 result 8781A8E5
++blocktest 32x304 be,vi,ha,va b:2 q:0 result 99FEA830
++blocktest 32x304 be,vi,ha,va b:2 q:1 result 99FEA830
++blocktest 32x304 be,vi,ha,va b:2 q:3 result 99FEA830
++blocktest 32x304 be,vi,ha,va b:2 q:7 result 99FEA830
++blocktest 32x304 be,vi,ha,va b:2 q:15 result 99FEA830
++blocktest 32x304 be,de b:4 q:0 result 4293C1D2
++blocktest 32x304 be,de b:4 q:1 result DF76C556
++blocktest 32x304 be,de b:4 q:3 result 1A4C8EE
++blocktest 32x304 be,de b:4 q:7 result 4770C79D
++blocktest 32x304 be,de b:4 q:15 result 4770C79D
++blocktest 32x304 be,h1,v1 b:4 q:0 result E12FC1D2
++blocktest 32x304 be,h1,v1 b:4 q:1 result E12FC1D2
++blocktest 32x304 be,h1,v1 b:4 q:3 result E12FC1D2
++blocktest 32x304 be,h1,v1 b:4 q:7 result E12FC1D2
++blocktest 32x304 be,h1,v1 b:4 q:15 result E12FC1D2
++blocktest 32x304 be,ha,va b:4 q:0 result 3A4CC1D2
++blocktest 32x304 be,ha,va b:4 q:1 result 3A4CC1D2
++blocktest 32x304 be,ha,va b:4 q:3 result 3A4CC1D2
++blocktest 32x304 be,ha,va b:4 q:7 result 3A4CC1D2
++blocktest 32x304 be,ha,va b:4 q:15 result 3A4CC1D2
++blocktest 32x304 be,al,de b:4 q:0 result 4293C1D2
++blocktest 32x304 be,al,de b:4 q:1 result B364C532
++blocktest 32x304 be,al,de b:4 q:3 result 9246C710
++blocktest 32x304 be,al,de b:4 q:7 result 98D1C5E5
++blocktest 32x304 be,al,de b:4 q:15 result 98D1C5E5
++blocktest 32x304 be,vi,de b:4 q:0 result 4293C1D2
++blocktest 32x304 be,vi,de b:4 q:1 result DF76C556
++blocktest 32x304 be,vi,de b:4 q:3 result 1A4C8EE
++blocktest 32x304 be,vi,de b:4 q:7 result 4770C79D
++blocktest 32x304 be,vi,de b:4 q:15 result 4770C79D
++blocktest 32x304 be,vi,ha,va b:4 q:0 result 61E5C07A
++blocktest 32x304 be,vi,ha,va b:4 q:1 result 61E5C07A
++blocktest 32x304 be,vi,ha,va b:4 q:3 result 61E5C07A
++blocktest 32x304 be,vi,ha,va b:4 q:7 result 61E5C07A
++blocktest 32x304 be,vi,ha,va b:4 q:15 result 61E5C07A
++blocktest 32x304 be,de b:8 q:0 result 281DE0C5
++blocktest 32x304 be,de b:8 q:1 result 1A4ADF1D
++blocktest 32x304 be,de b:8 q:3 result 5524DC6E
++blocktest 32x304 be,de b:8 q:7 result ACECDB77
++blocktest 32x304 be,de b:8 q:15 result ACECDB77
++blocktest 32x304 be,h1,v1 b:8 q:0 result 1986E0C5
++blocktest 32x304 be,h1,v1 b:8 q:1 result 1986E0C5
++blocktest 32x304 be,h1,v1 b:8 q:3 result 1986E0C5
++blocktest 32x304 be,h1,v1 b:8 q:7 result 1986E0C5
++blocktest 32x304 be,h1,v1 b:8 q:15 result 1986E0C5
++blocktest 32x304 be,ha,va b:8 q:0 result 665E0C5
++blocktest 32x304 be,ha,va b:8 q:1 result 665E0C5
++blocktest 32x304 be,ha,va b:8 q:3 result 665E0C5
++blocktest 32x304 be,ha,va b:8 q:7 result 665E0C5
++blocktest 32x304 be,ha,va b:8 q:15 result 665E0C5
++blocktest 32x304 be,al,de b:8 q:0 result 281DE0C5
++blocktest 32x304 be,al,de b:8 q:1 result 1A4ADF1D
++blocktest 32x304 be,al,de b:8 q:3 result 5524DC6E
++blocktest 32x304 be,al,de b:8 q:7 result ACECDB77
++blocktest 32x304 be,al,de b:8 q:15 result ACECDB77
++blocktest 32x304 be,vi,de b:8 q:0 result 281DE0C5
++blocktest 32x304 be,vi,de b:8 q:1 result 1A4ADF1D
++blocktest 32x304 be,vi,de b:8 q:3 result 5524DC6E
++blocktest 32x304 be,vi,de b:8 q:7 result ACECDB77
++blocktest 32x304 be,vi,de b:8 q:15 result ACECDB77
++blocktest 32x304 be,vi,ha,va b:8 q:0 result 5DBFE942
++blocktest 32x304 be,vi,ha,va b:8 q:1 result 5DBFE942
++blocktest 32x304 be,vi,ha,va b:8 q:3 result 5DBFE942
++blocktest 32x304 be,vi,ha,va b:8 q:7 result 5DBFE942
++blocktest 32x304 be,vi,ha,va b:8 q:15 result 5DBFE942
++blocktest 32x304 be,de b:16 q:0 result 93C541FA
++blocktest 32x304 be,de b:16 q:1 result A9A541FA
++blocktest 32x304 be,de b:16 q:3 result BB6941FF
++blocktest 32x304 be,de b:16 q:7 result 16834201
++blocktest 32x304 be,de b:16 q:15 result 16834201
++blocktest 32x304 be,h1,v1 b:16 q:0 result 8C4F41FA
++blocktest 32x304 be,h1,v1 b:16 q:1 result 8C4F41FA
++blocktest 32x304 be,h1,v1 b:16 q:3 result 8C4F41FA
++blocktest 32x304 be,h1,v1 b:16 q:7 result 8C4F41FA
++blocktest 32x304 be,h1,v1 b:16 q:15 result 8C4F41FA
++blocktest 32x304 be,ha,va b:16 q:0 result 68A141FA
++blocktest 32x304 be,ha,va b:16 q:1 result 68A141FA
++blocktest 32x304 be,ha,va b:16 q:3 result 68A141FA
++blocktest 32x304 be,ha,va b:16 q:7 result 68A141FA
++blocktest 32x304 be,ha,va b:16 q:15 result 68A141FA
++blocktest 32x304 be,al,de b:16 q:0 result 93C541FA
++blocktest 32x304 be,al,de b:16 q:1 result A9A541FA
++blocktest 32x304 be,al,de b:16 q:3 result BB6941FF
++blocktest 32x304 be,al,de b:16 q:7 result 16834201
++blocktest 32x304 be,al,de b:16 q:15 result 16834201
++blocktest 32x304 be,vi,de b:16 q:0 result 93C541FA
++blocktest 32x304 be,vi,de b:16 q:1 result A9A541FA
++blocktest 32x304 be,vi,de b:16 q:3 result BB6941FF
++blocktest 32x304 be,vi,de b:16 q:7 result 16834201
++blocktest 32x304 be,vi,de b:16 q:15 result 16834201
++blocktest 32x304 be,vi,ha,va b:16 q:0 result 84A649E0
++blocktest 32x304 be,vi,ha,va b:16 q:1 result 84A649E0
++blocktest 32x304 be,vi,ha,va b:16 q:3 result 84A649E0
++blocktest 32x304 be,vi,ha,va b:16 q:7 result 84A649E0
++blocktest 32x304 be,vi,ha,va b:16 q:15 result 84A649E0
++blocktest 80x16 be,de b:1 q:0 result 8B49A358
++blocktest 80x16 be,de b:1 q:1 result 8B49A358
++blocktest 80x16 be,de b:1 q:3 result 8B49A358
++blocktest 80x16 be,de b:1 q:7 result 5D51A2B5
++blocktest 80x16 be,de b:1 q:15 result 5D51A2B5
++blocktest 80x16 be,h1,v1 b:1 q:0 result 8B49A358
++blocktest 80x16 be,h1,v1 b:1 q:1 result 8B49A358
++blocktest 80x16 be,h1,v1 b:1 q:3 result 8B49A358
++blocktest 80x16 be,h1,v1 b:1 q:7 result 8B49A358
++blocktest 80x16 be,h1,v1 b:1 q:15 result 8B49A358
++blocktest 80x16 be,ha,va b:1 q:0 result 8B49A358
++blocktest 80x16 be,ha,va b:1 q:1 result 8B49A358
++blocktest 80x16 be,ha,va b:1 q:3 result 8B49A358
++blocktest 80x16 be,ha,va b:1 q:7 result 8B49A358
++blocktest 80x16 be,ha,va b:1 q:15 result 8B49A358
++blocktest 80x16 be,al,de b:1 q:0 result 8B49A358
++blocktest 80x16 be,al,de b:1 q:1 result 8B49A358
++blocktest 80x16 be,al,de b:1 q:3 result 8B49A358
++blocktest 80x16 be,al,de b:1 q:7 result 8B35A2C7
++blocktest 80x16 be,al,de b:1 q:15 result 8B35A2C7
++blocktest 80x16 be,vi,de b:1 q:0 result 8B49A358
++blocktest 80x16 be,vi,de b:1 q:1 result 8B49A358
++blocktest 80x16 be,vi,de b:1 q:3 result 8B49A358
++blocktest 80x16 be,vi,de b:1 q:7 result 5D51A2B5
++blocktest 80x16 be,vi,de b:1 q:15 result 5D51A2B5
++blocktest 80x16 be,vi,ha,va b:1 q:0 result 8B49A358
++blocktest 80x16 be,vi,ha,va b:1 q:1 result 8B49A358
++blocktest 80x16 be,vi,ha,va b:1 q:3 result 8B49A358
++blocktest 80x16 be,vi,ha,va b:1 q:7 result 8B49A358
++blocktest 80x16 be,vi,ha,va b:1 q:15 result 8B49A358
++blocktest 80x16 be,de b:2 q:0 result FB737CD8
++blocktest 80x16 be,de b:2 q:1 result FB737CD8
++blocktest 80x16 be,de b:2 q:3 result FB737CD8
++blocktest 80x16 be,de b:2 q:7 result 1BE97C8A
++blocktest 80x16 be,de b:2 q:15 result 1BE97C8A
++blocktest 80x16 be,h1,v1 b:2 q:0 result FB737CD8
++blocktest 80x16 be,h1,v1 b:2 q:1 result FB737CD8
++blocktest 80x16 be,h1,v1 b:2 q:3 result FB737CD8
++blocktest 80x16 be,h1,v1 b:2 q:7 result FB737CD8
++blocktest 80x16 be,h1,v1 b:2 q:15 result FB737CD8
++blocktest 80x16 be,ha,va b:2 q:0 result FB737CD8
++blocktest 80x16 be,ha,va b:2 q:1 result FB737CD8
++blocktest 80x16 be,ha,va b:2 q:3 result FB737CD8
++blocktest 80x16 be,ha,va b:2 q:7 result FB737CD8
++blocktest 80x16 be,ha,va b:2 q:15 result FB737CD8
++blocktest 80x16 be,al,de b:2 q:0 result FB737CD8
++blocktest 80x16 be,al,de b:2 q:1 result FB737CD8
++blocktest 80x16 be,al,de b:2 q:3 result FB737CD8
++blocktest 80x16 be,al,de b:2 q:7 result 5C0A7C9B
++blocktest 80x16 be,al,de b:2 q:15 result 5C0A7C9B
++blocktest 80x16 be,vi,de b:2 q:0 result FB737CD8
++blocktest 80x16 be,vi,de b:2 q:1 result FB737CD8
++blocktest 80x16 be,vi,de b:2 q:3 result FB737CD8
++blocktest 80x16 be,vi,de b:2 q:7 result 1BE97C8A
++blocktest 80x16 be,vi,de b:2 q:15 result 1BE97C8A
++blocktest 80x16 be,vi,ha,va b:2 q:0 result FB737CD8
++blocktest 80x16 be,vi,ha,va b:2 q:1 result FB737CD8
++blocktest 80x16 be,vi,ha,va b:2 q:3 result FB737CD8
++blocktest 80x16 be,vi,ha,va b:2 q:7 result FB737CD8
++blocktest 80x16 be,vi,ha,va b:2 q:15 result FB737CD8
++blocktest 80x16 be,de b:4 q:0 result 6E3FC149
++blocktest 80x16 be,de b:4 q:1 result 6E3FC149
++blocktest 80x16 be,de b:4 q:3 result 6E3FC149
++blocktest 80x16 be,de b:4 q:7 result D701C039
++blocktest 80x16 be,de b:4 q:15 result D701C039
++blocktest 80x16 be,h1,v1 b:4 q:0 result 6E3FC149
++blocktest 80x16 be,h1,v1 b:4 q:1 result 6E3FC149
++blocktest 80x16 be,h1,v1 b:4 q:3 result 6E3FC149
++blocktest 80x16 be,h1,v1 b:4 q:7 result 6E3FC149
++blocktest 80x16 be,h1,v1 b:4 q:15 result 6E3FC149
++blocktest 80x16 be,ha,va b:4 q:0 result 6E3FC149
++blocktest 80x16 be,ha,va b:4 q:1 result 6E3FC149
++blocktest 80x16 be,ha,va b:4 q:3 result 6E3FC149
++blocktest 80x16 be,ha,va b:4 q:7 result 6E3FC149
++blocktest 80x16 be,ha,va b:4 q:15 result 6E3FC149
++blocktest 80x16 be,al,de b:4 q:0 result 6E3FC149
++blocktest 80x16 be,al,de b:4 q:1 result 6E3FC149
++blocktest 80x16 be,al,de b:4 q:3 result 6E3FC149
++blocktest 80x16 be,al,de b:4 q:7 result D3E0C071
++blocktest 80x16 be,al,de b:4 q:15 result D3E0C071
++blocktest 80x16 be,vi,de b:4 q:0 result 6E3FC149
++blocktest 80x16 be,vi,de b:4 q:1 result 6E3FC149
++blocktest 80x16 be,vi,de b:4 q:3 result 6E3FC149
++blocktest 80x16 be,vi,de b:4 q:7 result D701C039
++blocktest 80x16 be,vi,de b:4 q:15 result D701C039
++blocktest 80x16 be,vi,ha,va b:4 q:0 result 6E3FC149
++blocktest 80x16 be,vi,ha,va b:4 q:1 result 6E3FC149
++blocktest 80x16 be,vi,ha,va b:4 q:3 result 6E3FC149
++blocktest 80x16 be,vi,ha,va b:4 q:7 result 6E3FC149
++blocktest 80x16 be,vi,ha,va b:4 q:15 result 6E3FC149
++blocktest 80x16 be,de b:8 q:0 result 9DCA2F0A
++blocktest 80x16 be,de b:8 q:1 result 9DCA2F0A
++blocktest 80x16 be,de b:8 q:3 result 9DCA2F0A
++blocktest 80x16 be,de b:8 q:7 result 9DCA2F0A
++blocktest 80x16 be,de b:8 q:15 result 9DCA2F0A
++blocktest 80x16 be,h1,v1 b:8 q:0 result 9DCA2F0A
++blocktest 80x16 be,h1,v1 b:8 q:1 result 9DCA2F0A
++blocktest 80x16 be,h1,v1 b:8 q:3 result 9DCA2F0A
++blocktest 80x16 be,h1,v1 b:8 q:7 result 9DCA2F0A
++blocktest 80x16 be,h1,v1 b:8 q:15 result 9DCA2F0A
++blocktest 80x16 be,ha,va b:8 q:0 result 9DCA2F0A
++blocktest 80x16 be,ha,va b:8 q:1 result 9DCA2F0A
++blocktest 80x16 be,ha,va b:8 q:3 result 9DCA2F0A
++blocktest 80x16 be,ha,va b:8 q:7 result 9DCA2F0A
++blocktest 80x16 be,ha,va b:8 q:15 result 9DCA2F0A
++blocktest 80x16 be,al,de b:8 q:0 result 9DCA2F0A
++blocktest 80x16 be,al,de b:8 q:1 result 9DCA2F0A
++blocktest 80x16 be,al,de b:8 q:3 result 9DCA2F0A
++blocktest 80x16 be,al,de b:8 q:7 result 9DCA2F0A
++blocktest 80x16 be,al,de b:8 q:15 result 9DCA2F0A
++blocktest 80x16 be,vi,de b:8 q:0 result 9DCA2F0A
++blocktest 80x16 be,vi,de b:8 q:1 result 9DCA2F0A
++blocktest 80x16 be,vi,de b:8 q:3 result 9DCA2F0A
++blocktest 80x16 be,vi,de b:8 q:7 result 9DCA2F0A
++blocktest 80x16 be,vi,de b:8 q:15 result 9DCA2F0A
++blocktest 80x16 be,vi,ha,va b:8 q:0 result 9DCA2F0A
++blocktest 80x16 be,vi,ha,va b:8 q:1 result 9DCA2F0A
++blocktest 80x16 be,vi,ha,va b:8 q:3 result 9DCA2F0A
++blocktest 80x16 be,vi,ha,va b:8 q:7 result 9DCA2F0A
++blocktest 80x16 be,vi,ha,va b:8 q:15 result 9DCA2F0A
++blocktest 80x16 be,de b:16 q:0 result 45DF797B
++blocktest 80x16 be,de b:16 q:1 result 45DF797B
++blocktest 80x16 be,de b:16 q:3 result 45DF797B
++blocktest 80x16 be,de b:16 q:7 result 45DF797B
++blocktest 80x16 be,de b:16 q:15 result 45DF797B
++blocktest 80x16 be,h1,v1 b:16 q:0 result 45DF797B
++blocktest 80x16 be,h1,v1 b:16 q:1 result 45DF797B
++blocktest 80x16 be,h1,v1 b:16 q:3 result 45DF797B
++blocktest 80x16 be,h1,v1 b:16 q:7 result 45DF797B
++blocktest 80x16 be,h1,v1 b:16 q:15 result 45DF797B
++blocktest 80x16 be,ha,va b:16 q:0 result 45DF797B
++blocktest 80x16 be,ha,va b:16 q:1 result 45DF797B
++blocktest 80x16 be,ha,va b:16 q:3 result 45DF797B
++blocktest 80x16 be,ha,va b:16 q:7 result 45DF797B
++blocktest 80x16 be,ha,va b:16 q:15 result 45DF797B
++blocktest 80x16 be,al,de b:16 q:0 result 45DF797B
++blocktest 80x16 be,al,de b:16 q:1 result 45DF797B
++blocktest 80x16 be,al,de b:16 q:3 result 45DF797B
++blocktest 80x16 be,al,de b:16 q:7 result 45DF797B
++blocktest 80x16 be,al,de b:16 q:15 result 45DF797B
++blocktest 80x16 be,vi,de b:16 q:0 result 45DF797B
++blocktest 80x16 be,vi,de b:16 q:1 result 45DF797B
++blocktest 80x16 be,vi,de b:16 q:3 result 45DF797B
++blocktest 80x16 be,vi,de b:16 q:7 result 45DF797B
++blocktest 80x16 be,vi,de b:16 q:15 result 45DF797B
++blocktest 80x16 be,vi,ha,va b:16 q:0 result 45DF797B
++blocktest 80x16 be,vi,ha,va b:16 q:1 result 45DF797B
++blocktest 80x16 be,vi,ha,va b:16 q:3 result 45DF797B
++blocktest 80x16 be,vi,ha,va b:16 q:7 result 45DF797B
++blocktest 80x16 be,vi,ha,va b:16 q:15 result 45DF797B
++blocktest 80x64 be,de b:1 q:0 result D4BEC0D
++blocktest 80x64 be,de b:1 q:1 result D4BEC0D
++blocktest 80x64 be,de b:1 q:3 result D4BEC0D
++blocktest 80x64 be,de b:1 q:7 result 315BEB14
++blocktest 80x64 be,de b:1 q:15 result 315BEB14
++blocktest 80x64 be,h1,v1 b:1 q:0 result 8AFEC0D
++blocktest 80x64 be,h1,v1 b:1 q:1 result 8AFEC0D
++blocktest 80x64 be,h1,v1 b:1 q:3 result 8AFEC0D
++blocktest 80x64 be,h1,v1 b:1 q:7 result 8AFEC0D
++blocktest 80x64 be,h1,v1 b:1 q:15 result 8AFEC0D
++blocktest 80x64 be,ha,va b:1 q:0 result D4BEC0D
++blocktest 80x64 be,ha,va b:1 q:1 result D4BEC0D
++blocktest 80x64 be,ha,va b:1 q:3 result D4BEC0D
++blocktest 80x64 be,ha,va b:1 q:7 result D4BEC0D
++blocktest 80x64 be,ha,va b:1 q:15 result D4BEC0D
++blocktest 80x64 be,al,de b:1 q:0 result D4BEC0D
++blocktest 80x64 be,al,de b:1 q:1 result D4BEC0D
++blocktest 80x64 be,al,de b:1 q:3 result D4BEC0D
++blocktest 80x64 be,al,de b:1 q:7 result 64DCEB19
++blocktest 80x64 be,al,de b:1 q:15 result 64DCEB19
++blocktest 80x64 be,vi,de b:1 q:0 result D4BEC0D
++blocktest 80x64 be,vi,de b:1 q:1 result D4BEC0D
++blocktest 80x64 be,vi,de b:1 q:3 result D4BEC0D
++blocktest 80x64 be,vi,de b:1 q:7 result 315BEB14
++blocktest 80x64 be,vi,de b:1 q:15 result 315BEB14
++blocktest 80x64 be,vi,ha,va b:1 q:0 result D4BEC0D
++blocktest 80x64 be,vi,ha,va b:1 q:1 result D4BEC0D
++blocktest 80x64 be,vi,ha,va b:1 q:3 result D4BEC0D
++blocktest 80x64 be,vi,ha,va b:1 q:7 result D4BEC0D
++blocktest 80x64 be,vi,ha,va b:1 q:15 result D4BEC0D
++blocktest 80x64 be,de b:2 q:0 result E0C4BF0D
++blocktest 80x64 be,de b:2 q:1 result E0C4BF0D
++blocktest 80x64 be,de b:2 q:3 result E0C4BF0D
++blocktest 80x64 be,de b:2 q:7 result E0EEBE71
++blocktest 80x64 be,de b:2 q:15 result E0EEBE71
++blocktest 80x64 be,h1,v1 b:2 q:0 result CF40BF0D
++blocktest 80x64 be,h1,v1 b:2 q:1 result CF40BF0D
++blocktest 80x64 be,h1,v1 b:2 q:3 result CF40BF0D
++blocktest 80x64 be,h1,v1 b:2 q:7 result CF40BF0D
++blocktest 80x64 be,h1,v1 b:2 q:15 result CF40BF0D
++blocktest 80x64 be,ha,va b:2 q:0 result E0C4BF0D
++blocktest 80x64 be,ha,va b:2 q:1 result E0C4BF0D
++blocktest 80x64 be,ha,va b:2 q:3 result E0C4BF0D
++blocktest 80x64 be,ha,va b:2 q:7 result E0C4BF0D
++blocktest 80x64 be,ha,va b:2 q:15 result E0C4BF0D
++blocktest 80x64 be,al,de b:2 q:0 result E0C4BF0D
++blocktest 80x64 be,al,de b:2 q:1 result E0C4BF0D
++blocktest 80x64 be,al,de b:2 q:3 result E0C4BF0D
++blocktest 80x64 be,al,de b:2 q:7 result 5907BE97
++blocktest 80x64 be,al,de b:2 q:15 result 5907BE97
++blocktest 80x64 be,vi,de b:2 q:0 result E0C4BF0D
++blocktest 80x64 be,vi,de b:2 q:1 result E0C4BF0D
++blocktest 80x64 be,vi,de b:2 q:3 result E0C4BF0D
++blocktest 80x64 be,vi,de b:2 q:7 result E0EEBE71
++blocktest 80x64 be,vi,de b:2 q:15 result E0EEBE71
++blocktest 80x64 be,vi,ha,va b:2 q:0 result E0C4BF0D
++blocktest 80x64 be,vi,ha,va b:2 q:1 result E0C4BF0D
++blocktest 80x64 be,vi,ha,va b:2 q:3 result E0C4BF0D
++blocktest 80x64 be,vi,ha,va b:2 q:7 result E0C4BF0D
++blocktest 80x64 be,vi,ha,va b:2 q:15 result E0C4BF0D
++blocktest 80x64 be,de b:4 q:0 result AFCCD77E
++blocktest 80x64 be,de b:4 q:1 result 43ABD976
++blocktest 80x64 be,de b:4 q:3 result A155DBE2
++blocktest 80x64 be,de b:4 q:7 result 2EAED8DF
++blocktest 80x64 be,de b:4 q:15 result 2EAED8DF
++blocktest 80x64 be,h1,v1 b:4 q:0 result B6DFD77E
++blocktest 80x64 be,h1,v1 b:4 q:1 result B6DFD77E
++blocktest 80x64 be,h1,v1 b:4 q:3 result B6DFD77E
++blocktest 80x64 be,h1,v1 b:4 q:7 result B6DFD77E
++blocktest 80x64 be,h1,v1 b:4 q:15 result B6DFD77E
++blocktest 80x64 be,ha,va b:4 q:0 result 9B7AD77E
++blocktest 80x64 be,ha,va b:4 q:1 result 9B7AD77E
++blocktest 80x64 be,ha,va b:4 q:3 result 9B7AD77E
++blocktest 80x64 be,ha,va b:4 q:7 result 9B7AD77E
++blocktest 80x64 be,ha,va b:4 q:15 result 9B7AD77E
++blocktest 80x64 be,al,de b:4 q:0 result AFCCD77E
++blocktest 80x64 be,al,de b:4 q:1 result DEBDD9D6
++blocktest 80x64 be,al,de b:4 q:3 result 4FE9DB7E
++blocktest 80x64 be,al,de b:4 q:7 result C492D87D
++blocktest 80x64 be,al,de b:4 q:15 result C492D87D
++blocktest 80x64 be,vi,de b:4 q:0 result AFCCD77E
++blocktest 80x64 be,vi,de b:4 q:1 result 43ABD976
++blocktest 80x64 be,vi,de b:4 q:3 result A155DBE2
++blocktest 80x64 be,vi,de b:4 q:7 result 2EAED8DF
++blocktest 80x64 be,vi,de b:4 q:15 result 2EAED8DF
++blocktest 80x64 be,vi,ha,va b:4 q:0 result 6A81D3BF
++blocktest 80x64 be,vi,ha,va b:4 q:1 result 6A81D3BF
++blocktest 80x64 be,vi,ha,va b:4 q:3 result 6A81D3BF
++blocktest 80x64 be,vi,ha,va b:4 q:7 result 6A81D3BF
++blocktest 80x64 be,vi,ha,va b:4 q:15 result 6A81D3BF
++blocktest 80x64 be,de b:8 q:0 result 70654673
++blocktest 80x64 be,de b:8 q:1 result B03D4523
++blocktest 80x64 be,de b:8 q:3 result 2D5A43C0
++blocktest 80x64 be,de b:8 q:7 result 2D994325
++blocktest 80x64 be,de b:8 q:15 result 2D994325
++blocktest 80x64 be,h1,v1 b:8 q:0 result F0B94673
++blocktest 80x64 be,h1,v1 b:8 q:1 result F0B94673
++blocktest 80x64 be,h1,v1 b:8 q:3 result F0B94673
++blocktest 80x64 be,h1,v1 b:8 q:7 result F0B94673
++blocktest 80x64 be,h1,v1 b:8 q:15 result F0B94673
++blocktest 80x64 be,ha,va b:8 q:0 result AC814673
++blocktest 80x64 be,ha,va b:8 q:1 result AC814673
++blocktest 80x64 be,ha,va b:8 q:3 result AC814673
++blocktest 80x64 be,ha,va b:8 q:7 result AC814673
++blocktest 80x64 be,ha,va b:8 q:15 result AC814673
++blocktest 80x64 be,al,de b:8 q:0 result 70654673
++blocktest 80x64 be,al,de b:8 q:1 result 3D3B4543
++blocktest 80x64 be,al,de b:8 q:3 result 161043F0
++blocktest 80x64 be,al,de b:8 q:7 result 164F4355
++blocktest 80x64 be,al,de b:8 q:15 result 164F4355
++blocktest 80x64 be,vi,de b:8 q:0 result 70654673
++blocktest 80x64 be,vi,de b:8 q:1 result B03D4523
++blocktest 80x64 be,vi,de b:8 q:3 result 2D5A43C0
++blocktest 80x64 be,vi,de b:8 q:7 result 2D994325
++blocktest 80x64 be,vi,de b:8 q:15 result 2D994325
++blocktest 80x64 be,vi,ha,va b:8 q:0 result 7E744EC3
++blocktest 80x64 be,vi,ha,va b:8 q:1 result 7E744EC3
++blocktest 80x64 be,vi,ha,va b:8 q:3 result 7E744EC3
++blocktest 80x64 be,vi,ha,va b:8 q:7 result 7E744EC3
++blocktest 80x64 be,vi,ha,va b:8 q:15 result 7E744EC3
++blocktest 80x64 be,de b:16 q:0 result ED376028
++blocktest 80x64 be,de b:16 q:1 result FE676028
++blocktest 80x64 be,de b:16 q:3 result E8826028
++blocktest 80x64 be,de b:16 q:7 result 5FA76038
++blocktest 80x64 be,de b:16 q:15 result 5FA76038
++blocktest 80x64 be,h1,v1 b:16 q:0 result 3EC36028
++blocktest 80x64 be,h1,v1 b:16 q:1 result 3EC36028
++blocktest 80x64 be,h1,v1 b:16 q:3 result 3EC36028
++blocktest 80x64 be,h1,v1 b:16 q:7 result 3EC36028
++blocktest 80x64 be,h1,v1 b:16 q:15 result 3EC36028
++blocktest 80x64 be,ha,va b:16 q:0 result C7756028
++blocktest 80x64 be,ha,va b:16 q:1 result C7756028
++blocktest 80x64 be,ha,va b:16 q:3 result C7756028
++blocktest 80x64 be,ha,va b:16 q:7 result C7756028
++blocktest 80x64 be,ha,va b:16 q:15 result C7756028
++blocktest 80x64 be,al,de b:16 q:0 result ED376028
++blocktest 80x64 be,al,de b:16 q:1 result FCD76028
++blocktest 80x64 be,al,de b:16 q:3 result E6F26028
++blocktest 80x64 be,al,de b:16 q:7 result 5E176038
++blocktest 80x64 be,al,de b:16 q:15 result 5E176038
++blocktest 80x64 be,vi,de b:16 q:0 result ED376028
++blocktest 80x64 be,vi,de b:16 q:1 result FE676028
++blocktest 80x64 be,vi,de b:16 q:3 result E8826028
++blocktest 80x64 be,vi,de b:16 q:7 result 5FA76038
++blocktest 80x64 be,vi,de b:16 q:15 result 5FA76038
++blocktest 80x64 be,vi,ha,va b:16 q:0 result 5B487283
++blocktest 80x64 be,vi,ha,va b:16 q:1 result 5B487283
++blocktest 80x64 be,vi,ha,va b:16 q:3 result 5B487283
++blocktest 80x64 be,vi,ha,va b:16 q:7 result 5B487283
++blocktest 80x64 be,vi,ha,va b:16 q:15 result 5B487283
++blocktest 80x304 be,de b:1 q:0 result 9FAE9EA5
++blocktest 80x304 be,de b:1 q:1 result 9FAE9EA5
++blocktest 80x304 be,de b:1 q:3 result 9FAE9EA5
++blocktest 80x304 be,de b:1 q:7 result 98109DA6
++blocktest 80x304 be,de b:1 q:15 result 98109DA6
++blocktest 80x304 be,h1,v1 b:1 q:0 result DEFCA0A5
++blocktest 80x304 be,h1,v1 b:1 q:1 result DEFCA0A5
++blocktest 80x304 be,h1,v1 b:1 q:3 result DEFCA0A5
++blocktest 80x304 be,h1,v1 b:1 q:7 result DEFCA0A5
++blocktest 80x304 be,h1,v1 b:1 q:15 result DEFCA0A5
++blocktest 80x304 be,ha,va b:1 q:0 result 9FAE9EA5
++blocktest 80x304 be,ha,va b:1 q:1 result 9FAE9EA5
++blocktest 80x304 be,ha,va b:1 q:3 result 9FAE9EA5
++blocktest 80x304 be,ha,va b:1 q:7 result 9FAE9EA5
++blocktest 80x304 be,ha,va b:1 q:15 result 9FAE9EA5
++blocktest 80x304 be,al,de b:1 q:0 result 9FAE9EA5
++blocktest 80x304 be,al,de b:1 q:1 result 9FAE9EA5
++blocktest 80x304 be,al,de b:1 q:3 result 9FAE9EA5
++blocktest 80x304 be,al,de b:1 q:7 result 98109DA6
++blocktest 80x304 be,al,de b:1 q:15 result 98109DA6
++blocktest 80x304 be,vi,de b:1 q:0 result 9FAE9EA5
++blocktest 80x304 be,vi,de b:1 q:1 result 9FAE9EA5
++blocktest 80x304 be,vi,de b:1 q:3 result 9FAE9EA5
++blocktest 80x304 be,vi,de b:1 q:7 result 98109DA6
++blocktest 80x304 be,vi,de b:1 q:15 result 98109DA6
++blocktest 80x304 be,vi,ha,va b:1 q:0 result 9FAE9EA5
++blocktest 80x304 be,vi,ha,va b:1 q:1 result 9FAE9EA5
++blocktest 80x304 be,vi,ha,va b:1 q:3 result 9FAE9EA5
++blocktest 80x304 be,vi,ha,va b:1 q:7 result 9FAE9EA5
++blocktest 80x304 be,vi,ha,va b:1 q:15 result 9FAE9EA5
++blocktest 80x304 be,de b:2 q:0 result 6A5144A5
++blocktest 80x304 be,de b:2 q:1 result 6A5144A5
++blocktest 80x304 be,de b:2 q:3 result 6A5144A5
++blocktest 80x304 be,de b:2 q:7 result 2DF345B5
++blocktest 80x304 be,de b:2 q:15 result 2DF345B5
++blocktest 80x304 be,h1,v1 b:2 q:0 result A7E836A5
++blocktest 80x304 be,h1,v1 b:2 q:1 result A7E836A5
++blocktest 80x304 be,h1,v1 b:2 q:3 result A7E836A5
++blocktest 80x304 be,h1,v1 b:2 q:7 result A7E836A5
++blocktest 80x304 be,h1,v1 b:2 q:15 result A7E836A5
++blocktest 80x304 be,ha,va b:2 q:0 result 6A5144A5
++blocktest 80x304 be,ha,va b:2 q:1 result 6A5144A5
++blocktest 80x304 be,ha,va b:2 q:3 result 6A5144A5
++blocktest 80x304 be,ha,va b:2 q:7 result 6A5144A5
++blocktest 80x304 be,ha,va b:2 q:15 result 6A5144A5
++blocktest 80x304 be,al,de b:2 q:0 result 6A5144A5
++blocktest 80x304 be,al,de b:2 q:1 result 6A5144A5
++blocktest 80x304 be,al,de b:2 q:3 result 6A5144A5
++blocktest 80x304 be,al,de b:2 q:7 result 5E084557
++blocktest 80x304 be,al,de b:2 q:15 result 5E084557
++blocktest 80x304 be,vi,de b:2 q:0 result 6A5144A5
++blocktest 80x304 be,vi,de b:2 q:1 result 6A5144A5
++blocktest 80x304 be,vi,de b:2 q:3 result 6A5144A5
++blocktest 80x304 be,vi,de b:2 q:7 result 2DF345B5
++blocktest 80x304 be,vi,de b:2 q:15 result 2DF345B5
++blocktest 80x304 be,vi,ha,va b:2 q:0 result 6A5144A5
++blocktest 80x304 be,vi,ha,va b:2 q:1 result 6A5144A5
++blocktest 80x304 be,vi,ha,va b:2 q:3 result 6A5144A5
++blocktest 80x304 be,vi,ha,va b:2 q:7 result 6A5144A5
++blocktest 80x304 be,vi,ha,va b:2 q:15 result 6A5144A5
++blocktest 80x304 be,de b:4 q:0 result E605D56
++blocktest 80x304 be,de b:4 q:1 result BA1C6B96
++blocktest 80x304 be,de b:4 q:3 result C6D877AB
++blocktest 80x304 be,de b:4 q:7 result 539D6FC6
++blocktest 80x304 be,de b:4 q:15 result 539D6FC6
++blocktest 80x304 be,h1,v1 b:4 q:0 result 62F55D56
++blocktest 80x304 be,h1,v1 b:4 q:1 result 62F55D56
++blocktest 80x304 be,h1,v1 b:4 q:3 result 62F55D56
++blocktest 80x304 be,h1,v1 b:4 q:7 result 62F55D56
++blocktest 80x304 be,h1,v1 b:4 q:15 result 62F55D56
++blocktest 80x304 be,ha,va b:4 q:0 result D92E5D56
++blocktest 80x304 be,ha,va b:4 q:1 result D92E5D56
++blocktest 80x304 be,ha,va b:4 q:3 result D92E5D56
++blocktest 80x304 be,ha,va b:4 q:7 result D92E5D56
++blocktest 80x304 be,ha,va b:4 q:15 result D92E5D56
++blocktest 80x304 be,al,de b:4 q:0 result E605D56
++blocktest 80x304 be,al,de b:4 q:1 result 8BE26AFA
++blocktest 80x304 be,al,de b:4 q:3 result 75737478
++blocktest 80x304 be,al,de b:4 q:7 result 53516C47
++blocktest 80x304 be,al,de b:4 q:15 result 53516C47
++blocktest 80x304 be,vi,de b:4 q:0 result E605D56
++blocktest 80x304 be,vi,de b:4 q:1 result BA1C6B96
++blocktest 80x304 be,vi,de b:4 q:3 result C6D877AB
++blocktest 80x304 be,vi,de b:4 q:7 result 539D6FC6
++blocktest 80x304 be,vi,de b:4 q:15 result 539D6FC6
++blocktest 80x304 be,vi,ha,va b:4 q:0 result 3586591D
++blocktest 80x304 be,vi,ha,va b:4 q:1 result 3586591D
++blocktest 80x304 be,vi,ha,va b:4 q:3 result 3586591D
++blocktest 80x304 be,vi,ha,va b:4 q:7 result 3586591D
++blocktest 80x304 be,vi,ha,va b:4 q:15 result 3586591D
++blocktest 80x304 be,de b:8 q:0 result 24D6BF99
++blocktest 80x304 be,de b:8 q:1 result 11CBB8C1
++blocktest 80x304 be,de b:8 q:3 result 76CFB06A
++blocktest 80x304 be,de b:8 q:7 result C22CAD49
++blocktest 80x304 be,de b:8 q:15 result C22CAD49
++blocktest 80x304 be,h1,v1 b:8 q:0 result B7BEBF99
++blocktest 80x304 be,h1,v1 b:8 q:1 result B7BEBF99
++blocktest 80x304 be,h1,v1 b:8 q:3 result B7BEBF99
++blocktest 80x304 be,h1,v1 b:8 q:7 result B7BEBF99
++blocktest 80x304 be,h1,v1 b:8 q:15 result B7BEBF99
++blocktest 80x304 be,ha,va b:8 q:0 result 2C8DBF99
++blocktest 80x304 be,ha,va b:8 q:1 result 2C8DBF99
++blocktest 80x304 be,ha,va b:8 q:3 result 2C8DBF99
++blocktest 80x304 be,ha,va b:8 q:7 result 2C8DBF99
++blocktest 80x304 be,ha,va b:8 q:15 result 2C8DBF99
++blocktest 80x304 be,al,de b:8 q:0 result 24D6BF99
++blocktest 80x304 be,al,de b:8 q:1 result 566DB911
++blocktest 80x304 be,al,de b:8 q:3 result 5D4DB136
++blocktest 80x304 be,al,de b:8 q:7 result A8AAAE15
++blocktest 80x304 be,al,de b:8 q:15 result A8AAAE15
++blocktest 80x304 be,vi,de b:8 q:0 result 24D6BF99
++blocktest 80x304 be,vi,de b:8 q:1 result 11CBB8C1
++blocktest 80x304 be,vi,de b:8 q:3 result 76CFB06A
++blocktest 80x304 be,vi,de b:8 q:7 result C22CAD49
++blocktest 80x304 be,vi,de b:8 q:15 result C22CAD49
++blocktest 80x304 be,vi,ha,va b:8 q:0 result BA23C574
++blocktest 80x304 be,vi,ha,va b:8 q:1 result BA23C574
++blocktest 80x304 be,vi,ha,va b:8 q:3 result BA23C574
++blocktest 80x304 be,vi,ha,va b:8 q:7 result BA23C574
++blocktest 80x304 be,vi,ha,va b:8 q:15 result BA23C574
++blocktest 80x304 be,de b:16 q:0 result ABE69056
++blocktest 80x304 be,de b:16 q:1 result 8259056
++blocktest 80x304 be,de b:16 q:3 result 39779099
++blocktest 80x304 be,de b:16 q:7 result E39890D0
++blocktest 80x304 be,de b:16 q:15 result E39890D0
++blocktest 80x304 be,h1,v1 b:16 q:0 result E75E9056
++blocktest 80x304 be,h1,v1 b:16 q:1 result E75E9056
++blocktest 80x304 be,h1,v1 b:16 q:3 result E75E9056
++blocktest 80x304 be,h1,v1 b:16 q:7 result E75E9056
++blocktest 80x304 be,h1,v1 b:16 q:15 result E75E9056
++blocktest 80x304 be,ha,va b:16 q:0 result C6359056
++blocktest 80x304 be,ha,va b:16 q:1 result C6359056
++blocktest 80x304 be,ha,va b:16 q:3 result C6359056
++blocktest 80x304 be,ha,va b:16 q:7 result C6359056
++blocktest 80x304 be,ha,va b:16 q:15 result C6359056
++blocktest 80x304 be,al,de b:16 q:0 result ABE69056
++blocktest 80x304 be,al,de b:16 q:1 result 3759056
++blocktest 80x304 be,al,de b:16 q:3 result 23459096
++blocktest 80x304 be,al,de b:16 q:7 result CD6690CD
++blocktest 80x304 be,al,de b:16 q:15 result CD6690CD
++blocktest 80x304 be,vi,de b:16 q:0 result ABE69056
++blocktest 80x304 be,vi,de b:16 q:1 result 8259056
++blocktest 80x304 be,vi,de b:16 q:3 result 39779099
++blocktest 80x304 be,vi,de b:16 q:7 result E39890D0
++blocktest 80x304 be,vi,de b:16 q:15 result E39890D0
++blocktest 80x304 be,vi,ha,va b:16 q:0 result 533A780
++blocktest 80x304 be,vi,ha,va b:16 q:1 result 533A780
++blocktest 80x304 be,vi,ha,va b:16 q:3 result 533A780
++blocktest 80x304 be,vi,ha,va b:16 q:7 result 533A780
++blocktest 80x304 be,vi,ha,va b:16 q:15 result 533A780
++blocktest 224x16 be,de b:1 q:0 result 7B974D31
++blocktest 224x16 be,de b:1 q:1 result 7B974D31
++blocktest 224x16 be,de b:1 q:3 result 7B974D31
++blocktest 224x16 be,de b:1 q:7 result EB794AC0
++blocktest 224x16 be,de b:1 q:15 result EB794AC0
++blocktest 224x16 be,h1,v1 b:1 q:0 result 7B974D31
++blocktest 224x16 be,h1,v1 b:1 q:1 result 7B974D31
++blocktest 224x16 be,h1,v1 b:1 q:3 result 7B974D31
++blocktest 224x16 be,h1,v1 b:1 q:7 result 7B974D31
++blocktest 224x16 be,h1,v1 b:1 q:15 result 7B974D31
++blocktest 224x16 be,ha,va b:1 q:0 result 7B974D31
++blocktest 224x16 be,ha,va b:1 q:1 result 7B974D31
++blocktest 224x16 be,ha,va b:1 q:3 result 7B974D31
++blocktest 224x16 be,ha,va b:1 q:7 result 7B974D31
++blocktest 224x16 be,ha,va b:1 q:15 result 7B974D31
++blocktest 224x16 be,al,de b:1 q:0 result 7B974D31
++blocktest 224x16 be,al,de b:1 q:1 result 7B974D31
++blocktest 224x16 be,al,de b:1 q:3 result 7B974D31
++blocktest 224x16 be,al,de b:1 q:7 result 470B4ACC
++blocktest 224x16 be,al,de b:1 q:15 result 470B4ACC
++blocktest 224x16 be,vi,de b:1 q:0 result 7B974D31
++blocktest 224x16 be,vi,de b:1 q:1 result 7B974D31
++blocktest 224x16 be,vi,de b:1 q:3 result 7B974D31
++blocktest 224x16 be,vi,de b:1 q:7 result EB794AC0
++blocktest 224x16 be,vi,de b:1 q:15 result EB794AC0
++blocktest 224x16 be,vi,ha,va b:1 q:0 result 7B974D31
++blocktest 224x16 be,vi,ha,va b:1 q:1 result 7B974D31
++blocktest 224x16 be,vi,ha,va b:1 q:3 result 7B974D31
++blocktest 224x16 be,vi,ha,va b:1 q:7 result 7B974D31
++blocktest 224x16 be,vi,ha,va b:1 q:15 result 7B974D31
++blocktest 224x16 be,de b:2 q:0 result 7C63EBA2
++blocktest 224x16 be,de b:2 q:1 result 7C63EBA2
++blocktest 224x16 be,de b:2 q:3 result 7C63EBA2
++blocktest 224x16 be,de b:2 q:7 result 52FEBA4
++blocktest 224x16 be,de b:2 q:15 result 52FEBA4
++blocktest 224x16 be,h1,v1 b:2 q:0 result 370E9A2
++blocktest 224x16 be,h1,v1 b:2 q:1 result 370E9A2
++blocktest 224x16 be,h1,v1 b:2 q:3 result 370E9A2
++blocktest 224x16 be,h1,v1 b:2 q:7 result 370E9A2
++blocktest 224x16 be,h1,v1 b:2 q:15 result 370E9A2
++blocktest 224x16 be,ha,va b:2 q:0 result 7C63EBA2
++blocktest 224x16 be,ha,va b:2 q:1 result 7C63EBA2
++blocktest 224x16 be,ha,va b:2 q:3 result 7C63EBA2
++blocktest 224x16 be,ha,va b:2 q:7 result 7C63EBA2
++blocktest 224x16 be,ha,va b:2 q:15 result 7C63EBA2
++blocktest 224x16 be,al,de b:2 q:0 result 7C63EBA2
++blocktest 224x16 be,al,de b:2 q:1 result 7C63EBA2
++blocktest 224x16 be,al,de b:2 q:3 result 7C63EBA2
++blocktest 224x16 be,al,de b:2 q:7 result 9A22EB6E
++blocktest 224x16 be,al,de b:2 q:15 result 9A22EB6E
++blocktest 224x16 be,vi,de b:2 q:0 result 7C63EBA2
++blocktest 224x16 be,vi,de b:2 q:1 result 7C63EBA2
++blocktest 224x16 be,vi,de b:2 q:3 result 7C63EBA2
++blocktest 224x16 be,vi,de b:2 q:7 result 52FEBA4
++blocktest 224x16 be,vi,de b:2 q:15 result 52FEBA4
++blocktest 224x16 be,vi,ha,va b:2 q:0 result 7C63EBA2
++blocktest 224x16 be,vi,ha,va b:2 q:1 result 7C63EBA2
++blocktest 224x16 be,vi,ha,va b:2 q:3 result 7C63EBA2
++blocktest 224x16 be,vi,ha,va b:2 q:7 result 7C63EBA2
++blocktest 224x16 be,vi,ha,va b:2 q:15 result 7C63EBA2
++blocktest 224x16 be,de b:4 q:0 result E4F2C1D3
++blocktest 224x16 be,de b:4 q:1 result 2500C2CF
++blocktest 224x16 be,de b:4 q:3 result 73CDC2CD
++blocktest 224x16 be,de b:4 q:7 result A0B7C1F4
++blocktest 224x16 be,de b:4 q:15 result A0B7C1F4
++blocktest 224x16 be,h1,v1 b:4 q:0 result 45ACC1D3
++blocktest 224x16 be,h1,v1 b:4 q:1 result 45ACC1D3
++blocktest 224x16 be,h1,v1 b:4 q:3 result 45ACC1D3
++blocktest 224x16 be,h1,v1 b:4 q:7 result 45ACC1D3
++blocktest 224x16 be,h1,v1 b:4 q:15 result 45ACC1D3
++blocktest 224x16 be,ha,va b:4 q:0 result 4E66C1D3
++blocktest 224x16 be,ha,va b:4 q:1 result 4E66C1D3
++blocktest 224x16 be,ha,va b:4 q:3 result 4E66C1D3
++blocktest 224x16 be,ha,va b:4 q:7 result 4E66C1D3
++blocktest 224x16 be,ha,va b:4 q:15 result 4E66C1D3
++blocktest 224x16 be,al,de b:4 q:0 result E4F2C1D3
++blocktest 224x16 be,al,de b:4 q:1 result F942C1D3
++blocktest 224x16 be,al,de b:4 q:3 result 57C4C1DC
++blocktest 224x16 be,al,de b:4 q:7 result 6F21C0E2
++blocktest 224x16 be,al,de b:4 q:15 result 6F21C0E2
++blocktest 224x16 be,vi,de b:4 q:0 result E4F2C1D3
++blocktest 224x16 be,vi,de b:4 q:1 result 2500C2CF
++blocktest 224x16 be,vi,de b:4 q:3 result 73CDC2CD
++blocktest 224x16 be,vi,de b:4 q:7 result A0B7C1F4
++blocktest 224x16 be,vi,de b:4 q:15 result A0B7C1F4
++blocktest 224x16 be,vi,ha,va b:4 q:0 result E4DEC108
++blocktest 224x16 be,vi,ha,va b:4 q:1 result E4DEC108
++blocktest 224x16 be,vi,ha,va b:4 q:3 result E4DEC108
++blocktest 224x16 be,vi,ha,va b:4 q:7 result E4DEC108
++blocktest 224x16 be,vi,ha,va b:4 q:15 result E4DEC108
++blocktest 224x16 be,de b:8 q:0 result 74FB2724
++blocktest 224x16 be,de b:8 q:1 result 4B862654
++blocktest 224x16 be,de b:8 q:3 result EA182630
++blocktest 224x16 be,de b:8 q:7 result EA182630
++blocktest 224x16 be,de b:8 q:15 result EA182630
++blocktest 224x16 be,h1,v1 b:8 q:0 result A0A22724
++blocktest 224x16 be,h1,v1 b:8 q:1 result A0A22724
++blocktest 224x16 be,h1,v1 b:8 q:3 result A0A22724
++blocktest 224x16 be,h1,v1 b:8 q:7 result A0A22724
++blocktest 224x16 be,h1,v1 b:8 q:15 result A0A22724
++blocktest 224x16 be,ha,va b:8 q:0 result DE0C2724
++blocktest 224x16 be,ha,va b:8 q:1 result DE0C2724
++blocktest 224x16 be,ha,va b:8 q:3 result DE0C2724
++blocktest 224x16 be,ha,va b:8 q:7 result DE0C2724
++blocktest 224x16 be,ha,va b:8 q:15 result DE0C2724
++blocktest 224x16 be,al,de b:8 q:0 result 74FB2724
++blocktest 224x16 be,al,de b:8 q:1 result 9842674
++blocktest 224x16 be,al,de b:8 q:3 result 49372650
++blocktest 224x16 be,al,de b:8 q:7 result 49372650
++blocktest 224x16 be,al,de b:8 q:15 result 49372650
++blocktest 224x16 be,vi,de b:8 q:0 result 74FB2724
++blocktest 224x16 be,vi,de b:8 q:1 result 4B862654
++blocktest 224x16 be,vi,de b:8 q:3 result EA182630
++blocktest 224x16 be,vi,de b:8 q:7 result EA182630
++blocktest 224x16 be,vi,de b:8 q:15 result EA182630
++blocktest 224x16 be,vi,ha,va b:8 q:0 result 629B2562
++blocktest 224x16 be,vi,ha,va b:8 q:1 result 629B2562
++blocktest 224x16 be,vi,ha,va b:8 q:3 result 629B2562
++blocktest 224x16 be,vi,ha,va b:8 q:7 result 629B2562
++blocktest 224x16 be,vi,ha,va b:8 q:15 result 629B2562
++blocktest 224x16 be,de b:16 q:0 result 6BB5D37
++blocktest 224x16 be,de b:16 q:1 result 133B5D37
++blocktest 224x16 be,de b:16 q:3 result 165B5D37
++blocktest 224x16 be,de b:16 q:7 result 165B5D37
++blocktest 224x16 be,de b:16 q:15 result 165B5D37
++blocktest 224x16 be,h1,v1 b:16 q:0 result 9135D37
++blocktest 224x16 be,h1,v1 b:16 q:1 result 9135D37
++blocktest 224x16 be,h1,v1 b:16 q:3 result 9135D37
++blocktest 224x16 be,h1,v1 b:16 q:7 result 9135D37
++blocktest 224x16 be,h1,v1 b:16 q:15 result 9135D37
++blocktest 224x16 be,ha,va b:16 q:0 result 8CB5D37
++blocktest 224x16 be,ha,va b:16 q:1 result 8CB5D37
++blocktest 224x16 be,ha,va b:16 q:3 result 8CB5D37
++blocktest 224x16 be,ha,va b:16 q:7 result 8CB5D37
++blocktest 224x16 be,ha,va b:16 q:15 result 8CB5D37
++blocktest 224x16 be,al,de b:16 q:0 result 6BB5D37
++blocktest 224x16 be,al,de b:16 q:1 result 11AB5D37
++blocktest 224x16 be,al,de b:16 q:3 result 14CB5D37
++blocktest 224x16 be,al,de b:16 q:7 result 14CB5D37
++blocktest 224x16 be,al,de b:16 q:15 result 14CB5D37
++blocktest 224x16 be,vi,de b:16 q:0 result 6BB5D37
++blocktest 224x16 be,vi,de b:16 q:1 result 133B5D37
++blocktest 224x16 be,vi,de b:16 q:3 result 165B5D37
++blocktest 224x16 be,vi,de b:16 q:7 result 165B5D37
++blocktest 224x16 be,vi,de b:16 q:15 result 165B5D37
++blocktest 224x16 be,vi,ha,va b:16 q:0 result 1D1A5D87
++blocktest 224x16 be,vi,ha,va b:16 q:1 result 1D1A5D87
++blocktest 224x16 be,vi,ha,va b:16 q:3 result 1D1A5D87
++blocktest 224x16 be,vi,ha,va b:16 q:7 result 1D1A5D87
++blocktest 224x16 be,vi,ha,va b:16 q:15 result 1D1A5D87
++blocktest 224x64 be,de b:1 q:0 result 9DC4B662
++blocktest 224x64 be,de b:1 q:1 result 9DC4B662
++blocktest 224x64 be,de b:1 q:3 result 9DC4B662
++blocktest 224x64 be,de b:1 q:7 result 5196B3A7
++blocktest 224x64 be,de b:1 q:15 result 5196B3A7
++blocktest 224x64 be,h1,v1 b:1 q:0 result 8043B662
++blocktest 224x64 be,h1,v1 b:1 q:1 result 8043B662
++blocktest 224x64 be,h1,v1 b:1 q:3 result 8043B662
++blocktest 224x64 be,h1,v1 b:1 q:7 result 8043B662
++blocktest 224x64 be,h1,v1 b:1 q:15 result 8043B662
++blocktest 224x64 be,ha,va b:1 q:0 result 9DC4B662
++blocktest 224x64 be,ha,va b:1 q:1 result 9DC4B662
++blocktest 224x64 be,ha,va b:1 q:3 result 9DC4B662
++blocktest 224x64 be,ha,va b:1 q:7 result 9DC4B662
++blocktest 224x64 be,ha,va b:1 q:15 result 9DC4B662
++blocktest 224x64 be,al,de b:1 q:0 result 9DC4B662
++blocktest 224x64 be,al,de b:1 q:1 result 9DC4B662
++blocktest 224x64 be,al,de b:1 q:3 result 9DC4B662
++blocktest 224x64 be,al,de b:1 q:7 result E1E7B3AC
++blocktest 224x64 be,al,de b:1 q:15 result E1E7B3AC
++blocktest 224x64 be,vi,de b:1 q:0 result 9DC4B662
++blocktest 224x64 be,vi,de b:1 q:1 result 9DC4B662
++blocktest 224x64 be,vi,de b:1 q:3 result 9DC4B662
++blocktest 224x64 be,vi,de b:1 q:7 result 5196B3A7
++blocktest 224x64 be,vi,de b:1 q:15 result 5196B3A7
++blocktest 224x64 be,vi,ha,va b:1 q:0 result 9DC4B662
++blocktest 224x64 be,vi,ha,va b:1 q:1 result 9DC4B662
++blocktest 224x64 be,vi,ha,va b:1 q:3 result 9DC4B662
++blocktest 224x64 be,vi,ha,va b:1 q:7 result 9DC4B662
++blocktest 224x64 be,vi,ha,va b:1 q:15 result 9DC4B662
++blocktest 224x64 be,de b:2 q:0 result 79DF7B62
++blocktest 224x64 be,de b:2 q:1 result 79DF7B62
++blocktest 224x64 be,de b:2 q:3 result 79DF7B62
++blocktest 224x64 be,de b:2 q:7 result 2D8E7BE4
++blocktest 224x64 be,de b:2 q:15 result 2D8E7BE4
++blocktest 224x64 be,h1,v1 b:2 q:0 result 5C657162
++blocktest 224x64 be,h1,v1 b:2 q:1 result 5C657162
++blocktest 224x64 be,h1,v1 b:2 q:3 result 5C657162
++blocktest 224x64 be,h1,v1 b:2 q:7 result 5C657162
++blocktest 224x64 be,h1,v1 b:2 q:15 result 5C657162
++blocktest 224x64 be,ha,va b:2 q:0 result 79DF7B62
++blocktest 224x64 be,ha,va b:2 q:1 result 79DF7B62
++blocktest 224x64 be,ha,va b:2 q:3 result 79DF7B62
++blocktest 224x64 be,ha,va b:2 q:7 result 79DF7B62
++blocktest 224x64 be,ha,va b:2 q:15 result 79DF7B62
++blocktest 224x64 be,al,de b:2 q:0 result 79DF7B62
++blocktest 224x64 be,al,de b:2 q:1 result 79DF7B62
++blocktest 224x64 be,al,de b:2 q:3 result 79DF7B62
++blocktest 224x64 be,al,de b:2 q:7 result AD9D7B81
++blocktest 224x64 be,al,de b:2 q:15 result AD9D7B81
++blocktest 224x64 be,vi,de b:2 q:0 result 79DF7B62
++blocktest 224x64 be,vi,de b:2 q:1 result 79DF7B62
++blocktest 224x64 be,vi,de b:2 q:3 result 79DF7B62
++blocktest 224x64 be,vi,de b:2 q:7 result 2D8E7BE4
++blocktest 224x64 be,vi,de b:2 q:15 result 2D8E7BE4
++blocktest 224x64 be,vi,ha,va b:2 q:0 result 79DF7B62
++blocktest 224x64 be,vi,ha,va b:2 q:1 result 79DF7B62
++blocktest 224x64 be,vi,ha,va b:2 q:3 result 79DF7B62
++blocktest 224x64 be,vi,ha,va b:2 q:7 result 79DF7B62
++blocktest 224x64 be,vi,ha,va b:2 q:15 result 79DF7B62
++blocktest 224x64 be,de b:4 q:0 result AE914153
++blocktest 224x64 be,de b:4 q:1 result DE0C4AFB
++blocktest 224x64 be,de b:4 q:3 result 979F51FD
++blocktest 224x64 be,de b:4 q:7 result CE154DF1
++blocktest 224x64 be,de b:4 q:15 result CE154DF1
++blocktest 224x64 be,h1,v1 b:4 q:0 result 5F14153
++blocktest 224x64 be,h1,v1 b:4 q:1 result 5F14153
++blocktest 224x64 be,h1,v1 b:4 q:3 result 5F14153
++blocktest 224x64 be,h1,v1 b:4 q:7 result 5F14153
++blocktest 224x64 be,h1,v1 b:4 q:15 result 5F14153
++blocktest 224x64 be,ha,va b:4 q:0 result 1DE74153
++blocktest 224x64 be,ha,va b:4 q:1 result 1DE74153
++blocktest 224x64 be,ha,va b:4 q:3 result 1DE74153
++blocktest 224x64 be,ha,va b:4 q:7 result 1DE74153
++blocktest 224x64 be,ha,va b:4 q:15 result 1DE74153
++blocktest 224x64 be,al,de b:4 q:0 result AE914153
++blocktest 224x64 be,al,de b:4 q:1 result AEBA49E7
++blocktest 224x64 be,al,de b:4 q:3 result 84954F94
++blocktest 224x64 be,al,de b:4 q:7 result C4C54B42
++blocktest 224x64 be,al,de b:4 q:15 result C4C54B42
++blocktest 224x64 be,vi,de b:4 q:0 result AE914153
++blocktest 224x64 be,vi,de b:4 q:1 result DE0C4AFB
++blocktest 224x64 be,vi,de b:4 q:3 result 979F51FD
++blocktest 224x64 be,vi,de b:4 q:7 result CE154DF1
++blocktest 224x64 be,vi,de b:4 q:15 result CE154DF1
++blocktest 224x64 be,vi,ha,va b:4 q:0 result BC013AC4
++blocktest 224x64 be,vi,ha,va b:4 q:1 result BC013AC4
++blocktest 224x64 be,vi,ha,va b:4 q:3 result BC013AC4
++blocktest 224x64 be,vi,ha,va b:4 q:7 result BC013AC4
++blocktest 224x64 be,vi,ha,va b:4 q:15 result BC013AC4
++blocktest 224x64 be,de b:8 q:0 result D73397F9
++blocktest 224x64 be,de b:8 q:1 result 47779359
++blocktest 224x64 be,de b:8 q:3 result 91918F0D
++blocktest 224x64 be,de b:8 q:7 result D4E08E8A
++blocktest 224x64 be,de b:8 q:15 result D4E08E8A
++blocktest 224x64 be,h1,v1 b:8 q:0 result B21997F9
++blocktest 224x64 be,h1,v1 b:8 q:1 result B21997F9
++blocktest 224x64 be,h1,v1 b:8 q:3 result B21997F9
++blocktest 224x64 be,h1,v1 b:8 q:7 result B21997F9
++blocktest 224x64 be,h1,v1 b:8 q:15 result B21997F9
++blocktest 224x64 be,ha,va b:8 q:0 result 76FD97F9
++blocktest 224x64 be,ha,va b:8 q:1 result 76FD97F9
++blocktest 224x64 be,ha,va b:8 q:3 result 76FD97F9
++blocktest 224x64 be,ha,va b:8 q:7 result 76FD97F9
++blocktest 224x64 be,ha,va b:8 q:15 result 76FD97F9
++blocktest 224x64 be,al,de b:8 q:0 result D73397F9
++blocktest 224x64 be,al,de b:8 q:1 result 4C099399
++blocktest 224x64 be,al,de b:8 q:3 result 93148F7D
++blocktest 224x64 be,al,de b:8 q:7 result D6638EFA
++blocktest 224x64 be,al,de b:8 q:15 result D6638EFA
++blocktest 224x64 be,vi,de b:8 q:0 result D73397F9
++blocktest 224x64 be,vi,de b:8 q:1 result 47779359
++blocktest 224x64 be,vi,de b:8 q:3 result 91918F0D
++blocktest 224x64 be,vi,de b:8 q:7 result D4E08E8A
++blocktest 224x64 be,vi,de b:8 q:15 result D4E08E8A
++blocktest 224x64 be,vi,ha,va b:8 q:0 result D5DE9A8F
++blocktest 224x64 be,vi,ha,va b:8 q:1 result D5DE9A8F
++blocktest 224x64 be,vi,ha,va b:8 q:3 result D5DE9A8F
++blocktest 224x64 be,vi,ha,va b:8 q:7 result D5DE9A8F
++blocktest 224x64 be,vi,ha,va b:8 q:15 result D5DE9A8F
++blocktest 224x64 be,de b:16 q:0 result B4243C5
++blocktest 224x64 be,de b:16 q:1 result 4B5243C5
++blocktest 224x64 be,de b:16 q:3 result 9F5443CD
++blocktest 224x64 be,de b:16 q:7 result 940743DE
++blocktest 224x64 be,de b:16 q:15 result 940743DE
++blocktest 224x64 be,h1,v1 b:16 q:0 result 87943C5
++blocktest 224x64 be,h1,v1 b:16 q:1 result 87943C5
++blocktest 224x64 be,h1,v1 b:16 q:3 result 87943C5
++blocktest 224x64 be,h1,v1 b:16 q:7 result 87943C5
++blocktest 224x64 be,h1,v1 b:16 q:15 result 87943C5
++blocktest 224x64 be,ha,va b:16 q:0 result 39B843C5
++blocktest 224x64 be,ha,va b:16 q:1 result 39B843C5
++blocktest 224x64 be,ha,va b:16 q:3 result 39B843C5
++blocktest 224x64 be,ha,va b:16 q:7 result 39B843C5
++blocktest 224x64 be,ha,va b:16 q:15 result 39B843C5
++blocktest 224x64 be,al,de b:16 q:0 result B4243C5
++blocktest 224x64 be,al,de b:16 q:1 result 483243C5
++blocktest 224x64 be,al,de b:16 q:3 result 3DF543CD
++blocktest 224x64 be,al,de b:16 q:7 result 32A843DE
++blocktest 224x64 be,al,de b:16 q:15 result 32A843DE
++blocktest 224x64 be,vi,de b:16 q:0 result B4243C5
++blocktest 224x64 be,vi,de b:16 q:1 result 4B5243C5
++blocktest 224x64 be,vi,de b:16 q:3 result 9F5443CD
++blocktest 224x64 be,vi,de b:16 q:7 result 940743DE
++blocktest 224x64 be,vi,de b:16 q:15 result 940743DE
++blocktest 224x64 be,vi,ha,va b:16 q:0 result D0645BCD
++blocktest 224x64 be,vi,ha,va b:16 q:1 result D0645BCD
++blocktest 224x64 be,vi,ha,va b:16 q:3 result D0645BCD
++blocktest 224x64 be,vi,ha,va b:16 q:7 result D0645BCD
++blocktest 224x64 be,vi,ha,va b:16 q:15 result D0645BCD
++blocktest 224x304 be,de b:1 q:0 result 53B54275
++blocktest 224x304 be,de b:1 q:1 result 53B54275
++blocktest 224x304 be,de b:1 q:3 result 53B54275
++blocktest 224x304 be,de b:1 q:7 result A08B4021
++blocktest 224x304 be,de b:1 q:15 result A08B4021
++blocktest 224x304 be,h1,v1 b:1 q:0 result C3264475
++blocktest 224x304 be,h1,v1 b:1 q:1 result C3264475
++blocktest 224x304 be,h1,v1 b:1 q:3 result C3264475
++blocktest 224x304 be,h1,v1 b:1 q:7 result C3264475
++blocktest 224x304 be,h1,v1 b:1 q:15 result C3264475
++blocktest 224x304 be,ha,va b:1 q:0 result 53B54275
++blocktest 224x304 be,ha,va b:1 q:1 result 53B54275
++blocktest 224x304 be,ha,va b:1 q:3 result 53B54275
++blocktest 224x304 be,ha,va b:1 q:7 result 53B54275
++blocktest 224x304 be,ha,va b:1 q:15 result 53B54275
++blocktest 224x304 be,al,de b:1 q:0 result 53B54275
++blocktest 224x304 be,al,de b:1 q:1 result 53B54275
++blocktest 224x304 be,al,de b:1 q:3 result 53B54275
++blocktest 224x304 be,al,de b:1 q:7 result 59FD402C
++blocktest 224x304 be,al,de b:1 q:15 result 59FD402C
++blocktest 224x304 be,vi,de b:1 q:0 result 53B54275
++blocktest 224x304 be,vi,de b:1 q:1 result 53B54275
++blocktest 224x304 be,vi,de b:1 q:3 result 53B54275
++blocktest 224x304 be,vi,de b:1 q:7 result A08B4021
++blocktest 224x304 be,vi,de b:1 q:15 result A08B4021
++blocktest 224x304 be,vi,ha,va b:1 q:0 result 53B54275
++blocktest 224x304 be,vi,ha,va b:1 q:1 result 53B54275
++blocktest 224x304 be,vi,ha,va b:1 q:3 result 53B54275
++blocktest 224x304 be,vi,ha,va b:1 q:7 result 53B54275
++blocktest 224x304 be,vi,ha,va b:1 q:15 result 53B54275
++blocktest 224x304 be,de b:2 q:0 result B84AE0E6
++blocktest 224x304 be,de b:2 q:1 result B84AE0E6
++blocktest 224x304 be,de b:2 q:3 result B84AE0E6
++blocktest 224x304 be,de b:2 q:7 result A383E65F
++blocktest 224x304 be,de b:2 q:15 result A383E65F
++blocktest 224x304 be,h1,v1 b:2 q:0 result F73DB6E6
++blocktest 224x304 be,h1,v1 b:2 q:1 result F73DB6E6
++blocktest 224x304 be,h1,v1 b:2 q:3 result F73DB6E6
++blocktest 224x304 be,h1,v1 b:2 q:7 result F73DB6E6
++blocktest 224x304 be,h1,v1 b:2 q:15 result F73DB6E6
++blocktest 224x304 be,ha,va b:2 q:0 result B84AE0E6
++blocktest 224x304 be,ha,va b:2 q:1 result B84AE0E6
++blocktest 224x304 be,ha,va b:2 q:3 result B84AE0E6
++blocktest 224x304 be,ha,va b:2 q:7 result B84AE0E6
++blocktest 224x304 be,ha,va b:2 q:15 result B84AE0E6
++blocktest 224x304 be,al,de b:2 q:0 result B84AE0E6
++blocktest 224x304 be,al,de b:2 q:1 result B84AE0E6
++blocktest 224x304 be,al,de b:2 q:3 result B84AE0E6
++blocktest 224x304 be,al,de b:2 q:7 result CFBE4AC
++blocktest 224x304 be,al,de b:2 q:15 result CFBE4AC
++blocktest 224x304 be,vi,de b:2 q:0 result B84AE0E6
++blocktest 224x304 be,vi,de b:2 q:1 result B84AE0E6
++blocktest 224x304 be,vi,de b:2 q:3 result B84AE0E6
++blocktest 224x304 be,vi,de b:2 q:7 result A383E65F
++blocktest 224x304 be,vi,de b:2 q:15 result A383E65F
++blocktest 224x304 be,vi,ha,va b:2 q:0 result B84AE0E6
++blocktest 224x304 be,vi,ha,va b:2 q:1 result B84AE0E6
++blocktest 224x304 be,vi,ha,va b:2 q:3 result B84AE0E6
++blocktest 224x304 be,vi,ha,va b:2 q:7 result B84AE0E6
++blocktest 224x304 be,vi,ha,va b:2 q:15 result B84AE0E6
++blocktest 224x304 be,de b:4 q:0 result B44F6E17
++blocktest 224x304 be,de b:4 q:1 result 324A9B17
++blocktest 224x304 be,de b:4 q:3 result D4C4BFDA
++blocktest 224x304 be,de b:4 q:7 result F406B4B4
++blocktest 224x304 be,de b:4 q:15 result F406B4B4
++blocktest 224x304 be,h1,v1 b:4 q:0 result FB6D6E17
++blocktest 224x304 be,h1,v1 b:4 q:1 result FB6D6E17
++blocktest 224x304 be,h1,v1 b:4 q:3 result FB6D6E17
++blocktest 224x304 be,h1,v1 b:4 q:7 result FB6D6E17
++blocktest 224x304 be,h1,v1 b:4 q:15 result FB6D6E17
++blocktest 224x304 be,ha,va b:4 q:0 result 937B6E17
++blocktest 224x304 be,ha,va b:4 q:1 result 937B6E17
++blocktest 224x304 be,ha,va b:4 q:3 result 937B6E17
++blocktest 224x304 be,ha,va b:4 q:7 result 937B6E17
++blocktest 224x304 be,ha,va b:4 q:15 result 937B6E17
++blocktest 224x304 be,al,de b:4 q:0 result B44F6E17
++blocktest 224x304 be,al,de b:4 q:1 result B59295FB
++blocktest 224x304 be,al,de b:4 q:3 result D448B333
++blocktest 224x304 be,al,de b:4 q:7 result B3E7A6A1
++blocktest 224x304 be,al,de b:4 q:15 result B3E7A6A1
++blocktest 224x304 be,vi,de b:4 q:0 result B44F6E17
++blocktest 224x304 be,vi,de b:4 q:1 result 324A9B17
++blocktest 224x304 be,vi,de b:4 q:3 result D4C4BFDA
++blocktest 224x304 be,vi,de b:4 q:7 result F406B4B4
++blocktest 224x304 be,vi,de b:4 q:15 result F406B4B4
++blocktest 224x304 be,vi,ha,va b:4 q:0 result DB095E70
++blocktest 224x304 be,vi,ha,va b:4 q:1 result DB095E70
++blocktest 224x304 be,vi,ha,va b:4 q:3 result DB095E70
++blocktest 224x304 be,vi,ha,va b:4 q:7 result DB095E70
++blocktest 224x304 be,vi,ha,va b:4 q:15 result DB095E70
++blocktest 224x304 be,de b:8 q:0 result 1759FECA
++blocktest 224x304 be,de b:8 q:1 result 300CE922
++blocktest 224x304 be,de b:8 q:3 result 57A4D129
++blocktest 224x304 be,de b:8 q:7 result 198ECCCC
++blocktest 224x304 be,de b:8 q:15 result 198ECCCC
++blocktest 224x304 be,h1,v1 b:8 q:0 result A492FECA
++blocktest 224x304 be,h1,v1 b:8 q:1 result A492FECA
++blocktest 224x304 be,h1,v1 b:8 q:3 result A492FECA
++blocktest 224x304 be,h1,v1 b:8 q:7 result A492FECA
++blocktest 224x304 be,h1,v1 b:8 q:15 result A492FECA
++blocktest 224x304 be,ha,va b:8 q:0 result F6C9FECA
++blocktest 224x304 be,ha,va b:8 q:1 result F6C9FECA
++blocktest 224x304 be,ha,va b:8 q:3 result F6C9FECA
++blocktest 224x304 be,ha,va b:8 q:7 result F6C9FECA
++blocktest 224x304 be,ha,va b:8 q:15 result F6C9FECA
++blocktest 224x304 be,al,de b:8 q:0 result 1759FECA
++blocktest 224x304 be,al,de b:8 q:1 result F53CEA12
++blocktest 224x304 be,al,de b:8 q:3 result 4381D346
++blocktest 224x304 be,al,de b:8 q:7 result 56BCEE9
++blocktest 224x304 be,al,de b:8 q:15 result 56BCEE9
++blocktest 224x304 be,vi,de b:8 q:0 result 1759FECA
++blocktest 224x304 be,vi,de b:8 q:1 result 300CE922
++blocktest 224x304 be,vi,de b:8 q:3 result 57A4D129
++blocktest 224x304 be,vi,de b:8 q:7 result 198ECCCC
++blocktest 224x304 be,vi,de b:8 q:15 result 198ECCCC
++blocktest 224x304 be,vi,ha,va b:8 q:0 result 9B1F09C
++blocktest 224x304 be,vi,ha,va b:8 q:1 result 9B1F09C
++blocktest 224x304 be,vi,ha,va b:8 q:3 result 9B1F09C
++blocktest 224x304 be,vi,ha,va b:8 q:7 result 9B1F09C
++blocktest 224x304 be,vi,ha,va b:8 q:15 result 9B1F09C
++blocktest 224x304 be,de b:16 q:0 result DA0000A5
++blocktest 224x304 be,de b:16 q:1 result FCAF00A5
++blocktest 224x304 be,de b:16 q:3 result 699D0124
++blocktest 224x304 be,de b:16 q:7 result D64E01B1
++blocktest 224x304 be,de b:16 q:15 result D64E01B1
++blocktest 224x304 be,h1,v1 b:16 q:0 result C12F00A5
++blocktest 224x304 be,h1,v1 b:16 q:1 result C12F00A5
++blocktest 224x304 be,h1,v1 b:16 q:3 result C12F00A5
++blocktest 224x304 be,h1,v1 b:16 q:7 result C12F00A5
++blocktest 224x304 be,h1,v1 b:16 q:15 result C12F00A5
++blocktest 224x304 be,ha,va b:16 q:0 result 8C0700A5
++blocktest 224x304 be,ha,va b:16 q:1 result 8C0700A5
++blocktest 224x304 be,ha,va b:16 q:3 result 8C0700A5
++blocktest 224x304 be,ha,va b:16 q:7 result 8C0700A5
++blocktest 224x304 be,ha,va b:16 q:15 result 8C0700A5
++blocktest 224x304 be,al,de b:16 q:0 result DA0000A5
++blocktest 224x304 be,al,de b:16 q:1 result EE9F00A5
++blocktest 224x304 be,al,de b:16 q:3 result 5B1B011E
++blocktest 224x304 be,al,de b:16 q:7 result C7CC01AB
++blocktest 224x304 be,al,de b:16 q:15 result C7CC01AB
++blocktest 224x304 be,vi,de b:16 q:0 result DA0000A5
++blocktest 224x304 be,vi,de b:16 q:1 result FCAF00A5
++blocktest 224x304 be,vi,de b:16 q:3 result 699D0124
++blocktest 224x304 be,vi,de b:16 q:7 result D64E01B1
++blocktest 224x304 be,vi,de b:16 q:15 result D64E01B1
++blocktest 224x304 be,vi,ha,va b:16 q:0 result 9B150165
++blocktest 224x304 be,vi,ha,va b:16 q:1 result 9B150165
++blocktest 224x304 be,vi,ha,va b:16 q:3 result 9B150165
++blocktest 224x304 be,vi,ha,va b:16 q:7 result 9B150165
++blocktest 224x304 be,vi,ha,va b:16 q:15 result 9B150165
+diff --git a/tests/ref/fate/filter-pp b/tests/ref/fate/filter-pp
+new file mode 100644
+index 0000000000000..5c0e2994c64da
+--- /dev/null
++++ b/tests/ref/fate/filter-pp
+@@ -0,0 +1,10 @@
++#tb 0: 1/25
++#media_type 0: video
++#codec_id 0: rawvideo
++#dimensions 0: 352x288
++#sar 0: 1/1
++0,          1,          1,        1,   152064, 0x0af8a873
++0,          2,          2,        1,   152064, 0xaeb99897
++0,          3,          3,        1,   152064, 0x8f3712c8
++0,          4,          4,        1,   152064, 0x5bf6a64c
++0,          5,          5,        1,   152064, 0x262de352
+diff --git a/tests/ref/fate/filter-pp1 b/tests/ref/fate/filter-pp1
+new file mode 100644
+index 0000000000000..8c6b7ba18e32c
+--- /dev/null
++++ b/tests/ref/fate/filter-pp1
+@@ -0,0 +1 @@
++pp1                 1a45041dd20a941e36b7729116950107
+diff --git a/tests/ref/fate/filter-pp2 b/tests/ref/fate/filter-pp2
+new file mode 100644
+index 0000000000000..ed5e77322ab9b
+--- /dev/null
++++ b/tests/ref/fate/filter-pp2
+@@ -0,0 +1 @@
++pp2                 566d48ad25dfa7a9680de933cbdf66d9
+diff --git a/tests/ref/fate/filter-pp3 b/tests/ref/fate/filter-pp3
+new file mode 100644
+index 0000000000000..536bf8e9d2d96
+--- /dev/null
++++ b/tests/ref/fate/filter-pp3
+@@ -0,0 +1 @@
++pp3                 586fc14a52699540a865c070dd113229
+diff --git a/tests/ref/fate/filter-pp4 b/tests/ref/fate/filter-pp4
+new file mode 100644
+index 0000000000000..efa9c8a2f2082
+--- /dev/null
++++ b/tests/ref/fate/filter-pp4
+@@ -0,0 +1 @@
++pp4                 8a072806ae6b5c68c5c3c57197641e4a
+diff --git a/tests/ref/fate/filter-pp5 b/tests/ref/fate/filter-pp5
+new file mode 100644
+index 0000000000000..682e8481ff201
+--- /dev/null
++++ b/tests/ref/fate/filter-pp5
+@@ -0,0 +1 @@
++pp5                 5695b8193095a63b9f397fff8343d1a6
+diff --git a/tests/ref/fate/filter-pp6 b/tests/ref/fate/filter-pp6
+new file mode 100644
+index 0000000000000..3280a69004575
+--- /dev/null
++++ b/tests/ref/fate/filter-pp6
+@@ -0,0 +1 @@
++pp6                 f823b3330935cd1824d526041b429d9a
+diff --git a/tests/ref/fate/filter-qp b/tests/ref/fate/filter-qp
+new file mode 100644
+index 0000000000000..3dd4c958746af
+--- /dev/null
++++ b/tests/ref/fate/filter-qp
+@@ -0,0 +1 @@
++qp                  2d4da13e883e073084d547a6b41ba688
+diff --git a/tests/ref/fate/stripetest b/tests/ref/fate/stripetest
+new file mode 100644
+index 0000000000000..31c30c8e59845
+--- /dev/null
++++ b/tests/ref/fate/stripetest
+@@ -0,0 +1,360 @@
++striptest 16x16 T:be,lb m:0 result B75464A3
++striptest 16x16 T:be,lb m:1 result B15C5EE1
++striptest 16x16 T:be,lb m:3 result 92D058DD
++striptest 16x16 T:be,lb m:7 result 32044FFD
++striptest 16x16 T:be,lb m:15 result E10A5D71
++striptest 16x16 T:be,li m:0 result BDD047EB
++striptest 16x16 T:be,li m:1 result 616441B0
++striptest 16x16 T:be,li m:3 result 558C37C7
++striptest 16x16 T:be,li m:7 result 7C432D31
++striptest 16x16 T:be,li m:15 result A1EA2DE3
++striptest 16x16 T:be,ci m:0 result B274814D
++striptest 16x16 T:be,ci m:1 result 87857BD2
++striptest 16x16 T:be,ci m:3 result 22D37968
++striptest 16x16 T:be,ci m:7 result 3DE37214
++striptest 16x16 T:be,ci m:15 result 8DFC8C6B
++striptest 16x16 T:be,md m:0 result ECC6470F
++striptest 16x16 T:be,md m:1 result 26B8426B
++striptest 16x16 T:be,md m:3 result 29023B89
++striptest 16x16 T:be,md m:7 result BE9D3241
++striptest 16x16 T:be,md m:15 result A68334B7
++striptest 16x16 T:be,fd m:0 result E1654815
++striptest 16x16 T:be,fd m:1 result 47CB41A7
++striptest 16x16 T:be,fd m:3 result 72937A6
++striptest 16x16 T:be,fd m:7 result F1522C31
++striptest 16x16 T:be,fd m:15 result 9AD82C81
++striptest 16x16 T:be,l5 m:0 result 3C796608
++striptest 16x16 T:be,l5 m:1 result E5DB5FD8
++striptest 16x16 T:be,l5 m:3 result 8C405943
++striptest 16x16 T:be,l5 m:7 result 11AE4FBB
++striptest 16x16 T:be,l5 m:15 result F9D5D70
++striptest 16x64 T:be,lb m:0 result 1E6F2D39
++striptest 16x64 T:be,lb m:1 result A4A45080
++striptest 16x64 T:be,lb m:3 result E3F9754A
++striptest 16x64 T:be,lb m:7 result F07062E9
++striptest 16x64 T:be,lb m:15 result 146B3ABB
++striptest 16x64 T:be,li m:0 result 902769D9
++striptest 16x64 T:be,li m:1 result 587F5FDD
++striptest 16x64 T:be,li m:3 result 98C64F74
++striptest 16x64 T:be,li m:7 result D04F2E9D
++striptest 16x64 T:be,li m:15 result B5BBEE5E
++striptest 16x64 T:be,ci m:0 result 3B54EFEC
++striptest 16x64 T:be,ci m:1 result 40553F60
++striptest 16x64 T:be,ci m:3 result 6CD498B5
++striptest 16x64 T:be,ci m:7 result 758F94A9
++striptest 16x64 T:be,ci m:15 result D93F8464
++striptest 16x64 T:be,md m:0 result 1534468B
++striptest 16x64 T:be,md m:1 result 51034B7D
++striptest 16x64 T:be,md m:3 result 8C8D5298
++striptest 16x64 T:be,md m:7 result BFAE319B
++striptest 16x64 T:be,md m:15 result AF99F19A
++striptest 16x64 T:be,fd m:0 result 331B6F73
++striptest 16x64 T:be,fd m:1 result F0BC60FD
++striptest 16x64 T:be,fd m:3 result CF484DC1
++striptest 16x64 T:be,fd m:7 result 4A6D2CF6
++striptest 16x64 T:be,fd m:15 result A66EEDEB
++striptest 16x64 T:be,l5 m:0 result 8D5B31DB
++striptest 16x64 T:be,l5 m:1 result BEF45364
++striptest 16x64 T:be,l5 m:3 result 49DF773B
++striptest 16x64 T:be,l5 m:7 result 74C16528
++striptest 16x64 T:be,l5 m:15 result FE573D47
++striptest 16x304 T:be,lb m:0 result D64AF689
++striptest 16x304 T:be,lb m:1 result 4A939516
++striptest 16x304 T:be,lb m:3 result 6CC4A9F1
++striptest 16x304 T:be,lb m:7 result B54DA3E6
++striptest 16x304 T:be,lb m:15 result E8ED947D
++striptest 16x304 T:be,li m:0 result 18F45FFF
++striptest 16x304 T:be,li m:1 result 6CFD4AC3
++striptest 16x304 T:be,li m:3 result 916325A
++striptest 16x304 T:be,li m:7 result 256D0CC4
++striptest 16x304 T:be,li m:15 result 89DCCBAC
++striptest 16x304 T:be,ci m:0 result 126A89B2
++striptest 16x304 T:be,ci m:1 result 792DD640
++striptest 16x304 T:be,ci m:3 result F8B15D3
++striptest 16x304 T:be,ci m:7 result 670C2E42
++striptest 16x304 T:be,ci m:15 result 71EF500A
++striptest 16x304 T:be,md m:0 result AA5ECCA8
++striptest 16x304 T:be,md m:1 result 99A74EF3
++striptest 16x304 T:be,md m:3 result 732A49B6
++striptest 16x304 T:be,md m:7 result 41152671
++striptest 16x304 T:be,md m:15 result 556AE624
++striptest 16x304 T:be,fd m:0 result 7338643
++striptest 16x304 T:be,fd m:1 result 752146F0
++striptest 16x304 T:be,fd m:3 result 4D4D2B2F
++striptest 16x304 T:be,fd m:7 result 296D03F3
++striptest 16x304 T:be,fd m:15 result 8362C227
++striptest 16x304 T:be,l5 m:0 result 2F06030A
++striptest 16x304 T:be,l5 m:1 result ECA299C7
++striptest 16x304 T:be,l5 m:3 result 5844ADCA
++striptest 16x304 T:be,l5 m:7 result 8A9CA976
++striptest 16x304 T:be,l5 m:15 result 8CDC9B7D
++striptest 32x16 T:be,lb m:0 result D62DF0CB
++striptest 32x16 T:be,lb m:1 result 303AE741
++striptest 32x16 T:be,lb m:3 result 37BFDEB2
++striptest 32x16 T:be,lb m:7 result 81F3CDB9
++striptest 32x16 T:be,lb m:15 result 1E7EE673
++striptest 32x16 T:be,li m:0 result D5CFBCDB
++striptest 32x16 T:be,li m:1 result 3151B49A
++striptest 32x16 T:be,li m:3 result 3964A991
++striptest 32x16 T:be,li m:7 result 6E5D9B68
++striptest 32x16 T:be,li m:15 result 450E9D09
++striptest 32x16 T:be,ci m:0 result 160E24FC
++striptest 32x16 T:be,ci m:1 result 54B5199D
++striptest 32x16 T:be,ci m:3 result 6B4912C9
++striptest 32x16 T:be,ci m:7 result 144FEB1
++striptest 32x16 T:be,ci m:15 result E96E2EFB
++striptest 32x16 T:be,md m:0 result 46FEBFE7
++striptest 32x16 T:be,md m:1 result ED2BBAD3
++striptest 32x16 T:be,md m:3 result B352B490
++striptest 32x16 T:be,md m:7 result 9ECDA45C
++striptest 32x16 T:be,md m:15 result B303A918
++striptest 32x16 T:be,fd m:0 result 3236BCFF
++striptest 32x16 T:be,fd m:1 result A9B4B49F
++striptest 32x16 T:be,fd m:3 result DFEDA9A4
++striptest 32x16 T:be,fd m:7 result 7BFC9A10
++striptest 32x16 T:be,fd m:15 result 7DAA9BC1
++striptest 32x16 T:be,l5 m:0 result EFE7F276
++striptest 32x16 T:be,l5 m:1 result FA1DE825
++striptest 32x16 T:be,l5 m:3 result 5005DF04
++striptest 32x16 T:be,l5 m:7 result C1E4CD9A
++striptest 32x16 T:be,l5 m:15 result 8178E6BC
++striptest 32x64 T:be,lb m:0 result 8C56EF7
++striptest 32x64 T:be,lb m:1 result F4DA575
++striptest 32x64 T:be,lb m:3 result C53DC302
++striptest 32x64 T:be,lb m:7 result 45489A36
++striptest 32x64 T:be,lb m:15 result 6412575D
++striptest 32x64 T:be,li m:0 result 5C779137
++striptest 32x64 T:be,li m:1 result 21DE74DF
++striptest 32x64 T:be,li m:3 result E3BC4E4D
++striptest 32x64 T:be,li m:7 result D8010B20
++striptest 32x64 T:be,li m:15 result 97ED88B0
++striptest 32x64 T:be,ci m:0 result F52C4BCA
++striptest 32x64 T:be,ci m:1 result 9F97D29C
++striptest 32x64 T:be,ci m:3 result 571D32E8
++striptest 32x64 T:be,ci m:7 result B61244F
++striptest 32x64 T:be,ci m:15 result 411D20E5
++striptest 32x64 T:be,md m:0 result 9D0A6629
++striptest 32x64 T:be,md m:1 result E0BA6229
++striptest 32x64 T:be,md m:3 result 895759F9
++striptest 32x64 T:be,md m:7 result E56F1265
++striptest 32x64 T:be,md m:15 result D56C91BF
++striptest 32x64 T:be,fd m:0 result B28194AC
++striptest 32x64 T:be,fd m:1 result DAFA71B2
++striptest 32x64 T:be,fd m:3 result 46374997
++striptest 32x64 T:be,fd m:7 result 49BD07FF
++striptest 32x64 T:be,fd m:15 result C37F87F8
++striptest 32x64 T:be,l5 m:0 result 31C27724
++striptest 32x64 T:be,l5 m:1 result 1E34AB3F
++striptest 32x64 T:be,l5 m:3 result 937CC78C
++striptest 32x64 T:be,l5 m:7 result E3AE9FA6
++striptest 32x64 T:be,l5 m:15 result E3CB5D3A
++striptest 32x304 T:be,lb m:0 result 96873EC4
++striptest 32x304 T:be,lb m:1 result F73560B0
++striptest 32x304 T:be,lb m:3 result 23868DD
++striptest 32x304 T:be,lb m:7 result 660D5005
++striptest 32x304 T:be,lb m:15 result 21D72EDC
++striptest 32x304 T:be,li m:0 result 3578C383
++striptest 32x304 T:be,li m:1 result 7E372AB
++striptest 32x304 T:be,li m:3 result 72DC2E19
++striptest 32x304 T:be,li m:7 result 5BF2D9DD
++striptest 32x304 T:be,li m:15 result 562D5100
++striptest 32x304 T:be,ci m:0 result 9B18B34C
++striptest 32x304 T:be,ci m:1 result D6973C87
++striptest 32x304 T:be,ci m:3 result 80A18C1C
++striptest 32x304 T:be,ci m:7 result D954AC92
++striptest 32x304 T:be,ci m:15 result 182F259
++striptest 32x304 T:be,md m:0 result 612A1191
++striptest 32x304 T:be,md m:1 result 11D3893C
++striptest 32x304 T:be,md m:3 result AB4D607C
++striptest 32x304 T:be,md m:7 result AD580914
++striptest 32x304 T:be,md m:15 result 6CB686E3
++striptest 32x304 T:be,fd m:0 result 2DFBF2FD
++striptest 32x304 T:be,fd m:1 result 43C640C
++striptest 32x304 T:be,fd m:3 result 31FF1A7F
++striptest 32x304 T:be,fd m:7 result C845C5A8
++striptest 32x304 T:be,fd m:15 result DFCD3EF6
++striptest 32x304 T:be,l5 m:0 result 9E04521A
++striptest 32x304 T:be,l5 m:1 result DA7E69FB
++striptest 32x304 T:be,l5 m:3 result 65A87204
++striptest 32x304 T:be,l5 m:7 result 5965E41
++striptest 32x304 T:be,l5 m:15 result EC7C4054
++striptest 80x16 T:be,lb m:0 result 111DA361
++striptest 80x16 T:be,lb m:1 result BEE5807F
++striptest 80x16 T:be,lb m:3 result 211C7853
++striptest 80x16 T:be,lb m:7 result 5450697F
++striptest 80x16 T:be,lb m:15 result 58E9478
++striptest 80x16 T:be,li m:0 result 38874149
++striptest 80x16 T:be,li m:1 result 2BBC2576
++striptest 80x16 T:be,li m:3 result 8A5714ED
++striptest 80x16 T:be,li m:7 result 5B0CFB30
++striptest 80x16 T:be,li m:15 result 66AA0055
++striptest 80x16 T:be,ci m:0 result 824D064D
++striptest 80x16 T:be,ci m:1 result 66AEDA81
++striptest 80x16 T:be,ci m:3 result A0EFD91E
++striptest 80x16 T:be,ci m:7 result F3BD56D
++striptest 80x16 T:be,ci m:15 result DF272622
++striptest 80x16 T:be,md m:0 result AFA5463D
++striptest 80x16 T:be,md m:1 result AC1C2EEA
++striptest 80x16 T:be,md m:3 result B13928CA
++striptest 80x16 T:be,md m:7 result 623E0985
++striptest 80x16 T:be,md m:15 result 11AD17F7
++striptest 80x16 T:be,fd m:0 result F2E403A
++striptest 80x16 T:be,fd m:1 result 74442449
++striptest 80x16 T:be,fd m:3 result 99161651
++striptest 80x16 T:be,fd m:7 result 735FF9A0
++striptest 80x16 T:be,fd m:15 result 52C70073
++striptest 80x16 T:be,l5 m:0 result 502A713
++striptest 80x16 T:be,l5 m:1 result 92B68284
++striptest 80x16 T:be,l5 m:3 result 8379797F
++striptest 80x16 T:be,l5 m:7 result 60986B80
++striptest 80x16 T:be,l5 m:15 result 172B954D
++striptest 80x64 T:be,lb m:0 result 5F5E1A40
++striptest 80x64 T:be,lb m:1 result D4573B0B
++striptest 80x64 T:be,lb m:3 result 878952B3
++striptest 80x64 T:be,lb m:7 result D8C714A1
++striptest 80x64 T:be,lb m:15 result 2EF9CC8F
++striptest 80x64 T:be,li m:0 result 997474D1
++striptest 80x64 T:be,li m:1 result 70B0FA2D
++striptest 80x64 T:be,li m:3 result A3D59129
++striptest 80x64 T:be,li m:7 result 3D6A10FC
++striptest 80x64 T:be,li m:15 result B2A16481
++striptest 80x64 T:be,ci m:0 result 8642BD76
++striptest 80x64 T:be,ci m:1 result D9E472E9
++striptest 80x64 T:be,ci m:3 result B68707CC
++striptest 80x64 T:be,ci m:7 result 3A580B8E
++striptest 80x64 T:be,ci m:15 result EF5E2771
++striptest 80x64 T:be,md m:0 result 12FB40C9
++striptest 80x64 T:be,md m:1 result 417FF439
++striptest 80x64 T:be,md m:3 result 9887B9A9
++striptest 80x64 T:be,md m:7 result AC03159
++striptest 80x64 T:be,md m:15 result DC2B8B70
++striptest 80x64 T:be,fd m:0 result 486E6CA9
++striptest 80x64 T:be,fd m:1 result 4740E6D8
++striptest 80x64 T:be,fd m:3 result FB284A3
++striptest 80x64 T:be,fd m:7 result C6C409A5
++striptest 80x64 T:be,fd m:15 result CA3F6366
++striptest 80x64 T:be,l5 m:0 result 9DAA28DE
++striptest 80x64 T:be,l5 m:1 result ECE545D4
++striptest 80x64 T:be,l5 m:3 result CD7D5CB2
++striptest 80x64 T:be,l5 m:7 result 77382111
++striptest 80x64 T:be,l5 m:15 result CFDED94C
++striptest 80x304 T:be,lb m:0 result 5F319B66
++striptest 80x304 T:be,lb m:1 result 12EF231E
++striptest 80x304 T:be,lb m:3 result 550BD604
++striptest 80x304 T:be,lb m:7 result B7327E26
++striptest 80x304 T:be,lb m:15 result 3740245A
++striptest 80x304 T:be,li m:0 result D685F82D
++striptest 80x304 T:be,li m:1 result A0A30EB2
++striptest 80x304 T:be,li m:3 result D8F4D287
++striptest 80x304 T:be,li m:7 result E8ABBB88
++striptest 80x304 T:be,li m:15 result CBE440B3
++striptest 80x304 T:be,ci m:0 result 4DD92E38
++striptest 80x304 T:be,ci m:1 result 80570956
++striptest 80x304 T:be,ci m:3 result B9199E43
++striptest 80x304 T:be,ci m:7 result 379900A8
++striptest 80x304 T:be,ci m:15 result C9CC544
++striptest 80x304 T:be,md m:0 result C9A0AA1
++striptest 80x304 T:be,md m:1 result D71C6826
++striptest 80x304 T:be,md m:3 result 358C53FF
++striptest 80x304 T:be,md m:7 result CC983926
++striptest 80x304 T:be,md m:15 result F1FAC564
++striptest 80x304 T:be,fd m:0 result 2CA4360A
++striptest 80x304 T:be,fd m:1 result CF71D48F
++striptest 80x304 T:be,fd m:3 result 5C849085
++striptest 80x304 T:be,fd m:7 result 560B833A
++striptest 80x304 T:be,fd m:15 result 6A3C1C08
++striptest 80x304 T:be,l5 m:0 result 659DC22A
++striptest 80x304 T:be,l5 m:1 result F5C03787
++striptest 80x304 T:be,l5 m:3 result 462BF053
++striptest 80x304 T:be,l5 m:7 result 82BDA906
++striptest 80x304 T:be,l5 m:15 result ACD5942
++striptest 224x16 T:be,lb m:0 result 356C0D23
++striptest 224x16 T:be,lb m:1 result D00F7A2A
++striptest 224x16 T:be,lb m:3 result E5EA5D23
++striptest 224x16 T:be,lb m:7 result 526D674E
++striptest 224x16 T:be,lb m:15 result BCE3B81D
++striptest 224x16 T:be,li m:0 result F1126804
++striptest 224x16 T:be,li m:1 result AF23B0EC
++striptest 224x16 T:be,li m:3 result 42C4FC3
++striptest 224x16 T:be,li m:7 result F87C00B2
++striptest 224x16 T:be,li m:15 result EC6026F
++striptest 224x16 T:be,ci m:0 result 297FB291
++striptest 224x16 T:be,ci m:1 result 1E673D4B
++striptest 224x16 T:be,ci m:3 result 8456644B
++striptest 224x16 T:be,ci m:7 result 3DC9CA10
++striptest 224x16 T:be,ci m:15 result 73EB67B2
++striptest 224x16 T:be,md m:0 result 43E06F84
++striptest 224x16 T:be,md m:1 result 8B4BD0B4
++striptest 224x16 T:be,md m:3 result F9E282D7
++striptest 224x16 T:be,md m:7 result CF442864
++striptest 224x16 T:be,md m:15 result 40FF4C35
++striptest 224x16 T:be,fd m:0 result E9136713
++striptest 224x16 T:be,fd m:1 result 5504AAD5
++striptest 224x16 T:be,fd m:3 result 62CF4ED1
++striptest 224x16 T:be,fd m:7 result 1FBFFEB5
++striptest 224x16 T:be,fd m:15 result 1A8802F2
++striptest 224x16 T:be,l5 m:0 result 6B4E140C
++striptest 224x16 T:be,l5 m:1 result 317D78DE
++striptest 224x16 T:be,l5 m:3 result 10D76452
++striptest 224x16 T:be,l5 m:7 result B4157203
++striptest 224x16 T:be,l5 m:15 result 7485BB4E
++striptest 224x64 T:be,lb m:0 result 2B8AC21B
++striptest 224x64 T:be,lb m:1 result 20901C76
++striptest 224x64 T:be,lb m:3 result 9DD93F3D
++striptest 224x64 T:be,lb m:7 result 7344B91E
++striptest 224x64 T:be,lb m:15 result 1AF370A4
++striptest 224x64 T:be,li m:0 result DBBDD6BD
++striptest 224x64 T:be,li m:1 result 11F7C325
++striptest 224x64 T:be,li m:3 result 3CE50C42
++striptest 224x64 T:be,li m:7 result 7E69E47E
++striptest 224x64 T:be,li m:15 result A4BBE1A1
++striptest 224x64 T:be,ci m:0 result F82BA5E8
++striptest 224x64 T:be,ci m:1 result 85115A85
++striptest 224x64 T:be,ci m:3 result 58C651AE
++striptest 224x64 T:be,ci m:7 result A9126A8F
++striptest 224x64 T:be,ci m:15 result 7B9FDB4F
++striptest 224x64 T:be,md m:0 result C2526431
++striptest 224x64 T:be,md m:1 result 827DC726
++striptest 224x64 T:be,md m:3 result 8DA3941F
++striptest 224x64 T:be,md m:7 result 51B05951
++striptest 224x64 T:be,md m:15 result ED5F5AD8
++striptest 224x64 T:be,fd m:0 result 12A1C5DC
++striptest 224x64 T:be,fd m:1 result 73CF788F
++striptest 224x64 T:be,fd m:3 result DA0EC20B
++striptest 224x64 T:be,fd m:7 result 5F61C207
++striptest 224x64 T:be,fd m:15 result D315E2C2
++striptest 224x64 T:be,l5 m:0 result B838DBE8
++striptest 224x64 T:be,l5 m:1 result 9DDA2818
++striptest 224x64 T:be,l5 m:3 result 936E539F
++striptest 224x64 T:be,l5 m:7 result B72DD580
++striptest 224x64 T:be,l5 m:15 result DEF9939C
++striptest 224x304 T:be,lb m:0 result 1FEC5688
++striptest 224x304 T:be,lb m:1 result 90A34708
++striptest 224x304 T:be,lb m:3 result A7392576
++striptest 224x304 T:be,lb m:7 result 5CE6F508
++striptest 224x304 T:be,lb m:15 result 1AED25A0
++striptest 224x304 T:be,li m:0 result 9DDCEAD8
++striptest 224x304 T:be,li m:1 result A0734E1E
++striptest 224x304 T:be,li m:3 result 1F7E2AA8
++striptest 224x304 T:be,li m:7 result A77BC413
++striptest 224x304 T:be,li m:15 result B2066E34
++striptest 224x304 T:be,ci m:0 result A1F1930F
++striptest 224x304 T:be,ci m:1 result B0BCBBCB
++striptest 224x304 T:be,ci m:3 result BC517C16
++striptest 224x304 T:be,ci m:7 result 42B87247
++striptest 224x304 T:be,ci m:15 result 390F228A
++striptest 224x304 T:be,md m:0 result 26DE8A64
++striptest 224x304 T:be,md m:1 result 422A5459
++striptest 224x304 T:be,md m:3 result 3FBA4F6
++striptest 224x304 T:be,md m:7 result 16B03C7E
++striptest 224x304 T:be,md m:15 result DC1EC11
++striptest 224x304 T:be,fd m:0 result AAC476C5
++striptest 224x304 T:be,fd m:1 result 43724E73
++striptest 224x304 T:be,fd m:3 result A35E0764
++striptest 224x304 T:be,fd m:7 result 7A17EA8D
++striptest 224x304 T:be,fd m:15 result FACA116D
++striptest 224x304 T:be,l5 m:0 result E9D6B236
++striptest 224x304 T:be,l5 m:1 result B4336EAD
++striptest 224x304 T:be,l5 m:3 result 284B6451
++striptest 224x304 T:be,l5 m:7 result 637B6C54
++striptest 224x304 T:be,l5 m:15 result 3503C609
+diff --git a/tests/ref/fate/temptest b/tests/ref/fate/temptest
+new file mode 100644
+index 0000000000000..e90fc46f81eea
+--- /dev/null
++++ b/tests/ref/fate/temptest
+@@ -0,0 +1,336 @@
++temptest 0 0 0 0 result 4747FD2B6BCBD98D
++temptest 0 0 0 1 result B131E49BB453EC88
++temptest 0 0 0 4 result 38CC2AC032A60E8E
++temptest 0 0 0 13 result B2C1B45AE4547480
++temptest 0 0 0 40 result 7CCF1AC011E2ACEB
++temptest 0 0 0 121 result CEFAC9CA19A5F777
++temptest 0 0 1 0 result 4747FD2B6BCBD98D
++temptest 0 0 1 1 result B131E49BB453EC88
++temptest 0 0 1 4 result 38CC2AC032A60E8E
++temptest 0 0 1 13 result B2C1B45AE4547480
++temptest 0 0 1 40 result 7CCF1AC011E2ACEB
++temptest 0 0 1 121 result CEFAC9CA19A5F777
++temptest 0 0 18 0 result 4747FD2B6BCBD98D
++temptest 0 0 18 1 result B131E49BB453EC88
++temptest 0 0 18 4 result 38CC2AC032A60E8E
++temptest 0 0 18 13 result B2C1B45AE4547480
++temptest 0 0 18 40 result 7CCF1AC011E2ACEB
++temptest 0 0 18 121 result CEFAC9CA19A5F777
++temptest 0 0 307 0 result 4747FD2B6BCBD98D
++temptest 0 0 307 1 result B131E49BB453EC88
++temptest 0 0 307 4 result 9A1F4C627F31E806
++temptest 0 0 307 13 result B2C1B45AE4547480
++temptest 0 0 307 40 result 7CCF1AC011E2ACEB
++temptest 0 0 307 121 result CEFAC9CA19A5F777
++temptest 0 0 5220 0 result A3F4794F3A735E24
++temptest 0 0 5220 1 result 2FEB559286787E28
++temptest 0 0 5220 4 result E77D4EBDFA3E06BF
++temptest 0 0 5220 13 result D77446C32EEDD169
++temptest 0 0 5220 40 result 7CCF1AC011E2ACEB
++temptest 0 0 5220 121 result CEFAC9CA19A5F777
++temptest 0 0 88741 0 result FBDDA11DF717CD14
++temptest 0 0 88741 1 result FB7C8CEBFD07B08B
++temptest 0 0 88741 4 result 677BF6D89305A705
++temptest 0 0 88741 13 result AC256153D241FEAC
++temptest 0 0 88741 40 result 53E5C6EFC8DA58D1
++temptest 0 0 88741 121 result 284B4DD880549A05
++temptest 0 1 1 0 result 4747FD2B6BCBD98D
++temptest 0 1 1 1 result B131E49BB453EC88
++temptest 0 1 1 4 result 38CC2AC032A60E8E
++temptest 0 1 1 13 result B2C1B45AE4547480
++temptest 0 1 1 40 result 7CCF1AC011E2ACEB
++temptest 0 1 1 121 result CEFAC9CA19A5F777
++temptest 0 1 18 0 result 4747FD2B6BCBD98D
++temptest 0 1 18 1 result B131E49BB453EC88
++temptest 0 1 18 4 result 38CC2AC032A60E8E
++temptest 0 1 18 13 result B2C1B45AE4547480
++temptest 0 1 18 40 result 7CCF1AC011E2ACEB
++temptest 0 1 18 121 result CEFAC9CA19A5F777
++temptest 0 1 307 0 result 4747FD2B6BCBD98D
++temptest 0 1 307 1 result B131E49BB453EC88
++temptest 0 1 307 4 result 9A1F4C627F31E806
++temptest 0 1 307 13 result B2C1B45AE4547480
++temptest 0 1 307 40 result 7CCF1AC011E2ACEB
++temptest 0 1 307 121 result CEFAC9CA19A5F777
++temptest 0 1 5220 0 result A3F4794F3A735E24
++temptest 0 1 5220 1 result 2FEB559286787E28
++temptest 0 1 5220 4 result E77D4EBDFA3E06BF
++temptest 0 1 5220 13 result D77446C32EEDD169
++temptest 0 1 5220 40 result 7CCF1AC011E2ACEB
++temptest 0 1 5220 121 result CEFAC9CA19A5F777
++temptest 0 1 88741 0 result FBDDA11DF717CD14
++temptest 0 1 88741 1 result FB7C8CEBFD07B08B
++temptest 0 1 88741 4 result 677BF6D89305A705
++temptest 0 1 88741 13 result AC256153D241FEAC
++temptest 0 1 88741 40 result 53E5C6EFC8DA58D1
++temptest 0 1 88741 121 result 284B4DD880549A05
++temptest 0 18 18 0 result 4747FD2B6BCBD98D
++temptest 0 18 18 1 result B131E49BB453EC88
++temptest 0 18 18 4 result 38CC2AC032A60E8E
++temptest 0 18 18 13 result B2C1B45AE4547480
++temptest 0 18 18 40 result 7CCF1AC011E2ACEB
++temptest 0 18 18 121 result CEFAC9CA19A5F777
++temptest 0 18 307 0 result 4747FD2B6BCBD98D
++temptest 0 18 307 1 result B131E49BB453EC88
++temptest 0 18 307 4 result 9A1F4C627F31E806
++temptest 0 18 307 13 result B2C1B45AE4547480
++temptest 0 18 307 40 result 7CCF1AC011E2ACEB
++temptest 0 18 307 121 result CEFAC9CA19A5F777
++temptest 0 18 5220 0 result E2D79A25DEB7D8A0
++temptest 0 18 5220 1 result 6ECE76692ABCF8A4
++temptest 0 18 5220 4 result E77D4EBDFA3E06BF
++temptest 0 18 5220 13 result D77446C32EEDD169
++temptest 0 18 5220 40 result 7CCF1AC011E2ACEB
++temptest 0 18 5220 121 result CEFAC9CA19A5F777
++temptest 0 18 88741 0 result FBDDA11DF717CD14
++temptest 0 18 88741 1 result FB7C8CEBFD07B08B
++temptest 0 18 88741 4 result 677BF6D89305A705
++temptest 0 18 88741 13 result AC256153D241FEAC
++temptest 0 18 88741 40 result 53E5C6EFC8DA58D1
++temptest 0 18 88741 121 result 284B4DD880549A05
++temptest 0 307 307 0 result 4747FD2B6BCBD98D
++temptest 0 307 307 1 result B131E49BB453EC88
++temptest 0 307 307 4 result B17A67893E803FB9
++temptest 0 307 307 13 result B2C1B45AE4547480
++temptest 0 307 307 40 result 7CCF1AC011E2ACEB
++temptest 0 307 307 121 result CEFAC9CA19A5F777
++temptest 0 307 5220 0 result 555181C06E0FA1AA
++temptest 0 307 5220 1 result 3235D486256EC1AE
++temptest 0 307 5220 4 result 964FE2F503607C70
++temptest 0 307 5220 13 result D77446C32EEDD169
++temptest 0 307 5220 40 result 7CCF1AC011E2ACEB
++temptest 0 307 5220 121 result CEFAC9CA19A5F777
++temptest 0 307 88741 0 result 797EDCC74D223AE8
++temptest 0 307 88741 1 result 791DC89553121E5F
++temptest 0 307 88741 4 result 46E37B54A5142319
++temptest 0 307 88741 13 result AC256153D241FEAC
++temptest 0 307 88741 40 result 53E5C6EFC8DA58D1
++temptest 0 307 88741 121 result 284B4DD880549A05
++temptest 0 5220 5220 0 result 4A2207CA23BA4CC0
++temptest 0 5220 5220 1 result E5B4E54A5D48B507
++temptest 0 5220 5220 4 result EA39A4876A38648F
++temptest 0 5220 5220 13 result B6B4F5C1A6864CBD
++temptest 0 5220 5220 40 result 7CCF1AC011E2ACEB
++temptest 0 5220 5220 121 result CEFAC9CA19A5F777
++temptest 0 5220 88741 0 result 706EBAB75F0C52EA
++temptest 0 5220 88741 1 result D4F0475270F0795C
++temptest 0 5220 88741 4 result DF8A5296FD69B527
++temptest 0 5220 88741 13 result BB5686FA9BA23C7B
++temptest 0 5220 88741 40 result A9201E8DBD3B9B3
++temptest 0 5220 88741 121 result 284B4DD880549A05
++temptest 0 88741 88741 0 result CF4F8ABE751594E0
++temptest 0 88741 88741 1 result 9222D52614EFA86B
++temptest 0 88741 88741 4 result DFC399F2247B7714
++temptest 0 88741 88741 13 result 4781E2B92F5BD91B
++temptest 0 88741 88741 40 result 8986560C6636BCBA
++temptest 0 88741 88741 121 result 31FBA2F823230BBF
++temptest 1 1 1 0 result 4747FD2B6BCBD98D
++temptest 1 1 1 1 result B131E49BB453EC88
++temptest 1 1 1 4 result 38CC2AC032A60E8E
++temptest 1 1 1 13 result B2C1B45AE4547480
++temptest 1 1 1 40 result 7CCF1AC011E2ACEB
++temptest 1 1 1 121 result CEFAC9CA19A5F777
++temptest 1 1 18 0 result 4747FD2B6BCBD98D
++temptest 1 1 18 1 result B131E49BB453EC88
++temptest 1 1 18 4 result 38CC2AC032A60E8E
++temptest 1 1 18 13 result B2C1B45AE4547480
++temptest 1 1 18 40 result 7CCF1AC011E2ACEB
++temptest 1 1 18 121 result CEFAC9CA19A5F777
++temptest 1 1 307 0 result 4747FD2B6BCBD98D
++temptest 1 1 307 1 result B131E49BB453EC88
++temptest 1 1 307 4 result 9A1F4C627F31E806
++temptest 1 1 307 13 result B2C1B45AE4547480
++temptest 1 1 307 40 result 7CCF1AC011E2ACEB
++temptest 1 1 307 121 result CEFAC9CA19A5F777
++temptest 1 1 5220 0 result A3F4794F3A735E24
++temptest 1 1 5220 1 result 2FEB559286787E28
++temptest 1 1 5220 4 result E77D4EBDFA3E06BF
++temptest 1 1 5220 13 result D77446C32EEDD169
++temptest 1 1 5220 40 result 7CCF1AC011E2ACEB
++temptest 1 1 5220 121 result CEFAC9CA19A5F777
++temptest 1 1 88741 0 result FBDDA11DF717CD14
++temptest 1 1 88741 1 result FB7C8CEBFD07B08B
++temptest 1 1 88741 4 result 677BF6D89305A705
++temptest 1 1 88741 13 result AC256153D241FEAC
++temptest 1 1 88741 40 result 53E5C6EFC8DA58D1
++temptest 1 1 88741 121 result 284B4DD880549A05
++temptest 1 18 18 0 result 4747FD2B6BCBD98D
++temptest 1 18 18 1 result B131E49BB453EC88
++temptest 1 18 18 4 result 38CC2AC032A60E8E
++temptest 1 18 18 13 result B2C1B45AE4547480
++temptest 1 18 18 40 result 7CCF1AC011E2ACEB
++temptest 1 18 18 121 result CEFAC9CA19A5F777
++temptest 1 18 307 0 result 4747FD2B6BCBD98D
++temptest 1 18 307 1 result B131E49BB453EC88
++temptest 1 18 307 4 result 9A1F4C627F31E806
++temptest 1 18 307 13 result B2C1B45AE4547480
++temptest 1 18 307 40 result 7CCF1AC011E2ACEB
++temptest 1 18 307 121 result CEFAC9CA19A5F777
++temptest 1 18 5220 0 result E2D79A25DEB7D8A0
++temptest 1 18 5220 1 result 6ECE76692ABCF8A4
++temptest 1 18 5220 4 result E77D4EBDFA3E06BF
++temptest 1 18 5220 13 result D77446C32EEDD169
++temptest 1 18 5220 40 result 7CCF1AC011E2ACEB
++temptest 1 18 5220 121 result CEFAC9CA19A5F777
++temptest 1 18 88741 0 result FBDDA11DF717CD14
++temptest 1 18 88741 1 result FB7C8CEBFD07B08B
++temptest 1 18 88741 4 result 677BF6D89305A705
++temptest 1 18 88741 13 result AC256153D241FEAC
++temptest 1 18 88741 40 result 53E5C6EFC8DA58D1
++temptest 1 18 88741 121 result 284B4DD880549A05
++temptest 1 307 307 0 result 4747FD2B6BCBD98D
++temptest 1 307 307 1 result B131E49BB453EC88
++temptest 1 307 307 4 result B17A67893E803FB9
++temptest 1 307 307 13 result B2C1B45AE4547480
++temptest 1 307 307 40 result 7CCF1AC011E2ACEB
++temptest 1 307 307 121 result CEFAC9CA19A5F777
++temptest 1 307 5220 0 result 555181C06E0FA1AA
++temptest 1 307 5220 1 result 3235D486256EC1AE
++temptest 1 307 5220 4 result 964FE2F503607C70
++temptest 1 307 5220 13 result D77446C32EEDD169
++temptest 1 307 5220 40 result 7CCF1AC011E2ACEB
++temptest 1 307 5220 121 result CEFAC9CA19A5F777
++temptest 1 307 88741 0 result 797EDCC74D223AE8
++temptest 1 307 88741 1 result 791DC89553121E5F
++temptest 1 307 88741 4 result 46E37B54A5142319
++temptest 1 307 88741 13 result AC256153D241FEAC
++temptest 1 307 88741 40 result 53E5C6EFC8DA58D1
++temptest 1 307 88741 121 result 284B4DD880549A05
++temptest 1 5220 5220 0 result 4A2207CA23BA4CC0
++temptest 1 5220 5220 1 result E5B4E54A5D48B507
++temptest 1 5220 5220 4 result EA39A4876A38648F
++temptest 1 5220 5220 13 result B6B4F5C1A6864CBD
++temptest 1 5220 5220 40 result 7CCF1AC011E2ACEB
++temptest 1 5220 5220 121 result CEFAC9CA19A5F777
++temptest 1 5220 88741 0 result 706EBAB75F0C52EA
++temptest 1 5220 88741 1 result D4F0475270F0795C
++temptest 1 5220 88741 4 result DF8A5296FD69B527
++temptest 1 5220 88741 13 result BB5686FA9BA23C7B
++temptest 1 5220 88741 40 result A9201E8DBD3B9B3
++temptest 1 5220 88741 121 result 284B4DD880549A05
++temptest 1 88741 88741 0 result CF4F8ABE751594E0
++temptest 1 88741 88741 1 result 9222D52614EFA86B
++temptest 1 88741 88741 4 result DFC399F2247B7714
++temptest 1 88741 88741 13 result 4781E2B92F5BD91B
++temptest 1 88741 88741 40 result 8986560C6636BCBA
++temptest 1 88741 88741 121 result 31FBA2F823230BBF
++temptest 18 18 18 0 result 4747FD2B6BCBD98D
++temptest 18 18 18 1 result B131E49BB453EC88
++temptest 18 18 18 4 result 38CC2AC032A60E8E
++temptest 18 18 18 13 result B2C1B45AE4547480
++temptest 18 18 18 40 result 7CCF1AC011E2ACEB
++temptest 18 18 18 121 result CEFAC9CA19A5F777
++temptest 18 18 307 0 result 4747FD2B6BCBD98D
++temptest 18 18 307 1 result B131E49BB453EC88
++temptest 18 18 307 4 result 9A1F4C627F31E806
++temptest 18 18 307 13 result B2C1B45AE4547480
++temptest 18 18 307 40 result 7CCF1AC011E2ACEB
++temptest 18 18 307 121 result CEFAC9CA19A5F777
++temptest 18 18 5220 0 result E2D79A25DEB7D8A0
++temptest 18 18 5220 1 result 6ECE76692ABCF8A4
++temptest 18 18 5220 4 result E77D4EBDFA3E06BF
++temptest 18 18 5220 13 result D77446C32EEDD169
++temptest 18 18 5220 40 result 7CCF1AC011E2ACEB
++temptest 18 18 5220 121 result CEFAC9CA19A5F777
++temptest 18 18 88741 0 result FBDDA11DF717CD14
++temptest 18 18 88741 1 result FB7C8CEBFD07B08B
++temptest 18 18 88741 4 result 677BF6D89305A705
++temptest 18 18 88741 13 result AC256153D241FEAC
++temptest 18 18 88741 40 result 53E5C6EFC8DA58D1
++temptest 18 18 88741 121 result 284B4DD880549A05
++temptest 18 307 307 0 result 4747FD2B6BCBD98D
++temptest 18 307 307 1 result B131E49BB453EC88
++temptest 18 307 307 4 result B17A67893E803FB9
++temptest 18 307 307 13 result B2C1B45AE4547480
++temptest 18 307 307 40 result 7CCF1AC011E2ACEB
++temptest 18 307 307 121 result CEFAC9CA19A5F777
++temptest 18 307 5220 0 result 555181C06E0FA1AA
++temptest 18 307 5220 1 result 3235D486256EC1AE
++temptest 18 307 5220 4 result 964FE2F503607C70
++temptest 18 307 5220 13 result D77446C32EEDD169
++temptest 18 307 5220 40 result 7CCF1AC011E2ACEB
++temptest 18 307 5220 121 result CEFAC9CA19A5F777
++temptest 18 307 88741 0 result 797EDCC74D223AE8
++temptest 18 307 88741 1 result 791DC89553121E5F
++temptest 18 307 88741 4 result 46E37B54A5142319
++temptest 18 307 88741 13 result AC256153D241FEAC
++temptest 18 307 88741 40 result 53E5C6EFC8DA58D1
++temptest 18 307 88741 121 result 284B4DD880549A05
++temptest 18 5220 5220 0 result 4A2207CA23BA4CC0
++temptest 18 5220 5220 1 result E5B4E54A5D48B507
++temptest 18 5220 5220 4 result EA39A4876A38648F
++temptest 18 5220 5220 13 result B6B4F5C1A6864CBD
++temptest 18 5220 5220 40 result 7CCF1AC011E2ACEB
++temptest 18 5220 5220 121 result CEFAC9CA19A5F777
++temptest 18 5220 88741 0 result 706EBAB75F0C52EA
++temptest 18 5220 88741 1 result D4F0475270F0795C
++temptest 18 5220 88741 4 result DF8A5296FD69B527
++temptest 18 5220 88741 13 result BB5686FA9BA23C7B
++temptest 18 5220 88741 40 result A9201E8DBD3B9B3
++temptest 18 5220 88741 121 result 284B4DD880549A05
++temptest 18 88741 88741 0 result CF4F8ABE751594E0
++temptest 18 88741 88741 1 result 9222D52614EFA86B
++temptest 18 88741 88741 4 result DFC399F2247B7714
++temptest 18 88741 88741 13 result 4781E2B92F5BD91B
++temptest 18 88741 88741 40 result 8986560C6636BCBA
++temptest 18 88741 88741 121 result 31FBA2F823230BBF
++temptest 307 307 307 0 result 4747FD2B6BCBD98D
++temptest 307 307 307 1 result B131E49BB453EC88
++temptest 307 307 307 4 result 8B1D395E5808B6DC
++temptest 307 307 307 13 result B2C1B45AE4547480
++temptest 307 307 307 40 result 7CCF1AC011E2ACEB
++temptest 307 307 307 121 result CEFAC9CA19A5F777
++temptest 307 307 5220 0 result A69033A091FC2080
++temptest 307 307 5220 1 result 32870FE3DE014084
++temptest 307 307 5220 4 result B2649AC2BCF207E4
++temptest 307 307 5220 13 result D77446C32EEDD169
++temptest 307 307 5220 40 result 7CCF1AC011E2ACEB
++temptest 307 307 5220 121 result CEFAC9CA19A5F777
++temptest 307 307 88741 0 result 6148B9F1437BB580
++temptest 307 307 88741 1 result 6F49A40209698F7
++temptest 307 307 88741 4 result 9E9DD518954D5E5
++temptest 307 307 88741 13 result AC256153D241FEAC
++temptest 307 307 88741 40 result 53E5C6EFC8DA58D1
++temptest 307 307 88741 121 result 284B4DD880549A05
++temptest 307 5220 5220 0 result 2A63D0D557F45750
++temptest 307 5220 5220 1 result 9254608D71205E52
++temptest 307 5220 5220 4 result E46F831B8295F417
++temptest 307 5220 5220 13 result B6B4F5C1A6864CBD
++temptest 307 5220 5220 40 result 7CCF1AC011E2ACEB
++temptest 307 5220 5220 121 result CEFAC9CA19A5F777
++temptest 307 5220 88741 0 result EADD24BF32F80792
++temptest 307 5220 88741 1 result DABC179FB1931BE8
++temptest 307 5220 88741 4 result 8AA934A713F0D4AD
++temptest 307 5220 88741 13 result BB5686FA9BA23C7B
++temptest 307 5220 88741 40 result A9201E8DBD3B9B3
++temptest 307 5220 88741 121 result 284B4DD880549A05
++temptest 307 88741 88741 0 result 1A2909BF51BC6E28
++temptest 307 88741 88741 1 result 6614127EF76D81B3
++temptest 307 88741 88741 4 result 9B0BC4A00B7DB1F2
++temptest 307 88741 88741 13 result 4781E2B92F5BD91B
++temptest 307 88741 88741 40 result 8986560C6636BCBA
++temptest 307 88741 88741 121 result 31FBA2F823230BBF
++temptest 5220 5220 5220 0 result 7FE69B4F88AD274B
++temptest 5220 5220 5220 1 result 2262574F78791826
++temptest 5220 5220 5220 4 result 597A21AB80E82FAC
++temptest 5220 5220 5220 13 result 7F930A71275853B8
++temptest 5220 5220 5220 40 result 7CCF1AC011E2ACEB
++temptest 5220 5220 5220 121 result CEFAC9CA19A5F777
++temptest 5220 5220 88741 0 result D5F7F8D19289D7C3
++temptest 5220 5220 88741 1 result CD3256F7DFF12EE2
++temptest 5220 5220 88741 4 result 84E2DB3DECECD065
++temptest 5220 5220 88741 13 result A751FC922A9A8365
++temptest 5220 5220 88741 40 result 2FA93067097FB349
++temptest 5220 5220 88741 121 result 284B4DD880549A05
++temptest 5220 88741 88741 0 result 684F350A49E03B23
++temptest 5220 88741 88741 1 result 6E9FD32757E3AD46
++temptest 5220 88741 88741 4 result 5F4C037B5CFEDACB
++temptest 5220 88741 88741 13 result 6B03209BFA60079D
++temptest 5220 88741 88741 40 result 8986560C6636BCBA
++temptest 5220 88741 88741 121 result 31FBA2F823230BBF
++temptest 88741 88741 88741 0 result B1D4DA59CAAF6224
++temptest 88741 88741 88741 1 result 42DD8F9FBDC2D6C0
++temptest 88741 88741 88741 4 result B40B6B1CAD3A609F
++temptest 88741 88741 88741 13 result 221AA124FEFA141C
++temptest 88741 88741 88741 40 result FC31041053B7B237
++temptest 88741 88741 88741 121 result CB3E66FC05552055
+diff --git a/tools/gen-rc b/tools/gen-rc
+index 797e0baafadbc..a28b013aaeb7a 100755
+--- a/tools/gen-rc
++++ b/tools/gen-rc
+@@ -42,6 +42,7 @@ EOF
+ # gen-rc libavformat   "FFmpeg container format library"
+ # gen-rc libavdevice   "FFmpeg device handling library"
+ # gen-rc libavfilter   "FFmpeg audio/video filtering library"
++# gen-rc libpostproc   "FFmpeg postprocessing library"
+ # gen-rc libswscale    "FFmpeg image rescaling library"
+ # gen-rc libswresample "FFmpeg audio resampling library"
+ 
diff --git a/tools/depends/target/ffmpeg/CMakeLists.txt b/tools/depends/target/ffmpeg/CMakeLists.txt
index 8924dc8c7305b..50c6b7d276345 100644
--- a/tools/depends/target/ffmpeg/CMakeLists.txt
+++ b/tools/depends/target/ffmpeg/CMakeLists.txt
@@ -34,7 +34,6 @@ list(APPEND ffmpeg_conf --disable-doc
                         --disable-sdl2
                         --disable-vulkan
                         --enable-gpl
-                        --enable-postproc
                         --enable-runtime-cpudetect
                         --enable-pthreads
                         --extra-version="Kodi"
@@ -152,6 +151,7 @@ endif()
 include(ExternalProject)
 externalproject_add(ffmpeg
                     SOURCE_DIR ${CMAKE_SOURCE_DIR}
+                    PATCH_COMMAND patch -p1 -i <SOURCE_DIR>/0001-libpostproc-plugin.patch
                     CONFIGURE_COMMAND ${pkgconf} ${pkgconf_path} <SOURCE_DIR>/configure
                       --prefix=${CMAKE_INSTALL_PREFIX}
                       --extra-version="kodi-${FFMPEG_VER}"
diff --git a/tools/depends/target/ffmpeg/FFMPEG-VERSION b/tools/depends/target/ffmpeg/FFMPEG-VERSION
index 6878045f11b59..49d9792f22d82 100644
--- a/tools/depends/target/ffmpeg/FFMPEG-VERSION
+++ b/tools/depends/target/ffmpeg/FFMPEG-VERSION
@@ -1,5 +1,6 @@
 LIBNAME=ffmpeg
-VERSION=7.1.1
-ARCHIVE=$(LIBNAME)-$(VERSION).tar.gz
-SHA512=332763b3230c68c0d5329ac455fb1964174e30d53bd043035ea201d6e22c55f29d63a59cff421fed7a3707ddc7e29ff44d267114defc1ffbc521504cd0e3e552
+VERSION=8.0
+ARCHIVE=$(LIBNAME)-$(VERSION).tar.xz
+SHA512=96f01fc3b881e208e8d35d858b2f60627f298b06103195e3e753b1c6429810d7a484d4daeebad6d0810172616383d103dfb5fcadc4512726c3719800d24a3fde
 
+BASE_URL=https://ffmpeg.org/releases/
diff --git a/tools/depends/target/ffmpeg/Makefile b/tools/depends/target/ffmpeg/Makefile
index cbee1fd65a985..38ea96d282001 100644
--- a/tools/depends/target/ffmpeg/Makefile
+++ b/tools/depends/target/ffmpeg/Makefile
@@ -43,6 +43,7 @@ $(PLATFORM): $(DEPS) | $(TARBALLS_LOCATION)/$(ARCHIVE).$(HASH_TYPE)
 	rm -rf $(PLATFORM); mkdir -p $(PLATFORM)/build
 	cd $(PLATFORM); $(ARCHIVE_TOOL) $(ARCHIVE_TOOL_FLAGS) $(TARBALLS_LOCATION)/$(ARCHIVE)
 	cd $(PLATFORM); cp ../CMakeLists.txt ./
+	cd $(PLATFORM); cp ../0001-libpostproc-plugin.patch ./
 	cd $(PLATFORM)/build; $(CMAKE) $(CMAKE_ARGS) ..
 
 .build-$(PLATFORM): $(PLATFORM)

From 83d949fc7ad1896fb7baa3c290b88413a84f487f Mon Sep 17 00:00:00 2001
From: Stephan Sundermann <stephansundermann@gmail.com>
Date: Sat, 9 Aug 2025 19:41:57 +0200
Subject: [PATCH 2/6] [ffmpeg] Encoder: Remove unused function GetData

Define AV_INPUT_BUFFER_MIN_SIZE for the old encode API is removed in 8.0, was already deprecated in https://github.com/FFmpeg/FFmpeg/commit/1d66a122df9fd5d8400b05c74462d0082990fc01
---
 xbmc/cores/AudioEngine/Encoders/AEEncoderFFmpeg.cpp | 9 ---------
 xbmc/cores/AudioEngine/Encoders/AEEncoderFFmpeg.h   | 4 +---
 xbmc/cores/AudioEngine/Interfaces/AEEncoder.h       | 7 -------
 3 files changed, 1 insertion(+), 19 deletions(-)

diff --git a/xbmc/cores/AudioEngine/Encoders/AEEncoderFFmpeg.cpp b/xbmc/cores/AudioEngine/Encoders/AEEncoderFFmpeg.cpp
index 5ffcaf5681a6f..555335c538cca 100644
--- a/xbmc/cores/AudioEngine/Encoders/AEEncoderFFmpeg.cpp
+++ b/xbmc/cores/AudioEngine/Encoders/AEEncoderFFmpeg.cpp
@@ -371,15 +371,6 @@ int CAEEncoderFFmpeg::Encode(uint8_t *in, int in_size, uint8_t *out, int out_siz
   return size;
 }
 
-int CAEEncoderFFmpeg::GetData(uint8_t **data)
-{
-  int size;
-  *data = m_Buffer;
-  size = m_BufferSize;
-  m_BufferSize = 0;
-  return size;
-}
-
 double CAEEncoderFFmpeg::GetDelay(unsigned int bufferSize)
 {
   if (!m_CodecCtx)
diff --git a/xbmc/cores/AudioEngine/Encoders/AEEncoderFFmpeg.h b/xbmc/cores/AudioEngine/Encoders/AEEncoderFFmpeg.h
index 3274d3ac4bca2..f59950ad2765a 100644
--- a/xbmc/cores/AudioEngine/Encoders/AEEncoderFFmpeg.h
+++ b/xbmc/cores/AudioEngine/Encoders/AEEncoderFFmpeg.h
@@ -31,8 +31,7 @@ class CAEEncoderFFmpeg: public IAEEncoder
   AVCodecID GetCodecID() override;
   unsigned int GetFrames() override;
 
-  int Encode(uint8_t *in, int in_size, uint8_t *out, int out_size) override;
-  int GetData(uint8_t **data) override;
+  int Encode(uint8_t* in, int in_size, uint8_t* out, int out_size) override;
   double GetDelay(unsigned int bufferSize) override;
 private:
   unsigned int BuildChannelLayout(const int64_t ffmap, CAEChannelInfo& layout);
@@ -44,7 +43,6 @@ class CAEEncoderFFmpeg: public IAEEncoder
   AVCodecContext *m_CodecCtx;
   SwrContext *m_SwrCtx;
   CAEChannelInfo m_Layout;
-  uint8_t m_Buffer[8 + AV_INPUT_BUFFER_MIN_SIZE];
   int m_BufferSize = 0;
   int m_OutputSize = 0;
   double m_OutputRatio = 0.0;
diff --git a/xbmc/cores/AudioEngine/Interfaces/AEEncoder.h b/xbmc/cores/AudioEngine/Interfaces/AEEncoder.h
index 5c207be402339..1c66ed4501f62 100644
--- a/xbmc/cores/AudioEngine/Interfaces/AEEncoder.h
+++ b/xbmc/cores/AudioEngine/Interfaces/AEEncoder.h
@@ -78,13 +78,6 @@ class IAEEncoder
    */
   virtual int Encode (uint8_t *in, int in_size, uint8_t *out, int out_size) = 0;
 
-  /**
-   * Get the encoded data
-   * @param data return pointer to the buffer with the current encoded block
-   * @return the size in bytes of *data
-   */
-  virtual int GetData(uint8_t **data) = 0;
-
   /**
    * Get the delay in seconds
    * @param bufferSize how much encoded data the caller has buffered to add to the delay

From 0f84173dcb8bbd620986dca31744a3be34817074 Mon Sep 17 00:00:00 2001
From: Stephan Sundermann <stephansundermann@gmail.com>
Date: Sat, 9 Aug 2025 19:49:22 +0200
Subject: [PATCH 3/6] [ffmpeg] Replace FF_PROFILE with AV_PROFILE

https://github.com/FFmpeg/FFmpeg/commit/822432769868da325ba03774df1084aa78b9a5a0
---
 .../Video/DVDVideoCodecAndroidMediaCodec.cpp  | 46 +++++++++----------
 .../DVDCodecs/Video/DVDVideoCodecDRMPRIME.cpp |  6 +--
 .../VideoPlayer/DVDCodecs/Video/VAAPI.cpp     | 16 +++----
 .../VideoPlayer/DVDCodecs/Video/VDPAU.cpp     |  2 +-
 4 files changed, 35 insertions(+), 35 deletions(-)

diff --git a/xbmc/cores/VideoPlayer/DVDCodecs/Video/DVDVideoCodecAndroidMediaCodec.cpp b/xbmc/cores/VideoPlayer/DVDCodecs/Video/DVDVideoCodecAndroidMediaCodec.cpp
index 83d8279419fa6..62c39f510ba6f 100644
--- a/xbmc/cores/VideoPlayer/DVDCodecs/Video/DVDVideoCodecAndroidMediaCodec.cpp
+++ b/xbmc/cores/VideoPlayer/DVDCodecs/Video/DVDVideoCodecAndroidMediaCodec.cpp
@@ -406,16 +406,16 @@ bool CDVDVideoCodecAndroidMediaCodec::Open(CDVDStreamInfo &hints, CDVDCodecOptio
     case AV_CODEC_ID_VP9:
       switch (m_hints.profile)
       {
-        case FF_PROFILE_VP9_0:
+        case AV_PROFILE_VP9_0:
           profile = CJNIMediaCodecInfoCodecProfileLevel::VP9Profile0;
           break;
-        case FF_PROFILE_VP9_1:
+        case AV_PROFILE_VP9_1:
           profile = CJNIMediaCodecInfoCodecProfileLevel::VP9Profile1;
           break;
-        case FF_PROFILE_VP9_2:
+        case AV_PROFILE_VP9_2:
           profile = CJNIMediaCodecInfoCodecProfileLevel::VP9Profile2;
           break;
-        case FF_PROFILE_VP9_3:
+        case AV_PROFILE_VP9_3:
           profile = CJNIMediaCodecInfoCodecProfileLevel::VP9Profile3;
           break;
         default:;
@@ -429,33 +429,33 @@ bool CDVDVideoCodecAndroidMediaCodec::Open(CDVDStreamInfo &hints, CDVDCodecOptio
     case AV_CODEC_ID_H264:
       switch (m_hints.profile)
       {
-        case FF_PROFILE_H264_BASELINE:
+        case AV_PROFILE_H264_BASELINE:
           profile = CJNIMediaCodecInfoCodecProfileLevel::AVCProfileBaseline;
           break;
-        case FF_PROFILE_H264_MAIN:
+        case AV_PROFILE_H264_MAIN:
           profile = CJNIMediaCodecInfoCodecProfileLevel::AVCProfileMain;
           break;
-        case FF_PROFILE_H264_EXTENDED:
+        case AV_PROFILE_H264_EXTENDED:
           profile = CJNIMediaCodecInfoCodecProfileLevel::AVCProfileExtended;
           break;
-        case FF_PROFILE_H264_HIGH:
+        case AV_PROFILE_H264_HIGH:
           profile = CJNIMediaCodecInfoCodecProfileLevel::AVCProfileHigh;
           break;
-        case FF_PROFILE_H264_HIGH_10:
+        case AV_PROFILE_H264_HIGH_10:
           profile = CJNIMediaCodecInfoCodecProfileLevel::AVCProfileHigh10;
           break;
-        case FF_PROFILE_H264_HIGH_422:
+        case AV_PROFILE_H264_HIGH_422:
           profile = CJNIMediaCodecInfoCodecProfileLevel::AVCProfileHigh422;
           break;
-        case FF_PROFILE_H264_HIGH_444:
+        case AV_PROFILE_H264_HIGH_444:
           profile = CJNIMediaCodecInfoCodecProfileLevel::AVCProfileHigh444;
           break;
         // All currently not supported formats
-        case FF_PROFILE_H264_HIGH_10_INTRA:
-        case FF_PROFILE_H264_HIGH_422_INTRA:
-        case FF_PROFILE_H264_HIGH_444_PREDICTIVE:
-        case FF_PROFILE_H264_HIGH_444_INTRA:
-        case FF_PROFILE_H264_CAVLC_444:
+        case AV_PROFILE_H264_HIGH_10_INTRA:
+        case AV_PROFILE_H264_HIGH_422_INTRA:
+        case AV_PROFILE_H264_HIGH_444_PREDICTIVE:
+        case AV_PROFILE_H264_HIGH_444_INTRA:
+        case AV_PROFILE_H264_CAVLC_444:
           goto FAIL;
         default:
           break;
@@ -477,16 +477,16 @@ bool CDVDVideoCodecAndroidMediaCodec::Open(CDVDStreamInfo &hints, CDVDCodecOptio
     {
       switch (m_hints.profile)
       {
-        case FF_PROFILE_HEVC_MAIN:
+        case AV_PROFILE_HEVC_MAIN:
           profile = CJNIMediaCodecInfoCodecProfileLevel::HEVCProfileMain;
           break;
-        case FF_PROFILE_HEVC_MAIN_10:
+        case AV_PROFILE_HEVC_MAIN_10:
           profile = CJNIMediaCodecInfoCodecProfileLevel::HEVCProfileMain10;
           break;
-        case FF_PROFILE_HEVC_MAIN_STILL_PICTURE:
+        case AV_PROFILE_HEVC_MAIN_STILL_PICTURE:
           profile = CJNIMediaCodecInfoCodecProfileLevel::HEVCProfileMainStill;
           break;
-        case FF_PROFILE_HEVC_REXT:
+        case AV_PROFILE_HEVC_REXT:
           // No known h/w decoder supporting Hi10P
           goto FAIL;
         default:
@@ -672,11 +672,11 @@ bool CDVDVideoCodecAndroidMediaCodec::Open(CDVDStreamInfo &hints, CDVDCodecOptio
     {
       switch (m_hints.profile)
       {
-        case FF_PROFILE_AV1_MAIN:
+        case AV_PROFILE_AV1_MAIN:
           profile = CJNIMediaCodecInfoCodecProfileLevel::AV1ProfileMain8;
           break;
-        case FF_PROFILE_AV1_HIGH:
-        case FF_PROFILE_AV1_PROFESSIONAL:
+        case AV_PROFILE_AV1_HIGH:
+        case AV_PROFILE_AV1_PROFESSIONAL:
           goto FAIL;
           break;
         default:
diff --git a/xbmc/cores/VideoPlayer/DVDCodecs/Video/DVDVideoCodecDRMPRIME.cpp b/xbmc/cores/VideoPlayer/DVDCodecs/Video/DVDVideoCodecDRMPRIME.cpp
index e79b9cd7188bb..07c505213691c 100644
--- a/xbmc/cores/VideoPlayer/DVDCodecs/Video/DVDVideoCodecDRMPRIME.cpp
+++ b/xbmc/cores/VideoPlayer/DVDCodecs/Video/DVDVideoCodecDRMPRIME.cpp
@@ -551,11 +551,11 @@ void CDVDVideoCodecDRMPRIME::SetPictureParams(VideoPicture* pVideoPicture)
 
   pVideoPicture->colorBits = 8;
   if (m_pCodecContext->codec_id == AV_CODEC_ID_HEVC &&
-      m_pCodecContext->profile == FF_PROFILE_HEVC_MAIN_10)
+      m_pCodecContext->profile == AV_PROFILE_HEVC_MAIN_10)
     pVideoPicture->colorBits = 10;
   else if (m_pCodecContext->codec_id == AV_CODEC_ID_H264 &&
-           (m_pCodecContext->profile == FF_PROFILE_H264_HIGH_10 ||
-            m_pCodecContext->profile == FF_PROFILE_H264_HIGH_10_INTRA))
+           (m_pCodecContext->profile == AV_PROFILE_H264_HIGH_10 ||
+            m_pCodecContext->profile == AV_PROFILE_H264_HIGH_10_INTRA))
     pVideoPicture->colorBits = 10;
 
   pVideoPicture->hasDisplayMetadata = false;
diff --git a/xbmc/cores/VideoPlayer/DVDCodecs/Video/VAAPI.cpp b/xbmc/cores/VideoPlayer/DVDCodecs/Video/VAAPI.cpp
index 8c83dcdaa6c46..e47adaae16dc9 100644
--- a/xbmc/cores/VideoPlayer/DVDCodecs/Video/VAAPI.cpp
+++ b/xbmc/cores/VideoPlayer/DVDCodecs/Video/VAAPI.cpp
@@ -611,7 +611,7 @@ bool CDecoder::Open(AVCodecContext* avctx, AVCodecContext* mainctx, const enum A
       break;
     case AV_CODEC_ID_H264:
     {
-      if (avctx->profile == FF_PROFILE_H264_CONSTRAINED_BASELINE)
+      if (avctx->profile == AV_PROFILE_H264_CONSTRAINED_BASELINE)
       {
         profile = VAProfileH264ConstrainedBaseline;
         if (!m_vaapiConfig.context->SupportsProfile(profile))
@@ -619,7 +619,7 @@ bool CDecoder::Open(AVCodecContext* avctx, AVCodecContext* mainctx, const enum A
       }
       else
       {
-        if(avctx->profile == FF_PROFILE_H264_MAIN)
+        if (avctx->profile == AV_PROFILE_H264_MAIN)
         {
           profile = VAProfileH264Main;
           if (m_vaapiConfig.context->SupportsProfile(profile))
@@ -633,14 +633,14 @@ bool CDecoder::Open(AVCodecContext* avctx, AVCodecContext* mainctx, const enum A
     }
     case AV_CODEC_ID_HEVC:
     {
-      if (avctx->profile == FF_PROFILE_HEVC_MAIN_10)
+      if (avctx->profile == AV_PROFILE_HEVC_MAIN_10)
       {
         if (!m_capDeepColor)
           return false;
 
         profile = VAProfileHEVCMain10;
       }
-      else if (avctx->profile == FF_PROFILE_HEVC_MAIN)
+      else if (avctx->profile == AV_PROFILE_HEVC_MAIN)
         profile = VAProfileHEVCMain;
       else
         profile = VAProfileNone;
@@ -657,9 +657,9 @@ bool CDecoder::Open(AVCodecContext* avctx, AVCodecContext* mainctx, const enum A
     }
     case AV_CODEC_ID_VP9:
     {
-      if (avctx->profile == FF_PROFILE_VP9_0)
+      if (avctx->profile == AV_PROFILE_VP9_0)
         profile = VAProfileVP9Profile0;
-      else if (avctx->profile == FF_PROFILE_VP9_2)
+      else if (avctx->profile == AV_PROFILE_VP9_2)
         profile = VAProfileVP9Profile2;
       else
         profile = VAProfileNone;
@@ -680,9 +680,9 @@ bool CDecoder::Open(AVCodecContext* avctx, AVCodecContext* mainctx, const enum A
 #if VA_CHECK_VERSION(1, 8, 0)
     case AV_CODEC_ID_AV1:
     {
-      if (avctx->profile == FF_PROFILE_AV1_MAIN)
+      if (avctx->profile == AV_PROFILE_AV1_MAIN)
         profile = VAProfileAV1Profile0;
-      else if (avctx->profile == FF_PROFILE_AV1_HIGH)
+      else if (avctx->profile == AV_PROFILE_AV1_HIGH)
         profile = VAProfileAV1Profile1;
       else
         profile = VAProfileNone;
diff --git a/xbmc/cores/VideoPlayer/DVDCodecs/Video/VDPAU.cpp b/xbmc/cores/VideoPlayer/DVDCodecs/Video/VDPAU.cpp
index 2bcba31b9ae92..b0c1b2eed403f 100644
--- a/xbmc/cores/VideoPlayer/DVDCodecs/Video/VDPAU.cpp
+++ b/xbmc/cores/VideoPlayer/DVDCodecs/Video/VDPAU.cpp
@@ -922,7 +922,7 @@ bool CDecoder::ConfigVDPAU(AVCodecContext* avctx, int ref_frames)
   }
   else if (avctx->codec_id == AV_CODEC_ID_VP9)
   {
-    if (avctx->profile != FF_PROFILE_VP9_0)
+    if (avctx->profile != AV_PROFILE_VP9_0)
       return false;
 
     m_vdpauConfig.maxReferences = 8;

From ea92377b85a4eb15f635b3420854421057241e3c Mon Sep 17 00:00:00 2001
From: Stephan Sundermann <stephansundermann@gmail.com>
Date: Wed, 6 Aug 2025 22:18:47 +0200
Subject: [PATCH 4/6] [ffmpeg] av_opt_set_int_list is deprecated in ffmpeg 8.0

---
 .../DVDCodecs/Video/DVDVideoCodecFFmpeg.cpp   | 32 ++++++++++++++-----
 .../VideoPlayer/DVDCodecs/Video/VAAPI.cpp     | 20 ++++++++++--
 2 files changed, 41 insertions(+), 11 deletions(-)

diff --git a/xbmc/cores/VideoPlayer/DVDCodecs/Video/DVDVideoCodecFFmpeg.cpp b/xbmc/cores/VideoPlayer/DVDCodecs/Video/DVDVideoCodecFFmpeg.cpp
index 1f339b5a8cfa1..37ccae10a3d1d 100644
--- a/xbmc/cores/VideoPlayer/DVDCodecs/Video/DVDVideoCodecFFmpeg.cpp
+++ b/xbmc/cores/VideoPlayer/DVDCodecs/Video/DVDVideoCodecFFmpeg.cpp
@@ -336,7 +336,9 @@ bool CDVDVideoCodecFFmpeg::Open(CDVDStreamInfo &hints, CDVDCodecOptions &options
 
   m_formats.clear();
   m_formats = m_processInfo.GetPixFormats();
+#if LIBAVFILTER_BUILD < AV_VERSION_INT(10, 6, 100)
   m_formats.push_back(AV_PIX_FMT_NONE); /* always add none to get a terminated list in ffmpeg world */
+#endif
   m_processInfo.SetSwDeinterlacingMethods();
   m_processInfo.SetVideoInterlaced(false);
 
@@ -1180,7 +1182,7 @@ int CDVDVideoCodecFFmpeg::FilterOpen(const std::string& filters, bool scale)
     return 0;
   }
 
-  if (!(m_pFilterGraph = avfilter_graph_alloc()))
+  if (!((m_pFilterGraph = avfilter_graph_alloc())))
   {
     CLog::Log(LOGERROR, "CDVDVideoCodecFFmpeg::FilterOpen - unable to alloc filter graph");
     return -1;
@@ -1197,21 +1199,35 @@ int CDVDVideoCodecFFmpeg::FilterOpen(const std::string& filters, bool scale)
       m_pCodecContext->sample_aspect_ratio.num != 0 ? m_pCodecContext->sample_aspect_ratio.num : 1,
       m_pCodecContext->sample_aspect_ratio.num != 0 ? m_pCodecContext->sample_aspect_ratio.den : 1);
 
-  if ((result = avfilter_graph_create_filter(&m_pFilterIn, srcFilter, "src", args.c_str(), NULL, m_pFilterGraph)) < 0)
+  if (!((m_pFilterOut = avfilter_graph_alloc_filter(m_pFilterGraph, outFilter, "out"))))
   {
-    CLog::Log(LOGERROR, "CDVDVideoCodecFFmpeg::FilterOpen - avfilter_graph_create_filter: src");
+    CLog::LogF(LOGERROR, "unable to alloc filter out");
+    return -1;
+  }
+
+#if LIBAVFILTER_BUILD >= AV_VERSION_INT(10, 6, 100)
+  if ((result = av_opt_set_array(m_pFilterOut, "pixel_formats", AV_OPT_SEARCH_CHILDREN, 0,
+                                 m_formats.size(), AV_OPT_TYPE_PIXEL_FMT, m_formats.data())) < 0)
+#else
+  if ((result = av_opt_set_int_list(m_pFilterOut, "pix_fmts", m_formats.data(), AV_PIX_FMT_NONE,
+                                    AV_OPT_SEARCH_CHILDREN)) < 0)
+#endif
+  {
+    CLog::LogF(LOGERROR, "failed setting pix formats");
     return result;
   }
 
-  if ((result = avfilter_graph_create_filter(&m_pFilterOut, outFilter, "out", NULL, NULL, m_pFilterGraph)) < 0)
+  if ((result = avfilter_init_str(m_pFilterOut, nullptr) < 0))
   {
-    CLog::Log(LOGERROR, "CDVDVideoCodecFFmpeg::FilterOpen - avfilter_graph_create_filter: out");
+    CLog::Log(LOGERROR, "CDVDVideoCodecFFmpeg::FilterOpen - avfilter_init_str: out");
+    avfilter_free(m_pFilterOut);
     return result;
   }
-  if ((result = av_opt_set_int_list(m_pFilterOut, "pix_fmts", m_formats.data(), AV_PIX_FMT_NONE,
-                                    AV_OPT_SEARCH_CHILDREN)) < 0)
+
+  if ((result = avfilter_graph_create_filter(&m_pFilterIn, srcFilter, "src", args.c_str(), NULL,
+                                             m_pFilterGraph)) < 0)
   {
-    CLog::Log(LOGERROR, "CDVDVideoCodecFFmpeg::FilterOpen - failed settings pix formats");
+    CLog::Log(LOGERROR, "CDVDVideoCodecFFmpeg::FilterOpen - avfilter_graph_create_filter: src");
     return result;
   }
 
diff --git a/xbmc/cores/VideoPlayer/DVDCodecs/Video/VAAPI.cpp b/xbmc/cores/VideoPlayer/DVDCodecs/Video/VAAPI.cpp
index e47adaae16dc9..e894d978ebdbb 100644
--- a/xbmc/cores/VideoPlayer/DVDCodecs/Video/VAAPI.cpp
+++ b/xbmc/cores/VideoPlayer/DVDCodecs/Video/VAAPI.cpp
@@ -2971,19 +2971,33 @@ bool CFFmpegPostproc::Init(EINTERLACEMETHOD method)
     return false;
   }
 
-  if (avfilter_graph_create_filter(&m_pFilterOut, outFilter, "out", NULL, NULL, m_pFilterGraph) < 0)
+  if (!((m_pFilterOut = avfilter_graph_alloc_filter(m_pFilterGraph, outFilter, "out"))))
   {
-    CLog::Log(LOGERROR, "CFFmpegPostproc::Init  - avfilter_graph_create_filter: out");
+    CLog::LogF(LOGERROR, "unable to alloc filter out");
     return false;
   }
 
+#if LIBAVFILTER_BUILD >= AV_VERSION_INT(10, 6, 100)
+  constexpr std::array<AVPixelFormat, 1> pixFmts = {{AV_PIX_FMT_NV12}};
+  if (av_opt_set_array(m_pFilterOut, "pixel_formats", AV_OPT_SEARCH_CHILDREN, 0, pixFmts.size(),
+                       AV_OPT_TYPE_PIXEL_FMT, pixFmts.data()) < 0)
+#else
   enum AVPixelFormat pix_fmts[] = { AV_PIX_FMT_NV12, AV_PIX_FMT_NONE };
-  if (av_opt_set_int_list(m_pFilterOut, "pix_fmts", pix_fmts,  AV_PIX_FMT_NONE, AV_OPT_SEARCH_CHILDREN) < 0)
+  if (av_opt_set_int_list(m_pFilterOut, "pix_fmts", pix_fmts, AV_PIX_FMT_NONE,
+                          AV_OPT_SEARCH_CHILDREN) < 0)
+#endif
   {
     CLog::Log(LOGERROR, "VAAPI::CFFmpegPostproc::Init  - failed settings pix formats");
     return false;
   }
 
+  if ((avfilter_init_str(m_pFilterOut, nullptr) < 0))
+  {
+    CLog::LogF(LOGERROR, "failed to initialize filter out");
+    avfilter_free(m_pFilterOut);
+    return false;
+  }
+
   AVFilterInOut* outputs = avfilter_inout_alloc();
   AVFilterInOut* inputs  = avfilter_inout_alloc();
 

From 8c845b998186e0c2ffdae43f058dfad82d2bbe74 Mon Sep 17 00:00:00 2001
From: Stephan Sundermann <stephansundermann@gmail.com>
Date: Fri, 22 Aug 2025 19:59:14 +0200
Subject: [PATCH 5/6] [ffmpeg] Remove deprecated FF_API_FRAME_PKT

---
 xbmc/cores/VideoPlayer/DVDCodecs/Video/VAAPI.cpp | 1 -
 1 file changed, 1 deletion(-)

diff --git a/xbmc/cores/VideoPlayer/DVDCodecs/Video/VAAPI.cpp b/xbmc/cores/VideoPlayer/DVDCodecs/Video/VAAPI.cpp
index e894d978ebdbb..3126ee68ba9bc 100644
--- a/xbmc/cores/VideoPlayer/DVDCodecs/Video/VAAPI.cpp
+++ b/xbmc/cores/VideoPlayer/DVDCodecs/Video/VAAPI.cpp
@@ -3112,7 +3112,6 @@ bool CFFmpegPostproc::AddPicture(CVaapiDecodedPicture &inPic)
   m_pFilterFrameIn->linesize[1] = image.pitches[1];
   m_pFilterFrameIn->data[2] = NULL;
   m_pFilterFrameIn->data[3] = NULL;
-  m_pFilterFrameIn->pkt_size = image.data_size;
 
   CheckSuccess(vaUnmapBuffer(m_config.dpy, image.buf), "vaUnmapBuffer");
   CheckSuccess(vaDestroyImage(m_config.dpy, image.image_id), "vaDestroyImage");

From ab1d3cbc5e17e0319da6f24dd5f20414336783b0 Mon Sep 17 00:00:00 2001
From: Stephan Sundermann <stephansundermann@gmail.com>
Date: Sat, 23 Aug 2025 15:11:28 +0200
Subject: [PATCH 6/6] [buildsteps][windows] Extract extension from VERSION file
 instead of hardcoded .tar.gz

---
 tools/buildsteps/windows/buildhelpers.sh | 3 ++-
 1 file changed, 2 insertions(+), 1 deletion(-)

diff --git a/tools/buildsteps/windows/buildhelpers.sh b/tools/buildsteps/windows/buildhelpers.sh
index 4815a00205dc9..6d29337af6a9e 100644
--- a/tools/buildsteps/windows/buildhelpers.sh
+++ b/tools/buildsteps/windows/buildhelpers.sh
@@ -147,7 +147,8 @@ do_loaddeps() {
   LIBNAME=$(grep "LIBNAME=" $file | sed 's/LIBNAME=//g;s/#.*$//g;/^$/d')
   VERSION=$(grep "VERSION=" $file | sed 's/VERSION=//g;s/#.*$//g;/^$/d')
   SHA512=$(grep "SHA512=" $file | sed 's/SHA512=//g;s/#.*$//g;/^$/d')
-  ARCHIVE=$LIBNAME-$VERSION.tar.gz
+  EXT=$(grep "ARCHIVE=" $file | sed 's/ARCHIVE=//g;s/#.*$//g;/^$/d' | cut -d'.' -f2-3)
+  ARCHIVE=$LIBNAME-$VERSION.$EXT
 
   BASE_URL=$(grep "BASE_URL=" $file | sed 's/BASE_URL=//g;s/#.*$//g;/^$/d')
   if [ -z "$BASE_URL" ]; then
openSUSE Build Service is sponsored by