eal/armv7: emulate vaddvq u16 variant
authorJerin Jacob <jerin.jacob@caviumnetworks.com>
Fri, 7 Jul 2017 16:26:54 +0000 (21:56 +0530)
committerThomas Monjalon <thomas@monjalon.net>
Mon, 10 Jul 2017 07:37:42 +0000 (09:37 +0200)
vaddvq_u16() is not available for armv7.
Emulate the vaddvq_u16() using armv7 NEON intrinsics.

Signed-off-by: Jerin Jacob <jerin.jacob@caviumnetworks.com>
Acked-by: Jianbo Liu <jianbo.liu@linaro.org>
lib/librte_eal/common/include/arch/arm/rte_vect.h

index ea7be29..7fec25e 100644 (file)
@@ -77,6 +77,17 @@ vqtbl1q_u8(uint8x16_t a, uint8x16_t b)
 
        return vld1q_u8(rte_ret.u8);
 }
+
+static inline uint16_t
+vaddvq_u16(uint16x8_t a)
+{
+       uint32x4_t m = vpaddlq_u16(a);
+       uint64x2_t n = vpaddlq_u32(m);
+       uint64x1_t o = vget_low_u64(n) + vget_high_u64(n);
+
+       return vget_lane_u32((uint32x2_t)o, 0);
+}
+
 #endif
 
 #if defined(RTE_TOOLCHAIN_GCC) && (GCC_VERSION < 70000)