aboutsummaryrefslogtreecommitdiffstats
path: root/libavfilter/vf_stack.c
diff options
context:
space:
mode:
authorJohn Cox <jc@kynesim.co.uk>2023-07-04 14:04:44 +0000
committerMartin Storsjö <martin@martin.st>2023-07-06 00:21:05 +0300
commit697533e76dbea8cc7fd6a0642bc60050cc05ead8 (patch)
tree6e42886cd5d23cbfbb42ac12941e7dc49a79b1cb /libavfilter/vf_stack.c
parent94cb94a2c0910d364a7181fc5cc0e9556b777d0a (diff)
downloadffmpeg-697533e76dbea8cc7fd6a0642bc60050cc05ead8.tar.gz
avfilter/vf_bwdif: Add a filter_line3 method for optimisation
Add an optional filter_line3 to the available optimisations. filter_line3 is equivalent to filter_line, memcpy, filter_line filter_line shares quite a number of loads and some calculations in common with its next iteration and testing shows that using aarch64 neon filter_line3s performance is 30% better than two filter_lines and a memcpy. Adds a test for vf_bwdif filter_line3 to checkasm Rounds job start lines down to a multiple of 4. This means that if filter_line3 exists then filter_line will not sometimes be called once at the end of a slice depending on thread count. The final slice may do up to 3 extra lines but filter_edge is faster than filter_line so it is unlikely to create any noticable thread load variation. Signed-off-by: John Cox <jc@kynesim.co.uk> Signed-off-by: Martin Storsjö <martin@martin.st>
Diffstat (limited to 'libavfilter/vf_stack.c')
0 files changed, 0 insertions, 0 deletions