From fd0e492b0b00d4e6f41d675d29cf878004d14c94 Mon Sep 17 00:00:00 2001 From: M-HT Date: Tue, 26 Sep 2023 21:02:36 +0200 Subject: [PATCH] Extend constant range in simde_vshll_n_XXX intrinsics (#1064) --- simde/arm/neon/shll_n.h | 12 +- test/arm/neon/shll_n.c | 248 ++++++++++++++++++++++++++++++++-------- 2 files changed, 204 insertions(+), 56 deletions(-) diff --git a/simde/arm/neon/shll_n.h b/simde/arm/neon/shll_n.h index 36fb96eaa..898e307ed 100644 --- a/simde/arm/neon/shll_n.h +++ b/simde/arm/neon/shll_n.h @@ -46,7 +46,7 @@ SIMDE_BEGIN_DECLS_ SIMDE_FUNCTION_ATTRIBUTES simde_int16x8_t simde_vshll_n_s8 (const simde_int8x8_t a, const int n) - SIMDE_REQUIRE_CONSTANT_RANGE(n, 1, 7) { + SIMDE_REQUIRE_CONSTANT_RANGE(n, 0, 8) { simde_int16x8_private r_; simde_int8x8_private a_ = simde_int8x8_to_private(a); @@ -68,7 +68,7 @@ simde_vshll_n_s8 (const simde_int8x8_t a, const int n) SIMDE_FUNCTION_ATTRIBUTES simde_int32x4_t simde_vshll_n_s16 (const simde_int16x4_t a, const int n) - SIMDE_REQUIRE_CONSTANT_RANGE(n, 1, 15) { + SIMDE_REQUIRE_CONSTANT_RANGE(n, 0, 16) { simde_int32x4_private r_; simde_int16x4_private a_ = simde_int16x4_to_private(a); @@ -90,7 +90,7 @@ simde_vshll_n_s16 (const simde_int16x4_t a, const int n) SIMDE_FUNCTION_ATTRIBUTES simde_int64x2_t simde_vshll_n_s32 (const simde_int32x2_t a, const int n) - SIMDE_REQUIRE_CONSTANT_RANGE(n, 1, 31) { + SIMDE_REQUIRE_CONSTANT_RANGE(n, 0, 32) { simde_int64x2_private r_; simde_int32x2_private a_ = simde_int32x2_to_private(a); @@ -112,7 +112,7 @@ simde_vshll_n_s32 (const simde_int32x2_t a, const int n) SIMDE_FUNCTION_ATTRIBUTES simde_uint16x8_t simde_vshll_n_u8 (const simde_uint8x8_t a, const int n) - SIMDE_REQUIRE_CONSTANT_RANGE(n, 1, 7) { + SIMDE_REQUIRE_CONSTANT_RANGE(n, 0, 8) { simde_uint16x8_private r_; simde_uint8x8_private a_ = simde_uint8x8_to_private(a); @@ -134,7 +134,7 @@ simde_vshll_n_u8 (const simde_uint8x8_t a, const int n) SIMDE_FUNCTION_ATTRIBUTES simde_uint32x4_t simde_vshll_n_u16 (const simde_uint16x4_t a, const int n) - SIMDE_REQUIRE_CONSTANT_RANGE(n, 1, 15) { + SIMDE_REQUIRE_CONSTANT_RANGE(n, 0, 16) { simde_uint32x4_private r_; simde_uint16x4_private a_ = simde_uint16x4_to_private(a); @@ -156,7 +156,7 @@ simde_vshll_n_u16 (const simde_uint16x4_t a, const int n) SIMDE_FUNCTION_ATTRIBUTES simde_uint64x2_t simde_vshll_n_u32 (const simde_uint32x2_t a, const int n) - SIMDE_REQUIRE_CONSTANT_RANGE(n, 1, 31) { + SIMDE_REQUIRE_CONSTANT_RANGE(n, 0, 32) { simde_uint64x2_private r_; simde_uint32x2_private a_ = simde_uint32x2_to_private(a); diff --git a/test/arm/neon/shll_n.c b/test/arm/neon/shll_n.c index 5c0067794..7ecde4f55 100644 --- a/test/arm/neon/shll_n.c +++ b/test/arm/neon/shll_n.c @@ -9,87 +9,111 @@ test_simde_vshll_n_s8 (SIMDE_MUNIT_TEST_ARGS) { #if 1 static const struct { int8_t a[8]; + int16_t r0[8]; int16_t r1[8]; int16_t r3[8]; int16_t r5[8]; int16_t r6[8]; int16_t r7[8]; + int16_t r8[8]; } test_vec[] = { { { INT8_C( 119), -INT8_C( 122), INT8_C( 124), -INT8_C( 86), INT8_C( 35), -INT8_C( 22), -INT8_C( 78), -INT8_C( 45) }, + { INT16_C( 119), -INT16_C( 122), INT16_C( 124), -INT16_C( 86), INT16_C( 35), -INT16_C( 22), -INT16_C( 78), -INT16_C( 45) }, { INT16_C( 238), -INT16_C( 244), INT16_C( 248), -INT16_C( 172), INT16_C( 70), -INT16_C( 44), -INT16_C( 156), -INT16_C( 90) }, { INT16_C( 952), -INT16_C( 976), INT16_C( 992), -INT16_C( 688), INT16_C( 280), -INT16_C( 176), -INT16_C( 624), -INT16_C( 360) }, { INT16_C( 3808), -INT16_C( 3904), INT16_C( 3968), -INT16_C( 2752), INT16_C( 1120), -INT16_C( 704), -INT16_C( 2496), -INT16_C( 1440) }, { INT16_C( 7616), -INT16_C( 7808), INT16_C( 7936), -INT16_C( 5504), INT16_C( 2240), -INT16_C( 1408), -INT16_C( 4992), -INT16_C( 2880) }, - { INT16_C( 15232), -INT16_C( 15616), INT16_C( 15872), -INT16_C( 11008), INT16_C( 4480), -INT16_C( 2816), -INT16_C( 9984), -INT16_C( 5760) } }, + { INT16_C( 15232), -INT16_C( 15616), INT16_C( 15872), -INT16_C( 11008), INT16_C( 4480), -INT16_C( 2816), -INT16_C( 9984), -INT16_C( 5760) }, + { INT16_C( 30464), -INT16_C( 31232), INT16_C( 31744), -INT16_C( 22016), INT16_C( 8960), -INT16_C( 5632), -INT16_C( 19968), -INT16_C( 11520) } }, { { INT8_C( 28), INT8_C( 120), INT8_C( 31), -INT8_C( 47), INT8_C( 121), INT8_C( 103), INT8_C( 15), INT8_C( 63) }, + { INT16_C( 28), INT16_C( 120), INT16_C( 31), -INT16_C( 47), INT16_C( 121), INT16_C( 103), INT16_C( 15), INT16_C( 63) }, { INT16_C( 56), INT16_C( 240), INT16_C( 62), -INT16_C( 94), INT16_C( 242), INT16_C( 206), INT16_C( 30), INT16_C( 126) }, { INT16_C( 224), INT16_C( 960), INT16_C( 248), -INT16_C( 376), INT16_C( 968), INT16_C( 824), INT16_C( 120), INT16_C( 504) }, { INT16_C( 896), INT16_C( 3840), INT16_C( 992), -INT16_C( 1504), INT16_C( 3872), INT16_C( 3296), INT16_C( 480), INT16_C( 2016) }, { INT16_C( 1792), INT16_C( 7680), INT16_C( 1984), -INT16_C( 3008), INT16_C( 7744), INT16_C( 6592), INT16_C( 960), INT16_C( 4032) }, - { INT16_C( 3584), INT16_C( 15360), INT16_C( 3968), -INT16_C( 6016), INT16_C( 15488), INT16_C( 13184), INT16_C( 1920), INT16_C( 8064) } }, + { INT16_C( 3584), INT16_C( 15360), INT16_C( 3968), -INT16_C( 6016), INT16_C( 15488), INT16_C( 13184), INT16_C( 1920), INT16_C( 8064) }, + { INT16_C( 7168), INT16_C( 30720), INT16_C( 7936), -INT16_C( 12032), INT16_C( 30976), INT16_C( 26368), INT16_C( 3840), INT16_C( 16128) } }, { { -INT8_C( 101), -INT8_C( 108), INT8_C( 56), -INT8_C( 44), -INT8_C( 85), -INT8_C( 11), INT8_C( 89), INT8_C( 39) }, + { -INT16_C( 101), -INT16_C( 108), INT16_C( 56), -INT16_C( 44), -INT16_C( 85), -INT16_C( 11), INT16_C( 89), INT16_C( 39) }, { -INT16_C( 202), -INT16_C( 216), INT16_C( 112), -INT16_C( 88), -INT16_C( 170), -INT16_C( 22), INT16_C( 178), INT16_C( 78) }, { -INT16_C( 808), -INT16_C( 864), INT16_C( 448), -INT16_C( 352), -INT16_C( 680), -INT16_C( 88), INT16_C( 712), INT16_C( 312) }, { -INT16_C( 3232), -INT16_C( 3456), INT16_C( 1792), -INT16_C( 1408), -INT16_C( 2720), -INT16_C( 352), INT16_C( 2848), INT16_C( 1248) }, { -INT16_C( 6464), -INT16_C( 6912), INT16_C( 3584), -INT16_C( 2816), -INT16_C( 5440), -INT16_C( 704), INT16_C( 5696), INT16_C( 2496) }, - { -INT16_C( 12928), -INT16_C( 13824), INT16_C( 7168), -INT16_C( 5632), -INT16_C( 10880), -INT16_C( 1408), INT16_C( 11392), INT16_C( 4992) } }, + { -INT16_C( 12928), -INT16_C( 13824), INT16_C( 7168), -INT16_C( 5632), -INT16_C( 10880), -INT16_C( 1408), INT16_C( 11392), INT16_C( 4992) }, + { -INT16_C( 25856), -INT16_C( 27648), INT16_C( 14336), -INT16_C( 11264), -INT16_C( 21760), -INT16_C( 2816), INT16_C( 22784), INT16_C( 9984) } }, { { INT8_C( 77), -INT8_C( 90), -INT8_C( 113), INT8_C( 79), INT8_C( 77), -INT8_C( 102), -INT8_C( 73), -INT8_C( 59) }, + { INT16_C( 77), -INT16_C( 90), -INT16_C( 113), INT16_C( 79), INT16_C( 77), -INT16_C( 102), -INT16_C( 73), -INT16_C( 59) }, { INT16_C( 154), -INT16_C( 180), -INT16_C( 226), INT16_C( 158), INT16_C( 154), -INT16_C( 204), -INT16_C( 146), -INT16_C( 118) }, { INT16_C( 616), -INT16_C( 720), -INT16_C( 904), INT16_C( 632), INT16_C( 616), -INT16_C( 816), -INT16_C( 584), -INT16_C( 472) }, { INT16_C( 2464), -INT16_C( 2880), -INT16_C( 3616), INT16_C( 2528), INT16_C( 2464), -INT16_C( 3264), -INT16_C( 2336), -INT16_C( 1888) }, { INT16_C( 4928), -INT16_C( 5760), -INT16_C( 7232), INT16_C( 5056), INT16_C( 4928), -INT16_C( 6528), -INT16_C( 4672), -INT16_C( 3776) }, - { INT16_C( 9856), -INT16_C( 11520), -INT16_C( 14464), INT16_C( 10112), INT16_C( 9856), -INT16_C( 13056), -INT16_C( 9344), -INT16_C( 7552) } }, + { INT16_C( 9856), -INT16_C( 11520), -INT16_C( 14464), INT16_C( 10112), INT16_C( 9856), -INT16_C( 13056), -INT16_C( 9344), -INT16_C( 7552) }, + { INT16_C( 19712), -INT16_C( 23040), -INT16_C( 28928), INT16_C( 20224), INT16_C( 19712), -INT16_C( 26112), -INT16_C( 18688), -INT16_C( 15104) } }, { { INT8_C( 32), INT8_C( 51), INT8_C( 111), INT8_C( 68), INT8_C( 30), INT8_C( 34), INT8_C( 23), INT8_C( 58) }, + { INT16_C( 32), INT16_C( 51), INT16_C( 111), INT16_C( 68), INT16_C( 30), INT16_C( 34), INT16_C( 23), INT16_C( 58) }, { INT16_C( 64), INT16_C( 102), INT16_C( 222), INT16_C( 136), INT16_C( 60), INT16_C( 68), INT16_C( 46), INT16_C( 116) }, { INT16_C( 256), INT16_C( 408), INT16_C( 888), INT16_C( 544), INT16_C( 240), INT16_C( 272), INT16_C( 184), INT16_C( 464) }, { INT16_C( 1024), INT16_C( 1632), INT16_C( 3552), INT16_C( 2176), INT16_C( 960), INT16_C( 1088), INT16_C( 736), INT16_C( 1856) }, { INT16_C( 2048), INT16_C( 3264), INT16_C( 7104), INT16_C( 4352), INT16_C( 1920), INT16_C( 2176), INT16_C( 1472), INT16_C( 3712) }, - { INT16_C( 4096), INT16_C( 6528), INT16_C( 14208), INT16_C( 8704), INT16_C( 3840), INT16_C( 4352), INT16_C( 2944), INT16_C( 7424) } }, + { INT16_C( 4096), INT16_C( 6528), INT16_C( 14208), INT16_C( 8704), INT16_C( 3840), INT16_C( 4352), INT16_C( 2944), INT16_C( 7424) }, + { INT16_C( 8192), INT16_C( 13056), INT16_C( 28416), INT16_C( 17408), INT16_C( 7680), INT16_C( 8704), INT16_C( 5888), INT16_C( 14848) } }, { { -INT8_C( 102), INT8_C( 54), INT8_C( 11), INT8_C( 19), -INT8_C( 98), INT8_C( 26), INT8_C( 83), INT8_C( 57) }, + { -INT16_C( 102), INT16_C( 54), INT16_C( 11), INT16_C( 19), -INT16_C( 98), INT16_C( 26), INT16_C( 83), INT16_C( 57) }, { -INT16_C( 204), INT16_C( 108), INT16_C( 22), INT16_C( 38), -INT16_C( 196), INT16_C( 52), INT16_C( 166), INT16_C( 114) }, { -INT16_C( 816), INT16_C( 432), INT16_C( 88), INT16_C( 152), -INT16_C( 784), INT16_C( 208), INT16_C( 664), INT16_C( 456) }, { -INT16_C( 3264), INT16_C( 1728), INT16_C( 352), INT16_C( 608), -INT16_C( 3136), INT16_C( 832), INT16_C( 2656), INT16_C( 1824) }, { -INT16_C( 6528), INT16_C( 3456), INT16_C( 704), INT16_C( 1216), -INT16_C( 6272), INT16_C( 1664), INT16_C( 5312), INT16_C( 3648) }, - { -INT16_C( 13056), INT16_C( 6912), INT16_C( 1408), INT16_C( 2432), -INT16_C( 12544), INT16_C( 3328), INT16_C( 10624), INT16_C( 7296) } }, + { -INT16_C( 13056), INT16_C( 6912), INT16_C( 1408), INT16_C( 2432), -INT16_C( 12544), INT16_C( 3328), INT16_C( 10624), INT16_C( 7296) }, + { -INT16_C( 26112), INT16_C( 13824), INT16_C( 2816), INT16_C( 4864), -INT16_C( 25088), INT16_C( 6656), INT16_C( 21248), INT16_C( 14592) } }, { { -INT8_C( 82), -INT8_C( 117), INT8_C( 13), INT8_C( 89), -INT8_C( 127), INT8_C( 102), -INT8_C( 127), -INT8_C( 50) }, + { -INT16_C( 82), -INT16_C( 117), INT16_C( 13), INT16_C( 89), -INT16_C( 127), INT16_C( 102), -INT16_C( 127), -INT16_C( 50) }, { -INT16_C( 164), -INT16_C( 234), INT16_C( 26), INT16_C( 178), -INT16_C( 254), INT16_C( 204), -INT16_C( 254), -INT16_C( 100) }, { -INT16_C( 656), -INT16_C( 936), INT16_C( 104), INT16_C( 712), -INT16_C( 1016), INT16_C( 816), -INT16_C( 1016), -INT16_C( 400) }, { -INT16_C( 2624), -INT16_C( 3744), INT16_C( 416), INT16_C( 2848), -INT16_C( 4064), INT16_C( 3264), -INT16_C( 4064), -INT16_C( 1600) }, { -INT16_C( 5248), -INT16_C( 7488), INT16_C( 832), INT16_C( 5696), -INT16_C( 8128), INT16_C( 6528), -INT16_C( 8128), -INT16_C( 3200) }, - { -INT16_C( 10496), -INT16_C( 14976), INT16_C( 1664), INT16_C( 11392), -INT16_C( 16256), INT16_C( 13056), -INT16_C( 16256), -INT16_C( 6400) } }, + { -INT16_C( 10496), -INT16_C( 14976), INT16_C( 1664), INT16_C( 11392), -INT16_C( 16256), INT16_C( 13056), -INT16_C( 16256), -INT16_C( 6400) }, + { -INT16_C( 20992), -INT16_C( 29952), INT16_C( 3328), INT16_C( 22784), -INT16_C( 32512), INT16_C( 26112), -INT16_C( 32512), -INT16_C( 12800) } }, }; for (size_t i = 0 ; i < (sizeof(test_vec) / sizeof(test_vec[0])) ; i++) { simde_int8x8_t a = simde_vld1_s8(test_vec[i].a); + simde_int16x8_t r0 = simde_vshll_n_s8(a, 0); simde_int16x8_t r1 = simde_vshll_n_s8(a, 1); simde_int16x8_t r3 = simde_vshll_n_s8(a, 3); simde_int16x8_t r5 = simde_vshll_n_s8(a, 5); simde_int16x8_t r6 = simde_vshll_n_s8(a, 6); simde_int16x8_t r7 = simde_vshll_n_s8(a, 7); + simde_int16x8_t r8 = simde_vshll_n_s8(a, 8); + simde_test_arm_neon_assert_equal_i16x8(r0, simde_vld1q_s16(test_vec[i].r0)); simde_test_arm_neon_assert_equal_i16x8(r1, simde_vld1q_s16(test_vec[i].r1)); simde_test_arm_neon_assert_equal_i16x8(r3, simde_vld1q_s16(test_vec[i].r3)); simde_test_arm_neon_assert_equal_i16x8(r5, simde_vld1q_s16(test_vec[i].r5)); simde_test_arm_neon_assert_equal_i16x8(r6, simde_vld1q_s16(test_vec[i].r6)); simde_test_arm_neon_assert_equal_i16x8(r7, simde_vld1q_s16(test_vec[i].r7)); + simde_test_arm_neon_assert_equal_i16x8(r8, simde_vld1q_s16(test_vec[i].r8)); } return 0; #else for (int i = 1 ; i < 8 ; i++) { simde_int8x8_t a = simde_test_arm_neon_random_i8x8(); + simde_int16x8_t r0 = simde_vshll_n_s8(a, 0); simde_int16x8_t r1 = simde_vshll_n_s8(a, 1); simde_int16x8_t r3 = simde_vshll_n_s8(a, 3); simde_int16x8_t r5 = simde_vshll_n_s8(a, 5); simde_int16x8_t r6 = simde_vshll_n_s8(a, 6); simde_int16x8_t r7 = simde_vshll_n_s8(a, 7); + simde_int16x8_t r8 = simde_vshll_n_s8(a, 8); simde_test_arm_neon_write_i8x8(2, a, SIMDE_TEST_VEC_POS_FIRST); + simde_test_arm_neon_write_i16x8(2, r0, SIMDE_TEST_VEC_POS_MIDDLE); simde_test_arm_neon_write_i16x8(2, r1, SIMDE_TEST_VEC_POS_MIDDLE); simde_test_arm_neon_write_i16x8(2, r3, SIMDE_TEST_VEC_POS_MIDDLE); simde_test_arm_neon_write_i16x8(2, r5, SIMDE_TEST_VEC_POS_MIDDLE); simde_test_arm_neon_write_i16x8(2, r6, SIMDE_TEST_VEC_POS_MIDDLE); - simde_test_arm_neon_write_i16x8(2, r7, SIMDE_TEST_VEC_POS_LAST); + simde_test_arm_neon_write_i16x8(2, r7, SIMDE_TEST_VEC_POS_MIDDLE); + simde_test_arm_neon_write_i16x8(2, r8, SIMDE_TEST_VEC_POS_LAST); } return 1; #endif @@ -100,87 +124,111 @@ test_simde_vshll_n_s16 (SIMDE_MUNIT_TEST_ARGS) { #if 1 static const struct { int16_t a[4]; + int32_t r0[4]; int32_t r3[4]; int32_t r6[4]; int32_t r10[4]; int32_t r13[4]; int32_t r15[4]; + int32_t r16[4]; } test_vec[] = { { { -INT16_C( 16425), -INT16_C( 17625), INT16_C( 19833), -INT16_C( 29566) }, + { -INT32_C( 16425), -INT32_C( 17625), INT32_C( 19833), -INT32_C( 29566) }, { -INT32_C( 131400), -INT32_C( 141000), INT32_C( 158664), -INT32_C( 236528) }, { -INT32_C( 1051200), -INT32_C( 1128000), INT32_C( 1269312), -INT32_C( 1892224) }, { -INT32_C( 16819200), -INT32_C( 18048000), INT32_C( 20308992), -INT32_C( 30275584) }, { -INT32_C( 134553600), -INT32_C( 144384000), INT32_C( 162471936), -INT32_C( 242204672) }, - { -INT32_C( 538214400), -INT32_C( 577536000), INT32_C( 649887744), -INT32_C( 968818688) } }, + { -INT32_C( 538214400), -INT32_C( 577536000), INT32_C( 649887744), -INT32_C( 968818688) }, + { -INT32_C( 1076428800), -INT32_C( 1155072000), INT32_C( 1299775488), -INT32_C( 1937637376) } }, { { -INT16_C( 23356), INT16_C( 16332), -INT16_C( 29218), INT16_C( 9163) }, + { -INT32_C( 23356), INT32_C( 16332), -INT32_C( 29218), INT32_C( 9163) }, { -INT32_C( 186848), INT32_C( 130656), -INT32_C( 233744), INT32_C( 73304) }, { -INT32_C( 1494784), INT32_C( 1045248), -INT32_C( 1869952), INT32_C( 586432) }, { -INT32_C( 23916544), INT32_C( 16723968), -INT32_C( 29919232), INT32_C( 9382912) }, { -INT32_C( 191332352), INT32_C( 133791744), -INT32_C( 239353856), INT32_C( 75063296) }, - { -INT32_C( 765329408), INT32_C( 535166976), -INT32_C( 957415424), INT32_C( 300253184) } }, + { -INT32_C( 765329408), INT32_C( 535166976), -INT32_C( 957415424), INT32_C( 300253184) }, + { -INT32_C( 1530658816), INT32_C( 1070333952), -INT32_C( 1914830848), INT32_C( 600506368) } }, { { INT16_C( 10258), INT16_C( 6440), -INT16_C( 19281), INT16_C( 26681) }, + { INT32_C( 10258), INT32_C( 6440), -INT32_C( 19281), INT32_C( 26681) }, { INT32_C( 82064), INT32_C( 51520), -INT32_C( 154248), INT32_C( 213448) }, { INT32_C( 656512), INT32_C( 412160), -INT32_C( 1233984), INT32_C( 1707584) }, { INT32_C( 10504192), INT32_C( 6594560), -INT32_C( 19743744), INT32_C( 27321344) }, { INT32_C( 84033536), INT32_C( 52756480), -INT32_C( 157949952), INT32_C( 218570752) }, - { INT32_C( 336134144), INT32_C( 211025920), -INT32_C( 631799808), INT32_C( 874283008) } }, + { INT32_C( 336134144), INT32_C( 211025920), -INT32_C( 631799808), INT32_C( 874283008) }, + { INT32_C( 672268288), INT32_C( 422051840), -INT32_C( 1263599616), INT32_C( 1748566016) } }, { { -INT16_C( 7477), -INT16_C( 22652), -INT16_C( 10993), -INT16_C( 6485) }, + { -INT32_C( 7477), -INT32_C( 22652), -INT32_C( 10993), -INT32_C( 6485) }, { -INT32_C( 59816), -INT32_C( 181216), -INT32_C( 87944), -INT32_C( 51880) }, { -INT32_C( 478528), -INT32_C( 1449728), -INT32_C( 703552), -INT32_C( 415040) }, { -INT32_C( 7656448), -INT32_C( 23195648), -INT32_C( 11256832), -INT32_C( 6640640) }, { -INT32_C( 61251584), -INT32_C( 185565184), -INT32_C( 90054656), -INT32_C( 53125120) }, - { -INT32_C( 245006336), -INT32_C( 742260736), -INT32_C( 360218624), -INT32_C( 212500480) } }, + { -INT32_C( 245006336), -INT32_C( 742260736), -INT32_C( 360218624), -INT32_C( 212500480) }, + { -INT32_C( 490012672), -INT32_C( 1484521472), -INT32_C( 720437248), -INT32_C( 425000960) } }, { { -INT16_C( 11628), INT16_C( 3489), INT16_C( 8991), -INT16_C( 7270) }, + { -INT32_C( 11628), INT32_C( 3489), INT32_C( 8991), -INT32_C( 7270) }, { -INT32_C( 93024), INT32_C( 27912), INT32_C( 71928), -INT32_C( 58160) }, { -INT32_C( 744192), INT32_C( 223296), INT32_C( 575424), -INT32_C( 465280) }, { -INT32_C( 11907072), INT32_C( 3572736), INT32_C( 9206784), -INT32_C( 7444480) }, { -INT32_C( 95256576), INT32_C( 28581888), INT32_C( 73654272), -INT32_C( 59555840) }, - { -INT32_C( 381026304), INT32_C( 114327552), INT32_C( 294617088), -INT32_C( 238223360) } }, + { -INT32_C( 381026304), INT32_C( 114327552), INT32_C( 294617088), -INT32_C( 238223360) }, + { -INT32_C( 762052608), INT32_C( 228655104), INT32_C( 589234176), -INT32_C( 476446720) } }, { { INT16_C( 26311), -INT16_C( 23006), -INT16_C( 4621), INT16_C( 1481) }, + { INT32_C( 26311), -INT32_C( 23006), -INT32_C( 4621), INT32_C( 1481) }, { INT32_C( 210488), -INT32_C( 184048), -INT32_C( 36968), INT32_C( 11848) }, { INT32_C( 1683904), -INT32_C( 1472384), -INT32_C( 295744), INT32_C( 94784) }, { INT32_C( 26942464), -INT32_C( 23558144), -INT32_C( 4731904), INT32_C( 1516544) }, { INT32_C( 215539712), -INT32_C( 188465152), -INT32_C( 37855232), INT32_C( 12132352) }, - { INT32_C( 862158848), -INT32_C( 753860608), -INT32_C( 151420928), INT32_C( 48529408) } }, + { INT32_C( 862158848), -INT32_C( 753860608), -INT32_C( 151420928), INT32_C( 48529408) }, + { INT32_C( 1724317696), -INT32_C( 1507721216), -INT32_C( 302841856), INT32_C( 97058816) } }, { { -INT16_C( 3819), -INT16_C( 15073), INT16_C( 22694), INT16_C( 28973) }, + { -INT32_C( 3819), -INT32_C( 15073), INT32_C( 22694), INT32_C( 28973) }, { -INT32_C( 30552), -INT32_C( 120584), INT32_C( 181552), INT32_C( 231784) }, { -INT32_C( 244416), -INT32_C( 964672), INT32_C( 1452416), INT32_C( 1854272) }, { -INT32_C( 3910656), -INT32_C( 15434752), INT32_C( 23238656), INT32_C( 29668352) }, { -INT32_C( 31285248), -INT32_C( 123478016), INT32_C( 185909248), INT32_C( 237346816) }, - { -INT32_C( 125140992), -INT32_C( 493912064), INT32_C( 743636992), INT32_C( 949387264) } }, + { -INT32_C( 125140992), -INT32_C( 493912064), INT32_C( 743636992), INT32_C( 949387264) }, + { -INT32_C( 250281984), -INT32_C( 987824128), INT32_C( 1487273984), INT32_C( 1898774528) } }, }; for (size_t i = 1 ; i < (sizeof(test_vec) / sizeof(test_vec[0])) ; i++) { simde_int16x4_t a = simde_vld1_s16(test_vec[i].a); + simde_int32x4_t r0 = simde_vshll_n_s16(a, 0); simde_int32x4_t r3 = simde_vshll_n_s16(a, 3); simde_int32x4_t r6 = simde_vshll_n_s16(a, 6); simde_int32x4_t r10 = simde_vshll_n_s16(a, 10); simde_int32x4_t r13 = simde_vshll_n_s16(a, 13); simde_int32x4_t r15 = simde_vshll_n_s16(a, 15); + simde_int32x4_t r16 = simde_vshll_n_s16(a, 16); + simde_test_arm_neon_assert_equal_i32x4(r0, simde_vld1q_s32(test_vec[i].r0)); simde_test_arm_neon_assert_equal_i32x4(r3, simde_vld1q_s32(test_vec[i].r3)); simde_test_arm_neon_assert_equal_i32x4(r6, simde_vld1q_s32(test_vec[i].r6)); simde_test_arm_neon_assert_equal_i32x4(r10, simde_vld1q_s32(test_vec[i].r10)); simde_test_arm_neon_assert_equal_i32x4(r13, simde_vld1q_s32(test_vec[i].r13)); simde_test_arm_neon_assert_equal_i32x4(r15, simde_vld1q_s32(test_vec[i].r15)); + simde_test_arm_neon_assert_equal_i32x4(r16, simde_vld1q_s32(test_vec[i].r16)); } return 0; #else for (int i = 1 ; i < 8 ; i++) { simde_int16x4_t a = simde_test_arm_neon_random_i16x4(); + simde_int32x4_t r0 = simde_vshll_n_s16(a, 0); simde_int32x4_t r3 = simde_vshll_n_s16(a, 3); simde_int32x4_t r6 = simde_vshll_n_s16(a, 6); simde_int32x4_t r10 = simde_vshll_n_s16(a, 10); simde_int32x4_t r13 = simde_vshll_n_s16(a, 13); simde_int32x4_t r15 = simde_vshll_n_s16(a, 15); + simde_int32x4_t r16 = simde_vshll_n_s16(a, 16); simde_test_arm_neon_write_i16x4(2, a, SIMDE_TEST_VEC_POS_FIRST); + simde_test_arm_neon_write_i32x4(2, r0, SIMDE_TEST_VEC_POS_MIDDLE); simde_test_arm_neon_write_i32x4(2, r3, SIMDE_TEST_VEC_POS_MIDDLE); simde_test_arm_neon_write_i32x4(2, r6, SIMDE_TEST_VEC_POS_MIDDLE); simde_test_arm_neon_write_i32x4(2, r10, SIMDE_TEST_VEC_POS_MIDDLE); simde_test_arm_neon_write_i32x4(2, r13, SIMDE_TEST_VEC_POS_MIDDLE); - simde_test_arm_neon_write_i32x4(2, r15, SIMDE_TEST_VEC_POS_LAST); + simde_test_arm_neon_write_i32x4(2, r15, SIMDE_TEST_VEC_POS_MIDDLE); + simde_test_arm_neon_write_i32x4(2, r16, SIMDE_TEST_VEC_POS_LAST); } return 1; #endif @@ -191,93 +239,119 @@ test_simde_vshll_n_s32 (SIMDE_MUNIT_TEST_ARGS) { #if 1 static const struct { int32_t a[2]; + int64_t r0[2]; int64_t r6[2]; int64_t r13[2]; int64_t r19[2]; int64_t r26[2]; int64_t r31[2]; + int64_t r32[2]; } test_vec[] = { { { INT32_C( 950429293), -INT32_C( 661372014) }, + { INT64_C( 950429293), -INT64_C( 661372014) }, { INT64_C( 60827474752), -INT64_C( 42327808896) }, { INT64_C( 7785916768256), -INT64_C( 5417959538688) }, { INT64_C( 498298673168384), -INT64_C( 346749410476032) }, { INT64_C( 63782230165553152), -INT64_C( 44383924540932096) }, - { INT64_C( 2041031365297700864), -INT64_C( 1420285585309827072) } }, + { INT64_C( 2041031365297700864), -INT64_C( 1420285585309827072) }, + { INT64_C( 4082062730595401728), -INT64_C( 2840571170619654144) } }, { { INT32_C( 1589323003), INT32_C( 86315474) }, + { INT64_C( 1589323003), INT64_C( 86315474) }, { INT64_C( 101716672192), INT64_C( 5524190336) }, { INT64_C( 13019734040576), INT64_C( 707096363008) }, { INT64_C( 833262978596864), INT64_C( 45254167232512) }, { INT64_C( 106657661260398592), INT64_C( 5792533405761536) }, - { INT64_C( 3413045160332754944), INT64_C( 185361068984369152) } }, + { INT64_C( 3413045160332754944), INT64_C( 185361068984369152) }, + { INT64_C( 6826090320665509888), INT64_C( 370722137968738304) } }, { { INT32_C( 855451097), -INT32_C( 1981432844) }, + { INT64_C( 855451097), -INT64_C( 1981432844) }, { INT64_C( 54748870208), -INT64_C( 126811702016) }, { INT64_C( 7007855386624), -INT64_C( 16231897858048) }, { INT64_C( 448502744743936), -INT64_C( 1038841462915072) }, { INT64_C( 57408351327223808), -INT64_C( 132971707253129216) }, - { INT64_C( 1837067242471161856), -INT64_C( 4255094632100134912) } }, + { INT64_C( 1837067242471161856), -INT64_C( 4255094632100134912) }, + { INT64_C( 3674134484942323712), -INT64_C( 8510189264200269824) } }, { { INT32_C( 478615849), INT32_C( 217270687) }, + { INT64_C( 478615849), INT64_C( 217270687) }, { INT64_C( 30631414336), INT64_C( 13905323968) }, { INT64_C( 3920821035008), INT64_C( 1779881467904) }, { INT64_C( 250932546240512), INT64_C( 113912413945856) }, { INT64_C( 32119365918785536), INT64_C( 14580788985069568) }, - { INT64_C( 1027819709401137152), INT64_C( 466585247522226176) } }, + { INT64_C( 1027819709401137152), INT64_C( 466585247522226176) }, + { INT64_C( 2055639418802274304), INT64_C( 933170495044452352) } }, { { INT32_C( 1111857584), -INT32_C( 669263395) }, + { INT64_C( 1111857584), -INT64_C( 669263395) }, { INT64_C( 71158885376), -INT64_C( 42832857280) }, { INT64_C( 9108337328128), -INT64_C( 5482605731840) }, { INT64_C( 582933589000192), -INT64_C( 350886766837760) }, { INT64_C( 74615499392024576), -INT64_C( 44913506155233280) }, - { INT64_C( 2387695980544786432), -INT64_C( 1437232196967464960) } }, + { INT64_C( 2387695980544786432), -INT64_C( 1437232196967464960) }, + { INT64_C( 4775391961089572864), -INT64_C( 2874464393934929920) } }, { { -INT32_C( 818489603), -INT32_C( 1043047448) }, + { -INT64_C( 818489603), -INT64_C( 1043047448) }, { -INT64_C( 52383334592), -INT64_C( 66755036672) }, { -INT64_C( 6705066827776), -INT64_C( 8544644694016) }, { -INT64_C( 429124276977664), -INT64_C( 546857260417024) }, { -INT64_C( 54927907453140992), -INT64_C( 69997729333379072) }, - { -INT64_C( 1757693038500511744), -INT64_C( 2239927338668130304) } }, + { -INT64_C( 1757693038500511744), -INT64_C( 2239927338668130304) }, + { -INT64_C( 3515386077001023488), -INT64_C( 4479854677336260608) } }, { { INT32_C( 1978913152), -INT32_C( 1224812403) }, + { INT64_C( 1978913152), -INT64_C( 1224812403) }, { INT64_C( 126650441728), -INT64_C( 78387993792) }, { INT64_C( 16211256541184), -INT64_C( 10033663205376) }, { INT64_C( 1037520418635776), -INT64_C( 642154445144064) }, { INT64_C( 132802613585379328), -INT64_C( 82195768978440192) }, - { INT64_C( 4249683634732138496), -INT64_C( 2630264607310086144) } }, + { INT64_C( 4249683634732138496), -INT64_C( 2630264607310086144) }, + { INT64_C( 8499367269464276992), -INT64_C( 5260529214620172288) } }, { { -INT32_C( 1865251343), INT32_C( 2141046223) }, + { -INT64_C( 1865251343), INT64_C( 2141046223) }, { -INT64_C( 119376085952), INT64_C( 137026958272) }, { -INT64_C( 15280139001856), INT64_C( 17539450658816) }, { -INT64_C( 977928896118784), INT64_C( 1122524842164224) }, { -INT64_C( 125174898703204352), INT64_C( 143683179797020672) }, - { -INT64_C( 4005596758502539264), INT64_C( 4597861753504661504) } }, + { -INT64_C( 4005596758502539264), INT64_C( 4597861753504661504) }, + { -INT64_C( 8011193517005078528), INT64_C( 9195723507009323008) } }, }; for (size_t i = 0 ; i < (sizeof(test_vec) / sizeof(test_vec[0])) ; i++) { simde_int32x2_t a = simde_vld1_s32(test_vec[i].a); + simde_int64x2_t r0 = simde_vshll_n_s32(a, 0); simde_int64x2_t r6 = simde_vshll_n_s32(a, 6); simde_int64x2_t r13 = simde_vshll_n_s32(a, 13); simde_int64x2_t r19 = simde_vshll_n_s32(a, 19); simde_int64x2_t r26 = simde_vshll_n_s32(a, 26); simde_int64x2_t r31 = simde_vshll_n_s32(a, 31); + simde_int64x2_t r32 = simde_vshll_n_s32(a, 32); + simde_test_arm_neon_assert_equal_i64x2(r0, simde_vld1q_s64(test_vec[i].r0)); simde_test_arm_neon_assert_equal_i64x2(r6, simde_vld1q_s64(test_vec[i].r6)); simde_test_arm_neon_assert_equal_i64x2(r13, simde_vld1q_s64(test_vec[i].r13)); simde_test_arm_neon_assert_equal_i64x2(r19, simde_vld1q_s64(test_vec[i].r19)); simde_test_arm_neon_assert_equal_i64x2(r26, simde_vld1q_s64(test_vec[i].r26)); simde_test_arm_neon_assert_equal_i64x2(r31, simde_vld1q_s64(test_vec[i].r31)); + simde_test_arm_neon_assert_equal_i64x2(r32, simde_vld1q_s64(test_vec[i].r32)); } return 0; #else for (int i = 0 ; i < 8 ; i++) { simde_int32x2_t a = simde_test_arm_neon_random_i32x2(); + simde_int64x2_t r0 = simde_vshll_n_s32(a, 0); simde_int64x2_t r6 = simde_vshll_n_s32(a, 6); simde_int64x2_t r13 = simde_vshll_n_s32(a, 13); simde_int64x2_t r19 = simde_vshll_n_s32(a, 19); simde_int64x2_t r26 = simde_vshll_n_s32(a, 26); simde_int64x2_t r31 = simde_vshll_n_s32(a, 31); + simde_int64x2_t r32 = simde_vshll_n_s32(a, 32); simde_test_arm_neon_write_i32x2(2, a, SIMDE_TEST_VEC_POS_FIRST); + simde_test_arm_neon_write_i64x2(2, r0, SIMDE_TEST_VEC_POS_MIDDLE); simde_test_arm_neon_write_i64x2(2, r6, SIMDE_TEST_VEC_POS_MIDDLE); simde_test_arm_neon_write_i64x2(2, r13, SIMDE_TEST_VEC_POS_MIDDLE); simde_test_arm_neon_write_i64x2(2, r19, SIMDE_TEST_VEC_POS_MIDDLE); simde_test_arm_neon_write_i64x2(2, r26, SIMDE_TEST_VEC_POS_MIDDLE); - simde_test_arm_neon_write_i64x2(2, r31, SIMDE_TEST_VEC_POS_LAST); + simde_test_arm_neon_write_i64x2(2, r31, SIMDE_TEST_VEC_POS_MIDDLE); + simde_test_arm_neon_write_i64x2(2, r32, SIMDE_TEST_VEC_POS_LAST); } return 1; #endif @@ -288,87 +362,111 @@ test_simde_vshll_n_u8 (SIMDE_MUNIT_TEST_ARGS) { #if 1 static const struct { uint8_t a[8]; + uint16_t r0[8]; uint16_t r1[8]; uint16_t r3[8]; uint16_t r5[8]; uint16_t r6[8]; uint16_t r7[8]; + uint16_t r8[8]; } test_vec[] = { { { UINT8_C(246), UINT8_C(145), UINT8_C(126), UINT8_C(115), UINT8_C(134), UINT8_C( 86), UINT8_C(120), UINT8_C(171) }, + { UINT16_C( 246), UINT16_C( 145), UINT16_C( 126), UINT16_C( 115), UINT16_C( 134), UINT16_C( 86), UINT16_C( 120), UINT16_C( 171) }, { UINT16_C( 492), UINT16_C( 290), UINT16_C( 252), UINT16_C( 230), UINT16_C( 268), UINT16_C( 172), UINT16_C( 240), UINT16_C( 342) }, { UINT16_C( 1968), UINT16_C( 1160), UINT16_C( 1008), UINT16_C( 920), UINT16_C( 1072), UINT16_C( 688), UINT16_C( 960), UINT16_C( 1368) }, { UINT16_C( 7872), UINT16_C( 4640), UINT16_C( 4032), UINT16_C( 3680), UINT16_C( 4288), UINT16_C( 2752), UINT16_C( 3840), UINT16_C( 5472) }, { UINT16_C(15744), UINT16_C( 9280), UINT16_C( 8064), UINT16_C( 7360), UINT16_C( 8576), UINT16_C( 5504), UINT16_C( 7680), UINT16_C(10944) }, - { UINT16_C(31488), UINT16_C(18560), UINT16_C(16128), UINT16_C(14720), UINT16_C(17152), UINT16_C(11008), UINT16_C(15360), UINT16_C(21888) } }, + { UINT16_C(31488), UINT16_C(18560), UINT16_C(16128), UINT16_C(14720), UINT16_C(17152), UINT16_C(11008), UINT16_C(15360), UINT16_C(21888) }, + { UINT16_C(62976), UINT16_C(37120), UINT16_C(32256), UINT16_C(29440), UINT16_C(34304), UINT16_C(22016), UINT16_C(30720), UINT16_C(43776) } }, { { UINT8_C(219), UINT8_C( 52), UINT8_C(252), UINT8_C( 39), UINT8_C(171), UINT8_C(183), UINT8_C( 80), UINT8_C(207) }, + { UINT16_C( 219), UINT16_C( 52), UINT16_C( 252), UINT16_C( 39), UINT16_C( 171), UINT16_C( 183), UINT16_C( 80), UINT16_C( 207) }, { UINT16_C( 438), UINT16_C( 104), UINT16_C( 504), UINT16_C( 78), UINT16_C( 342), UINT16_C( 366), UINT16_C( 160), UINT16_C( 414) }, { UINT16_C( 1752), UINT16_C( 416), UINT16_C( 2016), UINT16_C( 312), UINT16_C( 1368), UINT16_C( 1464), UINT16_C( 640), UINT16_C( 1656) }, { UINT16_C( 7008), UINT16_C( 1664), UINT16_C( 8064), UINT16_C( 1248), UINT16_C( 5472), UINT16_C( 5856), UINT16_C( 2560), UINT16_C( 6624) }, { UINT16_C(14016), UINT16_C( 3328), UINT16_C(16128), UINT16_C( 2496), UINT16_C(10944), UINT16_C(11712), UINT16_C( 5120), UINT16_C(13248) }, - { UINT16_C(28032), UINT16_C( 6656), UINT16_C(32256), UINT16_C( 4992), UINT16_C(21888), UINT16_C(23424), UINT16_C(10240), UINT16_C(26496) } }, + { UINT16_C(28032), UINT16_C( 6656), UINT16_C(32256), UINT16_C( 4992), UINT16_C(21888), UINT16_C(23424), UINT16_C(10240), UINT16_C(26496) }, + { UINT16_C(56064), UINT16_C(13312), UINT16_C(64512), UINT16_C( 9984), UINT16_C(43776), UINT16_C(46848), UINT16_C(20480), UINT16_C(52992) } }, { { UINT8_C(175), UINT8_C(179), UINT8_C( 48), UINT8_C( 9), UINT8_C(110), UINT8_C(240), UINT8_C(197), UINT8_C(131) }, + { UINT16_C( 175), UINT16_C( 179), UINT16_C( 48), UINT16_C( 9), UINT16_C( 110), UINT16_C( 240), UINT16_C( 197), UINT16_C( 131) }, { UINT16_C( 350), UINT16_C( 358), UINT16_C( 96), UINT16_C( 18), UINT16_C( 220), UINT16_C( 480), UINT16_C( 394), UINT16_C( 262) }, { UINT16_C( 1400), UINT16_C( 1432), UINT16_C( 384), UINT16_C( 72), UINT16_C( 880), UINT16_C( 1920), UINT16_C( 1576), UINT16_C( 1048) }, { UINT16_C( 5600), UINT16_C( 5728), UINT16_C( 1536), UINT16_C( 288), UINT16_C( 3520), UINT16_C( 7680), UINT16_C( 6304), UINT16_C( 4192) }, { UINT16_C(11200), UINT16_C(11456), UINT16_C( 3072), UINT16_C( 576), UINT16_C( 7040), UINT16_C(15360), UINT16_C(12608), UINT16_C( 8384) }, - { UINT16_C(22400), UINT16_C(22912), UINT16_C( 6144), UINT16_C( 1152), UINT16_C(14080), UINT16_C(30720), UINT16_C(25216), UINT16_C(16768) } }, + { UINT16_C(22400), UINT16_C(22912), UINT16_C( 6144), UINT16_C( 1152), UINT16_C(14080), UINT16_C(30720), UINT16_C(25216), UINT16_C(16768) }, + { UINT16_C(44800), UINT16_C(45824), UINT16_C(12288), UINT16_C( 2304), UINT16_C(28160), UINT16_C(61440), UINT16_C(50432), UINT16_C(33536) } }, { { UINT8_C( 10), UINT8_C(140), UINT8_C(195), UINT8_C( 96), UINT8_C(201), UINT8_C(111), UINT8_C(166), UINT8_C(191) }, + { UINT16_C( 10), UINT16_C( 140), UINT16_C( 195), UINT16_C( 96), UINT16_C( 201), UINT16_C( 111), UINT16_C( 166), UINT16_C( 191) }, { UINT16_C( 20), UINT16_C( 280), UINT16_C( 390), UINT16_C( 192), UINT16_C( 402), UINT16_C( 222), UINT16_C( 332), UINT16_C( 382) }, { UINT16_C( 80), UINT16_C( 1120), UINT16_C( 1560), UINT16_C( 768), UINT16_C( 1608), UINT16_C( 888), UINT16_C( 1328), UINT16_C( 1528) }, { UINT16_C( 320), UINT16_C( 4480), UINT16_C( 6240), UINT16_C( 3072), UINT16_C( 6432), UINT16_C( 3552), UINT16_C( 5312), UINT16_C( 6112) }, { UINT16_C( 640), UINT16_C( 8960), UINT16_C(12480), UINT16_C( 6144), UINT16_C(12864), UINT16_C( 7104), UINT16_C(10624), UINT16_C(12224) }, - { UINT16_C( 1280), UINT16_C(17920), UINT16_C(24960), UINT16_C(12288), UINT16_C(25728), UINT16_C(14208), UINT16_C(21248), UINT16_C(24448) } }, + { UINT16_C( 1280), UINT16_C(17920), UINT16_C(24960), UINT16_C(12288), UINT16_C(25728), UINT16_C(14208), UINT16_C(21248), UINT16_C(24448) }, + { UINT16_C( 2560), UINT16_C(35840), UINT16_C(49920), UINT16_C(24576), UINT16_C(51456), UINT16_C(28416), UINT16_C(42496), UINT16_C(48896) } }, { { UINT8_C( 0), UINT8_C( 36), UINT8_C( 51), UINT8_C(134), UINT8_C(123), UINT8_C(171), UINT8_C( 50), UINT8_C( 86) }, + { UINT16_C( 0), UINT16_C( 36), UINT16_C( 51), UINT16_C( 134), UINT16_C( 123), UINT16_C( 171), UINT16_C( 50), UINT16_C( 86) }, { UINT16_C( 0), UINT16_C( 72), UINT16_C( 102), UINT16_C( 268), UINT16_C( 246), UINT16_C( 342), UINT16_C( 100), UINT16_C( 172) }, { UINT16_C( 0), UINT16_C( 288), UINT16_C( 408), UINT16_C( 1072), UINT16_C( 984), UINT16_C( 1368), UINT16_C( 400), UINT16_C( 688) }, { UINT16_C( 0), UINT16_C( 1152), UINT16_C( 1632), UINT16_C( 4288), UINT16_C( 3936), UINT16_C( 5472), UINT16_C( 1600), UINT16_C( 2752) }, { UINT16_C( 0), UINT16_C( 2304), UINT16_C( 3264), UINT16_C( 8576), UINT16_C( 7872), UINT16_C(10944), UINT16_C( 3200), UINT16_C( 5504) }, - { UINT16_C( 0), UINT16_C( 4608), UINT16_C( 6528), UINT16_C(17152), UINT16_C(15744), UINT16_C(21888), UINT16_C( 6400), UINT16_C(11008) } }, + { UINT16_C( 0), UINT16_C( 4608), UINT16_C( 6528), UINT16_C(17152), UINT16_C(15744), UINT16_C(21888), UINT16_C( 6400), UINT16_C(11008) }, + { UINT16_C( 0), UINT16_C( 9216), UINT16_C(13056), UINT16_C(34304), UINT16_C(31488), UINT16_C(43776), UINT16_C(12800), UINT16_C(22016) } }, { { UINT8_C(223), UINT8_C( 46), UINT8_C(125), UINT8_C(139), UINT8_C(229), UINT8_C(205), UINT8_C( 90), UINT8_C(149) }, + { UINT16_C( 223), UINT16_C( 46), UINT16_C( 125), UINT16_C( 139), UINT16_C( 229), UINT16_C( 205), UINT16_C( 90), UINT16_C( 149) }, { UINT16_C( 446), UINT16_C( 92), UINT16_C( 250), UINT16_C( 278), UINT16_C( 458), UINT16_C( 410), UINT16_C( 180), UINT16_C( 298) }, { UINT16_C( 1784), UINT16_C( 368), UINT16_C( 1000), UINT16_C( 1112), UINT16_C( 1832), UINT16_C( 1640), UINT16_C( 720), UINT16_C( 1192) }, { UINT16_C( 7136), UINT16_C( 1472), UINT16_C( 4000), UINT16_C( 4448), UINT16_C( 7328), UINT16_C( 6560), UINT16_C( 2880), UINT16_C( 4768) }, { UINT16_C(14272), UINT16_C( 2944), UINT16_C( 8000), UINT16_C( 8896), UINT16_C(14656), UINT16_C(13120), UINT16_C( 5760), UINT16_C( 9536) }, - { UINT16_C(28544), UINT16_C( 5888), UINT16_C(16000), UINT16_C(17792), UINT16_C(29312), UINT16_C(26240), UINT16_C(11520), UINT16_C(19072) } }, + { UINT16_C(28544), UINT16_C( 5888), UINT16_C(16000), UINT16_C(17792), UINT16_C(29312), UINT16_C(26240), UINT16_C(11520), UINT16_C(19072) }, + { UINT16_C(57088), UINT16_C(11776), UINT16_C(32000), UINT16_C(35584), UINT16_C(58624), UINT16_C(52480), UINT16_C(23040), UINT16_C(38144) } }, { { UINT8_C(128), UINT8_C(138), UINT8_C(158), UINT8_C(239), UINT8_C(122), UINT8_C( 99), UINT8_C(114), UINT8_C(133) }, + { UINT16_C( 128), UINT16_C( 138), UINT16_C( 158), UINT16_C( 239), UINT16_C( 122), UINT16_C( 99), UINT16_C( 114), UINT16_C( 133) }, { UINT16_C( 256), UINT16_C( 276), UINT16_C( 316), UINT16_C( 478), UINT16_C( 244), UINT16_C( 198), UINT16_C( 228), UINT16_C( 266) }, { UINT16_C( 1024), UINT16_C( 1104), UINT16_C( 1264), UINT16_C( 1912), UINT16_C( 976), UINT16_C( 792), UINT16_C( 912), UINT16_C( 1064) }, { UINT16_C( 4096), UINT16_C( 4416), UINT16_C( 5056), UINT16_C( 7648), UINT16_C( 3904), UINT16_C( 3168), UINT16_C( 3648), UINT16_C( 4256) }, { UINT16_C( 8192), UINT16_C( 8832), UINT16_C(10112), UINT16_C(15296), UINT16_C( 7808), UINT16_C( 6336), UINT16_C( 7296), UINT16_C( 8512) }, - { UINT16_C(16384), UINT16_C(17664), UINT16_C(20224), UINT16_C(30592), UINT16_C(15616), UINT16_C(12672), UINT16_C(14592), UINT16_C(17024) } }, + { UINT16_C(16384), UINT16_C(17664), UINT16_C(20224), UINT16_C(30592), UINT16_C(15616), UINT16_C(12672), UINT16_C(14592), UINT16_C(17024) }, + { UINT16_C(32768), UINT16_C(35328), UINT16_C(40448), UINT16_C(61184), UINT16_C(31232), UINT16_C(25344), UINT16_C(29184), UINT16_C(34048) } }, }; for (size_t i = 1 ; i < (sizeof(test_vec) / sizeof(test_vec[0])) ; i++) { simde_uint8x8_t a = simde_vld1_u8(test_vec[i].a); + simde_uint16x8_t r0 = simde_vshll_n_u8(a, 0); simde_uint16x8_t r1 = simde_vshll_n_u8(a, 1); simde_uint16x8_t r3 = simde_vshll_n_u8(a, 3); simde_uint16x8_t r5 = simde_vshll_n_u8(a, 5); simde_uint16x8_t r6 = simde_vshll_n_u8(a, 6); simde_uint16x8_t r7 = simde_vshll_n_u8(a, 7); + simde_uint16x8_t r8 = simde_vshll_n_u8(a, 8); + simde_test_arm_neon_assert_equal_u16x8(r0, simde_vld1q_u16(test_vec[i].r0)); simde_test_arm_neon_assert_equal_u16x8(r1, simde_vld1q_u16(test_vec[i].r1)); simde_test_arm_neon_assert_equal_u16x8(r3, simde_vld1q_u16(test_vec[i].r3)); simde_test_arm_neon_assert_equal_u16x8(r5, simde_vld1q_u16(test_vec[i].r5)); simde_test_arm_neon_assert_equal_u16x8(r6, simde_vld1q_u16(test_vec[i].r6)); simde_test_arm_neon_assert_equal_u16x8(r7, simde_vld1q_u16(test_vec[i].r7)); + simde_test_arm_neon_assert_equal_u16x8(r8, simde_vld1q_u16(test_vec[i].r8)); } return 0; #else for (int i = 1 ; i < 8 ; i++) { simde_uint8x8_t a = simde_test_arm_neon_random_u8x8(); + simde_uint16x8_t r0 = simde_vshll_n_u8(a, 0); simde_uint16x8_t r1 = simde_vshll_n_u8(a, 1); simde_uint16x8_t r3 = simde_vshll_n_u8(a, 3); simde_uint16x8_t r5 = simde_vshll_n_u8(a, 5); simde_uint16x8_t r6 = simde_vshll_n_u8(a, 6); simde_uint16x8_t r7 = simde_vshll_n_u8(a, 7); + simde_uint16x8_t r8 = simde_vshll_n_u8(a, 8); simde_test_arm_neon_write_u8x8(2, a, SIMDE_TEST_VEC_POS_FIRST); + simde_test_arm_neon_write_u16x8(2, r0, SIMDE_TEST_VEC_POS_MIDDLE); simde_test_arm_neon_write_u16x8(2, r1, SIMDE_TEST_VEC_POS_MIDDLE); simde_test_arm_neon_write_u16x8(2, r3, SIMDE_TEST_VEC_POS_MIDDLE); simde_test_arm_neon_write_u16x8(2, r5, SIMDE_TEST_VEC_POS_MIDDLE); simde_test_arm_neon_write_u16x8(2, r6, SIMDE_TEST_VEC_POS_MIDDLE); - simde_test_arm_neon_write_u16x8(2, r7, SIMDE_TEST_VEC_POS_LAST); + simde_test_arm_neon_write_u16x8(2, r7, SIMDE_TEST_VEC_POS_MIDDLE); + simde_test_arm_neon_write_u16x8(2, r8, SIMDE_TEST_VEC_POS_LAST); } return 1; #endif @@ -379,87 +477,111 @@ test_simde_vshll_n_u16 (SIMDE_MUNIT_TEST_ARGS) { #if 1 static const struct { uint16_t a[4]; + uint32_t r0[4]; uint32_t r3[4]; uint32_t r6[4]; uint32_t r10[4]; uint32_t r13[4]; uint32_t r15[4]; + uint32_t r16[4]; } test_vec[] = { { { UINT16_C(28903), UINT16_C( 4536), UINT16_C(57309), UINT16_C(47082) }, + { UINT32_C( 28903), UINT32_C( 4536), UINT32_C( 57309), UINT32_C( 47082) }, { UINT32_C( 231224), UINT32_C( 36288), UINT32_C( 458472), UINT32_C( 376656) }, { UINT32_C( 1849792), UINT32_C( 290304), UINT32_C( 3667776), UINT32_C( 3013248) }, { UINT32_C( 29596672), UINT32_C( 4644864), UINT32_C( 58684416), UINT32_C( 48211968) }, { UINT32_C( 236773376), UINT32_C( 37158912), UINT32_C( 469475328), UINT32_C( 385695744) }, - { UINT32_C( 947093504), UINT32_C( 148635648), UINT32_C(1877901312), UINT32_C(1542782976) } }, + { UINT32_C( 947093504), UINT32_C( 148635648), UINT32_C(1877901312), UINT32_C(1542782976) }, + { UINT32_C(1894187008), UINT32_C( 297271296), UINT32_C(3755802624), UINT32_C(3085565952) } }, { { UINT16_C(20626), UINT16_C(43076), UINT16_C(52517), UINT16_C(52086) }, + { UINT32_C( 20626), UINT32_C( 43076), UINT32_C( 52517), UINT32_C( 52086) }, { UINT32_C( 165008), UINT32_C( 344608), UINT32_C( 420136), UINT32_C( 416688) }, { UINT32_C( 1320064), UINT32_C( 2756864), UINT32_C( 3361088), UINT32_C( 3333504) }, { UINT32_C( 21121024), UINT32_C( 44109824), UINT32_C( 53777408), UINT32_C( 53336064) }, { UINT32_C( 168968192), UINT32_C( 352878592), UINT32_C( 430219264), UINT32_C( 426688512) }, - { UINT32_C( 675872768), UINT32_C(1411514368), UINT32_C(1720877056), UINT32_C(1706754048) } }, + { UINT32_C( 675872768), UINT32_C(1411514368), UINT32_C(1720877056), UINT32_C(1706754048) }, + { UINT32_C(1351745536), UINT32_C(2823028736), UINT32_C(3441754112), UINT32_C(3413508096) } }, { { UINT16_C(31758), UINT16_C(51303), UINT16_C(54820), UINT16_C(59119) }, + { UINT32_C( 31758), UINT32_C( 51303), UINT32_C( 54820), UINT32_C( 59119) }, { UINT32_C( 254064), UINT32_C( 410424), UINT32_C( 438560), UINT32_C( 472952) }, { UINT32_C( 2032512), UINT32_C( 3283392), UINT32_C( 3508480), UINT32_C( 3783616) }, { UINT32_C( 32520192), UINT32_C( 52534272), UINT32_C( 56135680), UINT32_C( 60537856) }, { UINT32_C( 260161536), UINT32_C( 420274176), UINT32_C( 449085440), UINT32_C( 484302848) }, - { UINT32_C(1040646144), UINT32_C(1681096704), UINT32_C(1796341760), UINT32_C(1937211392) } }, + { UINT32_C(1040646144), UINT32_C(1681096704), UINT32_C(1796341760), UINT32_C(1937211392) }, + { UINT32_C(2081292288), UINT32_C(3362193408), UINT32_C(3592683520), UINT32_C(3874422784) } }, { { UINT16_C(10599), UINT16_C(45769), UINT16_C(46438), UINT16_C(19779) }, + { UINT32_C( 10599), UINT32_C( 45769), UINT32_C( 46438), UINT32_C( 19779) }, { UINT32_C( 84792), UINT32_C( 366152), UINT32_C( 371504), UINT32_C( 158232) }, { UINT32_C( 678336), UINT32_C( 2929216), UINT32_C( 2972032), UINT32_C( 1265856) }, { UINT32_C( 10853376), UINT32_C( 46867456), UINT32_C( 47552512), UINT32_C( 20253696) }, { UINT32_C( 86827008), UINT32_C( 374939648), UINT32_C( 380420096), UINT32_C( 162029568) }, - { UINT32_C( 347308032), UINT32_C(1499758592), UINT32_C(1521680384), UINT32_C( 648118272) } }, + { UINT32_C( 347308032), UINT32_C(1499758592), UINT32_C(1521680384), UINT32_C( 648118272) }, + { UINT32_C( 694616064), UINT32_C(2999517184), UINT32_C(3043360768), UINT32_C(1296236544) } }, { { UINT16_C(64294), UINT16_C( 863), UINT16_C(18906), UINT16_C(28091) }, + { UINT32_C( 64294), UINT32_C( 863), UINT32_C( 18906), UINT32_C( 28091) }, { UINT32_C( 514352), UINT32_C( 6904), UINT32_C( 151248), UINT32_C( 224728) }, { UINT32_C( 4114816), UINT32_C( 55232), UINT32_C( 1209984), UINT32_C( 1797824) }, { UINT32_C( 65837056), UINT32_C( 883712), UINT32_C( 19359744), UINT32_C( 28765184) }, { UINT32_C( 526696448), UINT32_C( 7069696), UINT32_C( 154877952), UINT32_C( 230121472) }, - { UINT32_C(2106785792), UINT32_C( 28278784), UINT32_C( 619511808), UINT32_C( 920485888) } }, + { UINT32_C(2106785792), UINT32_C( 28278784), UINT32_C( 619511808), UINT32_C( 920485888) }, + { UINT32_C(4213571584), UINT32_C( 56557568), UINT32_C(1239023616), UINT32_C(1840971776) } }, { { UINT16_C(65434), UINT16_C(48917), UINT16_C(35788), UINT16_C(55946) }, + { UINT32_C( 65434), UINT32_C( 48917), UINT32_C( 35788), UINT32_C( 55946) }, { UINT32_C( 523472), UINT32_C( 391336), UINT32_C( 286304), UINT32_C( 447568) }, { UINT32_C( 4187776), UINT32_C( 3130688), UINT32_C( 2290432), UINT32_C( 3580544) }, { UINT32_C( 67004416), UINT32_C( 50091008), UINT32_C( 36646912), UINT32_C( 57288704) }, { UINT32_C( 536035328), UINT32_C( 400728064), UINT32_C( 293175296), UINT32_C( 458309632) }, - { UINT32_C(2144141312), UINT32_C(1602912256), UINT32_C(1172701184), UINT32_C(1833238528) } }, + { UINT32_C(2144141312), UINT32_C(1602912256), UINT32_C(1172701184), UINT32_C(1833238528) }, + { UINT32_C(4288282624), UINT32_C(3205824512), UINT32_C(2345402368), UINT32_C(3666477056) } }, { { UINT16_C(61703), UINT16_C(11170), UINT16_C(37319), UINT16_C(11793) }, + { UINT32_C( 61703), UINT32_C( 11170), UINT32_C( 37319), UINT32_C( 11793) }, { UINT32_C( 493624), UINT32_C( 89360), UINT32_C( 298552), UINT32_C( 94344) }, { UINT32_C( 3948992), UINT32_C( 714880), UINT32_C( 2388416), UINT32_C( 754752) }, { UINT32_C( 63183872), UINT32_C( 11438080), UINT32_C( 38214656), UINT32_C( 12076032) }, { UINT32_C( 505470976), UINT32_C( 91504640), UINT32_C( 305717248), UINT32_C( 96608256) }, - { UINT32_C(2021883904), UINT32_C( 366018560), UINT32_C(1222868992), UINT32_C( 386433024) } }, + { UINT32_C(2021883904), UINT32_C( 366018560), UINT32_C(1222868992), UINT32_C( 386433024) }, + { UINT32_C(4043767808), UINT32_C( 732037120), UINT32_C(2445737984), UINT32_C( 772866048) } }, }; for (size_t i = 0 ; i < (sizeof(test_vec) / sizeof(test_vec[0])) ; i++) { simde_uint16x4_t a = simde_vld1_u16(test_vec[i].a); + simde_uint32x4_t r0 = simde_vshll_n_u16(a, 0); simde_uint32x4_t r3 = simde_vshll_n_u16(a, 3); simde_uint32x4_t r6 = simde_vshll_n_u16(a, 6); simde_uint32x4_t r10 = simde_vshll_n_u16(a, 10); simde_uint32x4_t r13 = simde_vshll_n_u16(a, 13); simde_uint32x4_t r15 = simde_vshll_n_u16(a, 15); + simde_uint32x4_t r16 = simde_vshll_n_u16(a, 16); + simde_test_arm_neon_assert_equal_u32x4(r0, simde_vld1q_u32(test_vec[i].r0)); simde_test_arm_neon_assert_equal_u32x4(r3, simde_vld1q_u32(test_vec[i].r3)); simde_test_arm_neon_assert_equal_u32x4(r6, simde_vld1q_u32(test_vec[i].r6)); simde_test_arm_neon_assert_equal_u32x4(r10, simde_vld1q_u32(test_vec[i].r10)); simde_test_arm_neon_assert_equal_u32x4(r13, simde_vld1q_u32(test_vec[i].r13)); simde_test_arm_neon_assert_equal_u32x4(r15, simde_vld1q_u32(test_vec[i].r15)); + simde_test_arm_neon_assert_equal_u32x4(r16, simde_vld1q_u32(test_vec[i].r16)); } return 0; #else for (int i = 1 ; i < 8 ; i++) { simde_uint16x4_t a = simde_test_arm_neon_random_u16x4(); + simde_uint32x4_t r0 = simde_vshll_n_u16(a, 0); simde_uint32x4_t r3 = simde_vshll_n_u16(a, 3); simde_uint32x4_t r6 = simde_vshll_n_u16(a, 6); simde_uint32x4_t r10 = simde_vshll_n_u16(a, 10); simde_uint32x4_t r13 = simde_vshll_n_u16(a, 13); simde_uint32x4_t r15 = simde_vshll_n_u16(a, 15); + simde_uint32x4_t r16 = simde_vshll_n_u16(a, 16); simde_test_arm_neon_write_u16x4(2, a, SIMDE_TEST_VEC_POS_FIRST); + simde_test_arm_neon_write_u32x4(2, r0, SIMDE_TEST_VEC_POS_MIDDLE); simde_test_arm_neon_write_u32x4(2, r3, SIMDE_TEST_VEC_POS_MIDDLE); simde_test_arm_neon_write_u32x4(2, r6, SIMDE_TEST_VEC_POS_MIDDLE); simde_test_arm_neon_write_u32x4(2, r10, SIMDE_TEST_VEC_POS_MIDDLE); simde_test_arm_neon_write_u32x4(2, r13, SIMDE_TEST_VEC_POS_MIDDLE); - simde_test_arm_neon_write_u32x4(2, r15, SIMDE_TEST_VEC_POS_LAST); + simde_test_arm_neon_write_u32x4(2, r15, SIMDE_TEST_VEC_POS_MIDDLE); + simde_test_arm_neon_write_u32x4(2, r16, SIMDE_TEST_VEC_POS_LAST); } return 1; #endif @@ -470,93 +592,119 @@ test_simde_vshll_n_u32 (SIMDE_MUNIT_TEST_ARGS) { #if 1 static const struct { uint32_t a[2]; + uint64_t r0[2]; uint64_t r6[2]; uint64_t r13[2]; uint64_t r19[2]; uint64_t r26[2]; uint64_t r31[2]; + uint64_t r32[2]; } test_vec[] = { { { UINT32_C(3167749647), UINT32_C(2453210766) }, + { UINT64_C( 3167749647), UINT64_C( 2453210766) }, { UINT64_C( 202735977408), UINT64_C( 157005489024) }, { UINT64_C( 25950205108224), UINT64_C( 20096702595072) }, { UINT64_C( 1660813126926336), UINT64_C( 1286188966084608) }, { UINT64_C( 212584080246571008), UINT64_C( 164632187658829824) }, - { UINT64_C( 6802690567890272256), UINT64_C( 5268230005082554368) } }, + { UINT64_C( 6802690567890272256), UINT64_C( 5268230005082554368) }, + { UINT64_C(13605381135780544512), UINT64_C(10536460010165108736) } }, { { UINT32_C( 335553320), UINT32_C(2727292564) }, + { UINT64_C( 335553320), UINT64_C( 2727292564) }, { UINT64_C( 21475412480), UINT64_C( 174546724096) }, { UINT64_C( 2748852797440), UINT64_C( 22341980684288) }, { UINT64_C( 175926579036160), UINT64_C( 1429886763794432) }, { UINT64_C( 22518602116628480), UINT64_C( 183025505765687296) }, - { UINT64_C( 720595267732111360), UINT64_C( 5856816184501993472) } }, + { UINT64_C( 720595267732111360), UINT64_C( 5856816184501993472) }, + { UINT64_C( 1441190535464222720), UINT64_C(11713632369003986944) } }, { { UINT32_C(1640172987), UINT32_C(3573820190) }, + { UINT64_C( 1640172987), UINT64_C( 3573820190) }, { UINT64_C( 104971071168), UINT64_C( 228724492160) }, { UINT64_C( 13436297109504), UINT64_C( 29276734996480) }, { UINT64_C( 859923015008256), UINT64_C( 1873711039774720) }, { UINT64_C( 110070145921056768), UINT64_C( 239835013091164160) }, - { UINT64_C( 3522244669473816576), UINT64_C( 7674720418917253120) } }, + { UINT64_C( 3522244669473816576), UINT64_C( 7674720418917253120) }, + { UINT64_C( 7044489338947633152), UINT64_C(15349440837834506240) } }, { { UINT32_C(1895753867), UINT32_C(2409471616) }, + { UINT64_C( 1895753867), UINT64_C( 2409471616) }, { UINT64_C( 121328247488), UINT64_C( 154206183424) }, { UINT64_C( 15530015678464), UINT64_C( 19738391478272) }, { UINT64_C( 993921003421696), UINT64_C( 1263257054609408) }, { UINT64_C( 127221888437977088), UINT64_C( 161696902990004224) }, - { UINT64_C( 4071100430015266816), UINT64_C( 5174300895680135168) } }, + { UINT64_C( 4071100430015266816), UINT64_C( 5174300895680135168) }, + { UINT64_C( 8142200860030533632), UINT64_C(10348601791360270336) } }, { { UINT32_C( 860581540), UINT32_C(2630190196) }, + { UINT64_C( 860581540), UINT64_C( 2630190196) }, { UINT64_C( 55077218560), UINT64_C( 168332172544) }, { UINT64_C( 7049883975680), UINT64_C( 21546518085632) }, { UINT64_C( 451192574443520), UINT64_C( 1378977157480448) }, { UINT64_C( 57752649528770560), UINT64_C( 176509076157497344) }, - { UINT64_C( 1848084784920657920), UINT64_C( 5648290437039915008) } }, + { UINT64_C( 1848084784920657920), UINT64_C( 5648290437039915008) }, + { UINT64_C( 3696169569841315840), UINT64_C(11296580874079830016) } }, { { UINT32_C(1018283432), UINT32_C(2950578419) }, + { UINT64_C( 1018283432), UINT64_C( 2950578419) }, { UINT64_C( 65170139648), UINT64_C( 188837018816) }, { UINT64_C( 8341777874944), UINT64_C( 24171138408448) }, { UINT64_C( 533873783996416), UINT64_C( 1546952858140672) }, { UINT64_C( 68335844351541248), UINT64_C( 198009965842006016) }, - { UINT64_C( 2186747019249319936), UINT64_C( 6336318906944192512) } }, + { UINT64_C( 2186747019249319936), UINT64_C( 6336318906944192512) }, + { UINT64_C( 4373494038498639872), UINT64_C(12672637813888385024) } }, { { UINT32_C(1796252237), UINT32_C(1497371853) }, + { UINT64_C( 1796252237), UINT64_C( 1497371853) }, { UINT64_C( 114960143168), UINT64_C( 95831798592) }, { UINT64_C( 14714898325504), UINT64_C( 12266470219776) }, { UINT64_C( 941753492832256), UINT64_C( 785054094065664) }, { UINT64_C( 120544447082528768), UINT64_C( 100486924040404992) }, - { UINT64_C( 3857422306640920576), UINT64_C( 3215581569292959744) } }, + { UINT64_C( 3857422306640920576), UINT64_C( 3215581569292959744) }, + { UINT64_C( 7714844613281841152), UINT64_C( 6431163138585919488) } }, { { UINT32_C(2093563644), UINT32_C(2148230876) }, + { UINT64_C( 2093563644), UINT64_C( 2148230876) }, { UINT64_C( 133988073216), UINT64_C( 137486776064) }, { UINT64_C( 17150473371648), UINT64_C( 17598307336192) }, { UINT64_C( 1097630295785472), UINT64_C( 1126291669516288) }, { UINT64_C( 140496677860540416), UINT64_C( 144165333698084864) }, - { UINT64_C( 4495893691537293312), UINT64_C( 4613290678338715648) } }, + { UINT64_C( 4495893691537293312), UINT64_C( 4613290678338715648) }, + { UINT64_C( 8991787383074586624), UINT64_C( 9226581356677431296) } }, }; for (size_t i = 0 ; i < (sizeof(test_vec) / sizeof(test_vec[0])) ; i++) { simde_uint32x2_t a = simde_vld1_u32(test_vec[i].a); + simde_uint64x2_t r0 = simde_vshll_n_u32(a, 0); simde_uint64x2_t r6 = simde_vshll_n_u32(a, 6); simde_uint64x2_t r13 = simde_vshll_n_u32(a, 13); simde_uint64x2_t r19 = simde_vshll_n_u32(a, 19); simde_uint64x2_t r26 = simde_vshll_n_u32(a, 26); simde_uint64x2_t r31 = simde_vshll_n_u32(a, 31); + simde_uint64x2_t r32 = simde_vshll_n_u32(a, 32); + simde_test_arm_neon_assert_equal_u64x2(r0, simde_vld1q_u64(test_vec[i].r0)); simde_test_arm_neon_assert_equal_u64x2(r6, simde_vld1q_u64(test_vec[i].r6)); simde_test_arm_neon_assert_equal_u64x2(r13, simde_vld1q_u64(test_vec[i].r13)); simde_test_arm_neon_assert_equal_u64x2(r19, simde_vld1q_u64(test_vec[i].r19)); simde_test_arm_neon_assert_equal_u64x2(r26, simde_vld1q_u64(test_vec[i].r26)); simde_test_arm_neon_assert_equal_u64x2(r31, simde_vld1q_u64(test_vec[i].r31)); + simde_test_arm_neon_assert_equal_u64x2(r32, simde_vld1q_u64(test_vec[i].r32)); } return 0; #else for (int i = 0 ; i < 8 ; i++) { simde_uint32x2_t a = simde_test_arm_neon_random_u32x2(); + simde_uint64x2_t r0 = simde_vshll_n_u32(a, 0); simde_uint64x2_t r6 = simde_vshll_n_u32(a, 6); simde_uint64x2_t r13 = simde_vshll_n_u32(a, 13); simde_uint64x2_t r19 = simde_vshll_n_u32(a, 19); simde_uint64x2_t r26 = simde_vshll_n_u32(a, 26); simde_uint64x2_t r31 = simde_vshll_n_u32(a, 31); + simde_uint64x2_t r32 = simde_vshll_n_u32(a, 32); simde_test_arm_neon_write_u32x2(2, a, SIMDE_TEST_VEC_POS_FIRST); + simde_test_arm_neon_write_u64x2(2, r0, SIMDE_TEST_VEC_POS_MIDDLE); simde_test_arm_neon_write_u64x2(2, r6, SIMDE_TEST_VEC_POS_MIDDLE); simde_test_arm_neon_write_u64x2(2, r13, SIMDE_TEST_VEC_POS_MIDDLE); simde_test_arm_neon_write_u64x2(2, r19, SIMDE_TEST_VEC_POS_MIDDLE); simde_test_arm_neon_write_u64x2(2, r26, SIMDE_TEST_VEC_POS_MIDDLE); - simde_test_arm_neon_write_u64x2(2, r31, SIMDE_TEST_VEC_POS_LAST); + simde_test_arm_neon_write_u64x2(2, r31, SIMDE_TEST_VEC_POS_MIDDLE); + simde_test_arm_neon_write_u64x2(2, r32, SIMDE_TEST_VEC_POS_LAST); } return 1; #endif