commit | f40042533cb0d2e11d65b6fd878857c108d9c122 | [log] [tgz] |
---|---|---|
author | George Steed <george.steed@arm.com> | Fri May 03 17:46:40 2024 +0100 |
committer | Frank Barchard <fbarchard@chromium.org> | Thu Oct 24 21:27:39 2024 +0000 |
tree | 0aefbe39731e2367a4695822942c2f489d21d60c | |
parent | 4621b0cc7fd4f694b3ec4a2827cf82c4983fd237 [diff] |
[AArch64] Add SVE2 implementation of I422ToRGB565Row This makes use of the same approach as the Neon code to avoid redundant narrowing and then widening shifts by instead placing the values at the top portion of the lanes and then shifting down from there instead. Observed reduction in runtime compared to the existing Neon code: Cortex-A510: -41.1% Cortex-A520: -38.2% Cortex-A715: -21.5% Cortex-A720: -21.6% Cortex-X2: -21.6% Cortex-X3: -22.0% Cortex-X4: -23.5% Cortex-X925: -21.7% Bug: b/42280942 Change-Id: Id84872141435566bbf94a4bbf0227554b5b5fb91 Reviewed-on: https://chromium-review.googlesource.com/c/libyuv/libyuv/+/5802966 Reviewed-by: Justin Green <greenjustin@google.com> Reviewed-by: Frank Barchard <fbarchard@chromium.org>
libyuv is an open source project that includes YUV scaling and conversion functionality.
See Getting started for instructions on how to get started developing.
You can also browse the docs directory for more documentation.