1. 08 Jan, 2020 7 commits
  2. 07 Jan, 2020 15 commits
  3. 06 Jan, 2020 9 commits
  4. 05 Jan, 2020 8 commits
  5. 04 Jan, 2020 1 commit
    • Sebastian Pop's avatar
      swscale/aarch64: use multiply accumulate and shift-right narrow · c3a17fff
      Sebastian Pop authored
      This patch rewrites the innermost loop of ff_yuv2planeX_8_neon to avoid zips and
      horizontal adds by using fused multiply adds. The patch also uses ld1r to load
      one element and replicate it across all lanes of the vector. The patch also
      improves the clipping code by removing the shift right instructions and
      performing the shift with the shift-right narrow instructions.
      
      I see 8% difference on an m6g instance with neoverse-n1 CPUs:
      $ ffmpeg -nostats -f lavfi -i testsrc2=4k:d=2 -vf bench=start,scale=1024x1024,bench=stop -f null -
      before: t:0.014015 avg:0.014096 max:0.015018 min:0.013971
      after:  t:0.012985 avg:0.013013 max:0.013996 min:0.012818
      
      Tested with `make check` on aarch64-linux.
      Signed-off-by: 's avatarSebastian Pop <spop@amazon.com>
      Reviewed-by: 's avatarClément Bœsch <u@pkh.me>
      Signed-off-by: 's avatarMichael Niedermayer <michael@niedermayer.cc>
      c3a17fff