]> granicus.if.org Git - libx264/log
libx264
11 years agoAdd AVC-Intra 1080p50/60 Class 100 parameters
Kieran Kunhya [Sat, 21 Sep 2013 18:16:12 +0000 (19:16 +0100)]
Add AVC-Intra 1080p50/60 Class 100 parameters

Also add some compatibility fixes.

11 years agoAdd --filler option
Fiona Glaser [Mon, 9 Sep 2013 19:37:59 +0000 (12:37 -0700)]
Add --filler option

Allows generation of hard-CBR streams without using NAL HRD.
Useful if you want to be able to reconfigure the bitrate (which you can't do
with NAL HRD on).

11 years agoMake x264_encoder_reconfig more threadsafe
Anton Mitrofanov [Sun, 27 Oct 2013 11:22:51 +0000 (15:22 +0400)]
Make x264_encoder_reconfig more threadsafe

Do the reconfig when the next frame's encode begins.
Fixes some rare crashes with frame-threading and encoder_reconfig.

11 years agochroma-me: take shortcut in BI analysis
Fiona Glaser [Fri, 25 Oct 2013 00:19:00 +0000 (17:19 -0700)]
chroma-me: take shortcut in BI analysis

~100 cycles faster with subme>=9

11 years agoCRF-max: don't warn if VBV underflow occurs
Fiona Glaser [Thu, 24 Oct 2013 21:44:43 +0000 (14:44 -0700)]
CRF-max: don't warn if VBV underflow occurs

Only warn if underflow occurs for reasons other than CRF-max, as CRF-max
implies that VBV underflow is desired by the user.

11 years agox86inc: Make ym# behave the same way as xm#
Henrik Gramner [Fri, 18 Oct 2013 20:43:36 +0000 (22:43 +0200)]
x86inc: Make ym# behave the same way as xm#

This makes more sense for future implementations of templates with zmm registers.

11 years agoUse calloc instead of malloc + memset
Henrik Gramner [Fri, 18 Oct 2013 20:21:38 +0000 (22:21 +0200)]
Use calloc instead of malloc + memset

11 years agoReplace gf_malloc with regular malloc in mp4 muxer
Henrik Gramner [Thu, 10 Oct 2013 14:54:12 +0000 (16:54 +0200)]
Replace gf_malloc with regular malloc in mp4 muxer

It was used as a workaround for a bug that only existed in the GPAC repository
for a few weeks back in 2010. There's no reason to keep it anymore.

11 years agoUpdate to current libav/ffmpeg API
Anton Mitrofanov [Tue, 8 Oct 2013 19:20:40 +0000 (23:20 +0400)]
Update to current libav/ffmpeg API

11 years agoversion.sh: change to use /bin/sh
Rafaël Carré [Fri, 25 Oct 2013 14:12:24 +0000 (07:12 -0700)]
version.sh: change to use /bin/sh

11 years agoconfigure: don't generate a git version number if .git isn't present
Sean McGovern [Wed, 4 Sep 2013 21:15:00 +0000 (14:15 -0700)]
configure: don't generate a git version number if .git isn't present

11 years agoconfigure: include dependency libs in the Libs pkg-config
Martin Storsjo [Tue, 3 Sep 2013 21:56:18 +0000 (14:56 -0700)]
configure: include dependency libs in the Libs pkg-config

If only a static library is built, the user of the library that just
tries to link to the lib using the flags provided by pkg-config
might not know that only a static lib exists and that he'd have to
pass --static to pkg-config to get the internal dependencies to
be able to link the library.

For a shared build, the internal dependencies are kept in Libs.private
as before.

This matches how libav's pkg-config files are generated.

11 years agoFix compilation in case of HAVE_LOG2F check fails spuriously
Anton Mitrofanov [Thu, 17 Oct 2013 20:38:06 +0000 (00:38 +0400)]
Fix compilation in case of HAVE_LOG2F check fails spuriously

11 years agoFix compilation of shared library for Windows with original MinGW toolchain
Anton Mitrofanov [Sat, 12 Oct 2013 08:01:57 +0000 (12:01 +0400)]
Fix compilation of shared library for Windows with original MinGW toolchain

11 years agoFix possible crashes in resize and crop filters with high bitdepth input
Anton Mitrofanov [Tue, 8 Oct 2013 19:32:37 +0000 (23:32 +0400)]
Fix possible crashes in resize and crop filters with high bitdepth input

11 years agoFix INSTALL in configure for Solaris systems
Tim Mooney [Tue, 3 Sep 2013 20:43:50 +0000 (13:43 -0700)]
Fix INSTALL in configure for Solaris systems

11 years agoWorkaround for FFMS indexing bug
Henrik Gramner [Tue, 27 Aug 2013 22:50:31 +0000 (00:50 +0200)]
Workaround for FFMS indexing bug

If FFMS_ReadIndex is used with an empty index file it gets stuck in an infinite loop instead of returning NULL
like it's supposed to do on failure. Explicitly check if the file is empty before calling it as a workaround.

11 years agoFix masked access violation in KERNEL32
Anton Mitrofanov [Mon, 26 Aug 2013 17:20:31 +0000 (21:20 +0400)]
Fix masked access violation in KERNEL32

Caused crashes under gdb in Windows and might cause other unknown problems.

11 years agoFix GPAC support on Windows
Hiroki Taniura [Sat, 24 Aug 2013 16:18:57 +0000 (01:18 +0900)]
Fix GPAC support on Windows

11 years agoWindows Unicode support
Henrik Gramner [Sun, 11 Aug 2013 17:50:42 +0000 (19:50 +0200)]
Windows Unicode support

Windows, unlike most other operating systems, uses UTF-16 for Unicode strings while x264 is designed for UTF-8.

This patch does the following in order to handle things like Unicode filenames:
* Keep strings internally as UTF-8.
* Retrieve the CLI command line as UTF-16 and convert it to UTF-8.
* Always use Unicode versions of Windows API functions and convert strings to UTF-16 when calling them.
* Attempt to use legacy 8.3 short filenames for external libraries without Unicode support.

11 years agoAVC-Intra support
Kieran Kunhya [Sat, 20 Jul 2013 17:47:59 +0000 (18:47 +0100)]
AVC-Intra support

This format has been reverse engineered and x264's output has almost exactly
the same bitstream as Panasonic cameras and encoders produce. It therefore does
not comply with SMPTE RP2027 since Panasonic themselves do not comply with
their own specification. It has been tested in Avid, Premiere, Edius and
Quantel.

Parts of this patch were written by Fiona Glaser and some reverse
engineering was done by Joseph Artsimovich.

11 years agoTransparent hugepage support
Henrik Gramner [Mon, 8 Jul 2013 19:06:42 +0000 (12:06 -0700)]
Transparent hugepage support

Combine frame and mb data mallocs into a single large malloc.
Additionally, on Linux systems with hugepage support, ask for hugepages on
large mallocs.

This gives a small performance improvement (~0.2-0.9%) on systems without
hugepage support, as well as a small memory footprint reduction.

On recent Linux kernels with hugepage support enabled (set to madvise or
always), it improves performance up to 4% at the cost of about 7-12% more
memory usage on typical settings..

It may help even more on Haswell and other recent CPUs with improved 2MB page
support in hardware.

11 years agox86: SSSE3 implementation of pixel_sad_x3 and pixel_sad_x4
Henrik Gramner [Fri, 5 Jul 2013 19:15:54 +0000 (21:15 +0200)]
x86: SSSE3 implementation of pixel_sad_x3 and pixel_sad_x4

11 years agox86: Faster AVX2 pixel_sad_x3 and pixel_sad_x4
Henrik Gramner [Fri, 5 Jul 2013 19:15:49 +0000 (21:15 +0200)]
x86: Faster AVX2 pixel_sad_x3 and pixel_sad_x4

11 years agoconfigure: Support cygwin64
Diogo Franco [Wed, 24 Jul 2013 01:17:44 +0000 (22:17 -0300)]
configure: Support cygwin64

11 years agox86inc: Check for __OUTPUT_FORMAT__ having a value of "x64"
Derek Buitenhuis [Fri, 9 Aug 2013 17:39:27 +0000 (13:39 -0400)]
x86inc: Check for __OUTPUT_FORMAT__ having a value of "x64"

This is also a valid value for WIN64.

11 years agoFix cases in which intra refresh allowed prediction from disallowed pixels
Anton Mitrofanov [Tue, 23 Jul 2013 21:11:50 +0000 (14:11 -0700)]
Fix cases in which intra refresh allowed prediction from disallowed pixels

11 years agoFix a few minor bugs found with a static analyzer
Anton Mitrofanov [Tue, 6 Aug 2013 21:56:34 +0000 (01:56 +0400)]
Fix a few minor bugs found with a static analyzer

11 years agoFix AVX2 detection bug with "limit CPUID" enabled in BIOS
Fiona Glaser [Fri, 12 Jul 2013 23:07:35 +0000 (16:07 -0700)]
Fix AVX2 detection bug with "limit CPUID" enabled in BIOS

11 years agox86: Remove X264_CPU_SSE_MISALIGN functions
Henrik Gramner [Fri, 5 Jul 2013 19:15:43 +0000 (21:15 +0200)]
x86: Remove X264_CPU_SSE_MISALIGN functions

Prevents a crash if the misaligned exception mask bit is cleared for some reason.

Misaligned SSE functions are only used on AMD Phenom CPUs and the benefit is miniscule.
They also require modifying the MXCSR control register and by removing those functions
we can get rid of that complexity altogether.

VEX-encoded instructions also supports unaligned memory operands. I tried adding AVX
implementations of all removed functions but there were no performance improvements on
Ivy Bridge. pixel_sad_x3 and pixel_sad_x4 had significant code size reductions though
so I kept them and added some minor cosmetics fixes and tweaks.

11 years agoTweak i16x16-delta-quant-avoidance code
Fiona Glaser [Thu, 20 Jun 2013 22:51:39 +0000 (15:51 -0700)]
Tweak i16x16-delta-quant-avoidance code

Don't omit the delta quant if it'd raise the quantizer to do so; this fixes
a rare flickering issue caused by deblocking.

11 years agox86: faster AVX2 iDCT, AVX deblock_luma_h, deblock_luma_h_intra
Fiona Glaser [Sun, 9 Jun 2013 16:06:27 +0000 (09:06 -0700)]
x86: faster AVX2 iDCT, AVX deblock_luma_h, deblock_luma_h_intra

11 years agoAdd new color primaries, transfer characteristics, matrix coefficients
Lucien [Mon, 17 Jun 2013 18:28:09 +0000 (18:28 +0000)]
Add new color primaries, transfer characteristics, matrix coefficients

11 years agoAdd "--stitchable" option for segmented encoding
Fiona Glaser [Sat, 1 Jun 2013 00:01:29 +0000 (17:01 -0700)]
Add "--stitchable" option for segmented encoding

Stops x264 from attempting to optimize global stream headers, ensuring that
different segments of a video will have identical headers when used with
identical encoding settings.

11 years agoInterface: if vbv-maxrate < bitrate, set bitrate = vbv-maxrate
Fiona Glaser [Thu, 27 Jun 2013 15:29:06 +0000 (08:29 -0700)]
Interface: if vbv-maxrate < bitrate, set bitrate = vbv-maxrate

This probably makes more sense to the user than setting vbv-maxrate = bitrate,
as before.

11 years agoOpenCL cosmetics
Anton Mitrofanov [Tue, 28 May 2013 12:02:42 +0000 (05:02 -0700)]
OpenCL cosmetics

11 years agoFix possible crash when writing very large filler NALUs
Anton Mitrofanov [Mon, 17 Jun 2013 20:16:33 +0000 (00:16 +0400)]
Fix possible crash when writing very large filler NALUs

Bitstream-reallocation function didn't handle the case of filler.

11 years agoFix build with PIC on some systems
Loren Merritt [Mon, 17 Jun 2013 18:27:09 +0000 (11:27 -0700)]
Fix build with PIC on some systems

11 years agoFix potential misaligment crash in AVX2 denoise_dct
Henrik Gramner [Sun, 2 Jun 2013 16:41:17 +0000 (18:41 +0200)]
Fix potential misaligment crash in AVX2 denoise_dct

11 years agoFix building with compilers without inline asm support
Anton Mitrofanov [Mon, 27 May 2013 21:48:15 +0000 (01:48 +0400)]
Fix building with compilers without inline asm support

Also fix crash in high bit depth builds compiled with unaligned stack.

11 years agoFix compilation with OpenCL on MacOS X
Anton Mitrofanov [Wed, 22 May 2013 18:43:59 +0000 (22:43 +0400)]
Fix compilation with OpenCL on MacOS X

Also fix crash in the case of OpenCL error during encoding.

11 years agoOpenCL support improvement/refactoring
Anton Mitrofanov [Mon, 6 May 2013 18:51:11 +0000 (22:51 +0400)]
OpenCL support improvement/refactoring

Autoload the OpenCL library so that it's not required to run an openCL-enabled
build of x264.

Update X264_BUILD, which should have been changed with the first patch.

11 years agox86: shave a few instructions off AVX deblock
Fiona Glaser [Thu, 16 May 2013 20:51:37 +0000 (13:51 -0700)]
x86: shave a few instructions off AVX deblock

11 years agox86: AVX2 dequant_4x4_dc
Henrik Gramner [Tue, 14 May 2013 16:57:40 +0000 (18:57 +0200)]
x86: AVX2 dequant_4x4_dc

11 years agox86: AVX2 high bit-depth dequant
Henrik Gramner [Tue, 14 May 2013 16:53:12 +0000 (18:53 +0200)]
x86: AVX2 high bit-depth dequant

11 years agox86-64: 64-bit variant of AVX2 hpel_filter
Fiona Glaser [Fri, 10 May 2013 00:20:05 +0000 (17:20 -0700)]
x86-64: 64-bit variant of AVX2 hpel_filter

~5% faster than 32-bit.

11 years agox86: AVX2 high bit-depth denoise_dct
Henrik Gramner [Mon, 6 May 2013 16:41:24 +0000 (18:41 +0200)]
x86: AVX2 high bit-depth denoise_dct

28->15 cycles

Also reorder instructions to use fewer registers, 3 cycles faster on Ivy Bridge with 64-bit Windows.

11 years agox86: AVX2 high bit-depth quant
Henrik Gramner [Sat, 4 May 2013 16:48:58 +0000 (18:48 +0200)]
x86: AVX2 high bit-depth quant

quant_4x4: 13->6 cycles
quant_4x4_dc: 14->8 cycles
quant_8x8: 47->24 cycles
quant_4x4x4: 48->25 cycles

11 years agox86: AVX2 add16x16_idct_dc
Fiona Glaser [Wed, 1 May 2013 21:32:11 +0000 (14:32 -0700)]
x86: AVX2 add16x16_idct_dc

27 -> 19 cycles

11 years agox86: faster AVX2 quant_4x4x4
Fiona Glaser [Mon, 29 Apr 2013 23:16:54 +0000 (16:16 -0700)]
x86: faster AVX2 quant_4x4x4

10->9 cycles

11 years agox86: AVX2 intra_sad_x3_8x8c
Fiona Glaser [Sun, 28 Apr 2013 04:03:32 +0000 (21:03 -0700)]
x86: AVX2 intra_sad_x3_8x8c

30->22 cycles

11 years agox86: AVX2 high bit-depth intra_sad_x3_8x8
Henrik Gramner [Sun, 28 Apr 2013 09:11:03 +0000 (11:11 +0200)]
x86: AVX2 high bit-depth intra_sad_x3_8x8

43->24 cycles

11 years agox86: AVX2 deblock strength
Fiona Glaser [Wed, 24 Apr 2013 21:22:15 +0000 (14:22 -0700)]
x86: AVX2 deblock strength

30->18 cycles

11 years agox86: Faster high bit-depth intra_sad_x3_4x4
Henrik Gramner [Wed, 1 May 2013 15:42:48 +0000 (17:42 +0200)]
x86: Faster high bit-depth intra_sad_x3_4x4

20->16 cycles on Ivy Bridge

11 years agox86: faster SSSE3 hpel
Fiona Glaser [Wed, 1 May 2013 00:36:46 +0000 (17:36 -0700)]
x86: faster SSSE3 hpel

~7% faster using the pmulhrsw trick from mc_chroma.

11 years agox86-64: faster SSSE3 trellis
Fiona Glaser [Mon, 29 Apr 2013 21:22:23 +0000 (14:22 -0700)]
x86-64: faster SSSE3 trellis

~2% faster trellis.

11 years agox86: 32-byte align the stack if possible
Fiona Glaser [Fri, 3 May 2013 00:10:26 +0000 (17:10 -0700)]
x86: 32-byte align the stack if possible

Avoids the need for manual 32 byte array alignment on compilers that support
-mpreferred-stack-boundary.

11 years agox86inc: Utilize the shadow space on 64-bit Windows
Henrik Gramner [Sat, 11 May 2013 21:39:09 +0000 (23:39 +0200)]
x86inc: Utilize the shadow space on 64-bit Windows

Store XMM6 and XMM7 in the shadow space in functions that clobbers them.
This way we don't have to adjust the stack pointer as often,
reducing the number of instructions as well as code size.

11 years agox86: Don't use explicitly aligned versions of SAD on AVX CPUs
Henrik Gramner [Fri, 3 May 2013 21:06:10 +0000 (23:06 +0200)]
x86: Don't use explicitly aligned versions of SAD on AVX CPUs

On modern CPUs movdqu isn't slower than movdqa when used on aligned data and using the same code in both cases saves cache.

This was already done for the high bit-depth AVX2 implementation but the aligned version still exists as dead code so remove that.

11 years agox86: Add missing initializations for high bit-depth sad_aligned
Henrik Gramner [Fri, 3 May 2013 18:18:03 +0000 (20:18 +0200)]
x86: Add missing initializations for high bit-depth sad_aligned

11 years agox86: add Jaguar CPU detection
Fiona Glaser [Mon, 13 May 2013 23:52:18 +0000 (16:52 -0700)]
x86: add Jaguar CPU detection

11 years agox86inc: Remove .rodata kludges
Henrik Gramner [Tue, 7 May 2013 15:21:03 +0000 (17:21 +0200)]
x86inc: Remove .rodata kludges

The Mach-O bug was fixed in yasm 0.8.0 and we don't support versions that old.

a.out was superseded by ELF on sane systems a few decades ago.

11 years agocheckasm: Use 64-bit cycle counters
Henrik Gramner [Sat, 4 May 2013 14:21:32 +0000 (16:21 +0200)]
checkasm: Use 64-bit cycle counters

Prevents overflows that can occur in some cases.

11 years agocheckasm: Fix stack alignment bug
Henrik Gramner [Fri, 10 May 2013 11:55:32 +0000 (13:55 +0200)]
checkasm: Fix stack alignment bug

11 years agoFix invalid memcpy in sliced-threads
Fiona Glaser [Wed, 8 May 2013 17:48:41 +0000 (10:48 -0700)]
Fix invalid memcpy in sliced-threads

Likely didn't actually break in practice, but memcpy with src==dst
is incorrect.

11 years agoFix two bugs in slice-min-mbs and slices-max
Fiona Glaser [Mon, 29 Apr 2013 19:14:01 +0000 (12:14 -0700)]
Fix two bugs in slice-min-mbs and slices-max

Slices-max broke slice-max-size when slice-max wasn't used.
Slice-min-mbs broke in rare cases near the end of a threadslice.

11 years agox86: SSSE3 LUT-based faster coeff_level_run
Fiona Glaser [Fri, 5 Apr 2013 01:00:23 +0000 (18:00 -0700)]
x86: SSSE3 LUT-based faster coeff_level_run

~2x faster coeff_level_run.
Faster CAVLC encoding: {1%,2%,7%} overall with {superfast,medium,slower}.
Uses the same pshufb LUT abuse trick as in the previous ads_mvs patch.

11 years agox86-64: BMI2 cabac_residual functions
Fiona Glaser [Mon, 25 Mar 2013 21:03:37 +0000 (14:03 -0700)]
x86-64: BMI2 cabac_residual functions

11 years agox86: SSSE3 ads_mvs
Fiona Glaser [Wed, 20 Mar 2013 22:08:35 +0000 (15:08 -0700)]
x86: SSSE3 ads_mvs

~55% faster ads in benchasm, ~15-30% in real encoding.
~4% faster "placebo" preset overall.

11 years agox86: AVX2 pixel_ssd_nv12_core
Henrik Gramner [Tue, 16 Apr 2013 21:27:53 +0000 (23:27 +0200)]
x86: AVX2 pixel_ssd_nv12_core

11 years agox86: AVX2 high bit-depth pixel_ssd
Henrik Gramner [Tue, 16 Apr 2013 21:27:50 +0000 (23:27 +0200)]
x86: AVX2 high bit-depth pixel_ssd

11 years agox86: AVX2 high bit-depth pixel_sad_x3/pixel_sad_x4
Henrik Gramner [Tue, 16 Apr 2013 21:27:46 +0000 (23:27 +0200)]
x86: AVX2 high bit-depth pixel_sad_x3/pixel_sad_x4

Also reduce the number of xmm registers used by sse2/ssse3 pixel_sad_x3.

11 years agox86: AVX2 high bit-depth vsad
Henrik Gramner [Tue, 16 Apr 2013 21:27:43 +0000 (23:27 +0200)]
x86: AVX2 high bit-depth vsad

11 years agox86: AVX2 high bit-depth pixel_sad
Henrik Gramner [Tue, 16 Apr 2013 21:27:39 +0000 (23:27 +0200)]
x86: AVX2 high bit-depth pixel_sad

Also use loops instead of duplicating code; reduces code size by ~10kB with
negligible effect on performance.

11 years agox86: AVX2 high_bit_depth pixel_avg2, get_ref, mc_copy_w16, mc_luma
Henrik Gramner [Tue, 16 Apr 2013 21:27:35 +0000 (23:27 +0200)]
x86: AVX2 high_bit_depth pixel_avg2, get_ref, mc_copy_w16, mc_luma

Also reduce the number of xmm registers used by mc_copy_* to avoid
saving and restoring xmm6 and xmm7 on 64-bit Windows.

11 years agox86: AVX2 nal_escape
Henrik Gramner [Tue, 16 Apr 2013 21:27:32 +0000 (23:27 +0200)]
x86: AVX2 nal_escape

Also rewrite the entire function to be faster and drop the AVX version which is no longer useful.

11 years agox86: AVX memzero_aligned
Henrik Gramner [Tue, 16 Apr 2013 21:27:29 +0000 (23:27 +0200)]
x86: AVX memzero_aligned

11 years agox86: AVX2 predict_16x16_dc
Henrik Gramner [Tue, 16 Apr 2013 21:27:25 +0000 (23:27 +0200)]
x86: AVX2 predict_16x16_dc

11 years agox86: AVX2 predict_8x8c_p/predict_8x16c_p
Henrik Gramner [Tue, 16 Apr 2013 21:27:22 +0000 (23:27 +0200)]
x86: AVX2 predict_8x8c_p/predict_8x16c_p

11 years agox86: AVX2 predict_16x16_p
Henrik Gramner [Tue, 16 Apr 2013 21:27:18 +0000 (23:27 +0200)]
x86: AVX2 predict_16x16_p

Also fix the AVX implementation to correctly use the SSSE3 inline asm
instead of SSE2.

11 years agox86: AVX high bit-depth predict_16x16_v
Henrik Gramner [Tue, 16 Apr 2013 21:27:14 +0000 (23:27 +0200)]
x86: AVX high bit-depth predict_16x16_v

Also restructure some code to reduce code size of various functions,
especially in high bit-depth.

11 years agox86: AVX2 high bit-depth predict_4x4_h
Henrik Gramner [Tue, 16 Apr 2013 21:27:08 +0000 (23:27 +0200)]
x86: AVX2 high bit-depth predict_4x4_h

11 years agox86: AVX2 high bit-depth predict_16x16_h
Henrik Gramner [Tue, 16 Apr 2013 21:27:04 +0000 (23:27 +0200)]
x86: AVX2 high bit-depth predict_16x16_h

11 years agox86: AVX2 high bit-depth predict_8x8c_h/predict_8x16c_h
Henrik Gramner [Tue, 16 Apr 2013 21:27:00 +0000 (23:27 +0200)]
x86: AVX2 high bit-depth predict_8x8c_h/predict_8x16c_h

11 years agox86util: Support ymm registers in HADD macros
Henrik Gramner [Tue, 16 Apr 2013 21:26:47 +0000 (23:26 +0200)]
x86util: Support ymm registers in HADD macros

11 years agox86: more AVX2 framework, AVX2 functions, plus some existing asm tweaks
Fiona Glaser [Wed, 27 Feb 2013 00:26:34 +0000 (16:26 -0800)]
x86: more AVX2 framework, AVX2 functions, plus some existing asm tweaks

AVX2 functions:
mc_chroma
intra_sad_x3_16x16
last64
ads
hpel
dct4
idct4
sub16x16_dct8
quant_4x4x4
quant_4x4
quant_4x4_dc
quant_8x8
SAD_X3/X4
SATD
var
var2
SSD
zigzag interleave
weightp
weightb
intra_sad_8x8_x9
decimate
integral
hadamard_ac
sa8d_satd
sa8d
lowres_init
denoise

11 years agox86inc: create xm# and ym#, analagous to m#
Loren Merritt [Mon, 25 Feb 2013 21:16:45 +0000 (21:16 +0000)]
x86inc: create xm# and ym#, analagous to m#

For when we want to mix simd sizes within one function.

11 years agox86inc: fix AVX emulation of cmp(p|s)(s|d)
Fiona Glaser [Fri, 5 Apr 2013 23:08:35 +0000 (16:08 -0700)]
x86inc: fix AVX emulation of cmp(p|s)(s|d)

11 years agox86-64: cabac_block_residual assembly
Fiona Glaser [Wed, 6 Feb 2013 01:15:00 +0000 (17:15 -0800)]
x86-64: cabac_block_residual assembly

RDO: ~20% faster than C
Bitstream: ~50% faster than C
1-2% faster overall, highest on preset superfast/fast/medium.

11 years agoOpenCL lookahead
Steve Borho [Thu, 21 Feb 2013 18:48:40 +0000 (12:48 -0600)]
OpenCL lookahead

OpenCL support is compiled in by default, but must be enabled at runtime by an
--opencl command line flag. Compiling OpenCL support requires perl. To avoid
the perl requirement use: configure --disable-opencl.

When enabled, the lookahead thread is mostly off-loaded to an OpenCL capable GPU
device.  Lowres intra cost prediction, lowres motion search (including subpel)
and bidir cost predictions are all done on the GPU.  MB-tree and final slice
decisions are still done by the CPU.  Presets which do not use a threaded
lookahead will not use OpenCL at all (superfast, ultrafast).

Because of data dependencies, the GPU must use an iterative motion search which
performs more total work than the CPU would do, so this is not work efficient
or power efficient. But if there are spare GPU cycles to spare, it can often
speed up the encode. Output quality when OpenCL lookahead is enabled is often
very slightly worse in quality than the CPU quality (because of the same data
dependencies).

x264 must compile its OpenCL kernels for your device before running them, and in
order to avoid doing this every run it caches the compiled kernel binary in a
file named x264_lookahead.clbin (--opencl-clbin FNAME to override).  The cache
file will be ignored if the device, driver, or OpenCL source are changed.

x264 will use the first GPU device which supports the required cl_image
features required by its kernels. Most modern discrete GPUs and all AMD
integrated GPUs will work.  Intel integrated GPUs (up to IvyBridge) do not
support those necessary features. Use --opencl-device N to specify a number of
capable GPUs to skip during device detection.

Switchable graphics environments (e.g. AMD Enduro) are currently not supported,
as some have bugs in their OpenCL drivers that cause output to be silently
incorrect.

Developed by MulticoreWare with support from AMD and Telestream.

11 years agoweightp: improve scale/offset search, chroma
Fiona Glaser [Mon, 4 Mar 2013 23:19:47 +0000 (15:19 -0800)]
weightp: improve scale/offset search, chroma

Rescale the scale factor if the offset clips. This makes weightp more effective
in fades to/from white (and an other situation that requires big offsets).

Search more than 1 scale factor and more than 1 offset, depending on --subme.

Try to find the optimal chroma denominator instead of hardcoding it.

Overall improvement: a few percent in fade-heavy clips, such as a sample from
Avatar: TLA.

11 years agoAdd slices-max feature
Fiona Glaser [Tue, 19 Feb 2013 21:48:44 +0000 (13:48 -0800)]
Add slices-max feature

The H.264 spec technically has limits on the number of slices per frame. x264
normally ignores this, since most use-cases that require large numbers of
slices prefer it to. However, certain decoders may break with extremely large
numbers of slices, as can occur with some slice-max-size/mbs settings.

When set, x264 will refuse to create any slices beyond the maximum number,
even if slice-max-size/mbs requires otherwise.

11 years agoAdd slice-min-mbs feature
Fiona Glaser [Fri, 15 Feb 2013 01:22:02 +0000 (17:22 -0800)]
Add slice-min-mbs feature

Works in conjunction with slice-max-mbs and/or slice-max-size to avoid overly
small slices.
Useful with certain decoders that barf on extremely small slices.

If slice-min-mbs would be violated as a result of slice-max-size, x264 will
exceed slice-max-size and print a warning.

11 years agoDisable mbtree asm with cpu-independent option
Anton Mitrofanov [Tue, 26 Mar 2013 14:56:21 +0000 (18:56 +0400)]
Disable mbtree asm with cpu-independent option

Results vary between versions because of different rounding results.

11 years agoShow "avs: no" --disable-avs option instead of empty string
Anton Mitrofanov [Tue, 26 Mar 2013 14:30:00 +0000 (18:30 +0400)]
Show "avs: no" --disable-avs option instead of empty string

11 years agolavf input: don't use deprecated AVStream fields
Tim Walker [Tue, 19 Mar 2013 22:42:43 +0000 (23:42 +0100)]
lavf input: don't use deprecated AVStream fields

Fixes building against newer libavcodecs from the Libav project.

11 years agoFix y4m input with C420paldv colorspace
Anton Mitrofanov [Tue, 26 Mar 2013 15:54:36 +0000 (19:54 +0400)]
Fix y4m input with C420paldv colorspace

11 years agox86: correctly check stack alignment for Atom hadamard_ac
Fiona Glaser [Sat, 2 Mar 2013 09:22:29 +0000 (01:22 -0800)]
x86: correctly check stack alignment for Atom hadamard_ac

Regression in r2265 (only affected compilers with broken stack alignment,
like ICL on win32).

11 years agox86inc: fix some corner cases of SWAP
Loren Merritt [Mon, 25 Feb 2013 21:23:55 +0000 (21:23 +0000)]
x86inc: fix some corner cases of SWAP

SWAP with >=3 named (rather than numbered) args
PERMUTE followed by SWAP with 2 named args
used to produce the wrong permutation

11 years agoFix array overreads that caused miscompilation in gcc 4.8
Fiona Glaser [Wed, 27 Feb 2013 21:30:22 +0000 (13:30 -0800)]
Fix array overreads that caused miscompilation in gcc 4.8