openh264/codec/common/arm
Martin Storsjö 23f57adaea Do full register loads instead of single-lane loads in DeblockLumaEq4H_neon
Instead of loading the registers one lane at a time, load full
registers and then transpose them.

This is faster, reducing the runtime for the function from about
506 cycles to 434 cycles (tested on a Cortex A8).

This also avoids an issue which seems like a cpu bug, present
on Sony Xperia T (cpu implementer 0x51 architecture 7 variant 0x1
part 0x04d). On such a device, it seemed like the "vswp q9, q10"
could start executing before the previous
vld4.u8 {d20[x],d21[x],d22[x],d23[x]}, [r3], r1
had finished and written back their result. Changing the
"vswp q9, q10" into "vswp q10, q9", or into separate
"vswp d18, d20; vswp d19, d21" (or the other way around) seemed to
avoid the issue. This happened occasionally (a couple times per
100000 invocations or so).
2014-04-28 10:12:16 +03:00
..
arm_arch_common_macro.S reoranize common to inc/src/x86/arm 2014-03-18 19:41:32 -07:00
copy_mb_neon.S Move copy_mb neon code to common folder 2014-04-17 10:06:48 +08:00
deblocking_neon.S Do full register loads instead of single-lane loads in DeblockLumaEq4H_neon 2014-04-28 10:12:16 +03:00
expand_picture_neon.S Modify ARM32 Neon code for Expand Chroma Picture, when UVWidth%16==8. 2014-04-17 15:58:30 +08:00
mc_neon.S Fix potential issue for neon implement on encoder mode decision. 2014-04-13 19:41:29 -07:00