From 4fa3ea604ba9ea62836890619f072af52abf7f97 Mon Sep 17 00:00:00 2001 From: Mitchell Hashimoto Date: Sat, 3 Feb 2024 10:00:24 -0800 Subject: [PATCH] simd/aarch64: additional intrinsics --- src/simd/aarch64.zig | 10 ++++++++++ 1 file changed, 10 insertions(+) diff --git a/src/simd/aarch64.zig b/src/simd/aarch64.zig index 46f9ad8fb..584a22e2b 100644 --- a/src/simd/aarch64.zig +++ b/src/simd/aarch64.zig @@ -269,6 +269,16 @@ pub inline fn vqtbl1q_u8(t: @Vector(16, u8), idx: @Vector(16, u8)) @Vector(16, u ); } +pub inline fn vqtbl2q_u8(t: [2]@Vector(16, u8), idx: @Vector(16, u8)) @Vector(16, u8) { + return asm ( + \\ tbl %[ret].16b, { %[t0].16b, %[t1].16b }, %[idx].16b + : [ret] "=w" (-> @Vector(16, u8)), + : [idx] "w" (idx), + [t0] "w" (t[0]), + [t1] "w" (t[1]), + ); +} + pub inline fn vshrn_n_u16(a: @Vector(8, u16), n: u4) @Vector(8, u8) { assert(n <= 8); return asm (