From bdb6a4536f5d7ac2e5d6edca00c37a20b156b5de Mon Sep 17 00:00:00 2001 From: Momchil Velikov Date: Tue, 24 Dec 2024 17:23:30 +0000 Subject: [PATCH 1/2] [AArch64] Implement FP8 SVE/SME reinterpret intrinsics --- .../acle_sve2_fp8_reinterpret.c | 2279 +++++++++++++++++ clang/utils/TableGen/SveEmitter.cpp | 5 +- 2 files changed, 2282 insertions(+), 2 deletions(-) create mode 100644 clang/test/CodeGen/AArch64/fp8-intrinsics/acle_sve2_fp8_reinterpret.c diff --git a/clang/test/CodeGen/AArch64/fp8-intrinsics/acle_sve2_fp8_reinterpret.c b/clang/test/CodeGen/AArch64/fp8-intrinsics/acle_sve2_fp8_reinterpret.c new file mode 100644 index 0000000000000..f99d77108c608 --- /dev/null +++ b/clang/test/CodeGen/AArch64/fp8-intrinsics/acle_sve2_fp8_reinterpret.c @@ -0,0 +1,2279 @@ +// NOTE: Assertions have been autogenerated by utils/update_cc_test_checks.py UTC_ARGS: --version 5 +// RUN: %clang_cc1 -triple aarch64-none-linux-gnu -target-feature +sve -target-feature +fp8 -disable-O0-optnone -Werror -Wall -emit-llvm -o - %s | opt -S -p mem2reg,instcombine,tailcallelim | FileCheck %s +// RUN: %clang_cc1 -x c++ -triple aarch64-none-linux-gnu -target-feature +sme -target-feature +fp8 -disable-O0-optnone -Werror -Wall -emit-llvm -o - %s | opt -S -p mem2reg,instcombine,tailcallelim | FileCheck %s -check-prefix=CHECK-CXX + +// RUN: %clang_cc1 -DSVE_OVERLOADED_FORMS -triple aarch64-none-linux-gnu -target-feature +sve -target-feature +fp8 -disable-O0-optnone -Werror -Wall -emit-llvm -o - %s | opt -S -p mem2reg,instcombine,tailcallelim | FileCheck %s +// RUN: %clang_cc1 -x c++ -DSVE_OVERLOADED_FORMS -triple aarch64-none-linux-gnu -target-feature +sme -target-feature +fp8 -disable-O0-optnone -Werror -Wall -emit-llvm -o - %s | opt -S -p mem2reg,instcombine,tailcallelim | FileCheck %s -check-prefix=CHECK-CXX + +// RUN: %clang_cc1 -triple aarch64-none-linux-gnu -target-feature +sve -target-feature +fp8 -S -disable-O0-optnone -Werror -Wall -o /dev/null %s +// RUN: %clang_cc1 -triple aarch64-none-linux-gnu -target-feature +sme -target-feature +fp8 -S -disable-O0-optnone -Werror -Wall -o /dev/null %s + +// REQUIRES: aarch64-registered-target + +#ifdef __ARM_FEATURE_SME +#include +#else +#include +#endif + +#ifdef SVE_OVERLOADED_FORMS +#define SVE_ACLE_FUNC(A1, A2_UNUSED) A1 +#else +#define SVE_ACLE_FUNC(A1, A2) A1##A2 +#endif + +#ifdef __ARM_FEATURE_SME +#define STREAMING __arm_streaming +#else +#define STREAMING +#endif + +// CHECK-LABEL: define dso_local @test_svreinterpret_s8_mf8( +// CHECK-SAME: [[OP:%.*]]) #[[ATTR0:[0-9]+]] { +// CHECK-NEXT: [[ENTRY:.*:]] +// CHECK-NEXT: ret [[OP]] +// +// CHECK-CXX-LABEL: define dso_local @_Z25test_svreinterpret_s8_mf8u13__SVMfloat8_t( +// CHECK-CXX-SAME: [[OP:%.*]]) #[[ATTR0:[0-9]+]] { +// CHECK-CXX-NEXT: [[ENTRY:.*:]] +// CHECK-CXX-NEXT: ret [[OP]] +// +svint8_t test_svreinterpret_s8_mf8(svmfloat8_t op) STREAMING { + return SVE_ACLE_FUNC(svreinterpret_s8, _mf8)(op); +} + +// CHECK-LABEL: define dso_local @test_svreinterpret_u8_mf8( +// CHECK-SAME: [[OP:%.*]]) #[[ATTR0]] { +// CHECK-NEXT: [[ENTRY:.*:]] +// CHECK-NEXT: ret [[OP]] +// +// CHECK-CXX-LABEL: define dso_local @_Z25test_svreinterpret_u8_mf8u13__SVMfloat8_t( +// CHECK-CXX-SAME: [[OP:%.*]]) #[[ATTR0]] { +// CHECK-CXX-NEXT: [[ENTRY:.*:]] +// CHECK-CXX-NEXT: ret [[OP]] +// +svuint8_t test_svreinterpret_u8_mf8(svmfloat8_t op) STREAMING { + return SVE_ACLE_FUNC(svreinterpret_u8, _mf8)(op); +} + +// CHECK-LABEL: define dso_local @test_svreinterpret_mf8_s8( +// CHECK-SAME: [[OP:%.*]]) #[[ATTR0]] { +// CHECK-NEXT: [[ENTRY:.*:]] +// CHECK-NEXT: ret [[OP]] +// +// CHECK-CXX-LABEL: define dso_local @_Z25test_svreinterpret_mf8_s8u10__SVInt8_t( +// CHECK-CXX-SAME: [[OP:%.*]]) #[[ATTR0]] { +// CHECK-CXX-NEXT: [[ENTRY:.*:]] +// CHECK-CXX-NEXT: ret [[OP]] +// +svmfloat8_t test_svreinterpret_mf8_s8(svint8_t op) STREAMING { + return SVE_ACLE_FUNC(svreinterpret_mf8, _s8)(op); +} + +// CHECK-LABEL: define dso_local @test_svreinterpret_mf8_u8( +// CHECK-SAME: [[OP:%.*]]) #[[ATTR0]] { +// CHECK-NEXT: [[ENTRY:.*:]] +// CHECK-NEXT: ret [[OP]] +// +// CHECK-CXX-LABEL: define dso_local @_Z25test_svreinterpret_mf8_u8u11__SVUint8_t( +// CHECK-CXX-SAME: [[OP:%.*]]) #[[ATTR0]] { +// CHECK-CXX-NEXT: [[ENTRY:.*:]] +// CHECK-CXX-NEXT: ret [[OP]] +// +svmfloat8_t test_svreinterpret_mf8_u8(svuint8_t op) STREAMING { + return SVE_ACLE_FUNC(svreinterpret_mf8, _u8)(op); +} + +// CHECK-LABEL: define dso_local @test_svreinterpret_mf8_mf8( +// CHECK-SAME: [[OP:%.*]]) #[[ATTR0]] { +// CHECK-NEXT: [[ENTRY:.*:]] +// CHECK-NEXT: ret [[OP]] +// +// CHECK-CXX-LABEL: define dso_local @_Z26test_svreinterpret_mf8_mf8u13__SVMfloat8_t( +// CHECK-CXX-SAME: [[OP:%.*]]) #[[ATTR0]] { +// CHECK-CXX-NEXT: [[ENTRY:.*:]] +// CHECK-CXX-NEXT: ret [[OP]] +// +svmfloat8_t test_svreinterpret_mf8_mf8(svmfloat8_t op) STREAMING { + return SVE_ACLE_FUNC(svreinterpret_mf8, _mf8)(op); +} + +// CHECK-LABEL: define dso_local @test_svreinterpret_mf8_s16( +// CHECK-SAME: [[OP:%.*]]) #[[ATTR0]] { +// CHECK-NEXT: [[ENTRY:.*:]] +// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP]] to +// CHECK-NEXT: ret [[TMP0]] +// +// CHECK-CXX-LABEL: define dso_local @_Z26test_svreinterpret_mf8_s16u11__SVInt16_t( +// CHECK-CXX-SAME: [[OP:%.*]]) #[[ATTR0]] { +// CHECK-CXX-NEXT: [[ENTRY:.*:]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP]] to +// CHECK-CXX-NEXT: ret [[TMP0]] +// +svmfloat8_t test_svreinterpret_mf8_s16(svint16_t op) STREAMING { + return SVE_ACLE_FUNC(svreinterpret_mf8, _s16)(op); +} + +// CHECK-LABEL: define dso_local @test_svreinterpret_mf8_u16( +// CHECK-SAME: [[OP:%.*]]) #[[ATTR0]] { +// CHECK-NEXT: [[ENTRY:.*:]] +// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP]] to +// CHECK-NEXT: ret [[TMP0]] +// +// CHECK-CXX-LABEL: define dso_local @_Z26test_svreinterpret_mf8_u16u12__SVUint16_t( +// CHECK-CXX-SAME: [[OP:%.*]]) #[[ATTR0]] { +// CHECK-CXX-NEXT: [[ENTRY:.*:]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP]] to +// CHECK-CXX-NEXT: ret [[TMP0]] +// +svmfloat8_t test_svreinterpret_mf8_u16(svuint16_t op) STREAMING { + return SVE_ACLE_FUNC(svreinterpret_mf8, _u16)(op); +} + +// CHECK-LABEL: define dso_local @test_svreinterpret_mf8_s32( +// CHECK-SAME: [[OP:%.*]]) #[[ATTR0]] { +// CHECK-NEXT: [[ENTRY:.*:]] +// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP]] to +// CHECK-NEXT: ret [[TMP0]] +// +// CHECK-CXX-LABEL: define dso_local @_Z26test_svreinterpret_mf8_s32u11__SVInt32_t( +// CHECK-CXX-SAME: [[OP:%.*]]) #[[ATTR0]] { +// CHECK-CXX-NEXT: [[ENTRY:.*:]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP]] to +// CHECK-CXX-NEXT: ret [[TMP0]] +// +svmfloat8_t test_svreinterpret_mf8_s32(svint32_t op) STREAMING { + return SVE_ACLE_FUNC(svreinterpret_mf8, _s32)(op); +} + +// CHECK-LABEL: define dso_local @test_svreinterpret_mf8_u32( +// CHECK-SAME: [[OP:%.*]]) #[[ATTR0]] { +// CHECK-NEXT: [[ENTRY:.*:]] +// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP]] to +// CHECK-NEXT: ret [[TMP0]] +// +// CHECK-CXX-LABEL: define dso_local @_Z26test_svreinterpret_mf8_u32u12__SVUint32_t( +// CHECK-CXX-SAME: [[OP:%.*]]) #[[ATTR0]] { +// CHECK-CXX-NEXT: [[ENTRY:.*:]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP]] to +// CHECK-CXX-NEXT: ret [[TMP0]] +// +svmfloat8_t test_svreinterpret_mf8_u32(svuint32_t op) STREAMING { + return SVE_ACLE_FUNC(svreinterpret_mf8, _u32)(op); +} + +// CHECK-LABEL: define dso_local @test_svreinterpret_mf8_s64( +// CHECK-SAME: [[OP:%.*]]) #[[ATTR0]] { +// CHECK-NEXT: [[ENTRY:.*:]] +// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP]] to +// CHECK-NEXT: ret [[TMP0]] +// +// CHECK-CXX-LABEL: define dso_local @_Z26test_svreinterpret_mf8_s64u11__SVInt64_t( +// CHECK-CXX-SAME: [[OP:%.*]]) #[[ATTR0]] { +// CHECK-CXX-NEXT: [[ENTRY:.*:]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP]] to +// CHECK-CXX-NEXT: ret [[TMP0]] +// +svmfloat8_t test_svreinterpret_mf8_s64(svint64_t op) STREAMING { + return SVE_ACLE_FUNC(svreinterpret_mf8, _s64)(op); +} + +// CHECK-LABEL: define dso_local @test_svreinterpret_mf8_u64( +// CHECK-SAME: [[OP:%.*]]) #[[ATTR0]] { +// CHECK-NEXT: [[ENTRY:.*:]] +// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP]] to +// CHECK-NEXT: ret [[TMP0]] +// +// CHECK-CXX-LABEL: define dso_local @_Z26test_svreinterpret_mf8_u64u12__SVUint64_t( +// CHECK-CXX-SAME: [[OP:%.*]]) #[[ATTR0]] { +// CHECK-CXX-NEXT: [[ENTRY:.*:]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP]] to +// CHECK-CXX-NEXT: ret [[TMP0]] +// +svmfloat8_t test_svreinterpret_mf8_u64(svuint64_t op) STREAMING { + return SVE_ACLE_FUNC(svreinterpret_mf8, _u64)(op); +} + +// CHECK-LABEL: define dso_local @test_svreinterpret_mf8_f16( +// CHECK-SAME: [[OP:%.*]]) #[[ATTR0]] { +// CHECK-NEXT: [[ENTRY:.*:]] +// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP]] to +// CHECK-NEXT: ret [[TMP0]] +// +// CHECK-CXX-LABEL: define dso_local @_Z26test_svreinterpret_mf8_f16u13__SVFloat16_t( +// CHECK-CXX-SAME: [[OP:%.*]]) #[[ATTR0]] { +// CHECK-CXX-NEXT: [[ENTRY:.*:]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP]] to +// CHECK-CXX-NEXT: ret [[TMP0]] +// +svmfloat8_t test_svreinterpret_mf8_f16(svfloat16_t op) STREAMING { + return SVE_ACLE_FUNC(svreinterpret_mf8, _f16)(op); +} + +// CHECK-LABEL: define dso_local @test_svreinterpret_mf8_bf16( +// CHECK-SAME: [[OP:%.*]]) #[[ATTR0]] { +// CHECK-NEXT: [[ENTRY:.*:]] +// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP]] to +// CHECK-NEXT: ret [[TMP0]] +// +// CHECK-CXX-LABEL: define dso_local @_Z27test_svreinterpret_mf8_bf16u14__SVBfloat16_t( +// CHECK-CXX-SAME: [[OP:%.*]]) #[[ATTR0]] { +// CHECK-CXX-NEXT: [[ENTRY:.*:]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP]] to +// CHECK-CXX-NEXT: ret [[TMP0]] +// +svmfloat8_t test_svreinterpret_mf8_bf16(svbfloat16_t op) STREAMING { + return SVE_ACLE_FUNC(svreinterpret_mf8, _bf16)(op); +} + +// CHECK-LABEL: define dso_local @test_svreinterpret_mf8_f32( +// CHECK-SAME: [[OP:%.*]]) #[[ATTR0]] { +// CHECK-NEXT: [[ENTRY:.*:]] +// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP]] to +// CHECK-NEXT: ret [[TMP0]] +// +// CHECK-CXX-LABEL: define dso_local @_Z26test_svreinterpret_mf8_f32u13__SVFloat32_t( +// CHECK-CXX-SAME: [[OP:%.*]]) #[[ATTR0]] { +// CHECK-CXX-NEXT: [[ENTRY:.*:]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP]] to +// CHECK-CXX-NEXT: ret [[TMP0]] +// +svmfloat8_t test_svreinterpret_mf8_f32(svfloat32_t op) STREAMING { + return SVE_ACLE_FUNC(svreinterpret_mf8, _f32)(op); +} + +// CHECK-LABEL: define dso_local @test_svreinterpret_mf8_f64( +// CHECK-SAME: [[OP:%.*]]) #[[ATTR0]] { +// CHECK-NEXT: [[ENTRY:.*:]] +// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP]] to +// CHECK-NEXT: ret [[TMP0]] +// +// CHECK-CXX-LABEL: define dso_local @_Z26test_svreinterpret_mf8_f64u13__SVFloat64_t( +// CHECK-CXX-SAME: [[OP:%.*]]) #[[ATTR0]] { +// CHECK-CXX-NEXT: [[ENTRY:.*:]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP]] to +// CHECK-CXX-NEXT: ret [[TMP0]] +// +svmfloat8_t test_svreinterpret_mf8_f64(svfloat64_t op) STREAMING { + return SVE_ACLE_FUNC(svreinterpret_mf8, _f64)(op); +} + +// CHECK-LABEL: define dso_local @test_svreinterpret_s16_mf8( +// CHECK-SAME: [[OP:%.*]]) #[[ATTR0]] { +// CHECK-NEXT: [[ENTRY:.*:]] +// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP]] to +// CHECK-NEXT: ret [[TMP0]] +// +// CHECK-CXX-LABEL: define dso_local @_Z26test_svreinterpret_s16_mf8u13__SVMfloat8_t( +// CHECK-CXX-SAME: [[OP:%.*]]) #[[ATTR0]] { +// CHECK-CXX-NEXT: [[ENTRY:.*:]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP]] to +// CHECK-CXX-NEXT: ret [[TMP0]] +// +svint16_t test_svreinterpret_s16_mf8(svmfloat8_t op) STREAMING { + return SVE_ACLE_FUNC(svreinterpret_s16, _mf8)(op); +} + +// CHECK-LABEL: define dso_local @test_svreinterpret_u16_mf8( +// CHECK-SAME: [[OP:%.*]]) #[[ATTR0]] { +// CHECK-NEXT: [[ENTRY:.*:]] +// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP]] to +// CHECK-NEXT: ret [[TMP0]] +// +// CHECK-CXX-LABEL: define dso_local @_Z26test_svreinterpret_u16_mf8u13__SVMfloat8_t( +// CHECK-CXX-SAME: [[OP:%.*]]) #[[ATTR0]] { +// CHECK-CXX-NEXT: [[ENTRY:.*:]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP]] to +// CHECK-CXX-NEXT: ret [[TMP0]] +// +svuint16_t test_svreinterpret_u16_mf8(svmfloat8_t op) STREAMING { + return SVE_ACLE_FUNC(svreinterpret_u16, _mf8)(op); +} + +// CHECK-LABEL: define dso_local @test_svreinterpret_s32_mf8( +// CHECK-SAME: [[OP:%.*]]) #[[ATTR0]] { +// CHECK-NEXT: [[ENTRY:.*:]] +// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP]] to +// CHECK-NEXT: ret [[TMP0]] +// +// CHECK-CXX-LABEL: define dso_local @_Z26test_svreinterpret_s32_mf8u13__SVMfloat8_t( +// CHECK-CXX-SAME: [[OP:%.*]]) #[[ATTR0]] { +// CHECK-CXX-NEXT: [[ENTRY:.*:]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP]] to +// CHECK-CXX-NEXT: ret [[TMP0]] +// +svint32_t test_svreinterpret_s32_mf8(svmfloat8_t op) STREAMING { + return SVE_ACLE_FUNC(svreinterpret_s32, _mf8)(op); +} + +// CHECK-LABEL: define dso_local @test_svreinterpret_u32_mf8( +// CHECK-SAME: [[OP:%.*]]) #[[ATTR0]] { +// CHECK-NEXT: [[ENTRY:.*:]] +// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP]] to +// CHECK-NEXT: ret [[TMP0]] +// +// CHECK-CXX-LABEL: define dso_local @_Z26test_svreinterpret_u32_mf8u13__SVMfloat8_t( +// CHECK-CXX-SAME: [[OP:%.*]]) #[[ATTR0]] { +// CHECK-CXX-NEXT: [[ENTRY:.*:]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP]] to +// CHECK-CXX-NEXT: ret [[TMP0]] +// +svuint32_t test_svreinterpret_u32_mf8(svmfloat8_t op) STREAMING { + return SVE_ACLE_FUNC(svreinterpret_u32, _mf8)(op); +} + +// CHECK-LABEL: define dso_local @test_svreinterpret_s64_mf8( +// CHECK-SAME: [[OP:%.*]]) #[[ATTR0]] { +// CHECK-NEXT: [[ENTRY:.*:]] +// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP]] to +// CHECK-NEXT: ret [[TMP0]] +// +// CHECK-CXX-LABEL: define dso_local @_Z26test_svreinterpret_s64_mf8u13__SVMfloat8_t( +// CHECK-CXX-SAME: [[OP:%.*]]) #[[ATTR0]] { +// CHECK-CXX-NEXT: [[ENTRY:.*:]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP]] to +// CHECK-CXX-NEXT: ret [[TMP0]] +// +svint64_t test_svreinterpret_s64_mf8(svmfloat8_t op) STREAMING { + return SVE_ACLE_FUNC(svreinterpret_s64, _mf8)(op); +} + +// CHECK-LABEL: define dso_local @test_svreinterpret_u64_mf8( +// CHECK-SAME: [[OP:%.*]]) #[[ATTR0]] { +// CHECK-NEXT: [[ENTRY:.*:]] +// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP]] to +// CHECK-NEXT: ret [[TMP0]] +// +// CHECK-CXX-LABEL: define dso_local @_Z26test_svreinterpret_u64_mf8u13__SVMfloat8_t( +// CHECK-CXX-SAME: [[OP:%.*]]) #[[ATTR0]] { +// CHECK-CXX-NEXT: [[ENTRY:.*:]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP]] to +// CHECK-CXX-NEXT: ret [[TMP0]] +// +svuint64_t test_svreinterpret_u64_mf8(svmfloat8_t op) STREAMING { + return SVE_ACLE_FUNC(svreinterpret_u64, _mf8)(op); +} + +// CHECK-LABEL: define dso_local @test_svreinterpret_f16_mf8( +// CHECK-SAME: [[OP:%.*]]) #[[ATTR0]] { +// CHECK-NEXT: [[ENTRY:.*:]] +// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP]] to +// CHECK-NEXT: ret [[TMP0]] +// +// CHECK-CXX-LABEL: define dso_local @_Z26test_svreinterpret_f16_mf8u13__SVMfloat8_t( +// CHECK-CXX-SAME: [[OP:%.*]]) #[[ATTR0]] { +// CHECK-CXX-NEXT: [[ENTRY:.*:]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP]] to +// CHECK-CXX-NEXT: ret [[TMP0]] +// +svfloat16_t test_svreinterpret_f16_mf8(svmfloat8_t op) STREAMING { + return SVE_ACLE_FUNC(svreinterpret_f16, _mf8)(op); +} + +// CHECK-LABEL: define dso_local @test_svreinterpret_bf16_mf8( +// CHECK-SAME: [[OP:%.*]]) #[[ATTR0]] { +// CHECK-NEXT: [[ENTRY:.*:]] +// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP]] to +// CHECK-NEXT: ret [[TMP0]] +// +// CHECK-CXX-LABEL: define dso_local @_Z27test_svreinterpret_bf16_mf8u13__SVMfloat8_t( +// CHECK-CXX-SAME: [[OP:%.*]]) #[[ATTR0]] { +// CHECK-CXX-NEXT: [[ENTRY:.*:]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP]] to +// CHECK-CXX-NEXT: ret [[TMP0]] +// +svbfloat16_t test_svreinterpret_bf16_mf8(svmfloat8_t op) STREAMING { + return SVE_ACLE_FUNC(svreinterpret_bf16, _mf8)(op); +} + +// CHECK-LABEL: define dso_local @test_svreinterpret_f32_mf8( +// CHECK-SAME: [[OP:%.*]]) #[[ATTR0]] { +// CHECK-NEXT: [[ENTRY:.*:]] +// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP]] to +// CHECK-NEXT: ret [[TMP0]] +// +// CHECK-CXX-LABEL: define dso_local @_Z26test_svreinterpret_f32_mf8u13__SVMfloat8_t( +// CHECK-CXX-SAME: [[OP:%.*]]) #[[ATTR0]] { +// CHECK-CXX-NEXT: [[ENTRY:.*:]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP]] to +// CHECK-CXX-NEXT: ret [[TMP0]] +// +svfloat32_t test_svreinterpret_f32_mf8(svmfloat8_t op) STREAMING { + return SVE_ACLE_FUNC(svreinterpret_f32, _mf8)(op); +} + +// CHECK-LABEL: define dso_local @test_svreinterpret_f64_mf8( +// CHECK-SAME: [[OP:%.*]]) #[[ATTR0]] { +// CHECK-NEXT: [[ENTRY:.*:]] +// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP]] to +// CHECK-NEXT: ret [[TMP0]] +// +// CHECK-CXX-LABEL: define dso_local @_Z26test_svreinterpret_f64_mf8u13__SVMfloat8_t( +// CHECK-CXX-SAME: [[OP:%.*]]) #[[ATTR0]] { +// CHECK-CXX-NEXT: [[ENTRY:.*:]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP]] to +// CHECK-CXX-NEXT: ret [[TMP0]] +// +svfloat64_t test_svreinterpret_f64_mf8(svmfloat8_t op) STREAMING { + return SVE_ACLE_FUNC(svreinterpret_f64, _mf8)(op); +} + +// CHECK-LABEL: define dso_local { , } @test_svreinterpret_s8_mf8_x2( +// CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]]) #[[ATTR0]] { +// CHECK-NEXT: [[ENTRY:.*:]] +// CHECK-NEXT: [[TMP0:%.*]] = insertvalue { , } poison, [[OP_COERCE0]], 0 +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-NEXT: ret { , } [[TMP1]] +// +// CHECK-CXX-LABEL: define dso_local { , } @_Z28test_svreinterpret_s8_mf8_x213svmfloat8x2_t( +// CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]]) #[[ATTR0]] { +// CHECK-CXX-NEXT: [[ENTRY:.*:]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = insertvalue { , } poison, [[OP_COERCE0]], 0 +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-CXX-NEXT: ret { , } [[TMP1]] +// +svint8x2_t test_svreinterpret_s8_mf8_x2(svmfloat8x2_t op) STREAMING { + return SVE_ACLE_FUNC(svreinterpret_s8, _mf8_x2)(op); +} + +// CHECK-LABEL: define dso_local { , } @test_svreinterpret_u8_mf8_x2( +// CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]]) #[[ATTR0]] { +// CHECK-NEXT: [[ENTRY:.*:]] +// CHECK-NEXT: [[TMP0:%.*]] = insertvalue { , } poison, [[OP_COERCE0]], 0 +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-NEXT: ret { , } [[TMP1]] +// +// CHECK-CXX-LABEL: define dso_local { , } @_Z28test_svreinterpret_u8_mf8_x213svmfloat8x2_t( +// CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]]) #[[ATTR0]] { +// CHECK-CXX-NEXT: [[ENTRY:.*:]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = insertvalue { , } poison, [[OP_COERCE0]], 0 +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-CXX-NEXT: ret { , } [[TMP1]] +// +svuint8x2_t test_svreinterpret_u8_mf8_x2(svmfloat8x2_t op) STREAMING { + return SVE_ACLE_FUNC(svreinterpret_u8, _mf8_x2)(op); +} + +// CHECK-LABEL: define dso_local { , } @test_svreinterpret_mf8_s8_x2( +// CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]]) #[[ATTR0]] { +// CHECK-NEXT: [[ENTRY:.*:]] +// CHECK-NEXT: [[TMP0:%.*]] = insertvalue { , } poison, [[OP_COERCE0]], 0 +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-NEXT: ret { , } [[TMP1]] +// +// CHECK-CXX-LABEL: define dso_local { , } @_Z28test_svreinterpret_mf8_s8_x210svint8x2_t( +// CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]]) #[[ATTR0]] { +// CHECK-CXX-NEXT: [[ENTRY:.*:]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = insertvalue { , } poison, [[OP_COERCE0]], 0 +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-CXX-NEXT: ret { , } [[TMP1]] +// +svmfloat8x2_t test_svreinterpret_mf8_s8_x2(svint8x2_t op) STREAMING { + return SVE_ACLE_FUNC(svreinterpret_mf8, _s8_x2)(op); +} + +// CHECK-LABEL: define dso_local { , } @test_svreinterpret_mf8_u8_x2( +// CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]]) #[[ATTR0]] { +// CHECK-NEXT: [[ENTRY:.*:]] +// CHECK-NEXT: [[TMP0:%.*]] = insertvalue { , } poison, [[OP_COERCE0]], 0 +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-NEXT: ret { , } [[TMP1]] +// +// CHECK-CXX-LABEL: define dso_local { , } @_Z28test_svreinterpret_mf8_u8_x211svuint8x2_t( +// CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]]) #[[ATTR0]] { +// CHECK-CXX-NEXT: [[ENTRY:.*:]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = insertvalue { , } poison, [[OP_COERCE0]], 0 +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-CXX-NEXT: ret { , } [[TMP1]] +// +svmfloat8x2_t test_svreinterpret_mf8_u8_x2(svuint8x2_t op) STREAMING { + return SVE_ACLE_FUNC(svreinterpret_mf8, _u8_x2)(op); +} + +// CHECK-LABEL: define dso_local { , } @test_svreinterpret_mf8_mf8_x2( +// CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]]) #[[ATTR0]] { +// CHECK-NEXT: [[ENTRY:.*:]] +// CHECK-NEXT: [[TMP0:%.*]] = insertvalue { , } poison, [[OP_COERCE0]], 0 +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-NEXT: ret { , } [[TMP1]] +// +// CHECK-CXX-LABEL: define dso_local { , } @_Z29test_svreinterpret_mf8_mf8_x213svmfloat8x2_t( +// CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]]) #[[ATTR0]] { +// CHECK-CXX-NEXT: [[ENTRY:.*:]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = insertvalue { , } poison, [[OP_COERCE0]], 0 +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-CXX-NEXT: ret { , } [[TMP1]] +// +svmfloat8x2_t test_svreinterpret_mf8_mf8_x2(svmfloat8x2_t op) STREAMING { + return SVE_ACLE_FUNC(svreinterpret_mf8, _mf8_x2)(op); +} + +// CHECK-LABEL: define dso_local { , } @test_svreinterpret_mf8_s16_x2( +// CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]]) #[[ATTR0]] { +// CHECK-NEXT: [[ENTRY:.*:]] +// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , } poison, [[TMP0]], 0 +// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , } [[TMP1]], [[TMP2]], 1 +// CHECK-NEXT: ret { , } [[TMP3]] +// +// CHECK-CXX-LABEL: define dso_local { , } @_Z29test_svreinterpret_mf8_s16_x211svint16x2_t( +// CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]]) #[[ATTR0]] { +// CHECK-CXX-NEXT: [[ENTRY:.*:]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , } poison, [[TMP0]], 0 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , } [[TMP1]], [[TMP2]], 1 +// CHECK-CXX-NEXT: ret { , } [[TMP3]] +// +svmfloat8x2_t test_svreinterpret_mf8_s16_x2(svint16x2_t op) STREAMING { + return SVE_ACLE_FUNC(svreinterpret_mf8, _s16_x2)(op); +} + +// CHECK-LABEL: define dso_local { , } @test_svreinterpret_mf8_u16_x2( +// CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]]) #[[ATTR0]] { +// CHECK-NEXT: [[ENTRY:.*:]] +// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , } poison, [[TMP0]], 0 +// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , } [[TMP1]], [[TMP2]], 1 +// CHECK-NEXT: ret { , } [[TMP3]] +// +// CHECK-CXX-LABEL: define dso_local { , } @_Z29test_svreinterpret_mf8_u16_x212svuint16x2_t( +// CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]]) #[[ATTR0]] { +// CHECK-CXX-NEXT: [[ENTRY:.*:]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , } poison, [[TMP0]], 0 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , } [[TMP1]], [[TMP2]], 1 +// CHECK-CXX-NEXT: ret { , } [[TMP3]] +// +svmfloat8x2_t test_svreinterpret_mf8_u16_x2(svuint16x2_t op) STREAMING { + return SVE_ACLE_FUNC(svreinterpret_mf8, _u16_x2)(op); +} + +// CHECK-LABEL: define dso_local { , } @test_svreinterpret_mf8_s32_x2( +// CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]]) #[[ATTR0]] { +// CHECK-NEXT: [[ENTRY:.*:]] +// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , } poison, [[TMP0]], 0 +// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , } [[TMP1]], [[TMP2]], 1 +// CHECK-NEXT: ret { , } [[TMP3]] +// +// CHECK-CXX-LABEL: define dso_local { , } @_Z29test_svreinterpret_mf8_s32_x211svint32x2_t( +// CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]]) #[[ATTR0]] { +// CHECK-CXX-NEXT: [[ENTRY:.*:]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , } poison, [[TMP0]], 0 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , } [[TMP1]], [[TMP2]], 1 +// CHECK-CXX-NEXT: ret { , } [[TMP3]] +// +svmfloat8x2_t test_svreinterpret_mf8_s32_x2(svint32x2_t op) STREAMING { + return SVE_ACLE_FUNC(svreinterpret_mf8, _s32_x2)(op); +} + +// CHECK-LABEL: define dso_local { , } @test_svreinterpret_mf8_u32_x2( +// CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]]) #[[ATTR0]] { +// CHECK-NEXT: [[ENTRY:.*:]] +// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , } poison, [[TMP0]], 0 +// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , } [[TMP1]], [[TMP2]], 1 +// CHECK-NEXT: ret { , } [[TMP3]] +// +// CHECK-CXX-LABEL: define dso_local { , } @_Z29test_svreinterpret_mf8_u32_x212svuint32x2_t( +// CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]]) #[[ATTR0]] { +// CHECK-CXX-NEXT: [[ENTRY:.*:]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , } poison, [[TMP0]], 0 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , } [[TMP1]], [[TMP2]], 1 +// CHECK-CXX-NEXT: ret { , } [[TMP3]] +// +svmfloat8x2_t test_svreinterpret_mf8_u32_x2(svuint32x2_t op) STREAMING { + return SVE_ACLE_FUNC(svreinterpret_mf8, _u32_x2)(op); +} + +// CHECK-LABEL: define dso_local { , } @test_svreinterpret_mf8_s64_x2( +// CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]]) #[[ATTR0]] { +// CHECK-NEXT: [[ENTRY:.*:]] +// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , } poison, [[TMP0]], 0 +// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , } [[TMP1]], [[TMP2]], 1 +// CHECK-NEXT: ret { , } [[TMP3]] +// +// CHECK-CXX-LABEL: define dso_local { , } @_Z29test_svreinterpret_mf8_s64_x211svint64x2_t( +// CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]]) #[[ATTR0]] { +// CHECK-CXX-NEXT: [[ENTRY:.*:]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , } poison, [[TMP0]], 0 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , } [[TMP1]], [[TMP2]], 1 +// CHECK-CXX-NEXT: ret { , } [[TMP3]] +// +svmfloat8x2_t test_svreinterpret_mf8_s64_x2(svint64x2_t op) STREAMING { + return SVE_ACLE_FUNC(svreinterpret_mf8, _s64_x2)(op); +} + +// CHECK-LABEL: define dso_local { , } @test_svreinterpret_mf8_u64_x2( +// CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]]) #[[ATTR0]] { +// CHECK-NEXT: [[ENTRY:.*:]] +// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , } poison, [[TMP0]], 0 +// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , } [[TMP1]], [[TMP2]], 1 +// CHECK-NEXT: ret { , } [[TMP3]] +// +// CHECK-CXX-LABEL: define dso_local { , } @_Z29test_svreinterpret_mf8_u64_x212svuint64x2_t( +// CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]]) #[[ATTR0]] { +// CHECK-CXX-NEXT: [[ENTRY:.*:]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , } poison, [[TMP0]], 0 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , } [[TMP1]], [[TMP2]], 1 +// CHECK-CXX-NEXT: ret { , } [[TMP3]] +// +svmfloat8x2_t test_svreinterpret_mf8_u64_x2(svuint64x2_t op) STREAMING { + return SVE_ACLE_FUNC(svreinterpret_mf8, _u64_x2)(op); +} + +// CHECK-LABEL: define dso_local { , } @test_svreinterpret_mf8_f16_x2( +// CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]]) #[[ATTR0]] { +// CHECK-NEXT: [[ENTRY:.*:]] +// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , } poison, [[TMP0]], 0 +// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , } [[TMP1]], [[TMP2]], 1 +// CHECK-NEXT: ret { , } [[TMP3]] +// +// CHECK-CXX-LABEL: define dso_local { , } @_Z29test_svreinterpret_mf8_f16_x213svfloat16x2_t( +// CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]]) #[[ATTR0]] { +// CHECK-CXX-NEXT: [[ENTRY:.*:]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , } poison, [[TMP0]], 0 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , } [[TMP1]], [[TMP2]], 1 +// CHECK-CXX-NEXT: ret { , } [[TMP3]] +// +svmfloat8x2_t test_svreinterpret_mf8_f16_x2(svfloat16x2_t op) STREAMING { + return SVE_ACLE_FUNC(svreinterpret_mf8, _f16_x2)(op); +} + +// CHECK-LABEL: define dso_local { , } @test_svreinterpret_mf8_bf16_x2( +// CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]]) #[[ATTR0]] { +// CHECK-NEXT: [[ENTRY:.*:]] +// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , } poison, [[TMP0]], 0 +// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , } [[TMP1]], [[TMP2]], 1 +// CHECK-NEXT: ret { , } [[TMP3]] +// +// CHECK-CXX-LABEL: define dso_local { , } @_Z30test_svreinterpret_mf8_bf16_x214svbfloat16x2_t( +// CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]]) #[[ATTR0]] { +// CHECK-CXX-NEXT: [[ENTRY:.*:]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , } poison, [[TMP0]], 0 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , } [[TMP1]], [[TMP2]], 1 +// CHECK-CXX-NEXT: ret { , } [[TMP3]] +// +svmfloat8x2_t test_svreinterpret_mf8_bf16_x2(svbfloat16x2_t op) STREAMING { + return SVE_ACLE_FUNC(svreinterpret_mf8, _bf16_x2)(op); +} + +// CHECK-LABEL: define dso_local { , } @test_svreinterpret_mf8_f32_x2( +// CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]]) #[[ATTR0]] { +// CHECK-NEXT: [[ENTRY:.*:]] +// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , } poison, [[TMP0]], 0 +// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , } [[TMP1]], [[TMP2]], 1 +// CHECK-NEXT: ret { , } [[TMP3]] +// +// CHECK-CXX-LABEL: define dso_local { , } @_Z29test_svreinterpret_mf8_f32_x213svfloat32x2_t( +// CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]]) #[[ATTR0]] { +// CHECK-CXX-NEXT: [[ENTRY:.*:]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , } poison, [[TMP0]], 0 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , } [[TMP1]], [[TMP2]], 1 +// CHECK-CXX-NEXT: ret { , } [[TMP3]] +// +svmfloat8x2_t test_svreinterpret_mf8_f32_x2(svfloat32x2_t op) STREAMING { + return SVE_ACLE_FUNC(svreinterpret_mf8, _f32_x2)(op); +} + +// CHECK-LABEL: define dso_local { , } @test_svreinterpret_mf8_f64_x2( +// CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]]) #[[ATTR0]] { +// CHECK-NEXT: [[ENTRY:.*:]] +// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , } poison, [[TMP0]], 0 +// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , } [[TMP1]], [[TMP2]], 1 +// CHECK-NEXT: ret { , } [[TMP3]] +// +// CHECK-CXX-LABEL: define dso_local { , } @_Z29test_svreinterpret_mf8_f64_x213svfloat64x2_t( +// CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]]) #[[ATTR0]] { +// CHECK-CXX-NEXT: [[ENTRY:.*:]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , } poison, [[TMP0]], 0 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , } [[TMP1]], [[TMP2]], 1 +// CHECK-CXX-NEXT: ret { , } [[TMP3]] +// +svmfloat8x2_t test_svreinterpret_mf8_f64_x2(svfloat64x2_t op) STREAMING { + return SVE_ACLE_FUNC(svreinterpret_mf8, _f64_x2)(op); +} + +// CHECK-LABEL: define dso_local { , } @test_svreinterpret_s16_mf8_x2( +// CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]]) #[[ATTR0]] { +// CHECK-NEXT: [[ENTRY:.*:]] +// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , } poison, [[TMP0]], 0 +// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , } [[TMP1]], [[TMP2]], 1 +// CHECK-NEXT: ret { , } [[TMP3]] +// +// CHECK-CXX-LABEL: define dso_local { , } @_Z29test_svreinterpret_s16_mf8_x213svmfloat8x2_t( +// CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]]) #[[ATTR0]] { +// CHECK-CXX-NEXT: [[ENTRY:.*:]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , } poison, [[TMP0]], 0 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , } [[TMP1]], [[TMP2]], 1 +// CHECK-CXX-NEXT: ret { , } [[TMP3]] +// +svint16x2_t test_svreinterpret_s16_mf8_x2(svmfloat8x2_t op) STREAMING { + return SVE_ACLE_FUNC(svreinterpret_s16, _mf8_x2)(op); +} + +// CHECK-LABEL: define dso_local { , } @test_svreinterpret_u16_mf8_x2( +// CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]]) #[[ATTR0]] { +// CHECK-NEXT: [[ENTRY:.*:]] +// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , } poison, [[TMP0]], 0 +// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , } [[TMP1]], [[TMP2]], 1 +// CHECK-NEXT: ret { , } [[TMP3]] +// +// CHECK-CXX-LABEL: define dso_local { , } @_Z29test_svreinterpret_u16_mf8_x213svmfloat8x2_t( +// CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]]) #[[ATTR0]] { +// CHECK-CXX-NEXT: [[ENTRY:.*:]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , } poison, [[TMP0]], 0 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , } [[TMP1]], [[TMP2]], 1 +// CHECK-CXX-NEXT: ret { , } [[TMP3]] +// +svuint16x2_t test_svreinterpret_u16_mf8_x2(svmfloat8x2_t op) STREAMING { + return SVE_ACLE_FUNC(svreinterpret_u16, _mf8_x2)(op); +} + +// CHECK-LABEL: define dso_local { , } @test_svreinterpret_s32_mf8_x2( +// CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]]) #[[ATTR0]] { +// CHECK-NEXT: [[ENTRY:.*:]] +// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , } poison, [[TMP0]], 0 +// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , } [[TMP1]], [[TMP2]], 1 +// CHECK-NEXT: ret { , } [[TMP3]] +// +// CHECK-CXX-LABEL: define dso_local { , } @_Z29test_svreinterpret_s32_mf8_x213svmfloat8x2_t( +// CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]]) #[[ATTR0]] { +// CHECK-CXX-NEXT: [[ENTRY:.*:]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , } poison, [[TMP0]], 0 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , } [[TMP1]], [[TMP2]], 1 +// CHECK-CXX-NEXT: ret { , } [[TMP3]] +// +svint32x2_t test_svreinterpret_s32_mf8_x2(svmfloat8x2_t op) STREAMING { + return SVE_ACLE_FUNC(svreinterpret_s32, _mf8_x2)(op); +} + +// CHECK-LABEL: define dso_local { , } @test_svreinterpret_u32_mf8_x2( +// CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]]) #[[ATTR0]] { +// CHECK-NEXT: [[ENTRY:.*:]] +// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , } poison, [[TMP0]], 0 +// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , } [[TMP1]], [[TMP2]], 1 +// CHECK-NEXT: ret { , } [[TMP3]] +// +// CHECK-CXX-LABEL: define dso_local { , } @_Z29test_svreinterpret_u32_mf8_x213svmfloat8x2_t( +// CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]]) #[[ATTR0]] { +// CHECK-CXX-NEXT: [[ENTRY:.*:]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , } poison, [[TMP0]], 0 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , } [[TMP1]], [[TMP2]], 1 +// CHECK-CXX-NEXT: ret { , } [[TMP3]] +// +svuint32x2_t test_svreinterpret_u32_mf8_x2(svmfloat8x2_t op) STREAMING { + return SVE_ACLE_FUNC(svreinterpret_u32, _mf8_x2)(op); +} + +// CHECK-LABEL: define dso_local { , } @test_svreinterpret_s64_mf8_x2( +// CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]]) #[[ATTR0]] { +// CHECK-NEXT: [[ENTRY:.*:]] +// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , } poison, [[TMP0]], 0 +// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , } [[TMP1]], [[TMP2]], 1 +// CHECK-NEXT: ret { , } [[TMP3]] +// +// CHECK-CXX-LABEL: define dso_local { , } @_Z29test_svreinterpret_s64_mf8_x213svmfloat8x2_t( +// CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]]) #[[ATTR0]] { +// CHECK-CXX-NEXT: [[ENTRY:.*:]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , } poison, [[TMP0]], 0 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , } [[TMP1]], [[TMP2]], 1 +// CHECK-CXX-NEXT: ret { , } [[TMP3]] +// +svint64x2_t test_svreinterpret_s64_mf8_x2(svmfloat8x2_t op) STREAMING { + return SVE_ACLE_FUNC(svreinterpret_s64, _mf8_x2)(op); +} + +// CHECK-LABEL: define dso_local { , } @test_svreinterpret_u64_mf8_x2( +// CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]]) #[[ATTR0]] { +// CHECK-NEXT: [[ENTRY:.*:]] +// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , } poison, [[TMP0]], 0 +// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , } [[TMP1]], [[TMP2]], 1 +// CHECK-NEXT: ret { , } [[TMP3]] +// +// CHECK-CXX-LABEL: define dso_local { , } @_Z29test_svreinterpret_u64_mf8_x213svmfloat8x2_t( +// CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]]) #[[ATTR0]] { +// CHECK-CXX-NEXT: [[ENTRY:.*:]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , } poison, [[TMP0]], 0 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , } [[TMP1]], [[TMP2]], 1 +// CHECK-CXX-NEXT: ret { , } [[TMP3]] +// +svuint64x2_t test_svreinterpret_u64_mf8_x2(svmfloat8x2_t op) STREAMING { + return SVE_ACLE_FUNC(svreinterpret_u64, _mf8_x2)(op); +} + +// CHECK-LABEL: define dso_local { , } @test_svreinterpret_f16_mf8_x2( +// CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]]) #[[ATTR0]] { +// CHECK-NEXT: [[ENTRY:.*:]] +// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , } poison, [[TMP0]], 0 +// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , } [[TMP1]], [[TMP2]], 1 +// CHECK-NEXT: ret { , } [[TMP3]] +// +// CHECK-CXX-LABEL: define dso_local { , } @_Z29test_svreinterpret_f16_mf8_x213svmfloat8x2_t( +// CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]]) #[[ATTR0]] { +// CHECK-CXX-NEXT: [[ENTRY:.*:]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , } poison, [[TMP0]], 0 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , } [[TMP1]], [[TMP2]], 1 +// CHECK-CXX-NEXT: ret { , } [[TMP3]] +// +svfloat16x2_t test_svreinterpret_f16_mf8_x2(svmfloat8x2_t op) STREAMING { + return SVE_ACLE_FUNC(svreinterpret_f16, _mf8_x2)(op); +} + +// CHECK-LABEL: define dso_local { , } @test_svreinterpret_bf16_mf8_x2( +// CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]]) #[[ATTR0]] { +// CHECK-NEXT: [[ENTRY:.*:]] +// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , } poison, [[TMP0]], 0 +// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , } [[TMP1]], [[TMP2]], 1 +// CHECK-NEXT: ret { , } [[TMP3]] +// +// CHECK-CXX-LABEL: define dso_local { , } @_Z30test_svreinterpret_bf16_mf8_x213svmfloat8x2_t( +// CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]]) #[[ATTR0]] { +// CHECK-CXX-NEXT: [[ENTRY:.*:]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , } poison, [[TMP0]], 0 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , } [[TMP1]], [[TMP2]], 1 +// CHECK-CXX-NEXT: ret { , } [[TMP3]] +// +svbfloat16x2_t test_svreinterpret_bf16_mf8_x2(svmfloat8x2_t op) STREAMING { + return SVE_ACLE_FUNC(svreinterpret_bf16, _mf8_x2)(op); +} + +// CHECK-LABEL: define dso_local { , } @test_svreinterpret_f32_mf8_x2( +// CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]]) #[[ATTR0]] { +// CHECK-NEXT: [[ENTRY:.*:]] +// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , } poison, [[TMP0]], 0 +// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , } [[TMP1]], [[TMP2]], 1 +// CHECK-NEXT: ret { , } [[TMP3]] +// +// CHECK-CXX-LABEL: define dso_local { , } @_Z29test_svreinterpret_f32_mf8_x213svmfloat8x2_t( +// CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]]) #[[ATTR0]] { +// CHECK-CXX-NEXT: [[ENTRY:.*:]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , } poison, [[TMP0]], 0 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , } [[TMP1]], [[TMP2]], 1 +// CHECK-CXX-NEXT: ret { , } [[TMP3]] +// +svfloat32x2_t test_svreinterpret_f32_mf8_x2(svmfloat8x2_t op) STREAMING { + return SVE_ACLE_FUNC(svreinterpret_f32, _mf8_x2)(op); +} + +// CHECK-LABEL: define dso_local { , } @test_svreinterpret_f64_mf8_x2( +// CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]]) #[[ATTR0]] { +// CHECK-NEXT: [[ENTRY:.*:]] +// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , } poison, [[TMP0]], 0 +// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , } [[TMP1]], [[TMP2]], 1 +// CHECK-NEXT: ret { , } [[TMP3]] +// +// CHECK-CXX-LABEL: define dso_local { , } @_Z29test_svreinterpret_f64_mf8_x213svmfloat8x2_t( +// CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]]) #[[ATTR0]] { +// CHECK-CXX-NEXT: [[ENTRY:.*:]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , } poison, [[TMP0]], 0 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , } [[TMP1]], [[TMP2]], 1 +// CHECK-CXX-NEXT: ret { , } [[TMP3]] +// +svfloat64x2_t test_svreinterpret_f64_mf8_x2(svmfloat8x2_t op) STREAMING { + return SVE_ACLE_FUNC(svreinterpret_f64, _mf8_x2)(op); +} + +// CHECK-LABEL: define dso_local { , , } @test_svreinterpret_s8_mf8_x3( +// CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]]) #[[ATTR0]] { +// CHECK-NEXT: [[ENTRY:.*:]] +// CHECK-NEXT: [[TMP0:%.*]] = insertvalue { , , } poison, [[OP_COERCE0]], 0 +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-NEXT: [[TMP2:%.*]] = insertvalue { , , } [[TMP1]], [[OP_COERCE2]], 2 +// CHECK-NEXT: ret { , , } [[TMP2]] +// +// CHECK-CXX-LABEL: define dso_local { , , } @_Z28test_svreinterpret_s8_mf8_x313svmfloat8x3_t( +// CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]]) #[[ATTR0]] { +// CHECK-CXX-NEXT: [[ENTRY:.*:]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = insertvalue { , , } poison, [[OP_COERCE0]], 0 +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = insertvalue { , , } [[TMP1]], [[OP_COERCE2]], 2 +// CHECK-CXX-NEXT: ret { , , } [[TMP2]] +// +svint8x3_t test_svreinterpret_s8_mf8_x3(svmfloat8x3_t op) STREAMING { + return SVE_ACLE_FUNC(svreinterpret_s8, _mf8_x3)(op); +} + +// CHECK-LABEL: define dso_local { , , } @test_svreinterpret_u8_mf8_x3( +// CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]]) #[[ATTR0]] { +// CHECK-NEXT: [[ENTRY:.*:]] +// CHECK-NEXT: [[TMP0:%.*]] = insertvalue { , , } poison, [[OP_COERCE0]], 0 +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-NEXT: [[TMP2:%.*]] = insertvalue { , , } [[TMP1]], [[OP_COERCE2]], 2 +// CHECK-NEXT: ret { , , } [[TMP2]] +// +// CHECK-CXX-LABEL: define dso_local { , , } @_Z28test_svreinterpret_u8_mf8_x313svmfloat8x3_t( +// CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]]) #[[ATTR0]] { +// CHECK-CXX-NEXT: [[ENTRY:.*:]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = insertvalue { , , } poison, [[OP_COERCE0]], 0 +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = insertvalue { , , } [[TMP1]], [[OP_COERCE2]], 2 +// CHECK-CXX-NEXT: ret { , , } [[TMP2]] +// +svuint8x3_t test_svreinterpret_u8_mf8_x3(svmfloat8x3_t op) STREAMING { + return SVE_ACLE_FUNC(svreinterpret_u8, _mf8_x3)(op); +} + +// CHECK-LABEL: define dso_local { , , } @test_svreinterpret_mf8_s8_x3( +// CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]]) #[[ATTR0]] { +// CHECK-NEXT: [[ENTRY:.*:]] +// CHECK-NEXT: [[TMP0:%.*]] = insertvalue { , , } poison, [[OP_COERCE0]], 0 +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-NEXT: [[TMP2:%.*]] = insertvalue { , , } [[TMP1]], [[OP_COERCE2]], 2 +// CHECK-NEXT: ret { , , } [[TMP2]] +// +// CHECK-CXX-LABEL: define dso_local { , , } @_Z28test_svreinterpret_mf8_s8_x310svint8x3_t( +// CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]]) #[[ATTR0]] { +// CHECK-CXX-NEXT: [[ENTRY:.*:]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = insertvalue { , , } poison, [[OP_COERCE0]], 0 +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = insertvalue { , , } [[TMP1]], [[OP_COERCE2]], 2 +// CHECK-CXX-NEXT: ret { , , } [[TMP2]] +// +svmfloat8x3_t test_svreinterpret_mf8_s8_x3(svint8x3_t op) STREAMING { + return SVE_ACLE_FUNC(svreinterpret_mf8, _s8_x3)(op); +} + +// CHECK-LABEL: define dso_local { , , } @test_svreinterpret_mf8_u8_x3( +// CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]]) #[[ATTR0]] { +// CHECK-NEXT: [[ENTRY:.*:]] +// CHECK-NEXT: [[TMP0:%.*]] = insertvalue { , , } poison, [[OP_COERCE0]], 0 +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-NEXT: [[TMP2:%.*]] = insertvalue { , , } [[TMP1]], [[OP_COERCE2]], 2 +// CHECK-NEXT: ret { , , } [[TMP2]] +// +// CHECK-CXX-LABEL: define dso_local { , , } @_Z28test_svreinterpret_mf8_u8_x311svuint8x3_t( +// CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]]) #[[ATTR0]] { +// CHECK-CXX-NEXT: [[ENTRY:.*:]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = insertvalue { , , } poison, [[OP_COERCE0]], 0 +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = insertvalue { , , } [[TMP1]], [[OP_COERCE2]], 2 +// CHECK-CXX-NEXT: ret { , , } [[TMP2]] +// +svmfloat8x3_t test_svreinterpret_mf8_u8_x3(svuint8x3_t op) STREAMING { + return SVE_ACLE_FUNC(svreinterpret_mf8, _u8_x3)(op); +} + +// CHECK-LABEL: define dso_local { , , } @test_svreinterpret_mf8_mf8_x3( +// CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]]) #[[ATTR0]] { +// CHECK-NEXT: [[ENTRY:.*:]] +// CHECK-NEXT: [[TMP0:%.*]] = insertvalue { , , } poison, [[OP_COERCE0]], 0 +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-NEXT: [[TMP2:%.*]] = insertvalue { , , } [[TMP1]], [[OP_COERCE2]], 2 +// CHECK-NEXT: ret { , , } [[TMP2]] +// +// CHECK-CXX-LABEL: define dso_local { , , } @_Z29test_svreinterpret_mf8_mf8_x313svmfloat8x3_t( +// CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]]) #[[ATTR0]] { +// CHECK-CXX-NEXT: [[ENTRY:.*:]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = insertvalue { , , } poison, [[OP_COERCE0]], 0 +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = insertvalue { , , } [[TMP1]], [[OP_COERCE2]], 2 +// CHECK-CXX-NEXT: ret { , , } [[TMP2]] +// +svmfloat8x3_t test_svreinterpret_mf8_mf8_x3(svmfloat8x3_t op) STREAMING { + return SVE_ACLE_FUNC(svreinterpret_mf8, _mf8_x3)(op); +} + +// CHECK-LABEL: define dso_local { , , } @test_svreinterpret_mf8_s16_x3( +// CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]]) #[[ATTR0]] { +// CHECK-NEXT: [[ENTRY:.*:]] +// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , } poison, [[TMP0]], 0 +// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , } [[TMP1]], [[TMP2]], 1 +// CHECK-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to +// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , } [[TMP3]], [[TMP4]], 2 +// CHECK-NEXT: ret { , , } [[TMP5]] +// +// CHECK-CXX-LABEL: define dso_local { , , } @_Z29test_svreinterpret_mf8_s16_x311svint16x3_t( +// CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]]) #[[ATTR0]] { +// CHECK-CXX-NEXT: [[ENTRY:.*:]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , } poison, [[TMP0]], 0 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , } [[TMP1]], [[TMP2]], 1 +// CHECK-CXX-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to +// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , } [[TMP3]], [[TMP4]], 2 +// CHECK-CXX-NEXT: ret { , , } [[TMP5]] +// +svmfloat8x3_t test_svreinterpret_mf8_s16_x3(svint16x3_t op) STREAMING { + return SVE_ACLE_FUNC(svreinterpret_mf8, _s16_x3)(op); +} + +// CHECK-LABEL: define dso_local { , , } @test_svreinterpret_mf8_u16_x3( +// CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]]) #[[ATTR0]] { +// CHECK-NEXT: [[ENTRY:.*:]] +// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , } poison, [[TMP0]], 0 +// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , } [[TMP1]], [[TMP2]], 1 +// CHECK-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to +// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , } [[TMP3]], [[TMP4]], 2 +// CHECK-NEXT: ret { , , } [[TMP5]] +// +// CHECK-CXX-LABEL: define dso_local { , , } @_Z29test_svreinterpret_mf8_u16_x312svuint16x3_t( +// CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]]) #[[ATTR0]] { +// CHECK-CXX-NEXT: [[ENTRY:.*:]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , } poison, [[TMP0]], 0 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , } [[TMP1]], [[TMP2]], 1 +// CHECK-CXX-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to +// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , } [[TMP3]], [[TMP4]], 2 +// CHECK-CXX-NEXT: ret { , , } [[TMP5]] +// +svmfloat8x3_t test_svreinterpret_mf8_u16_x3(svuint16x3_t op) STREAMING { + return SVE_ACLE_FUNC(svreinterpret_mf8, _u16_x3)(op); +} + +// CHECK-LABEL: define dso_local { , , } @test_svreinterpret_mf8_s32_x3( +// CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]]) #[[ATTR0]] { +// CHECK-NEXT: [[ENTRY:.*:]] +// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , } poison, [[TMP0]], 0 +// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , } [[TMP1]], [[TMP2]], 1 +// CHECK-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to +// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , } [[TMP3]], [[TMP4]], 2 +// CHECK-NEXT: ret { , , } [[TMP5]] +// +// CHECK-CXX-LABEL: define dso_local { , , } @_Z29test_svreinterpret_mf8_s32_x311svint32x3_t( +// CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]]) #[[ATTR0]] { +// CHECK-CXX-NEXT: [[ENTRY:.*:]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , } poison, [[TMP0]], 0 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , } [[TMP1]], [[TMP2]], 1 +// CHECK-CXX-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to +// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , } [[TMP3]], [[TMP4]], 2 +// CHECK-CXX-NEXT: ret { , , } [[TMP5]] +// +svmfloat8x3_t test_svreinterpret_mf8_s32_x3(svint32x3_t op) STREAMING { + return SVE_ACLE_FUNC(svreinterpret_mf8, _s32_x3)(op); +} + +// CHECK-LABEL: define dso_local { , , } @test_svreinterpret_mf8_u32_x3( +// CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]]) #[[ATTR0]] { +// CHECK-NEXT: [[ENTRY:.*:]] +// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , } poison, [[TMP0]], 0 +// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , } [[TMP1]], [[TMP2]], 1 +// CHECK-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to +// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , } [[TMP3]], [[TMP4]], 2 +// CHECK-NEXT: ret { , , } [[TMP5]] +// +// CHECK-CXX-LABEL: define dso_local { , , } @_Z29test_svreinterpret_mf8_u32_x312svuint32x3_t( +// CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]]) #[[ATTR0]] { +// CHECK-CXX-NEXT: [[ENTRY:.*:]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , } poison, [[TMP0]], 0 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , } [[TMP1]], [[TMP2]], 1 +// CHECK-CXX-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to +// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , } [[TMP3]], [[TMP4]], 2 +// CHECK-CXX-NEXT: ret { , , } [[TMP5]] +// +svmfloat8x3_t test_svreinterpret_mf8_u32_x3(svuint32x3_t op) STREAMING { + return SVE_ACLE_FUNC(svreinterpret_mf8, _u32_x3)(op); +} + +// CHECK-LABEL: define dso_local { , , } @test_svreinterpret_mf8_s64_x3( +// CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]]) #[[ATTR0]] { +// CHECK-NEXT: [[ENTRY:.*:]] +// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , } poison, [[TMP0]], 0 +// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , } [[TMP1]], [[TMP2]], 1 +// CHECK-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to +// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , } [[TMP3]], [[TMP4]], 2 +// CHECK-NEXT: ret { , , } [[TMP5]] +// +// CHECK-CXX-LABEL: define dso_local { , , } @_Z29test_svreinterpret_mf8_s64_x311svint64x3_t( +// CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]]) #[[ATTR0]] { +// CHECK-CXX-NEXT: [[ENTRY:.*:]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , } poison, [[TMP0]], 0 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , } [[TMP1]], [[TMP2]], 1 +// CHECK-CXX-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to +// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , } [[TMP3]], [[TMP4]], 2 +// CHECK-CXX-NEXT: ret { , , } [[TMP5]] +// +svmfloat8x3_t test_svreinterpret_mf8_s64_x3(svint64x3_t op) STREAMING { + return SVE_ACLE_FUNC(svreinterpret_mf8, _s64_x3)(op); +} + +// CHECK-LABEL: define dso_local { , , } @test_svreinterpret_mf8_u64_x3( +// CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]]) #[[ATTR0]] { +// CHECK-NEXT: [[ENTRY:.*:]] +// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , } poison, [[TMP0]], 0 +// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , } [[TMP1]], [[TMP2]], 1 +// CHECK-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to +// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , } [[TMP3]], [[TMP4]], 2 +// CHECK-NEXT: ret { , , } [[TMP5]] +// +// CHECK-CXX-LABEL: define dso_local { , , } @_Z29test_svreinterpret_mf8_u64_x312svuint64x3_t( +// CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]]) #[[ATTR0]] { +// CHECK-CXX-NEXT: [[ENTRY:.*:]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , } poison, [[TMP0]], 0 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , } [[TMP1]], [[TMP2]], 1 +// CHECK-CXX-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to +// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , } [[TMP3]], [[TMP4]], 2 +// CHECK-CXX-NEXT: ret { , , } [[TMP5]] +// +svmfloat8x3_t test_svreinterpret_mf8_u64_x3(svuint64x3_t op) STREAMING { + return SVE_ACLE_FUNC(svreinterpret_mf8, _u64_x3)(op); +} + +// CHECK-LABEL: define dso_local { , , } @test_svreinterpret_mf8_f16_x3( +// CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]]) #[[ATTR0]] { +// CHECK-NEXT: [[ENTRY:.*:]] +// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , } poison, [[TMP0]], 0 +// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , } [[TMP1]], [[TMP2]], 1 +// CHECK-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to +// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , } [[TMP3]], [[TMP4]], 2 +// CHECK-NEXT: ret { , , } [[TMP5]] +// +// CHECK-CXX-LABEL: define dso_local { , , } @_Z29test_svreinterpret_mf8_f16_x313svfloat16x3_t( +// CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]]) #[[ATTR0]] { +// CHECK-CXX-NEXT: [[ENTRY:.*:]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , } poison, [[TMP0]], 0 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , } [[TMP1]], [[TMP2]], 1 +// CHECK-CXX-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to +// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , } [[TMP3]], [[TMP4]], 2 +// CHECK-CXX-NEXT: ret { , , } [[TMP5]] +// +svmfloat8x3_t test_svreinterpret_mf8_f16_x3(svfloat16x3_t op) STREAMING { + return SVE_ACLE_FUNC(svreinterpret_mf8, _f16_x3)(op); +} + +// CHECK-LABEL: define dso_local { , , } @test_svreinterpret_mf8_bf16_x3( +// CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]]) #[[ATTR0]] { +// CHECK-NEXT: [[ENTRY:.*:]] +// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , } poison, [[TMP0]], 0 +// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , } [[TMP1]], [[TMP2]], 1 +// CHECK-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to +// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , } [[TMP3]], [[TMP4]], 2 +// CHECK-NEXT: ret { , , } [[TMP5]] +// +// CHECK-CXX-LABEL: define dso_local { , , } @_Z30test_svreinterpret_mf8_bf16_x314svbfloat16x3_t( +// CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]]) #[[ATTR0]] { +// CHECK-CXX-NEXT: [[ENTRY:.*:]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , } poison, [[TMP0]], 0 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , } [[TMP1]], [[TMP2]], 1 +// CHECK-CXX-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to +// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , } [[TMP3]], [[TMP4]], 2 +// CHECK-CXX-NEXT: ret { , , } [[TMP5]] +// +svmfloat8x3_t test_svreinterpret_mf8_bf16_x3(svbfloat16x3_t op) STREAMING { + return SVE_ACLE_FUNC(svreinterpret_mf8, _bf16_x3)(op); +} + +// CHECK-LABEL: define dso_local { , , } @test_svreinterpret_mf8_f32_x3( +// CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]]) #[[ATTR0]] { +// CHECK-NEXT: [[ENTRY:.*:]] +// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , } poison, [[TMP0]], 0 +// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , } [[TMP1]], [[TMP2]], 1 +// CHECK-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to +// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , } [[TMP3]], [[TMP4]], 2 +// CHECK-NEXT: ret { , , } [[TMP5]] +// +// CHECK-CXX-LABEL: define dso_local { , , } @_Z29test_svreinterpret_mf8_f32_x313svfloat32x3_t( +// CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]]) #[[ATTR0]] { +// CHECK-CXX-NEXT: [[ENTRY:.*:]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , } poison, [[TMP0]], 0 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , } [[TMP1]], [[TMP2]], 1 +// CHECK-CXX-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to +// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , } [[TMP3]], [[TMP4]], 2 +// CHECK-CXX-NEXT: ret { , , } [[TMP5]] +// +svmfloat8x3_t test_svreinterpret_mf8_f32_x3(svfloat32x3_t op) STREAMING { + return SVE_ACLE_FUNC(svreinterpret_mf8, _f32_x3)(op); +} + +// CHECK-LABEL: define dso_local { , , } @test_svreinterpret_mf8_f64_x3( +// CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]]) #[[ATTR0]] { +// CHECK-NEXT: [[ENTRY:.*:]] +// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , } poison, [[TMP0]], 0 +// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , } [[TMP1]], [[TMP2]], 1 +// CHECK-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to +// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , } [[TMP3]], [[TMP4]], 2 +// CHECK-NEXT: ret { , , } [[TMP5]] +// +// CHECK-CXX-LABEL: define dso_local { , , } @_Z29test_svreinterpret_mf8_f64_x313svfloat64x3_t( +// CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]]) #[[ATTR0]] { +// CHECK-CXX-NEXT: [[ENTRY:.*:]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , } poison, [[TMP0]], 0 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , } [[TMP1]], [[TMP2]], 1 +// CHECK-CXX-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to +// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , } [[TMP3]], [[TMP4]], 2 +// CHECK-CXX-NEXT: ret { , , } [[TMP5]] +// +svmfloat8x3_t test_svreinterpret_mf8_f64_x3(svfloat64x3_t op) STREAMING { + return SVE_ACLE_FUNC(svreinterpret_mf8, _f64_x3)(op); +} + +// CHECK-LABEL: define dso_local { , , } @test_svreinterpret_s16_mf8_x3( +// CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]]) #[[ATTR0]] { +// CHECK-NEXT: [[ENTRY:.*:]] +// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , } poison, [[TMP0]], 0 +// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , } [[TMP1]], [[TMP2]], 1 +// CHECK-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to +// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , } [[TMP3]], [[TMP4]], 2 +// CHECK-NEXT: ret { , , } [[TMP5]] +// +// CHECK-CXX-LABEL: define dso_local { , , } @_Z29test_svreinterpret_s16_mf8_x313svmfloat8x3_t( +// CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]]) #[[ATTR0]] { +// CHECK-CXX-NEXT: [[ENTRY:.*:]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , } poison, [[TMP0]], 0 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , } [[TMP1]], [[TMP2]], 1 +// CHECK-CXX-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to +// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , } [[TMP3]], [[TMP4]], 2 +// CHECK-CXX-NEXT: ret { , , } [[TMP5]] +// +svint16x3_t test_svreinterpret_s16_mf8_x3(svmfloat8x3_t op) STREAMING { + return SVE_ACLE_FUNC(svreinterpret_s16, _mf8_x3)(op); +} + +// CHECK-LABEL: define dso_local { , , } @test_svreinterpret_u16_mf8_x3( +// CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]]) #[[ATTR0]] { +// CHECK-NEXT: [[ENTRY:.*:]] +// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , } poison, [[TMP0]], 0 +// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , } [[TMP1]], [[TMP2]], 1 +// CHECK-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to +// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , } [[TMP3]], [[TMP4]], 2 +// CHECK-NEXT: ret { , , } [[TMP5]] +// +// CHECK-CXX-LABEL: define dso_local { , , } @_Z29test_svreinterpret_u16_mf8_x313svmfloat8x3_t( +// CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]]) #[[ATTR0]] { +// CHECK-CXX-NEXT: [[ENTRY:.*:]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , } poison, [[TMP0]], 0 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , } [[TMP1]], [[TMP2]], 1 +// CHECK-CXX-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to +// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , } [[TMP3]], [[TMP4]], 2 +// CHECK-CXX-NEXT: ret { , , } [[TMP5]] +// +svuint16x3_t test_svreinterpret_u16_mf8_x3(svmfloat8x3_t op) STREAMING { + return SVE_ACLE_FUNC(svreinterpret_u16, _mf8_x3)(op); +} + +// CHECK-LABEL: define dso_local { , , } @test_svreinterpret_s32_mf8_x3( +// CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]]) #[[ATTR0]] { +// CHECK-NEXT: [[ENTRY:.*:]] +// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , } poison, [[TMP0]], 0 +// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , } [[TMP1]], [[TMP2]], 1 +// CHECK-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to +// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , } [[TMP3]], [[TMP4]], 2 +// CHECK-NEXT: ret { , , } [[TMP5]] +// +// CHECK-CXX-LABEL: define dso_local { , , } @_Z29test_svreinterpret_s32_mf8_x313svmfloat8x3_t( +// CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]]) #[[ATTR0]] { +// CHECK-CXX-NEXT: [[ENTRY:.*:]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , } poison, [[TMP0]], 0 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , } [[TMP1]], [[TMP2]], 1 +// CHECK-CXX-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to +// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , } [[TMP3]], [[TMP4]], 2 +// CHECK-CXX-NEXT: ret { , , } [[TMP5]] +// +svint32x3_t test_svreinterpret_s32_mf8_x3(svmfloat8x3_t op) STREAMING { + return SVE_ACLE_FUNC(svreinterpret_s32, _mf8_x3)(op); +} + +// CHECK-LABEL: define dso_local { , , } @test_svreinterpret_u32_mf8_x3( +// CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]]) #[[ATTR0]] { +// CHECK-NEXT: [[ENTRY:.*:]] +// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , } poison, [[TMP0]], 0 +// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , } [[TMP1]], [[TMP2]], 1 +// CHECK-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to +// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , } [[TMP3]], [[TMP4]], 2 +// CHECK-NEXT: ret { , , } [[TMP5]] +// +// CHECK-CXX-LABEL: define dso_local { , , } @_Z29test_svreinterpret_u32_mf8_x313svmfloat8x3_t( +// CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]]) #[[ATTR0]] { +// CHECK-CXX-NEXT: [[ENTRY:.*:]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , } poison, [[TMP0]], 0 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , } [[TMP1]], [[TMP2]], 1 +// CHECK-CXX-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to +// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , } [[TMP3]], [[TMP4]], 2 +// CHECK-CXX-NEXT: ret { , , } [[TMP5]] +// +svuint32x3_t test_svreinterpret_u32_mf8_x3(svmfloat8x3_t op) STREAMING { + return SVE_ACLE_FUNC(svreinterpret_u32, _mf8_x3)(op); +} + +// CHECK-LABEL: define dso_local { , , } @test_svreinterpret_s64_mf8_x3( +// CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]]) #[[ATTR0]] { +// CHECK-NEXT: [[ENTRY:.*:]] +// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , } poison, [[TMP0]], 0 +// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , } [[TMP1]], [[TMP2]], 1 +// CHECK-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to +// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , } [[TMP3]], [[TMP4]], 2 +// CHECK-NEXT: ret { , , } [[TMP5]] +// +// CHECK-CXX-LABEL: define dso_local { , , } @_Z29test_svreinterpret_s64_mf8_x313svmfloat8x3_t( +// CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]]) #[[ATTR0]] { +// CHECK-CXX-NEXT: [[ENTRY:.*:]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , } poison, [[TMP0]], 0 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , } [[TMP1]], [[TMP2]], 1 +// CHECK-CXX-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to +// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , } [[TMP3]], [[TMP4]], 2 +// CHECK-CXX-NEXT: ret { , , } [[TMP5]] +// +svint64x3_t test_svreinterpret_s64_mf8_x3(svmfloat8x3_t op) STREAMING { + return SVE_ACLE_FUNC(svreinterpret_s64, _mf8_x3)(op); +} + +// CHECK-LABEL: define dso_local { , , } @test_svreinterpret_u64_mf8_x3( +// CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]]) #[[ATTR0]] { +// CHECK-NEXT: [[ENTRY:.*:]] +// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , } poison, [[TMP0]], 0 +// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , } [[TMP1]], [[TMP2]], 1 +// CHECK-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to +// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , } [[TMP3]], [[TMP4]], 2 +// CHECK-NEXT: ret { , , } [[TMP5]] +// +// CHECK-CXX-LABEL: define dso_local { , , } @_Z29test_svreinterpret_u64_mf8_x313svmfloat8x3_t( +// CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]]) #[[ATTR0]] { +// CHECK-CXX-NEXT: [[ENTRY:.*:]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , } poison, [[TMP0]], 0 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , } [[TMP1]], [[TMP2]], 1 +// CHECK-CXX-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to +// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , } [[TMP3]], [[TMP4]], 2 +// CHECK-CXX-NEXT: ret { , , } [[TMP5]] +// +svuint64x3_t test_svreinterpret_u64_mf8_x3(svmfloat8x3_t op) STREAMING { + return SVE_ACLE_FUNC(svreinterpret_u64, _mf8_x3)(op); +} + +// CHECK-LABEL: define dso_local { , , } @test_svreinterpret_f16_mf8_x3( +// CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]]) #[[ATTR0]] { +// CHECK-NEXT: [[ENTRY:.*:]] +// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , } poison, [[TMP0]], 0 +// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , } [[TMP1]], [[TMP2]], 1 +// CHECK-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to +// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , } [[TMP3]], [[TMP4]], 2 +// CHECK-NEXT: ret { , , } [[TMP5]] +// +// CHECK-CXX-LABEL: define dso_local { , , } @_Z29test_svreinterpret_f16_mf8_x313svmfloat8x3_t( +// CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]]) #[[ATTR0]] { +// CHECK-CXX-NEXT: [[ENTRY:.*:]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , } poison, [[TMP0]], 0 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , } [[TMP1]], [[TMP2]], 1 +// CHECK-CXX-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to +// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , } [[TMP3]], [[TMP4]], 2 +// CHECK-CXX-NEXT: ret { , , } [[TMP5]] +// +svfloat16x3_t test_svreinterpret_f16_mf8_x3(svmfloat8x3_t op) STREAMING { + return SVE_ACLE_FUNC(svreinterpret_f16, _mf8_x3)(op); +} + +// CHECK-LABEL: define dso_local { , , } @test_svreinterpret_bf16_mf8_x3( +// CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]]) #[[ATTR0]] { +// CHECK-NEXT: [[ENTRY:.*:]] +// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , } poison, [[TMP0]], 0 +// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , } [[TMP1]], [[TMP2]], 1 +// CHECK-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to +// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , } [[TMP3]], [[TMP4]], 2 +// CHECK-NEXT: ret { , , } [[TMP5]] +// +// CHECK-CXX-LABEL: define dso_local { , , } @_Z30test_svreinterpret_bf16_mf8_x313svmfloat8x3_t( +// CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]]) #[[ATTR0]] { +// CHECK-CXX-NEXT: [[ENTRY:.*:]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , } poison, [[TMP0]], 0 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , } [[TMP1]], [[TMP2]], 1 +// CHECK-CXX-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to +// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , } [[TMP3]], [[TMP4]], 2 +// CHECK-CXX-NEXT: ret { , , } [[TMP5]] +// +svbfloat16x3_t test_svreinterpret_bf16_mf8_x3(svmfloat8x3_t op) STREAMING { + return SVE_ACLE_FUNC(svreinterpret_bf16, _mf8_x3)(op); +} + +// CHECK-LABEL: define dso_local { , , } @test_svreinterpret_f32_mf8_x3( +// CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]]) #[[ATTR0]] { +// CHECK-NEXT: [[ENTRY:.*:]] +// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , } poison, [[TMP0]], 0 +// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , } [[TMP1]], [[TMP2]], 1 +// CHECK-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to +// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , } [[TMP3]], [[TMP4]], 2 +// CHECK-NEXT: ret { , , } [[TMP5]] +// +// CHECK-CXX-LABEL: define dso_local { , , } @_Z29test_svreinterpret_f32_mf8_x313svmfloat8x3_t( +// CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]]) #[[ATTR0]] { +// CHECK-CXX-NEXT: [[ENTRY:.*:]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , } poison, [[TMP0]], 0 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , } [[TMP1]], [[TMP2]], 1 +// CHECK-CXX-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to +// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , } [[TMP3]], [[TMP4]], 2 +// CHECK-CXX-NEXT: ret { , , } [[TMP5]] +// +svfloat32x3_t test_svreinterpret_f32_mf8_x3(svmfloat8x3_t op) STREAMING { + return SVE_ACLE_FUNC(svreinterpret_f32, _mf8_x3)(op); +} + +// CHECK-LABEL: define dso_local { , , } @test_svreinterpret_f64_mf8_x3( +// CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]]) #[[ATTR0]] { +// CHECK-NEXT: [[ENTRY:.*:]] +// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , } poison, [[TMP0]], 0 +// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , } [[TMP1]], [[TMP2]], 1 +// CHECK-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to +// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , } [[TMP3]], [[TMP4]], 2 +// CHECK-NEXT: ret { , , } [[TMP5]] +// +// CHECK-CXX-LABEL: define dso_local { , , } @_Z29test_svreinterpret_f64_mf8_x313svmfloat8x3_t( +// CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]]) #[[ATTR0]] { +// CHECK-CXX-NEXT: [[ENTRY:.*:]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , } poison, [[TMP0]], 0 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , } [[TMP1]], [[TMP2]], 1 +// CHECK-CXX-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to +// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , } [[TMP3]], [[TMP4]], 2 +// CHECK-CXX-NEXT: ret { , , } [[TMP5]] +// +svfloat64x3_t test_svreinterpret_f64_mf8_x3(svmfloat8x3_t op) STREAMING { + return SVE_ACLE_FUNC(svreinterpret_f64, _mf8_x3)(op); +} + +// CHECK-LABEL: define dso_local { , , , } @test_svreinterpret_s8_mf8_x4( +// CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]], [[OP_COERCE3:%.*]]) #[[ATTR0]] { +// CHECK-NEXT: [[ENTRY:.*:]] +// CHECK-NEXT: [[TMP0:%.*]] = insertvalue { , , , } poison, [[OP_COERCE0]], 0 +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-NEXT: [[TMP2:%.*]] = insertvalue { , , , } [[TMP1]], [[OP_COERCE2]], 2 +// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP2]], [[OP_COERCE3]], 3 +// CHECK-NEXT: ret { , , , } [[TMP3]] +// +// CHECK-CXX-LABEL: define dso_local { , , , } @_Z28test_svreinterpret_s8_mf8_x413svmfloat8x4_t( +// CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]], [[OP_COERCE3:%.*]]) #[[ATTR0]] { +// CHECK-CXX-NEXT: [[ENTRY:.*:]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = insertvalue { , , , } poison, [[OP_COERCE0]], 0 +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = insertvalue { , , , } [[TMP1]], [[OP_COERCE2]], 2 +// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP2]], [[OP_COERCE3]], 3 +// CHECK-CXX-NEXT: ret { , , , } [[TMP3]] +// +svint8x4_t test_svreinterpret_s8_mf8_x4(svmfloat8x4_t op) STREAMING { + return SVE_ACLE_FUNC(svreinterpret_s8, _mf8_x4)(op); +} + +// CHECK-LABEL: define dso_local { , , , } @test_svreinterpret_u8_mf8_x4( +// CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]], [[OP_COERCE3:%.*]]) #[[ATTR0]] { +// CHECK-NEXT: [[ENTRY:.*:]] +// CHECK-NEXT: [[TMP0:%.*]] = insertvalue { , , , } poison, [[OP_COERCE0]], 0 +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-NEXT: [[TMP2:%.*]] = insertvalue { , , , } [[TMP1]], [[OP_COERCE2]], 2 +// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP2]], [[OP_COERCE3]], 3 +// CHECK-NEXT: ret { , , , } [[TMP3]] +// +// CHECK-CXX-LABEL: define dso_local { , , , } @_Z28test_svreinterpret_u8_mf8_x413svmfloat8x4_t( +// CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]], [[OP_COERCE3:%.*]]) #[[ATTR0]] { +// CHECK-CXX-NEXT: [[ENTRY:.*:]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = insertvalue { , , , } poison, [[OP_COERCE0]], 0 +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = insertvalue { , , , } [[TMP1]], [[OP_COERCE2]], 2 +// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP2]], [[OP_COERCE3]], 3 +// CHECK-CXX-NEXT: ret { , , , } [[TMP3]] +// +svuint8x4_t test_svreinterpret_u8_mf8_x4(svmfloat8x4_t op) STREAMING { + return SVE_ACLE_FUNC(svreinterpret_u8, _mf8_x4)(op); +} + +// CHECK-LABEL: define dso_local { , , , } @test_svreinterpret_mf8_s8_x4( +// CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]], [[OP_COERCE3:%.*]]) #[[ATTR0]] { +// CHECK-NEXT: [[ENTRY:.*:]] +// CHECK-NEXT: [[TMP0:%.*]] = insertvalue { , , , } poison, [[OP_COERCE0]], 0 +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-NEXT: [[TMP2:%.*]] = insertvalue { , , , } [[TMP1]], [[OP_COERCE2]], 2 +// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP2]], [[OP_COERCE3]], 3 +// CHECK-NEXT: ret { , , , } [[TMP3]] +// +// CHECK-CXX-LABEL: define dso_local { , , , } @_Z28test_svreinterpret_mf8_s8_x410svint8x4_t( +// CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]], [[OP_COERCE3:%.*]]) #[[ATTR0]] { +// CHECK-CXX-NEXT: [[ENTRY:.*:]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = insertvalue { , , , } poison, [[OP_COERCE0]], 0 +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = insertvalue { , , , } [[TMP1]], [[OP_COERCE2]], 2 +// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP2]], [[OP_COERCE3]], 3 +// CHECK-CXX-NEXT: ret { , , , } [[TMP3]] +// +svmfloat8x4_t test_svreinterpret_mf8_s8_x4(svint8x4_t op) STREAMING { + return SVE_ACLE_FUNC(svreinterpret_mf8, _s8_x4)(op); +} + +// CHECK-LABEL: define dso_local { , , , } @test_svreinterpret_mf8_u8_x4( +// CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]], [[OP_COERCE3:%.*]]) #[[ATTR0]] { +// CHECK-NEXT: [[ENTRY:.*:]] +// CHECK-NEXT: [[TMP0:%.*]] = insertvalue { , , , } poison, [[OP_COERCE0]], 0 +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-NEXT: [[TMP2:%.*]] = insertvalue { , , , } [[TMP1]], [[OP_COERCE2]], 2 +// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP2]], [[OP_COERCE3]], 3 +// CHECK-NEXT: ret { , , , } [[TMP3]] +// +// CHECK-CXX-LABEL: define dso_local { , , , } @_Z28test_svreinterpret_mf8_u8_x411svuint8x4_t( +// CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]], [[OP_COERCE3:%.*]]) #[[ATTR0]] { +// CHECK-CXX-NEXT: [[ENTRY:.*:]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = insertvalue { , , , } poison, [[OP_COERCE0]], 0 +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = insertvalue { , , , } [[TMP1]], [[OP_COERCE2]], 2 +// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP2]], [[OP_COERCE3]], 3 +// CHECK-CXX-NEXT: ret { , , , } [[TMP3]] +// +svmfloat8x4_t test_svreinterpret_mf8_u8_x4(svuint8x4_t op) STREAMING { + return SVE_ACLE_FUNC(svreinterpret_mf8, _u8_x4)(op); +} + +// CHECK-LABEL: define dso_local { , , , } @test_svreinterpret_mf8_mf8_x4( +// CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]], [[OP_COERCE3:%.*]]) #[[ATTR0]] { +// CHECK-NEXT: [[ENTRY:.*:]] +// CHECK-NEXT: [[TMP0:%.*]] = insertvalue { , , , } poison, [[OP_COERCE0]], 0 +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-NEXT: [[TMP2:%.*]] = insertvalue { , , , } [[TMP1]], [[OP_COERCE2]], 2 +// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP2]], [[OP_COERCE3]], 3 +// CHECK-NEXT: ret { , , , } [[TMP3]] +// +// CHECK-CXX-LABEL: define dso_local { , , , } @_Z29test_svreinterpret_mf8_mf8_x413svmfloat8x4_t( +// CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]], [[OP_COERCE3:%.*]]) #[[ATTR0]] { +// CHECK-CXX-NEXT: [[ENTRY:.*:]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = insertvalue { , , , } poison, [[OP_COERCE0]], 0 +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = insertvalue { , , , } [[TMP1]], [[OP_COERCE2]], 2 +// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP2]], [[OP_COERCE3]], 3 +// CHECK-CXX-NEXT: ret { , , , } [[TMP3]] +// +svmfloat8x4_t test_svreinterpret_mf8_mf8_x4(svmfloat8x4_t op) STREAMING { + return SVE_ACLE_FUNC(svreinterpret_mf8, _mf8_x4)(op); +} + +// CHECK-LABEL: define dso_local { , , , } @test_svreinterpret_mf8_s16_x4( +// CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]], [[OP_COERCE3:%.*]]) #[[ATTR0]] { +// CHECK-NEXT: [[ENTRY:.*:]] +// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , , } poison, [[TMP0]], 0 +// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP1]], [[TMP2]], 1 +// CHECK-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to +// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , , } [[TMP3]], [[TMP4]], 2 +// CHECK-NEXT: [[TMP6:%.*]] = bitcast [[OP_COERCE3]] to +// CHECK-NEXT: [[TMP7:%.*]] = insertvalue { , , , } [[TMP5]], [[TMP6]], 3 +// CHECK-NEXT: ret { , , , } [[TMP7]] +// +// CHECK-CXX-LABEL: define dso_local { , , , } @_Z29test_svreinterpret_mf8_s16_x411svint16x4_t( +// CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]], [[OP_COERCE3:%.*]]) #[[ATTR0]] { +// CHECK-CXX-NEXT: [[ENTRY:.*:]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , , } poison, [[TMP0]], 0 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP1]], [[TMP2]], 1 +// CHECK-CXX-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to +// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , , } [[TMP3]], [[TMP4]], 2 +// CHECK-CXX-NEXT: [[TMP6:%.*]] = bitcast [[OP_COERCE3]] to +// CHECK-CXX-NEXT: [[TMP7:%.*]] = insertvalue { , , , } [[TMP5]], [[TMP6]], 3 +// CHECK-CXX-NEXT: ret { , , , } [[TMP7]] +// +svmfloat8x4_t test_svreinterpret_mf8_s16_x4(svint16x4_t op) STREAMING { + return SVE_ACLE_FUNC(svreinterpret_mf8, _s16_x4)(op); +} + +// CHECK-LABEL: define dso_local { , , , } @test_svreinterpret_mf8_u16_x4( +// CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]], [[OP_COERCE3:%.*]]) #[[ATTR0]] { +// CHECK-NEXT: [[ENTRY:.*:]] +// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , , } poison, [[TMP0]], 0 +// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP1]], [[TMP2]], 1 +// CHECK-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to +// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , , } [[TMP3]], [[TMP4]], 2 +// CHECK-NEXT: [[TMP6:%.*]] = bitcast [[OP_COERCE3]] to +// CHECK-NEXT: [[TMP7:%.*]] = insertvalue { , , , } [[TMP5]], [[TMP6]], 3 +// CHECK-NEXT: ret { , , , } [[TMP7]] +// +// CHECK-CXX-LABEL: define dso_local { , , , } @_Z29test_svreinterpret_mf8_u16_x412svuint16x4_t( +// CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]], [[OP_COERCE3:%.*]]) #[[ATTR0]] { +// CHECK-CXX-NEXT: [[ENTRY:.*:]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , , } poison, [[TMP0]], 0 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP1]], [[TMP2]], 1 +// CHECK-CXX-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to +// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , , } [[TMP3]], [[TMP4]], 2 +// CHECK-CXX-NEXT: [[TMP6:%.*]] = bitcast [[OP_COERCE3]] to +// CHECK-CXX-NEXT: [[TMP7:%.*]] = insertvalue { , , , } [[TMP5]], [[TMP6]], 3 +// CHECK-CXX-NEXT: ret { , , , } [[TMP7]] +// +svmfloat8x4_t test_svreinterpret_mf8_u16_x4(svuint16x4_t op) STREAMING { + return SVE_ACLE_FUNC(svreinterpret_mf8, _u16_x4)(op); +} + +// CHECK-LABEL: define dso_local { , , , } @test_svreinterpret_mf8_s32_x4( +// CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]], [[OP_COERCE3:%.*]]) #[[ATTR0]] { +// CHECK-NEXT: [[ENTRY:.*:]] +// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , , } poison, [[TMP0]], 0 +// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP1]], [[TMP2]], 1 +// CHECK-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to +// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , , } [[TMP3]], [[TMP4]], 2 +// CHECK-NEXT: [[TMP6:%.*]] = bitcast [[OP_COERCE3]] to +// CHECK-NEXT: [[TMP7:%.*]] = insertvalue { , , , } [[TMP5]], [[TMP6]], 3 +// CHECK-NEXT: ret { , , , } [[TMP7]] +// +// CHECK-CXX-LABEL: define dso_local { , , , } @_Z29test_svreinterpret_mf8_s32_x411svint32x4_t( +// CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]], [[OP_COERCE3:%.*]]) #[[ATTR0]] { +// CHECK-CXX-NEXT: [[ENTRY:.*:]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , , } poison, [[TMP0]], 0 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP1]], [[TMP2]], 1 +// CHECK-CXX-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to +// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , , } [[TMP3]], [[TMP4]], 2 +// CHECK-CXX-NEXT: [[TMP6:%.*]] = bitcast [[OP_COERCE3]] to +// CHECK-CXX-NEXT: [[TMP7:%.*]] = insertvalue { , , , } [[TMP5]], [[TMP6]], 3 +// CHECK-CXX-NEXT: ret { , , , } [[TMP7]] +// +svmfloat8x4_t test_svreinterpret_mf8_s32_x4(svint32x4_t op) STREAMING { + return SVE_ACLE_FUNC(svreinterpret_mf8, _s32_x4)(op); +} + +// CHECK-LABEL: define dso_local { , , , } @test_svreinterpret_mf8_u32_x4( +// CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]], [[OP_COERCE3:%.*]]) #[[ATTR0]] { +// CHECK-NEXT: [[ENTRY:.*:]] +// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , , } poison, [[TMP0]], 0 +// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP1]], [[TMP2]], 1 +// CHECK-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to +// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , , } [[TMP3]], [[TMP4]], 2 +// CHECK-NEXT: [[TMP6:%.*]] = bitcast [[OP_COERCE3]] to +// CHECK-NEXT: [[TMP7:%.*]] = insertvalue { , , , } [[TMP5]], [[TMP6]], 3 +// CHECK-NEXT: ret { , , , } [[TMP7]] +// +// CHECK-CXX-LABEL: define dso_local { , , , } @_Z29test_svreinterpret_mf8_u32_x412svuint32x4_t( +// CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]], [[OP_COERCE3:%.*]]) #[[ATTR0]] { +// CHECK-CXX-NEXT: [[ENTRY:.*:]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , , } poison, [[TMP0]], 0 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP1]], [[TMP2]], 1 +// CHECK-CXX-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to +// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , , } [[TMP3]], [[TMP4]], 2 +// CHECK-CXX-NEXT: [[TMP6:%.*]] = bitcast [[OP_COERCE3]] to +// CHECK-CXX-NEXT: [[TMP7:%.*]] = insertvalue { , , , } [[TMP5]], [[TMP6]], 3 +// CHECK-CXX-NEXT: ret { , , , } [[TMP7]] +// +svmfloat8x4_t test_svreinterpret_mf8_u32_x4(svuint32x4_t op) STREAMING { + return SVE_ACLE_FUNC(svreinterpret_mf8, _u32_x4)(op); +} + +// CHECK-LABEL: define dso_local { , , , } @test_svreinterpret_mf8_s64_x4( +// CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]], [[OP_COERCE3:%.*]]) #[[ATTR0]] { +// CHECK-NEXT: [[ENTRY:.*:]] +// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , , } poison, [[TMP0]], 0 +// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP1]], [[TMP2]], 1 +// CHECK-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to +// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , , } [[TMP3]], [[TMP4]], 2 +// CHECK-NEXT: [[TMP6:%.*]] = bitcast [[OP_COERCE3]] to +// CHECK-NEXT: [[TMP7:%.*]] = insertvalue { , , , } [[TMP5]], [[TMP6]], 3 +// CHECK-NEXT: ret { , , , } [[TMP7]] +// +// CHECK-CXX-LABEL: define dso_local { , , , } @_Z29test_svreinterpret_mf8_s64_x411svint64x4_t( +// CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]], [[OP_COERCE3:%.*]]) #[[ATTR0]] { +// CHECK-CXX-NEXT: [[ENTRY:.*:]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , , } poison, [[TMP0]], 0 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP1]], [[TMP2]], 1 +// CHECK-CXX-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to +// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , , } [[TMP3]], [[TMP4]], 2 +// CHECK-CXX-NEXT: [[TMP6:%.*]] = bitcast [[OP_COERCE3]] to +// CHECK-CXX-NEXT: [[TMP7:%.*]] = insertvalue { , , , } [[TMP5]], [[TMP6]], 3 +// CHECK-CXX-NEXT: ret { , , , } [[TMP7]] +// +svmfloat8x4_t test_svreinterpret_mf8_s64_x4(svint64x4_t op) STREAMING { + return SVE_ACLE_FUNC(svreinterpret_mf8, _s64_x4)(op); +} + +// CHECK-LABEL: define dso_local { , , , } @test_svreinterpret_mf8_u64_x4( +// CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]], [[OP_COERCE3:%.*]]) #[[ATTR0]] { +// CHECK-NEXT: [[ENTRY:.*:]] +// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , , } poison, [[TMP0]], 0 +// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP1]], [[TMP2]], 1 +// CHECK-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to +// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , , } [[TMP3]], [[TMP4]], 2 +// CHECK-NEXT: [[TMP6:%.*]] = bitcast [[OP_COERCE3]] to +// CHECK-NEXT: [[TMP7:%.*]] = insertvalue { , , , } [[TMP5]], [[TMP6]], 3 +// CHECK-NEXT: ret { , , , } [[TMP7]] +// +// CHECK-CXX-LABEL: define dso_local { , , , } @_Z29test_svreinterpret_mf8_u64_x412svuint64x4_t( +// CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]], [[OP_COERCE3:%.*]]) #[[ATTR0]] { +// CHECK-CXX-NEXT: [[ENTRY:.*:]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , , } poison, [[TMP0]], 0 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP1]], [[TMP2]], 1 +// CHECK-CXX-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to +// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , , } [[TMP3]], [[TMP4]], 2 +// CHECK-CXX-NEXT: [[TMP6:%.*]] = bitcast [[OP_COERCE3]] to +// CHECK-CXX-NEXT: [[TMP7:%.*]] = insertvalue { , , , } [[TMP5]], [[TMP6]], 3 +// CHECK-CXX-NEXT: ret { , , , } [[TMP7]] +// +svmfloat8x4_t test_svreinterpret_mf8_u64_x4(svuint64x4_t op) STREAMING { + return SVE_ACLE_FUNC(svreinterpret_mf8, _u64_x4)(op); +} + +// CHECK-LABEL: define dso_local { , , , } @test_svreinterpret_mf8_f16_x4( +// CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]], [[OP_COERCE3:%.*]]) #[[ATTR0]] { +// CHECK-NEXT: [[ENTRY:.*:]] +// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , , } poison, [[TMP0]], 0 +// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP1]], [[TMP2]], 1 +// CHECK-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to +// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , , } [[TMP3]], [[TMP4]], 2 +// CHECK-NEXT: [[TMP6:%.*]] = bitcast [[OP_COERCE3]] to +// CHECK-NEXT: [[TMP7:%.*]] = insertvalue { , , , } [[TMP5]], [[TMP6]], 3 +// CHECK-NEXT: ret { , , , } [[TMP7]] +// +// CHECK-CXX-LABEL: define dso_local { , , , } @_Z29test_svreinterpret_mf8_f16_x413svfloat16x4_t( +// CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]], [[OP_COERCE3:%.*]]) #[[ATTR0]] { +// CHECK-CXX-NEXT: [[ENTRY:.*:]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , , } poison, [[TMP0]], 0 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP1]], [[TMP2]], 1 +// CHECK-CXX-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to +// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , , } [[TMP3]], [[TMP4]], 2 +// CHECK-CXX-NEXT: [[TMP6:%.*]] = bitcast [[OP_COERCE3]] to +// CHECK-CXX-NEXT: [[TMP7:%.*]] = insertvalue { , , , } [[TMP5]], [[TMP6]], 3 +// CHECK-CXX-NEXT: ret { , , , } [[TMP7]] +// +svmfloat8x4_t test_svreinterpret_mf8_f16_x4(svfloat16x4_t op) STREAMING { + return SVE_ACLE_FUNC(svreinterpret_mf8, _f16_x4)(op); +} + +// CHECK-LABEL: define dso_local { , , , } @test_svreinterpret_mf8_bf16_x4( +// CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]], [[OP_COERCE3:%.*]]) #[[ATTR0]] { +// CHECK-NEXT: [[ENTRY:.*:]] +// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , , } poison, [[TMP0]], 0 +// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP1]], [[TMP2]], 1 +// CHECK-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to +// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , , } [[TMP3]], [[TMP4]], 2 +// CHECK-NEXT: [[TMP6:%.*]] = bitcast [[OP_COERCE3]] to +// CHECK-NEXT: [[TMP7:%.*]] = insertvalue { , , , } [[TMP5]], [[TMP6]], 3 +// CHECK-NEXT: ret { , , , } [[TMP7]] +// +// CHECK-CXX-LABEL: define dso_local { , , , } @_Z30test_svreinterpret_mf8_bf16_x414svbfloat16x4_t( +// CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]], [[OP_COERCE3:%.*]]) #[[ATTR0]] { +// CHECK-CXX-NEXT: [[ENTRY:.*:]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , , } poison, [[TMP0]], 0 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP1]], [[TMP2]], 1 +// CHECK-CXX-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to +// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , , } [[TMP3]], [[TMP4]], 2 +// CHECK-CXX-NEXT: [[TMP6:%.*]] = bitcast [[OP_COERCE3]] to +// CHECK-CXX-NEXT: [[TMP7:%.*]] = insertvalue { , , , } [[TMP5]], [[TMP6]], 3 +// CHECK-CXX-NEXT: ret { , , , } [[TMP7]] +// +svmfloat8x4_t test_svreinterpret_mf8_bf16_x4(svbfloat16x4_t op) STREAMING { + return SVE_ACLE_FUNC(svreinterpret_mf8, _bf16_x4)(op); +} + +// CHECK-LABEL: define dso_local { , , , } @test_svreinterpret_mf8_f32_x4( +// CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]], [[OP_COERCE3:%.*]]) #[[ATTR0]] { +// CHECK-NEXT: [[ENTRY:.*:]] +// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , , } poison, [[TMP0]], 0 +// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP1]], [[TMP2]], 1 +// CHECK-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to +// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , , } [[TMP3]], [[TMP4]], 2 +// CHECK-NEXT: [[TMP6:%.*]] = bitcast [[OP_COERCE3]] to +// CHECK-NEXT: [[TMP7:%.*]] = insertvalue { , , , } [[TMP5]], [[TMP6]], 3 +// CHECK-NEXT: ret { , , , } [[TMP7]] +// +// CHECK-CXX-LABEL: define dso_local { , , , } @_Z29test_svreinterpret_mf8_f32_x413svfloat32x4_t( +// CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]], [[OP_COERCE3:%.*]]) #[[ATTR0]] { +// CHECK-CXX-NEXT: [[ENTRY:.*:]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , , } poison, [[TMP0]], 0 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP1]], [[TMP2]], 1 +// CHECK-CXX-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to +// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , , } [[TMP3]], [[TMP4]], 2 +// CHECK-CXX-NEXT: [[TMP6:%.*]] = bitcast [[OP_COERCE3]] to +// CHECK-CXX-NEXT: [[TMP7:%.*]] = insertvalue { , , , } [[TMP5]], [[TMP6]], 3 +// CHECK-CXX-NEXT: ret { , , , } [[TMP7]] +// +svmfloat8x4_t test_svreinterpret_mf8_f32_x4(svfloat32x4_t op) STREAMING { + return SVE_ACLE_FUNC(svreinterpret_mf8, _f32_x4)(op); +} + +// CHECK-LABEL: define dso_local { , , , } @test_svreinterpret_mf8_f64_x4( +// CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]], [[OP_COERCE3:%.*]]) #[[ATTR0]] { +// CHECK-NEXT: [[ENTRY:.*:]] +// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , , } poison, [[TMP0]], 0 +// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP1]], [[TMP2]], 1 +// CHECK-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to +// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , , } [[TMP3]], [[TMP4]], 2 +// CHECK-NEXT: [[TMP6:%.*]] = bitcast [[OP_COERCE3]] to +// CHECK-NEXT: [[TMP7:%.*]] = insertvalue { , , , } [[TMP5]], [[TMP6]], 3 +// CHECK-NEXT: ret { , , , } [[TMP7]] +// +// CHECK-CXX-LABEL: define dso_local { , , , } @_Z29test_svreinterpret_mf8_f64_x413svfloat64x4_t( +// CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]], [[OP_COERCE3:%.*]]) #[[ATTR0]] { +// CHECK-CXX-NEXT: [[ENTRY:.*:]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , , } poison, [[TMP0]], 0 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP1]], [[TMP2]], 1 +// CHECK-CXX-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to +// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , , } [[TMP3]], [[TMP4]], 2 +// CHECK-CXX-NEXT: [[TMP6:%.*]] = bitcast [[OP_COERCE3]] to +// CHECK-CXX-NEXT: [[TMP7:%.*]] = insertvalue { , , , } [[TMP5]], [[TMP6]], 3 +// CHECK-CXX-NEXT: ret { , , , } [[TMP7]] +// +svmfloat8x4_t test_svreinterpret_mf8_f64_x4(svfloat64x4_t op) STREAMING { + return SVE_ACLE_FUNC(svreinterpret_mf8, _f64_x4)(op); +} + +// CHECK-LABEL: define dso_local { , , , } @test_svreinterpret_s16_mf8_x4( +// CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]], [[OP_COERCE3:%.*]]) #[[ATTR0]] { +// CHECK-NEXT: [[ENTRY:.*:]] +// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , , } poison, [[TMP0]], 0 +// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP1]], [[TMP2]], 1 +// CHECK-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to +// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , , } [[TMP3]], [[TMP4]], 2 +// CHECK-NEXT: [[TMP6:%.*]] = bitcast [[OP_COERCE3]] to +// CHECK-NEXT: [[TMP7:%.*]] = insertvalue { , , , } [[TMP5]], [[TMP6]], 3 +// CHECK-NEXT: ret { , , , } [[TMP7]] +// +// CHECK-CXX-LABEL: define dso_local { , , , } @_Z29test_svreinterpret_s16_mf8_x413svmfloat8x4_t( +// CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]], [[OP_COERCE3:%.*]]) #[[ATTR0]] { +// CHECK-CXX-NEXT: [[ENTRY:.*:]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , , } poison, [[TMP0]], 0 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP1]], [[TMP2]], 1 +// CHECK-CXX-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to +// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , , } [[TMP3]], [[TMP4]], 2 +// CHECK-CXX-NEXT: [[TMP6:%.*]] = bitcast [[OP_COERCE3]] to +// CHECK-CXX-NEXT: [[TMP7:%.*]] = insertvalue { , , , } [[TMP5]], [[TMP6]], 3 +// CHECK-CXX-NEXT: ret { , , , } [[TMP7]] +// +svint16x4_t test_svreinterpret_s16_mf8_x4(svmfloat8x4_t op) STREAMING { + return SVE_ACLE_FUNC(svreinterpret_s16, _mf8_x4)(op); +} + +// CHECK-LABEL: define dso_local { , , , } @test_svreinterpret_u16_mf8_x4( +// CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]], [[OP_COERCE3:%.*]]) #[[ATTR0]] { +// CHECK-NEXT: [[ENTRY:.*:]] +// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , , } poison, [[TMP0]], 0 +// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP1]], [[TMP2]], 1 +// CHECK-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to +// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , , } [[TMP3]], [[TMP4]], 2 +// CHECK-NEXT: [[TMP6:%.*]] = bitcast [[OP_COERCE3]] to +// CHECK-NEXT: [[TMP7:%.*]] = insertvalue { , , , } [[TMP5]], [[TMP6]], 3 +// CHECK-NEXT: ret { , , , } [[TMP7]] +// +// CHECK-CXX-LABEL: define dso_local { , , , } @_Z29test_svreinterpret_u16_mf8_x413svmfloat8x4_t( +// CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]], [[OP_COERCE3:%.*]]) #[[ATTR0]] { +// CHECK-CXX-NEXT: [[ENTRY:.*:]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , , } poison, [[TMP0]], 0 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP1]], [[TMP2]], 1 +// CHECK-CXX-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to +// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , , } [[TMP3]], [[TMP4]], 2 +// CHECK-CXX-NEXT: [[TMP6:%.*]] = bitcast [[OP_COERCE3]] to +// CHECK-CXX-NEXT: [[TMP7:%.*]] = insertvalue { , , , } [[TMP5]], [[TMP6]], 3 +// CHECK-CXX-NEXT: ret { , , , } [[TMP7]] +// +svuint16x4_t test_svreinterpret_u16_mf8_x4(svmfloat8x4_t op) STREAMING { + return SVE_ACLE_FUNC(svreinterpret_u16, _mf8_x4)(op); +} + +// CHECK-LABEL: define dso_local { , , , } @test_svreinterpret_s32_mf8_x4( +// CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]], [[OP_COERCE3:%.*]]) #[[ATTR0]] { +// CHECK-NEXT: [[ENTRY:.*:]] +// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , , } poison, [[TMP0]], 0 +// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP1]], [[TMP2]], 1 +// CHECK-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to +// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , , } [[TMP3]], [[TMP4]], 2 +// CHECK-NEXT: [[TMP6:%.*]] = bitcast [[OP_COERCE3]] to +// CHECK-NEXT: [[TMP7:%.*]] = insertvalue { , , , } [[TMP5]], [[TMP6]], 3 +// CHECK-NEXT: ret { , , , } [[TMP7]] +// +// CHECK-CXX-LABEL: define dso_local { , , , } @_Z29test_svreinterpret_s32_mf8_x413svmfloat8x4_t( +// CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]], [[OP_COERCE3:%.*]]) #[[ATTR0]] { +// CHECK-CXX-NEXT: [[ENTRY:.*:]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , , } poison, [[TMP0]], 0 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP1]], [[TMP2]], 1 +// CHECK-CXX-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to +// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , , } [[TMP3]], [[TMP4]], 2 +// CHECK-CXX-NEXT: [[TMP6:%.*]] = bitcast [[OP_COERCE3]] to +// CHECK-CXX-NEXT: [[TMP7:%.*]] = insertvalue { , , , } [[TMP5]], [[TMP6]], 3 +// CHECK-CXX-NEXT: ret { , , , } [[TMP7]] +// +svint32x4_t test_svreinterpret_s32_mf8_x4(svmfloat8x4_t op) STREAMING { + return SVE_ACLE_FUNC(svreinterpret_s32, _mf8_x4)(op); +} + +// CHECK-LABEL: define dso_local { , , , } @test_svreinterpret_u32_mf8_x4( +// CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]], [[OP_COERCE3:%.*]]) #[[ATTR0]] { +// CHECK-NEXT: [[ENTRY:.*:]] +// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , , } poison, [[TMP0]], 0 +// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP1]], [[TMP2]], 1 +// CHECK-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to +// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , , } [[TMP3]], [[TMP4]], 2 +// CHECK-NEXT: [[TMP6:%.*]] = bitcast [[OP_COERCE3]] to +// CHECK-NEXT: [[TMP7:%.*]] = insertvalue { , , , } [[TMP5]], [[TMP6]], 3 +// CHECK-NEXT: ret { , , , } [[TMP7]] +// +// CHECK-CXX-LABEL: define dso_local { , , , } @_Z29test_svreinterpret_u32_mf8_x413svmfloat8x4_t( +// CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]], [[OP_COERCE3:%.*]]) #[[ATTR0]] { +// CHECK-CXX-NEXT: [[ENTRY:.*:]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , , } poison, [[TMP0]], 0 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP1]], [[TMP2]], 1 +// CHECK-CXX-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to +// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , , } [[TMP3]], [[TMP4]], 2 +// CHECK-CXX-NEXT: [[TMP6:%.*]] = bitcast [[OP_COERCE3]] to +// CHECK-CXX-NEXT: [[TMP7:%.*]] = insertvalue { , , , } [[TMP5]], [[TMP6]], 3 +// CHECK-CXX-NEXT: ret { , , , } [[TMP7]] +// +svuint32x4_t test_svreinterpret_u32_mf8_x4(svmfloat8x4_t op) STREAMING { + return SVE_ACLE_FUNC(svreinterpret_u32, _mf8_x4)(op); +} + +// CHECK-LABEL: define dso_local { , , , } @test_svreinterpret_s64_mf8_x4( +// CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]], [[OP_COERCE3:%.*]]) #[[ATTR0]] { +// CHECK-NEXT: [[ENTRY:.*:]] +// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , , } poison, [[TMP0]], 0 +// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP1]], [[TMP2]], 1 +// CHECK-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to +// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , , } [[TMP3]], [[TMP4]], 2 +// CHECK-NEXT: [[TMP6:%.*]] = bitcast [[OP_COERCE3]] to +// CHECK-NEXT: [[TMP7:%.*]] = insertvalue { , , , } [[TMP5]], [[TMP6]], 3 +// CHECK-NEXT: ret { , , , } [[TMP7]] +// +// CHECK-CXX-LABEL: define dso_local { , , , } @_Z29test_svreinterpret_s64_mf8_x413svmfloat8x4_t( +// CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]], [[OP_COERCE3:%.*]]) #[[ATTR0]] { +// CHECK-CXX-NEXT: [[ENTRY:.*:]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , , } poison, [[TMP0]], 0 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP1]], [[TMP2]], 1 +// CHECK-CXX-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to +// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , , } [[TMP3]], [[TMP4]], 2 +// CHECK-CXX-NEXT: [[TMP6:%.*]] = bitcast [[OP_COERCE3]] to +// CHECK-CXX-NEXT: [[TMP7:%.*]] = insertvalue { , , , } [[TMP5]], [[TMP6]], 3 +// CHECK-CXX-NEXT: ret { , , , } [[TMP7]] +// +svint64x4_t test_svreinterpret_s64_mf8_x4(svmfloat8x4_t op) STREAMING { + return SVE_ACLE_FUNC(svreinterpret_s64, _mf8_x4)(op); +} + +// CHECK-LABEL: define dso_local { , , , } @test_svreinterpret_u64_mf8_x4( +// CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]], [[OP_COERCE3:%.*]]) #[[ATTR0]] { +// CHECK-NEXT: [[ENTRY:.*:]] +// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , , } poison, [[TMP0]], 0 +// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP1]], [[TMP2]], 1 +// CHECK-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to +// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , , } [[TMP3]], [[TMP4]], 2 +// CHECK-NEXT: [[TMP6:%.*]] = bitcast [[OP_COERCE3]] to +// CHECK-NEXT: [[TMP7:%.*]] = insertvalue { , , , } [[TMP5]], [[TMP6]], 3 +// CHECK-NEXT: ret { , , , } [[TMP7]] +// +// CHECK-CXX-LABEL: define dso_local { , , , } @_Z29test_svreinterpret_u64_mf8_x413svmfloat8x4_t( +// CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]], [[OP_COERCE3:%.*]]) #[[ATTR0]] { +// CHECK-CXX-NEXT: [[ENTRY:.*:]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , , } poison, [[TMP0]], 0 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP1]], [[TMP2]], 1 +// CHECK-CXX-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to +// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , , } [[TMP3]], [[TMP4]], 2 +// CHECK-CXX-NEXT: [[TMP6:%.*]] = bitcast [[OP_COERCE3]] to +// CHECK-CXX-NEXT: [[TMP7:%.*]] = insertvalue { , , , } [[TMP5]], [[TMP6]], 3 +// CHECK-CXX-NEXT: ret { , , , } [[TMP7]] +// +svuint64x4_t test_svreinterpret_u64_mf8_x4(svmfloat8x4_t op) STREAMING { + return SVE_ACLE_FUNC(svreinterpret_u64, _mf8_x4)(op); +} + +// CHECK-LABEL: define dso_local { , , , } @test_svreinterpret_f16_mf8_x4( +// CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]], [[OP_COERCE3:%.*]]) #[[ATTR0]] { +// CHECK-NEXT: [[ENTRY:.*:]] +// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , , } poison, [[TMP0]], 0 +// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP1]], [[TMP2]], 1 +// CHECK-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to +// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , , } [[TMP3]], [[TMP4]], 2 +// CHECK-NEXT: [[TMP6:%.*]] = bitcast [[OP_COERCE3]] to +// CHECK-NEXT: [[TMP7:%.*]] = insertvalue { , , , } [[TMP5]], [[TMP6]], 3 +// CHECK-NEXT: ret { , , , } [[TMP7]] +// +// CHECK-CXX-LABEL: define dso_local { , , , } @_Z29test_svreinterpret_f16_mf8_x413svmfloat8x4_t( +// CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]], [[OP_COERCE3:%.*]]) #[[ATTR0]] { +// CHECK-CXX-NEXT: [[ENTRY:.*:]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , , } poison, [[TMP0]], 0 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP1]], [[TMP2]], 1 +// CHECK-CXX-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to +// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , , } [[TMP3]], [[TMP4]], 2 +// CHECK-CXX-NEXT: [[TMP6:%.*]] = bitcast [[OP_COERCE3]] to +// CHECK-CXX-NEXT: [[TMP7:%.*]] = insertvalue { , , , } [[TMP5]], [[TMP6]], 3 +// CHECK-CXX-NEXT: ret { , , , } [[TMP7]] +// +svfloat16x4_t test_svreinterpret_f16_mf8_x4(svmfloat8x4_t op) STREAMING { + return SVE_ACLE_FUNC(svreinterpret_f16, _mf8_x4)(op); +} + +// CHECK-LABEL: define dso_local { , , , } @test_svreinterpret_bf16_mf8_x4( +// CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]], [[OP_COERCE3:%.*]]) #[[ATTR0]] { +// CHECK-NEXT: [[ENTRY:.*:]] +// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , , } poison, [[TMP0]], 0 +// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP1]], [[TMP2]], 1 +// CHECK-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to +// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , , } [[TMP3]], [[TMP4]], 2 +// CHECK-NEXT: [[TMP6:%.*]] = bitcast [[OP_COERCE3]] to +// CHECK-NEXT: [[TMP7:%.*]] = insertvalue { , , , } [[TMP5]], [[TMP6]], 3 +// CHECK-NEXT: ret { , , , } [[TMP7]] +// +// CHECK-CXX-LABEL: define dso_local { , , , } @_Z30test_svreinterpret_bf16_mf8_x413svmfloat8x4_t( +// CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]], [[OP_COERCE3:%.*]]) #[[ATTR0]] { +// CHECK-CXX-NEXT: [[ENTRY:.*:]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , , } poison, [[TMP0]], 0 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP1]], [[TMP2]], 1 +// CHECK-CXX-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to +// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , , } [[TMP3]], [[TMP4]], 2 +// CHECK-CXX-NEXT: [[TMP6:%.*]] = bitcast [[OP_COERCE3]] to +// CHECK-CXX-NEXT: [[TMP7:%.*]] = insertvalue { , , , } [[TMP5]], [[TMP6]], 3 +// CHECK-CXX-NEXT: ret { , , , } [[TMP7]] +// +svbfloat16x4_t test_svreinterpret_bf16_mf8_x4(svmfloat8x4_t op) STREAMING { + return SVE_ACLE_FUNC(svreinterpret_bf16, _mf8_x4)(op); +} + +// CHECK-LABEL: define dso_local { , , , } @test_svreinterpret_f32_mf8_x4( +// CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]], [[OP_COERCE3:%.*]]) #[[ATTR0]] { +// CHECK-NEXT: [[ENTRY:.*:]] +// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , , } poison, [[TMP0]], 0 +// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP1]], [[TMP2]], 1 +// CHECK-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to +// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , , } [[TMP3]], [[TMP4]], 2 +// CHECK-NEXT: [[TMP6:%.*]] = bitcast [[OP_COERCE3]] to +// CHECK-NEXT: [[TMP7:%.*]] = insertvalue { , , , } [[TMP5]], [[TMP6]], 3 +// CHECK-NEXT: ret { , , , } [[TMP7]] +// +// CHECK-CXX-LABEL: define dso_local { , , , } @_Z29test_svreinterpret_f32_mf8_x413svmfloat8x4_t( +// CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]], [[OP_COERCE3:%.*]]) #[[ATTR0]] { +// CHECK-CXX-NEXT: [[ENTRY:.*:]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , , } poison, [[TMP0]], 0 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP1]], [[TMP2]], 1 +// CHECK-CXX-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to +// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , , } [[TMP3]], [[TMP4]], 2 +// CHECK-CXX-NEXT: [[TMP6:%.*]] = bitcast [[OP_COERCE3]] to +// CHECK-CXX-NEXT: [[TMP7:%.*]] = insertvalue { , , , } [[TMP5]], [[TMP6]], 3 +// CHECK-CXX-NEXT: ret { , , , } [[TMP7]] +// +svfloat32x4_t test_svreinterpret_f32_mf8_x4(svmfloat8x4_t op) STREAMING { + return SVE_ACLE_FUNC(svreinterpret_f32, _mf8_x4)(op); +} + +// CHECK-LABEL: define dso_local { , , , } @test_svreinterpret_f64_mf8_x4( +// CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]], [[OP_COERCE3:%.*]]) #[[ATTR0]] { +// CHECK-NEXT: [[ENTRY:.*:]] +// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , , } poison, [[TMP0]], 0 +// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP1]], [[TMP2]], 1 +// CHECK-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to +// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , , } [[TMP3]], [[TMP4]], 2 +// CHECK-NEXT: [[TMP6:%.*]] = bitcast [[OP_COERCE3]] to +// CHECK-NEXT: [[TMP7:%.*]] = insertvalue { , , , } [[TMP5]], [[TMP6]], 3 +// CHECK-NEXT: ret { , , , } [[TMP7]] +// +// CHECK-CXX-LABEL: define dso_local { , , , } @_Z29test_svreinterpret_f64_mf8_x413svmfloat8x4_t( +// CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]], [[OP_COERCE3:%.*]]) #[[ATTR0]] { +// CHECK-CXX-NEXT: [[ENTRY:.*:]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , , } poison, [[TMP0]], 0 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to +// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP1]], [[TMP2]], 1 +// CHECK-CXX-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to +// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , , } [[TMP3]], [[TMP4]], 2 +// CHECK-CXX-NEXT: [[TMP6:%.*]] = bitcast [[OP_COERCE3]] to +// CHECK-CXX-NEXT: [[TMP7:%.*]] = insertvalue { , , , } [[TMP5]], [[TMP6]], 3 +// CHECK-CXX-NEXT: ret { , , , } [[TMP7]] +// +svfloat64x4_t test_svreinterpret_f64_mf8_x4(svmfloat8x4_t op) STREAMING { + return SVE_ACLE_FUNC(svreinterpret_f64, _mf8_x4)(op); +} diff --git a/clang/utils/TableGen/SveEmitter.cpp b/clang/utils/TableGen/SveEmitter.cpp index 97b768db3a313..35477cfc3cf45 100644 --- a/clang/utils/TableGen/SveEmitter.cpp +++ b/clang/utils/TableGen/SveEmitter.cpp @@ -295,7 +295,7 @@ class SVEEmitter { const char *Suffix; }; - static const std::array Reinterprets; + static const std::array Reinterprets; const RecordKeeper &Records; StringMap EltTypes; @@ -418,9 +418,10 @@ class SVEEmitter { SmallVectorImpl> &Out); }; -const std::array SVEEmitter::Reinterprets = +const std::array SVEEmitter::Reinterprets = {{{SVEType("c", 'd'), "s8"}, {SVEType("Uc", 'd'), "u8"}, + {SVEType("m", 'd'), "mf8"}, {SVEType("s", 'd'), "s16"}, {SVEType("Us", 'd'), "u16"}, {SVEType("i", 'd'), "s32"}, From ce075ee9e88142edfce5e3825ec27baab8c8c49b Mon Sep 17 00:00:00 2001 From: Momchil Velikov Date: Mon, 13 Jan 2025 15:27:29 +0000 Subject: [PATCH 2/2] [fixup] Leave only mem2reg in opt pipeline for tests --- .../acle_sve2_fp8_reinterpret.c | 2651 +++++++++++------ 1 file changed, 1777 insertions(+), 874 deletions(-) diff --git a/clang/test/CodeGen/AArch64/fp8-intrinsics/acle_sve2_fp8_reinterpret.c b/clang/test/CodeGen/AArch64/fp8-intrinsics/acle_sve2_fp8_reinterpret.c index f99d77108c608..7c70bcf6b4d66 100644 --- a/clang/test/CodeGen/AArch64/fp8-intrinsics/acle_sve2_fp8_reinterpret.c +++ b/clang/test/CodeGen/AArch64/fp8-intrinsics/acle_sve2_fp8_reinterpret.c @@ -1,9 +1,9 @@ // NOTE: Assertions have been autogenerated by utils/update_cc_test_checks.py UTC_ARGS: --version 5 -// RUN: %clang_cc1 -triple aarch64-none-linux-gnu -target-feature +sve -target-feature +fp8 -disable-O0-optnone -Werror -Wall -emit-llvm -o - %s | opt -S -p mem2reg,instcombine,tailcallelim | FileCheck %s -// RUN: %clang_cc1 -x c++ -triple aarch64-none-linux-gnu -target-feature +sme -target-feature +fp8 -disable-O0-optnone -Werror -Wall -emit-llvm -o - %s | opt -S -p mem2reg,instcombine,tailcallelim | FileCheck %s -check-prefix=CHECK-CXX +// RUN: %clang_cc1 -triple aarch64-none-linux-gnu -target-feature +sve -target-feature +fp8 -disable-O0-optnone -Werror -Wall -emit-llvm -o - %s | opt -S -p mem2reg | FileCheck %s +// RUN: %clang_cc1 -x c++ -triple aarch64-none-linux-gnu -target-feature +sme -target-feature +fp8 -disable-O0-optnone -Werror -Wall -emit-llvm -o - %s | opt -S -p mem2reg | FileCheck %s -check-prefix=CHECK-CXX -// RUN: %clang_cc1 -DSVE_OVERLOADED_FORMS -triple aarch64-none-linux-gnu -target-feature +sve -target-feature +fp8 -disable-O0-optnone -Werror -Wall -emit-llvm -o - %s | opt -S -p mem2reg,instcombine,tailcallelim | FileCheck %s -// RUN: %clang_cc1 -x c++ -DSVE_OVERLOADED_FORMS -triple aarch64-none-linux-gnu -target-feature +sme -target-feature +fp8 -disable-O0-optnone -Werror -Wall -emit-llvm -o - %s | opt -S -p mem2reg,instcombine,tailcallelim | FileCheck %s -check-prefix=CHECK-CXX +// RUN: %clang_cc1 -DSVE_OVERLOADED_FORMS -triple aarch64-none-linux-gnu -target-feature +sve -target-feature +fp8 -disable-O0-optnone -Werror -Wall -emit-llvm -o - %s | opt -S -p mem2reg | FileCheck %s +// RUN: %clang_cc1 -x c++ -DSVE_OVERLOADED_FORMS -triple aarch64-none-linux-gnu -target-feature +sme -target-feature +fp8 -disable-O0-optnone -Werror -Wall -emit-llvm -o - %s | opt -S -p mem2reg | FileCheck %s -check-prefix=CHECK-CXX // RUN: %clang_cc1 -triple aarch64-none-linux-gnu -target-feature +sve -target-feature +fp8 -S -disable-O0-optnone -Werror -Wall -o /dev/null %s // RUN: %clang_cc1 -triple aarch64-none-linux-gnu -target-feature +sme -target-feature +fp8 -S -disable-O0-optnone -Werror -Wall -o /dev/null %s @@ -423,14 +423,22 @@ svfloat64_t test_svreinterpret_f64_mf8(svmfloat8_t op) STREAMING { // CHECK-NEXT: [[ENTRY:.*:]] // CHECK-NEXT: [[TMP0:%.*]] = insertvalue { , } poison, [[OP_COERCE0]], 0 // CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , } [[TMP0]], [[OP_COERCE1]], 1 -// CHECK-NEXT: ret { , } [[TMP1]] +// CHECK-NEXT: [[TMP2:%.*]] = extractvalue { , } [[TMP1]], 0 +// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , } poison, [[TMP2]], 0 +// CHECK-NEXT: [[TMP4:%.*]] = extractvalue { , } [[TMP1]], 1 +// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , } [[TMP3]], [[TMP4]], 1 +// CHECK-NEXT: ret { , } [[TMP5]] // // CHECK-CXX-LABEL: define dso_local { , } @_Z28test_svreinterpret_s8_mf8_x213svmfloat8x2_t( // CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]]) #[[ATTR0]] { // CHECK-CXX-NEXT: [[ENTRY:.*:]] // CHECK-CXX-NEXT: [[TMP0:%.*]] = insertvalue { , } poison, [[OP_COERCE0]], 0 // CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , } [[TMP0]], [[OP_COERCE1]], 1 -// CHECK-CXX-NEXT: ret { , } [[TMP1]] +// CHECK-CXX-NEXT: [[TMP2:%.*]] = extractvalue { , } [[TMP1]], 0 +// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , } poison, [[TMP2]], 0 +// CHECK-CXX-NEXT: [[TMP4:%.*]] = extractvalue { , } [[TMP1]], 1 +// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , } [[TMP3]], [[TMP4]], 1 +// CHECK-CXX-NEXT: ret { , } [[TMP5]] // svint8x2_t test_svreinterpret_s8_mf8_x2(svmfloat8x2_t op) STREAMING { return SVE_ACLE_FUNC(svreinterpret_s8, _mf8_x2)(op); @@ -441,14 +449,22 @@ svint8x2_t test_svreinterpret_s8_mf8_x2(svmfloat8x2_t op) STREAMING { // CHECK-NEXT: [[ENTRY:.*:]] // CHECK-NEXT: [[TMP0:%.*]] = insertvalue { , } poison, [[OP_COERCE0]], 0 // CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , } [[TMP0]], [[OP_COERCE1]], 1 -// CHECK-NEXT: ret { , } [[TMP1]] +// CHECK-NEXT: [[TMP2:%.*]] = extractvalue { , } [[TMP1]], 0 +// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , } poison, [[TMP2]], 0 +// CHECK-NEXT: [[TMP4:%.*]] = extractvalue { , } [[TMP1]], 1 +// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , } [[TMP3]], [[TMP4]], 1 +// CHECK-NEXT: ret { , } [[TMP5]] // // CHECK-CXX-LABEL: define dso_local { , } @_Z28test_svreinterpret_u8_mf8_x213svmfloat8x2_t( // CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]]) #[[ATTR0]] { // CHECK-CXX-NEXT: [[ENTRY:.*:]] // CHECK-CXX-NEXT: [[TMP0:%.*]] = insertvalue { , } poison, [[OP_COERCE0]], 0 // CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , } [[TMP0]], [[OP_COERCE1]], 1 -// CHECK-CXX-NEXT: ret { , } [[TMP1]] +// CHECK-CXX-NEXT: [[TMP2:%.*]] = extractvalue { , } [[TMP1]], 0 +// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , } poison, [[TMP2]], 0 +// CHECK-CXX-NEXT: [[TMP4:%.*]] = extractvalue { , } [[TMP1]], 1 +// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , } [[TMP3]], [[TMP4]], 1 +// CHECK-CXX-NEXT: ret { , } [[TMP5]] // svuint8x2_t test_svreinterpret_u8_mf8_x2(svmfloat8x2_t op) STREAMING { return SVE_ACLE_FUNC(svreinterpret_u8, _mf8_x2)(op); @@ -459,14 +475,22 @@ svuint8x2_t test_svreinterpret_u8_mf8_x2(svmfloat8x2_t op) STREAMING { // CHECK-NEXT: [[ENTRY:.*:]] // CHECK-NEXT: [[TMP0:%.*]] = insertvalue { , } poison, [[OP_COERCE0]], 0 // CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , } [[TMP0]], [[OP_COERCE1]], 1 -// CHECK-NEXT: ret { , } [[TMP1]] +// CHECK-NEXT: [[TMP2:%.*]] = extractvalue { , } [[TMP1]], 0 +// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , } poison, [[TMP2]], 0 +// CHECK-NEXT: [[TMP4:%.*]] = extractvalue { , } [[TMP1]], 1 +// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , } [[TMP3]], [[TMP4]], 1 +// CHECK-NEXT: ret { , } [[TMP5]] // // CHECK-CXX-LABEL: define dso_local { , } @_Z28test_svreinterpret_mf8_s8_x210svint8x2_t( // CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]]) #[[ATTR0]] { // CHECK-CXX-NEXT: [[ENTRY:.*:]] // CHECK-CXX-NEXT: [[TMP0:%.*]] = insertvalue { , } poison, [[OP_COERCE0]], 0 // CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , } [[TMP0]], [[OP_COERCE1]], 1 -// CHECK-CXX-NEXT: ret { , } [[TMP1]] +// CHECK-CXX-NEXT: [[TMP2:%.*]] = extractvalue { , } [[TMP1]], 0 +// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , } poison, [[TMP2]], 0 +// CHECK-CXX-NEXT: [[TMP4:%.*]] = extractvalue { , } [[TMP1]], 1 +// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , } [[TMP3]], [[TMP4]], 1 +// CHECK-CXX-NEXT: ret { , } [[TMP5]] // svmfloat8x2_t test_svreinterpret_mf8_s8_x2(svint8x2_t op) STREAMING { return SVE_ACLE_FUNC(svreinterpret_mf8, _s8_x2)(op); @@ -477,14 +501,22 @@ svmfloat8x2_t test_svreinterpret_mf8_s8_x2(svint8x2_t op) STREAMING { // CHECK-NEXT: [[ENTRY:.*:]] // CHECK-NEXT: [[TMP0:%.*]] = insertvalue { , } poison, [[OP_COERCE0]], 0 // CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , } [[TMP0]], [[OP_COERCE1]], 1 -// CHECK-NEXT: ret { , } [[TMP1]] +// CHECK-NEXT: [[TMP2:%.*]] = extractvalue { , } [[TMP1]], 0 +// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , } poison, [[TMP2]], 0 +// CHECK-NEXT: [[TMP4:%.*]] = extractvalue { , } [[TMP1]], 1 +// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , } [[TMP3]], [[TMP4]], 1 +// CHECK-NEXT: ret { , } [[TMP5]] // // CHECK-CXX-LABEL: define dso_local { , } @_Z28test_svreinterpret_mf8_u8_x211svuint8x2_t( // CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]]) #[[ATTR0]] { // CHECK-CXX-NEXT: [[ENTRY:.*:]] // CHECK-CXX-NEXT: [[TMP0:%.*]] = insertvalue { , } poison, [[OP_COERCE0]], 0 // CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , } [[TMP0]], [[OP_COERCE1]], 1 -// CHECK-CXX-NEXT: ret { , } [[TMP1]] +// CHECK-CXX-NEXT: [[TMP2:%.*]] = extractvalue { , } [[TMP1]], 0 +// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , } poison, [[TMP2]], 0 +// CHECK-CXX-NEXT: [[TMP4:%.*]] = extractvalue { , } [[TMP1]], 1 +// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , } [[TMP3]], [[TMP4]], 1 +// CHECK-CXX-NEXT: ret { , } [[TMP5]] // svmfloat8x2_t test_svreinterpret_mf8_u8_x2(svuint8x2_t op) STREAMING { return SVE_ACLE_FUNC(svreinterpret_mf8, _u8_x2)(op); @@ -495,36 +527,53 @@ svmfloat8x2_t test_svreinterpret_mf8_u8_x2(svuint8x2_t op) STREAMING { // CHECK-NEXT: [[ENTRY:.*:]] // CHECK-NEXT: [[TMP0:%.*]] = insertvalue { , } poison, [[OP_COERCE0]], 0 // CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , } [[TMP0]], [[OP_COERCE1]], 1 -// CHECK-NEXT: ret { , } [[TMP1]] +// CHECK-NEXT: [[TMP2:%.*]] = extractvalue { , } [[TMP1]], 0 +// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , } poison, [[TMP2]], 0 +// CHECK-NEXT: [[TMP4:%.*]] = extractvalue { , } [[TMP1]], 1 +// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , } [[TMP3]], [[TMP4]], 1 +// CHECK-NEXT: ret { , } [[TMP5]] // // CHECK-CXX-LABEL: define dso_local { , } @_Z29test_svreinterpret_mf8_mf8_x213svmfloat8x2_t( // CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]]) #[[ATTR0]] { // CHECK-CXX-NEXT: [[ENTRY:.*:]] // CHECK-CXX-NEXT: [[TMP0:%.*]] = insertvalue { , } poison, [[OP_COERCE0]], 0 // CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , } [[TMP0]], [[OP_COERCE1]], 1 -// CHECK-CXX-NEXT: ret { , } [[TMP1]] +// CHECK-CXX-NEXT: [[TMP2:%.*]] = extractvalue { , } [[TMP1]], 0 +// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , } poison, [[TMP2]], 0 +// CHECK-CXX-NEXT: [[TMP4:%.*]] = extractvalue { , } [[TMP1]], 1 +// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , } [[TMP3]], [[TMP4]], 1 +// CHECK-CXX-NEXT: ret { , } [[TMP5]] // svmfloat8x2_t test_svreinterpret_mf8_mf8_x2(svmfloat8x2_t op) STREAMING { return SVE_ACLE_FUNC(svreinterpret_mf8, _mf8_x2)(op); } +// // CHECK-LABEL: define dso_local { , } @test_svreinterpret_mf8_s16_x2( // CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]]) #[[ATTR0]] { // CHECK-NEXT: [[ENTRY:.*:]] -// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , } poison, [[TMP0]], 0 -// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , } [[TMP1]], [[TMP2]], 1 -// CHECK-NEXT: ret { , } [[TMP3]] +// CHECK-NEXT: [[TMP0:%.*]] = insertvalue { , } poison, [[OP_COERCE0]], 0 +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-NEXT: [[TMP2:%.*]] = extractvalue { , } [[TMP1]], 0 +// CHECK-NEXT: [[TMP3:%.*]] = bitcast [[TMP2]] to +// CHECK-NEXT: [[TMP4:%.*]] = insertvalue { , } poison, [[TMP3]], 0 +// CHECK-NEXT: [[TMP5:%.*]] = extractvalue { , } [[TMP1]], 1 +// CHECK-NEXT: [[TMP6:%.*]] = bitcast [[TMP5]] to +// CHECK-NEXT: [[TMP7:%.*]] = insertvalue { , } [[TMP4]], [[TMP6]], 1 +// CHECK-NEXT: ret { , } [[TMP7]] // // CHECK-CXX-LABEL: define dso_local { , } @_Z29test_svreinterpret_mf8_s16_x211svint16x2_t( // CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]]) #[[ATTR0]] { // CHECK-CXX-NEXT: [[ENTRY:.*:]] -// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , } poison, [[TMP0]], 0 -// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , } [[TMP1]], [[TMP2]], 1 -// CHECK-CXX-NEXT: ret { , } [[TMP3]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = insertvalue { , } poison, [[OP_COERCE0]], 0 +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = extractvalue { , } [[TMP1]], 0 +// CHECK-CXX-NEXT: [[TMP3:%.*]] = bitcast [[TMP2]] to +// CHECK-CXX-NEXT: [[TMP4:%.*]] = insertvalue { , } poison, [[TMP3]], 0 +// CHECK-CXX-NEXT: [[TMP5:%.*]] = extractvalue { , } [[TMP1]], 1 +// CHECK-CXX-NEXT: [[TMP6:%.*]] = bitcast [[TMP5]] to +// CHECK-CXX-NEXT: [[TMP7:%.*]] = insertvalue { , } [[TMP4]], [[TMP6]], 1 +// CHECK-CXX-NEXT: ret { , } [[TMP7]] // svmfloat8x2_t test_svreinterpret_mf8_s16_x2(svint16x2_t op) STREAMING { return SVE_ACLE_FUNC(svreinterpret_mf8, _s16_x2)(op); @@ -533,20 +582,28 @@ svmfloat8x2_t test_svreinterpret_mf8_s16_x2(svint16x2_t op) STREAMING { // CHECK-LABEL: define dso_local { , } @test_svreinterpret_mf8_u16_x2( // CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]]) #[[ATTR0]] { // CHECK-NEXT: [[ENTRY:.*:]] -// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , } poison, [[TMP0]], 0 -// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , } [[TMP1]], [[TMP2]], 1 -// CHECK-NEXT: ret { , } [[TMP3]] +// CHECK-NEXT: [[TMP0:%.*]] = insertvalue { , } poison, [[OP_COERCE0]], 0 +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-NEXT: [[TMP2:%.*]] = extractvalue { , } [[TMP1]], 0 +// CHECK-NEXT: [[TMP3:%.*]] = bitcast [[TMP2]] to +// CHECK-NEXT: [[TMP4:%.*]] = insertvalue { , } poison, [[TMP3]], 0 +// CHECK-NEXT: [[TMP5:%.*]] = extractvalue { , } [[TMP1]], 1 +// CHECK-NEXT: [[TMP6:%.*]] = bitcast [[TMP5]] to +// CHECK-NEXT: [[TMP7:%.*]] = insertvalue { , } [[TMP4]], [[TMP6]], 1 +// CHECK-NEXT: ret { , } [[TMP7]] // // CHECK-CXX-LABEL: define dso_local { , } @_Z29test_svreinterpret_mf8_u16_x212svuint16x2_t( // CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]]) #[[ATTR0]] { // CHECK-CXX-NEXT: [[ENTRY:.*:]] -// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , } poison, [[TMP0]], 0 -// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , } [[TMP1]], [[TMP2]], 1 -// CHECK-CXX-NEXT: ret { , } [[TMP3]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = insertvalue { , } poison, [[OP_COERCE0]], 0 +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = extractvalue { , } [[TMP1]], 0 +// CHECK-CXX-NEXT: [[TMP3:%.*]] = bitcast [[TMP2]] to +// CHECK-CXX-NEXT: [[TMP4:%.*]] = insertvalue { , } poison, [[TMP3]], 0 +// CHECK-CXX-NEXT: [[TMP5:%.*]] = extractvalue { , } [[TMP1]], 1 +// CHECK-CXX-NEXT: [[TMP6:%.*]] = bitcast [[TMP5]] to +// CHECK-CXX-NEXT: [[TMP7:%.*]] = insertvalue { , } [[TMP4]], [[TMP6]], 1 +// CHECK-CXX-NEXT: ret { , } [[TMP7]] // svmfloat8x2_t test_svreinterpret_mf8_u16_x2(svuint16x2_t op) STREAMING { return SVE_ACLE_FUNC(svreinterpret_mf8, _u16_x2)(op); @@ -555,20 +612,28 @@ svmfloat8x2_t test_svreinterpret_mf8_u16_x2(svuint16x2_t op) STREAMING { // CHECK-LABEL: define dso_local { , } @test_svreinterpret_mf8_s32_x2( // CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]]) #[[ATTR0]] { // CHECK-NEXT: [[ENTRY:.*:]] -// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , } poison, [[TMP0]], 0 -// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , } [[TMP1]], [[TMP2]], 1 -// CHECK-NEXT: ret { , } [[TMP3]] +// CHECK-NEXT: [[TMP0:%.*]] = insertvalue { , } poison, [[OP_COERCE0]], 0 +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-NEXT: [[TMP2:%.*]] = extractvalue { , } [[TMP1]], 0 +// CHECK-NEXT: [[TMP3:%.*]] = bitcast [[TMP2]] to +// CHECK-NEXT: [[TMP4:%.*]] = insertvalue { , } poison, [[TMP3]], 0 +// CHECK-NEXT: [[TMP5:%.*]] = extractvalue { , } [[TMP1]], 1 +// CHECK-NEXT: [[TMP6:%.*]] = bitcast [[TMP5]] to +// CHECK-NEXT: [[TMP7:%.*]] = insertvalue { , } [[TMP4]], [[TMP6]], 1 +// CHECK-NEXT: ret { , } [[TMP7]] // // CHECK-CXX-LABEL: define dso_local { , } @_Z29test_svreinterpret_mf8_s32_x211svint32x2_t( // CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]]) #[[ATTR0]] { // CHECK-CXX-NEXT: [[ENTRY:.*:]] -// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , } poison, [[TMP0]], 0 -// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , } [[TMP1]], [[TMP2]], 1 -// CHECK-CXX-NEXT: ret { , } [[TMP3]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = insertvalue { , } poison, [[OP_COERCE0]], 0 +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = extractvalue { , } [[TMP1]], 0 +// CHECK-CXX-NEXT: [[TMP3:%.*]] = bitcast [[TMP2]] to +// CHECK-CXX-NEXT: [[TMP4:%.*]] = insertvalue { , } poison, [[TMP3]], 0 +// CHECK-CXX-NEXT: [[TMP5:%.*]] = extractvalue { , } [[TMP1]], 1 +// CHECK-CXX-NEXT: [[TMP6:%.*]] = bitcast [[TMP5]] to +// CHECK-CXX-NEXT: [[TMP7:%.*]] = insertvalue { , } [[TMP4]], [[TMP6]], 1 +// CHECK-CXX-NEXT: ret { , } [[TMP7]] // svmfloat8x2_t test_svreinterpret_mf8_s32_x2(svint32x2_t op) STREAMING { return SVE_ACLE_FUNC(svreinterpret_mf8, _s32_x2)(op); @@ -577,20 +642,28 @@ svmfloat8x2_t test_svreinterpret_mf8_s32_x2(svint32x2_t op) STREAMING { // CHECK-LABEL: define dso_local { , } @test_svreinterpret_mf8_u32_x2( // CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]]) #[[ATTR0]] { // CHECK-NEXT: [[ENTRY:.*:]] -// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , } poison, [[TMP0]], 0 -// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , } [[TMP1]], [[TMP2]], 1 -// CHECK-NEXT: ret { , } [[TMP3]] +// CHECK-NEXT: [[TMP0:%.*]] = insertvalue { , } poison, [[OP_COERCE0]], 0 +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-NEXT: [[TMP2:%.*]] = extractvalue { , } [[TMP1]], 0 +// CHECK-NEXT: [[TMP3:%.*]] = bitcast [[TMP2]] to +// CHECK-NEXT: [[TMP4:%.*]] = insertvalue { , } poison, [[TMP3]], 0 +// CHECK-NEXT: [[TMP5:%.*]] = extractvalue { , } [[TMP1]], 1 +// CHECK-NEXT: [[TMP6:%.*]] = bitcast [[TMP5]] to +// CHECK-NEXT: [[TMP7:%.*]] = insertvalue { , } [[TMP4]], [[TMP6]], 1 +// CHECK-NEXT: ret { , } [[TMP7]] // // CHECK-CXX-LABEL: define dso_local { , } @_Z29test_svreinterpret_mf8_u32_x212svuint32x2_t( // CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]]) #[[ATTR0]] { // CHECK-CXX-NEXT: [[ENTRY:.*:]] -// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , } poison, [[TMP0]], 0 -// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , } [[TMP1]], [[TMP2]], 1 -// CHECK-CXX-NEXT: ret { , } [[TMP3]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = insertvalue { , } poison, [[OP_COERCE0]], 0 +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = extractvalue { , } [[TMP1]], 0 +// CHECK-CXX-NEXT: [[TMP3:%.*]] = bitcast [[TMP2]] to +// CHECK-CXX-NEXT: [[TMP4:%.*]] = insertvalue { , } poison, [[TMP3]], 0 +// CHECK-CXX-NEXT: [[TMP5:%.*]] = extractvalue { , } [[TMP1]], 1 +// CHECK-CXX-NEXT: [[TMP6:%.*]] = bitcast [[TMP5]] to +// CHECK-CXX-NEXT: [[TMP7:%.*]] = insertvalue { , } [[TMP4]], [[TMP6]], 1 +// CHECK-CXX-NEXT: ret { , } [[TMP7]] // svmfloat8x2_t test_svreinterpret_mf8_u32_x2(svuint32x2_t op) STREAMING { return SVE_ACLE_FUNC(svreinterpret_mf8, _u32_x2)(op); @@ -599,20 +672,28 @@ svmfloat8x2_t test_svreinterpret_mf8_u32_x2(svuint32x2_t op) STREAMING { // CHECK-LABEL: define dso_local { , } @test_svreinterpret_mf8_s64_x2( // CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]]) #[[ATTR0]] { // CHECK-NEXT: [[ENTRY:.*:]] -// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , } poison, [[TMP0]], 0 -// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , } [[TMP1]], [[TMP2]], 1 -// CHECK-NEXT: ret { , } [[TMP3]] +// CHECK-NEXT: [[TMP0:%.*]] = insertvalue { , } poison, [[OP_COERCE0]], 0 +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-NEXT: [[TMP2:%.*]] = extractvalue { , } [[TMP1]], 0 +// CHECK-NEXT: [[TMP3:%.*]] = bitcast [[TMP2]] to +// CHECK-NEXT: [[TMP4:%.*]] = insertvalue { , } poison, [[TMP3]], 0 +// CHECK-NEXT: [[TMP5:%.*]] = extractvalue { , } [[TMP1]], 1 +// CHECK-NEXT: [[TMP6:%.*]] = bitcast [[TMP5]] to +// CHECK-NEXT: [[TMP7:%.*]] = insertvalue { , } [[TMP4]], [[TMP6]], 1 +// CHECK-NEXT: ret { , } [[TMP7]] // // CHECK-CXX-LABEL: define dso_local { , } @_Z29test_svreinterpret_mf8_s64_x211svint64x2_t( // CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]]) #[[ATTR0]] { // CHECK-CXX-NEXT: [[ENTRY:.*:]] -// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , } poison, [[TMP0]], 0 -// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , } [[TMP1]], [[TMP2]], 1 -// CHECK-CXX-NEXT: ret { , } [[TMP3]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = insertvalue { , } poison, [[OP_COERCE0]], 0 +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = extractvalue { , } [[TMP1]], 0 +// CHECK-CXX-NEXT: [[TMP3:%.*]] = bitcast [[TMP2]] to +// CHECK-CXX-NEXT: [[TMP4:%.*]] = insertvalue { , } poison, [[TMP3]], 0 +// CHECK-CXX-NEXT: [[TMP5:%.*]] = extractvalue { , } [[TMP1]], 1 +// CHECK-CXX-NEXT: [[TMP6:%.*]] = bitcast [[TMP5]] to +// CHECK-CXX-NEXT: [[TMP7:%.*]] = insertvalue { , } [[TMP4]], [[TMP6]], 1 +// CHECK-CXX-NEXT: ret { , } [[TMP7]] // svmfloat8x2_t test_svreinterpret_mf8_s64_x2(svint64x2_t op) STREAMING { return SVE_ACLE_FUNC(svreinterpret_mf8, _s64_x2)(op); @@ -621,20 +702,28 @@ svmfloat8x2_t test_svreinterpret_mf8_s64_x2(svint64x2_t op) STREAMING { // CHECK-LABEL: define dso_local { , } @test_svreinterpret_mf8_u64_x2( // CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]]) #[[ATTR0]] { // CHECK-NEXT: [[ENTRY:.*:]] -// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , } poison, [[TMP0]], 0 -// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , } [[TMP1]], [[TMP2]], 1 -// CHECK-NEXT: ret { , } [[TMP3]] +// CHECK-NEXT: [[TMP0:%.*]] = insertvalue { , } poison, [[OP_COERCE0]], 0 +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-NEXT: [[TMP2:%.*]] = extractvalue { , } [[TMP1]], 0 +// CHECK-NEXT: [[TMP3:%.*]] = bitcast [[TMP2]] to +// CHECK-NEXT: [[TMP4:%.*]] = insertvalue { , } poison, [[TMP3]], 0 +// CHECK-NEXT: [[TMP5:%.*]] = extractvalue { , } [[TMP1]], 1 +// CHECK-NEXT: [[TMP6:%.*]] = bitcast [[TMP5]] to +// CHECK-NEXT: [[TMP7:%.*]] = insertvalue { , } [[TMP4]], [[TMP6]], 1 +// CHECK-NEXT: ret { , } [[TMP7]] // // CHECK-CXX-LABEL: define dso_local { , } @_Z29test_svreinterpret_mf8_u64_x212svuint64x2_t( // CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]]) #[[ATTR0]] { // CHECK-CXX-NEXT: [[ENTRY:.*:]] -// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , } poison, [[TMP0]], 0 -// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , } [[TMP1]], [[TMP2]], 1 -// CHECK-CXX-NEXT: ret { , } [[TMP3]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = insertvalue { , } poison, [[OP_COERCE0]], 0 +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = extractvalue { , } [[TMP1]], 0 +// CHECK-CXX-NEXT: [[TMP3:%.*]] = bitcast [[TMP2]] to +// CHECK-CXX-NEXT: [[TMP4:%.*]] = insertvalue { , } poison, [[TMP3]], 0 +// CHECK-CXX-NEXT: [[TMP5:%.*]] = extractvalue { , } [[TMP1]], 1 +// CHECK-CXX-NEXT: [[TMP6:%.*]] = bitcast [[TMP5]] to +// CHECK-CXX-NEXT: [[TMP7:%.*]] = insertvalue { , } [[TMP4]], [[TMP6]], 1 +// CHECK-CXX-NEXT: ret { , } [[TMP7]] // svmfloat8x2_t test_svreinterpret_mf8_u64_x2(svuint64x2_t op) STREAMING { return SVE_ACLE_FUNC(svreinterpret_mf8, _u64_x2)(op); @@ -643,20 +732,28 @@ svmfloat8x2_t test_svreinterpret_mf8_u64_x2(svuint64x2_t op) STREAMING { // CHECK-LABEL: define dso_local { , } @test_svreinterpret_mf8_f16_x2( // CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]]) #[[ATTR0]] { // CHECK-NEXT: [[ENTRY:.*:]] -// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , } poison, [[TMP0]], 0 -// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , } [[TMP1]], [[TMP2]], 1 -// CHECK-NEXT: ret { , } [[TMP3]] +// CHECK-NEXT: [[TMP0:%.*]] = insertvalue { , } poison, [[OP_COERCE0]], 0 +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-NEXT: [[TMP2:%.*]] = extractvalue { , } [[TMP1]], 0 +// CHECK-NEXT: [[TMP3:%.*]] = bitcast [[TMP2]] to +// CHECK-NEXT: [[TMP4:%.*]] = insertvalue { , } poison, [[TMP3]], 0 +// CHECK-NEXT: [[TMP5:%.*]] = extractvalue { , } [[TMP1]], 1 +// CHECK-NEXT: [[TMP6:%.*]] = bitcast [[TMP5]] to +// CHECK-NEXT: [[TMP7:%.*]] = insertvalue { , } [[TMP4]], [[TMP6]], 1 +// CHECK-NEXT: ret { , } [[TMP7]] // // CHECK-CXX-LABEL: define dso_local { , } @_Z29test_svreinterpret_mf8_f16_x213svfloat16x2_t( // CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]]) #[[ATTR0]] { // CHECK-CXX-NEXT: [[ENTRY:.*:]] -// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , } poison, [[TMP0]], 0 -// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , } [[TMP1]], [[TMP2]], 1 -// CHECK-CXX-NEXT: ret { , } [[TMP3]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = insertvalue { , } poison, [[OP_COERCE0]], 0 +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = extractvalue { , } [[TMP1]], 0 +// CHECK-CXX-NEXT: [[TMP3:%.*]] = bitcast [[TMP2]] to +// CHECK-CXX-NEXT: [[TMP4:%.*]] = insertvalue { , } poison, [[TMP3]], 0 +// CHECK-CXX-NEXT: [[TMP5:%.*]] = extractvalue { , } [[TMP1]], 1 +// CHECK-CXX-NEXT: [[TMP6:%.*]] = bitcast [[TMP5]] to +// CHECK-CXX-NEXT: [[TMP7:%.*]] = insertvalue { , } [[TMP4]], [[TMP6]], 1 +// CHECK-CXX-NEXT: ret { , } [[TMP7]] // svmfloat8x2_t test_svreinterpret_mf8_f16_x2(svfloat16x2_t op) STREAMING { return SVE_ACLE_FUNC(svreinterpret_mf8, _f16_x2)(op); @@ -665,20 +762,28 @@ svmfloat8x2_t test_svreinterpret_mf8_f16_x2(svfloat16x2_t op) STREAMING { // CHECK-LABEL: define dso_local { , } @test_svreinterpret_mf8_bf16_x2( // CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]]) #[[ATTR0]] { // CHECK-NEXT: [[ENTRY:.*:]] -// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , } poison, [[TMP0]], 0 -// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , } [[TMP1]], [[TMP2]], 1 -// CHECK-NEXT: ret { , } [[TMP3]] +// CHECK-NEXT: [[TMP0:%.*]] = insertvalue { , } poison, [[OP_COERCE0]], 0 +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-NEXT: [[TMP2:%.*]] = extractvalue { , } [[TMP1]], 0 +// CHECK-NEXT: [[TMP3:%.*]] = bitcast [[TMP2]] to +// CHECK-NEXT: [[TMP4:%.*]] = insertvalue { , } poison, [[TMP3]], 0 +// CHECK-NEXT: [[TMP5:%.*]] = extractvalue { , } [[TMP1]], 1 +// CHECK-NEXT: [[TMP6:%.*]] = bitcast [[TMP5]] to +// CHECK-NEXT: [[TMP7:%.*]] = insertvalue { , } [[TMP4]], [[TMP6]], 1 +// CHECK-NEXT: ret { , } [[TMP7]] // // CHECK-CXX-LABEL: define dso_local { , } @_Z30test_svreinterpret_mf8_bf16_x214svbfloat16x2_t( // CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]]) #[[ATTR0]] { // CHECK-CXX-NEXT: [[ENTRY:.*:]] -// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , } poison, [[TMP0]], 0 -// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , } [[TMP1]], [[TMP2]], 1 -// CHECK-CXX-NEXT: ret { , } [[TMP3]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = insertvalue { , } poison, [[OP_COERCE0]], 0 +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = extractvalue { , } [[TMP1]], 0 +// CHECK-CXX-NEXT: [[TMP3:%.*]] = bitcast [[TMP2]] to +// CHECK-CXX-NEXT: [[TMP4:%.*]] = insertvalue { , } poison, [[TMP3]], 0 +// CHECK-CXX-NEXT: [[TMP5:%.*]] = extractvalue { , } [[TMP1]], 1 +// CHECK-CXX-NEXT: [[TMP6:%.*]] = bitcast [[TMP5]] to +// CHECK-CXX-NEXT: [[TMP7:%.*]] = insertvalue { , } [[TMP4]], [[TMP6]], 1 +// CHECK-CXX-NEXT: ret { , } [[TMP7]] // svmfloat8x2_t test_svreinterpret_mf8_bf16_x2(svbfloat16x2_t op) STREAMING { return SVE_ACLE_FUNC(svreinterpret_mf8, _bf16_x2)(op); @@ -687,20 +792,28 @@ svmfloat8x2_t test_svreinterpret_mf8_bf16_x2(svbfloat16x2_t op) STREAMING { // CHECK-LABEL: define dso_local { , } @test_svreinterpret_mf8_f32_x2( // CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]]) #[[ATTR0]] { // CHECK-NEXT: [[ENTRY:.*:]] -// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , } poison, [[TMP0]], 0 -// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , } [[TMP1]], [[TMP2]], 1 -// CHECK-NEXT: ret { , } [[TMP3]] +// CHECK-NEXT: [[TMP0:%.*]] = insertvalue { , } poison, [[OP_COERCE0]], 0 +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-NEXT: [[TMP2:%.*]] = extractvalue { , } [[TMP1]], 0 +// CHECK-NEXT: [[TMP3:%.*]] = bitcast [[TMP2]] to +// CHECK-NEXT: [[TMP4:%.*]] = insertvalue { , } poison, [[TMP3]], 0 +// CHECK-NEXT: [[TMP5:%.*]] = extractvalue { , } [[TMP1]], 1 +// CHECK-NEXT: [[TMP6:%.*]] = bitcast [[TMP5]] to +// CHECK-NEXT: [[TMP7:%.*]] = insertvalue { , } [[TMP4]], [[TMP6]], 1 +// CHECK-NEXT: ret { , } [[TMP7]] // // CHECK-CXX-LABEL: define dso_local { , } @_Z29test_svreinterpret_mf8_f32_x213svfloat32x2_t( // CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]]) #[[ATTR0]] { // CHECK-CXX-NEXT: [[ENTRY:.*:]] -// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , } poison, [[TMP0]], 0 -// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , } [[TMP1]], [[TMP2]], 1 -// CHECK-CXX-NEXT: ret { , } [[TMP3]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = insertvalue { , } poison, [[OP_COERCE0]], 0 +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = extractvalue { , } [[TMP1]], 0 +// CHECK-CXX-NEXT: [[TMP3:%.*]] = bitcast [[TMP2]] to +// CHECK-CXX-NEXT: [[TMP4:%.*]] = insertvalue { , } poison, [[TMP3]], 0 +// CHECK-CXX-NEXT: [[TMP5:%.*]] = extractvalue { , } [[TMP1]], 1 +// CHECK-CXX-NEXT: [[TMP6:%.*]] = bitcast [[TMP5]] to +// CHECK-CXX-NEXT: [[TMP7:%.*]] = insertvalue { , } [[TMP4]], [[TMP6]], 1 +// CHECK-CXX-NEXT: ret { , } [[TMP7]] // svmfloat8x2_t test_svreinterpret_mf8_f32_x2(svfloat32x2_t op) STREAMING { return SVE_ACLE_FUNC(svreinterpret_mf8, _f32_x2)(op); @@ -709,20 +822,28 @@ svmfloat8x2_t test_svreinterpret_mf8_f32_x2(svfloat32x2_t op) STREAMING { // CHECK-LABEL: define dso_local { , } @test_svreinterpret_mf8_f64_x2( // CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]]) #[[ATTR0]] { // CHECK-NEXT: [[ENTRY:.*:]] -// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , } poison, [[TMP0]], 0 -// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , } [[TMP1]], [[TMP2]], 1 -// CHECK-NEXT: ret { , } [[TMP3]] +// CHECK-NEXT: [[TMP0:%.*]] = insertvalue { , } poison, [[OP_COERCE0]], 0 +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-NEXT: [[TMP2:%.*]] = extractvalue { , } [[TMP1]], 0 +// CHECK-NEXT: [[TMP3:%.*]] = bitcast [[TMP2]] to +// CHECK-NEXT: [[TMP4:%.*]] = insertvalue { , } poison, [[TMP3]], 0 +// CHECK-NEXT: [[TMP5:%.*]] = extractvalue { , } [[TMP1]], 1 +// CHECK-NEXT: [[TMP6:%.*]] = bitcast [[TMP5]] to +// CHECK-NEXT: [[TMP7:%.*]] = insertvalue { , } [[TMP4]], [[TMP6]], 1 +// CHECK-NEXT: ret { , } [[TMP7]] // // CHECK-CXX-LABEL: define dso_local { , } @_Z29test_svreinterpret_mf8_f64_x213svfloat64x2_t( // CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]]) #[[ATTR0]] { // CHECK-CXX-NEXT: [[ENTRY:.*:]] -// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , } poison, [[TMP0]], 0 -// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , } [[TMP1]], [[TMP2]], 1 -// CHECK-CXX-NEXT: ret { , } [[TMP3]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = insertvalue { , } poison, [[OP_COERCE0]], 0 +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = extractvalue { , } [[TMP1]], 0 +// CHECK-CXX-NEXT: [[TMP3:%.*]] = bitcast [[TMP2]] to +// CHECK-CXX-NEXT: [[TMP4:%.*]] = insertvalue { , } poison, [[TMP3]], 0 +// CHECK-CXX-NEXT: [[TMP5:%.*]] = extractvalue { , } [[TMP1]], 1 +// CHECK-CXX-NEXT: [[TMP6:%.*]] = bitcast [[TMP5]] to +// CHECK-CXX-NEXT: [[TMP7:%.*]] = insertvalue { , } [[TMP4]], [[TMP6]], 1 +// CHECK-CXX-NEXT: ret { , } [[TMP7]] // svmfloat8x2_t test_svreinterpret_mf8_f64_x2(svfloat64x2_t op) STREAMING { return SVE_ACLE_FUNC(svreinterpret_mf8, _f64_x2)(op); @@ -731,20 +852,28 @@ svmfloat8x2_t test_svreinterpret_mf8_f64_x2(svfloat64x2_t op) STREAMING { // CHECK-LABEL: define dso_local { , } @test_svreinterpret_s16_mf8_x2( // CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]]) #[[ATTR0]] { // CHECK-NEXT: [[ENTRY:.*:]] -// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , } poison, [[TMP0]], 0 -// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , } [[TMP1]], [[TMP2]], 1 -// CHECK-NEXT: ret { , } [[TMP3]] +// CHECK-NEXT: [[TMP0:%.*]] = insertvalue { , } poison, [[OP_COERCE0]], 0 +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-NEXT: [[TMP2:%.*]] = extractvalue { , } [[TMP1]], 0 +// CHECK-NEXT: [[TMP3:%.*]] = bitcast [[TMP2]] to +// CHECK-NEXT: [[TMP4:%.*]] = insertvalue { , } poison, [[TMP3]], 0 +// CHECK-NEXT: [[TMP5:%.*]] = extractvalue { , } [[TMP1]], 1 +// CHECK-NEXT: [[TMP6:%.*]] = bitcast [[TMP5]] to +// CHECK-NEXT: [[TMP7:%.*]] = insertvalue { , } [[TMP4]], [[TMP6]], 1 +// CHECK-NEXT: ret { , } [[TMP7]] // // CHECK-CXX-LABEL: define dso_local { , } @_Z29test_svreinterpret_s16_mf8_x213svmfloat8x2_t( // CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]]) #[[ATTR0]] { // CHECK-CXX-NEXT: [[ENTRY:.*:]] -// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , } poison, [[TMP0]], 0 -// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , } [[TMP1]], [[TMP2]], 1 -// CHECK-CXX-NEXT: ret { , } [[TMP3]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = insertvalue { , } poison, [[OP_COERCE0]], 0 +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = extractvalue { , } [[TMP1]], 0 +// CHECK-CXX-NEXT: [[TMP3:%.*]] = bitcast [[TMP2]] to +// CHECK-CXX-NEXT: [[TMP4:%.*]] = insertvalue { , } poison, [[TMP3]], 0 +// CHECK-CXX-NEXT: [[TMP5:%.*]] = extractvalue { , } [[TMP1]], 1 +// CHECK-CXX-NEXT: [[TMP6:%.*]] = bitcast [[TMP5]] to +// CHECK-CXX-NEXT: [[TMP7:%.*]] = insertvalue { , } [[TMP4]], [[TMP6]], 1 +// CHECK-CXX-NEXT: ret { , } [[TMP7]] // svint16x2_t test_svreinterpret_s16_mf8_x2(svmfloat8x2_t op) STREAMING { return SVE_ACLE_FUNC(svreinterpret_s16, _mf8_x2)(op); @@ -753,20 +882,28 @@ svint16x2_t test_svreinterpret_s16_mf8_x2(svmfloat8x2_t op) STREAMING { // CHECK-LABEL: define dso_local { , } @test_svreinterpret_u16_mf8_x2( // CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]]) #[[ATTR0]] { // CHECK-NEXT: [[ENTRY:.*:]] -// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , } poison, [[TMP0]], 0 -// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , } [[TMP1]], [[TMP2]], 1 -// CHECK-NEXT: ret { , } [[TMP3]] +// CHECK-NEXT: [[TMP0:%.*]] = insertvalue { , } poison, [[OP_COERCE0]], 0 +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-NEXT: [[TMP2:%.*]] = extractvalue { , } [[TMP1]], 0 +// CHECK-NEXT: [[TMP3:%.*]] = bitcast [[TMP2]] to +// CHECK-NEXT: [[TMP4:%.*]] = insertvalue { , } poison, [[TMP3]], 0 +// CHECK-NEXT: [[TMP5:%.*]] = extractvalue { , } [[TMP1]], 1 +// CHECK-NEXT: [[TMP6:%.*]] = bitcast [[TMP5]] to +// CHECK-NEXT: [[TMP7:%.*]] = insertvalue { , } [[TMP4]], [[TMP6]], 1 +// CHECK-NEXT: ret { , } [[TMP7]] // // CHECK-CXX-LABEL: define dso_local { , } @_Z29test_svreinterpret_u16_mf8_x213svmfloat8x2_t( // CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]]) #[[ATTR0]] { // CHECK-CXX-NEXT: [[ENTRY:.*:]] -// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , } poison, [[TMP0]], 0 -// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , } [[TMP1]], [[TMP2]], 1 -// CHECK-CXX-NEXT: ret { , } [[TMP3]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = insertvalue { , } poison, [[OP_COERCE0]], 0 +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = extractvalue { , } [[TMP1]], 0 +// CHECK-CXX-NEXT: [[TMP3:%.*]] = bitcast [[TMP2]] to +// CHECK-CXX-NEXT: [[TMP4:%.*]] = insertvalue { , } poison, [[TMP3]], 0 +// CHECK-CXX-NEXT: [[TMP5:%.*]] = extractvalue { , } [[TMP1]], 1 +// CHECK-CXX-NEXT: [[TMP6:%.*]] = bitcast [[TMP5]] to +// CHECK-CXX-NEXT: [[TMP7:%.*]] = insertvalue { , } [[TMP4]], [[TMP6]], 1 +// CHECK-CXX-NEXT: ret { , } [[TMP7]] // svuint16x2_t test_svreinterpret_u16_mf8_x2(svmfloat8x2_t op) STREAMING { return SVE_ACLE_FUNC(svreinterpret_u16, _mf8_x2)(op); @@ -775,20 +912,28 @@ svuint16x2_t test_svreinterpret_u16_mf8_x2(svmfloat8x2_t op) STREAMING { // CHECK-LABEL: define dso_local { , } @test_svreinterpret_s32_mf8_x2( // CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]]) #[[ATTR0]] { // CHECK-NEXT: [[ENTRY:.*:]] -// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , } poison, [[TMP0]], 0 -// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , } [[TMP1]], [[TMP2]], 1 -// CHECK-NEXT: ret { , } [[TMP3]] +// CHECK-NEXT: [[TMP0:%.*]] = insertvalue { , } poison, [[OP_COERCE0]], 0 +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-NEXT: [[TMP2:%.*]] = extractvalue { , } [[TMP1]], 0 +// CHECK-NEXT: [[TMP3:%.*]] = bitcast [[TMP2]] to +// CHECK-NEXT: [[TMP4:%.*]] = insertvalue { , } poison, [[TMP3]], 0 +// CHECK-NEXT: [[TMP5:%.*]] = extractvalue { , } [[TMP1]], 1 +// CHECK-NEXT: [[TMP6:%.*]] = bitcast [[TMP5]] to +// CHECK-NEXT: [[TMP7:%.*]] = insertvalue { , } [[TMP4]], [[TMP6]], 1 +// CHECK-NEXT: ret { , } [[TMP7]] // // CHECK-CXX-LABEL: define dso_local { , } @_Z29test_svreinterpret_s32_mf8_x213svmfloat8x2_t( // CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]]) #[[ATTR0]] { // CHECK-CXX-NEXT: [[ENTRY:.*:]] -// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , } poison, [[TMP0]], 0 -// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , } [[TMP1]], [[TMP2]], 1 -// CHECK-CXX-NEXT: ret { , } [[TMP3]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = insertvalue { , } poison, [[OP_COERCE0]], 0 +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = extractvalue { , } [[TMP1]], 0 +// CHECK-CXX-NEXT: [[TMP3:%.*]] = bitcast [[TMP2]] to +// CHECK-CXX-NEXT: [[TMP4:%.*]] = insertvalue { , } poison, [[TMP3]], 0 +// CHECK-CXX-NEXT: [[TMP5:%.*]] = extractvalue { , } [[TMP1]], 1 +// CHECK-CXX-NEXT: [[TMP6:%.*]] = bitcast [[TMP5]] to +// CHECK-CXX-NEXT: [[TMP7:%.*]] = insertvalue { , } [[TMP4]], [[TMP6]], 1 +// CHECK-CXX-NEXT: ret { , } [[TMP7]] // svint32x2_t test_svreinterpret_s32_mf8_x2(svmfloat8x2_t op) STREAMING { return SVE_ACLE_FUNC(svreinterpret_s32, _mf8_x2)(op); @@ -797,20 +942,28 @@ svint32x2_t test_svreinterpret_s32_mf8_x2(svmfloat8x2_t op) STREAMING { // CHECK-LABEL: define dso_local { , } @test_svreinterpret_u32_mf8_x2( // CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]]) #[[ATTR0]] { // CHECK-NEXT: [[ENTRY:.*:]] -// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , } poison, [[TMP0]], 0 -// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , } [[TMP1]], [[TMP2]], 1 -// CHECK-NEXT: ret { , } [[TMP3]] +// CHECK-NEXT: [[TMP0:%.*]] = insertvalue { , } poison, [[OP_COERCE0]], 0 +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-NEXT: [[TMP2:%.*]] = extractvalue { , } [[TMP1]], 0 +// CHECK-NEXT: [[TMP3:%.*]] = bitcast [[TMP2]] to +// CHECK-NEXT: [[TMP4:%.*]] = insertvalue { , } poison, [[TMP3]], 0 +// CHECK-NEXT: [[TMP5:%.*]] = extractvalue { , } [[TMP1]], 1 +// CHECK-NEXT: [[TMP6:%.*]] = bitcast [[TMP5]] to +// CHECK-NEXT: [[TMP7:%.*]] = insertvalue { , } [[TMP4]], [[TMP6]], 1 +// CHECK-NEXT: ret { , } [[TMP7]] // // CHECK-CXX-LABEL: define dso_local { , } @_Z29test_svreinterpret_u32_mf8_x213svmfloat8x2_t( // CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]]) #[[ATTR0]] { // CHECK-CXX-NEXT: [[ENTRY:.*:]] -// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , } poison, [[TMP0]], 0 -// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , } [[TMP1]], [[TMP2]], 1 -// CHECK-CXX-NEXT: ret { , } [[TMP3]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = insertvalue { , } poison, [[OP_COERCE0]], 0 +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = extractvalue { , } [[TMP1]], 0 +// CHECK-CXX-NEXT: [[TMP3:%.*]] = bitcast [[TMP2]] to +// CHECK-CXX-NEXT: [[TMP4:%.*]] = insertvalue { , } poison, [[TMP3]], 0 +// CHECK-CXX-NEXT: [[TMP5:%.*]] = extractvalue { , } [[TMP1]], 1 +// CHECK-CXX-NEXT: [[TMP6:%.*]] = bitcast [[TMP5]] to +// CHECK-CXX-NEXT: [[TMP7:%.*]] = insertvalue { , } [[TMP4]], [[TMP6]], 1 +// CHECK-CXX-NEXT: ret { , } [[TMP7]] // svuint32x2_t test_svreinterpret_u32_mf8_x2(svmfloat8x2_t op) STREAMING { return SVE_ACLE_FUNC(svreinterpret_u32, _mf8_x2)(op); @@ -819,20 +972,28 @@ svuint32x2_t test_svreinterpret_u32_mf8_x2(svmfloat8x2_t op) STREAMING { // CHECK-LABEL: define dso_local { , } @test_svreinterpret_s64_mf8_x2( // CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]]) #[[ATTR0]] { // CHECK-NEXT: [[ENTRY:.*:]] -// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , } poison, [[TMP0]], 0 -// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , } [[TMP1]], [[TMP2]], 1 -// CHECK-NEXT: ret { , } [[TMP3]] +// CHECK-NEXT: [[TMP0:%.*]] = insertvalue { , } poison, [[OP_COERCE0]], 0 +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-NEXT: [[TMP2:%.*]] = extractvalue { , } [[TMP1]], 0 +// CHECK-NEXT: [[TMP3:%.*]] = bitcast [[TMP2]] to +// CHECK-NEXT: [[TMP4:%.*]] = insertvalue { , } poison, [[TMP3]], 0 +// CHECK-NEXT: [[TMP5:%.*]] = extractvalue { , } [[TMP1]], 1 +// CHECK-NEXT: [[TMP6:%.*]] = bitcast [[TMP5]] to +// CHECK-NEXT: [[TMP7:%.*]] = insertvalue { , } [[TMP4]], [[TMP6]], 1 +// CHECK-NEXT: ret { , } [[TMP7]] // // CHECK-CXX-LABEL: define dso_local { , } @_Z29test_svreinterpret_s64_mf8_x213svmfloat8x2_t( // CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]]) #[[ATTR0]] { // CHECK-CXX-NEXT: [[ENTRY:.*:]] -// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , } poison, [[TMP0]], 0 -// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , } [[TMP1]], [[TMP2]], 1 -// CHECK-CXX-NEXT: ret { , } [[TMP3]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = insertvalue { , } poison, [[OP_COERCE0]], 0 +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = extractvalue { , } [[TMP1]], 0 +// CHECK-CXX-NEXT: [[TMP3:%.*]] = bitcast [[TMP2]] to +// CHECK-CXX-NEXT: [[TMP4:%.*]] = insertvalue { , } poison, [[TMP3]], 0 +// CHECK-CXX-NEXT: [[TMP5:%.*]] = extractvalue { , } [[TMP1]], 1 +// CHECK-CXX-NEXT: [[TMP6:%.*]] = bitcast [[TMP5]] to +// CHECK-CXX-NEXT: [[TMP7:%.*]] = insertvalue { , } [[TMP4]], [[TMP6]], 1 +// CHECK-CXX-NEXT: ret { , } [[TMP7]] // svint64x2_t test_svreinterpret_s64_mf8_x2(svmfloat8x2_t op) STREAMING { return SVE_ACLE_FUNC(svreinterpret_s64, _mf8_x2)(op); @@ -841,20 +1002,28 @@ svint64x2_t test_svreinterpret_s64_mf8_x2(svmfloat8x2_t op) STREAMING { // CHECK-LABEL: define dso_local { , } @test_svreinterpret_u64_mf8_x2( // CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]]) #[[ATTR0]] { // CHECK-NEXT: [[ENTRY:.*:]] -// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , } poison, [[TMP0]], 0 -// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , } [[TMP1]], [[TMP2]], 1 -// CHECK-NEXT: ret { , } [[TMP3]] +// CHECK-NEXT: [[TMP0:%.*]] = insertvalue { , } poison, [[OP_COERCE0]], 0 +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-NEXT: [[TMP2:%.*]] = extractvalue { , } [[TMP1]], 0 +// CHECK-NEXT: [[TMP3:%.*]] = bitcast [[TMP2]] to +// CHECK-NEXT: [[TMP4:%.*]] = insertvalue { , } poison, [[TMP3]], 0 +// CHECK-NEXT: [[TMP5:%.*]] = extractvalue { , } [[TMP1]], 1 +// CHECK-NEXT: [[TMP6:%.*]] = bitcast [[TMP5]] to +// CHECK-NEXT: [[TMP7:%.*]] = insertvalue { , } [[TMP4]], [[TMP6]], 1 +// CHECK-NEXT: ret { , } [[TMP7]] // // CHECK-CXX-LABEL: define dso_local { , } @_Z29test_svreinterpret_u64_mf8_x213svmfloat8x2_t( // CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]]) #[[ATTR0]] { // CHECK-CXX-NEXT: [[ENTRY:.*:]] -// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , } poison, [[TMP0]], 0 -// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , } [[TMP1]], [[TMP2]], 1 -// CHECK-CXX-NEXT: ret { , } [[TMP3]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = insertvalue { , } poison, [[OP_COERCE0]], 0 +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = extractvalue { , } [[TMP1]], 0 +// CHECK-CXX-NEXT: [[TMP3:%.*]] = bitcast [[TMP2]] to +// CHECK-CXX-NEXT: [[TMP4:%.*]] = insertvalue { , } poison, [[TMP3]], 0 +// CHECK-CXX-NEXT: [[TMP5:%.*]] = extractvalue { , } [[TMP1]], 1 +// CHECK-CXX-NEXT: [[TMP6:%.*]] = bitcast [[TMP5]] to +// CHECK-CXX-NEXT: [[TMP7:%.*]] = insertvalue { , } [[TMP4]], [[TMP6]], 1 +// CHECK-CXX-NEXT: ret { , } [[TMP7]] // svuint64x2_t test_svreinterpret_u64_mf8_x2(svmfloat8x2_t op) STREAMING { return SVE_ACLE_FUNC(svreinterpret_u64, _mf8_x2)(op); @@ -863,20 +1032,28 @@ svuint64x2_t test_svreinterpret_u64_mf8_x2(svmfloat8x2_t op) STREAMING { // CHECK-LABEL: define dso_local { , } @test_svreinterpret_f16_mf8_x2( // CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]]) #[[ATTR0]] { // CHECK-NEXT: [[ENTRY:.*:]] -// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , } poison, [[TMP0]], 0 -// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , } [[TMP1]], [[TMP2]], 1 -// CHECK-NEXT: ret { , } [[TMP3]] +// CHECK-NEXT: [[TMP0:%.*]] = insertvalue { , } poison, [[OP_COERCE0]], 0 +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-NEXT: [[TMP2:%.*]] = extractvalue { , } [[TMP1]], 0 +// CHECK-NEXT: [[TMP3:%.*]] = bitcast [[TMP2]] to +// CHECK-NEXT: [[TMP4:%.*]] = insertvalue { , } poison, [[TMP3]], 0 +// CHECK-NEXT: [[TMP5:%.*]] = extractvalue { , } [[TMP1]], 1 +// CHECK-NEXT: [[TMP6:%.*]] = bitcast [[TMP5]] to +// CHECK-NEXT: [[TMP7:%.*]] = insertvalue { , } [[TMP4]], [[TMP6]], 1 +// CHECK-NEXT: ret { , } [[TMP7]] // // CHECK-CXX-LABEL: define dso_local { , } @_Z29test_svreinterpret_f16_mf8_x213svmfloat8x2_t( // CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]]) #[[ATTR0]] { // CHECK-CXX-NEXT: [[ENTRY:.*:]] -// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , } poison, [[TMP0]], 0 -// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , } [[TMP1]], [[TMP2]], 1 -// CHECK-CXX-NEXT: ret { , } [[TMP3]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = insertvalue { , } poison, [[OP_COERCE0]], 0 +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = extractvalue { , } [[TMP1]], 0 +// CHECK-CXX-NEXT: [[TMP3:%.*]] = bitcast [[TMP2]] to +// CHECK-CXX-NEXT: [[TMP4:%.*]] = insertvalue { , } poison, [[TMP3]], 0 +// CHECK-CXX-NEXT: [[TMP5:%.*]] = extractvalue { , } [[TMP1]], 1 +// CHECK-CXX-NEXT: [[TMP6:%.*]] = bitcast [[TMP5]] to +// CHECK-CXX-NEXT: [[TMP7:%.*]] = insertvalue { , } [[TMP4]], [[TMP6]], 1 +// CHECK-CXX-NEXT: ret { , } [[TMP7]] // svfloat16x2_t test_svreinterpret_f16_mf8_x2(svmfloat8x2_t op) STREAMING { return SVE_ACLE_FUNC(svreinterpret_f16, _mf8_x2)(op); @@ -885,20 +1062,28 @@ svfloat16x2_t test_svreinterpret_f16_mf8_x2(svmfloat8x2_t op) STREAMING { // CHECK-LABEL: define dso_local { , } @test_svreinterpret_bf16_mf8_x2( // CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]]) #[[ATTR0]] { // CHECK-NEXT: [[ENTRY:.*:]] -// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , } poison, [[TMP0]], 0 -// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , } [[TMP1]], [[TMP2]], 1 -// CHECK-NEXT: ret { , } [[TMP3]] +// CHECK-NEXT: [[TMP0:%.*]] = insertvalue { , } poison, [[OP_COERCE0]], 0 +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-NEXT: [[TMP2:%.*]] = extractvalue { , } [[TMP1]], 0 +// CHECK-NEXT: [[TMP3:%.*]] = bitcast [[TMP2]] to +// CHECK-NEXT: [[TMP4:%.*]] = insertvalue { , } poison, [[TMP3]], 0 +// CHECK-NEXT: [[TMP5:%.*]] = extractvalue { , } [[TMP1]], 1 +// CHECK-NEXT: [[TMP6:%.*]] = bitcast [[TMP5]] to +// CHECK-NEXT: [[TMP7:%.*]] = insertvalue { , } [[TMP4]], [[TMP6]], 1 +// CHECK-NEXT: ret { , } [[TMP7]] // // CHECK-CXX-LABEL: define dso_local { , } @_Z30test_svreinterpret_bf16_mf8_x213svmfloat8x2_t( // CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]]) #[[ATTR0]] { // CHECK-CXX-NEXT: [[ENTRY:.*:]] -// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , } poison, [[TMP0]], 0 -// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , } [[TMP1]], [[TMP2]], 1 -// CHECK-CXX-NEXT: ret { , } [[TMP3]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = insertvalue { , } poison, [[OP_COERCE0]], 0 +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = extractvalue { , } [[TMP1]], 0 +// CHECK-CXX-NEXT: [[TMP3:%.*]] = bitcast [[TMP2]] to +// CHECK-CXX-NEXT: [[TMP4:%.*]] = insertvalue { , } poison, [[TMP3]], 0 +// CHECK-CXX-NEXT: [[TMP5:%.*]] = extractvalue { , } [[TMP1]], 1 +// CHECK-CXX-NEXT: [[TMP6:%.*]] = bitcast [[TMP5]] to +// CHECK-CXX-NEXT: [[TMP7:%.*]] = insertvalue { , } [[TMP4]], [[TMP6]], 1 +// CHECK-CXX-NEXT: ret { , } [[TMP7]] // svbfloat16x2_t test_svreinterpret_bf16_mf8_x2(svmfloat8x2_t op) STREAMING { return SVE_ACLE_FUNC(svreinterpret_bf16, _mf8_x2)(op); @@ -907,20 +1092,28 @@ svbfloat16x2_t test_svreinterpret_bf16_mf8_x2(svmfloat8x2_t op) STREAMING { // CHECK-LABEL: define dso_local { , } @test_svreinterpret_f32_mf8_x2( // CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]]) #[[ATTR0]] { // CHECK-NEXT: [[ENTRY:.*:]] -// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , } poison, [[TMP0]], 0 -// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , } [[TMP1]], [[TMP2]], 1 -// CHECK-NEXT: ret { , } [[TMP3]] +// CHECK-NEXT: [[TMP0:%.*]] = insertvalue { , } poison, [[OP_COERCE0]], 0 +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-NEXT: [[TMP2:%.*]] = extractvalue { , } [[TMP1]], 0 +// CHECK-NEXT: [[TMP3:%.*]] = bitcast [[TMP2]] to +// CHECK-NEXT: [[TMP4:%.*]] = insertvalue { , } poison, [[TMP3]], 0 +// CHECK-NEXT: [[TMP5:%.*]] = extractvalue { , } [[TMP1]], 1 +// CHECK-NEXT: [[TMP6:%.*]] = bitcast [[TMP5]] to +// CHECK-NEXT: [[TMP7:%.*]] = insertvalue { , } [[TMP4]], [[TMP6]], 1 +// CHECK-NEXT: ret { , } [[TMP7]] // // CHECK-CXX-LABEL: define dso_local { , } @_Z29test_svreinterpret_f32_mf8_x213svmfloat8x2_t( // CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]]) #[[ATTR0]] { // CHECK-CXX-NEXT: [[ENTRY:.*:]] -// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , } poison, [[TMP0]], 0 -// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , } [[TMP1]], [[TMP2]], 1 -// CHECK-CXX-NEXT: ret { , } [[TMP3]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = insertvalue { , } poison, [[OP_COERCE0]], 0 +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = extractvalue { , } [[TMP1]], 0 +// CHECK-CXX-NEXT: [[TMP3:%.*]] = bitcast [[TMP2]] to +// CHECK-CXX-NEXT: [[TMP4:%.*]] = insertvalue { , } poison, [[TMP3]], 0 +// CHECK-CXX-NEXT: [[TMP5:%.*]] = extractvalue { , } [[TMP1]], 1 +// CHECK-CXX-NEXT: [[TMP6:%.*]] = bitcast [[TMP5]] to +// CHECK-CXX-NEXT: [[TMP7:%.*]] = insertvalue { , } [[TMP4]], [[TMP6]], 1 +// CHECK-CXX-NEXT: ret { , } [[TMP7]] // svfloat32x2_t test_svreinterpret_f32_mf8_x2(svmfloat8x2_t op) STREAMING { return SVE_ACLE_FUNC(svreinterpret_f32, _mf8_x2)(op); @@ -929,20 +1122,28 @@ svfloat32x2_t test_svreinterpret_f32_mf8_x2(svmfloat8x2_t op) STREAMING { // CHECK-LABEL: define dso_local { , } @test_svreinterpret_f64_mf8_x2( // CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]]) #[[ATTR0]] { // CHECK-NEXT: [[ENTRY:.*:]] -// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , } poison, [[TMP0]], 0 -// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , } [[TMP1]], [[TMP2]], 1 -// CHECK-NEXT: ret { , } [[TMP3]] +// CHECK-NEXT: [[TMP0:%.*]] = insertvalue { , } poison, [[OP_COERCE0]], 0 +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-NEXT: [[TMP2:%.*]] = extractvalue { , } [[TMP1]], 0 +// CHECK-NEXT: [[TMP3:%.*]] = bitcast [[TMP2]] to +// CHECK-NEXT: [[TMP4:%.*]] = insertvalue { , } poison, [[TMP3]], 0 +// CHECK-NEXT: [[TMP5:%.*]] = extractvalue { , } [[TMP1]], 1 +// CHECK-NEXT: [[TMP6:%.*]] = bitcast [[TMP5]] to +// CHECK-NEXT: [[TMP7:%.*]] = insertvalue { , } [[TMP4]], [[TMP6]], 1 +// CHECK-NEXT: ret { , } [[TMP7]] // // CHECK-CXX-LABEL: define dso_local { , } @_Z29test_svreinterpret_f64_mf8_x213svmfloat8x2_t( // CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]]) #[[ATTR0]] { // CHECK-CXX-NEXT: [[ENTRY:.*:]] -// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , } poison, [[TMP0]], 0 -// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , } [[TMP1]], [[TMP2]], 1 -// CHECK-CXX-NEXT: ret { , } [[TMP3]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = insertvalue { , } poison, [[OP_COERCE0]], 0 +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = extractvalue { , } [[TMP1]], 0 +// CHECK-CXX-NEXT: [[TMP3:%.*]] = bitcast [[TMP2]] to +// CHECK-CXX-NEXT: [[TMP4:%.*]] = insertvalue { , } poison, [[TMP3]], 0 +// CHECK-CXX-NEXT: [[TMP5:%.*]] = extractvalue { , } [[TMP1]], 1 +// CHECK-CXX-NEXT: [[TMP6:%.*]] = bitcast [[TMP5]] to +// CHECK-CXX-NEXT: [[TMP7:%.*]] = insertvalue { , } [[TMP4]], [[TMP6]], 1 +// CHECK-CXX-NEXT: ret { , } [[TMP7]] // svfloat64x2_t test_svreinterpret_f64_mf8_x2(svmfloat8x2_t op) STREAMING { return SVE_ACLE_FUNC(svreinterpret_f64, _mf8_x2)(op); @@ -954,7 +1155,13 @@ svfloat64x2_t test_svreinterpret_f64_mf8_x2(svmfloat8x2_t op) STREAMING { // CHECK-NEXT: [[TMP0:%.*]] = insertvalue { , , } poison, [[OP_COERCE0]], 0 // CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , } [[TMP0]], [[OP_COERCE1]], 1 // CHECK-NEXT: [[TMP2:%.*]] = insertvalue { , , } [[TMP1]], [[OP_COERCE2]], 2 -// CHECK-NEXT: ret { , , } [[TMP2]] +// CHECK-NEXT: [[TMP3:%.*]] = extractvalue { , , } [[TMP2]], 0 +// CHECK-NEXT: [[TMP4:%.*]] = insertvalue { , , } poison, [[TMP3]], 0 +// CHECK-NEXT: [[TMP5:%.*]] = extractvalue { , , } [[TMP2]], 1 +// CHECK-NEXT: [[TMP6:%.*]] = insertvalue { , , } [[TMP4]], [[TMP5]], 1 +// CHECK-NEXT: [[TMP7:%.*]] = extractvalue { , , } [[TMP2]], 2 +// CHECK-NEXT: [[TMP8:%.*]] = insertvalue { , , } [[TMP6]], [[TMP7]], 2 +// CHECK-NEXT: ret { , , } [[TMP8]] // // CHECK-CXX-LABEL: define dso_local { , , } @_Z28test_svreinterpret_s8_mf8_x313svmfloat8x3_t( // CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]]) #[[ATTR0]] { @@ -962,7 +1169,13 @@ svfloat64x2_t test_svreinterpret_f64_mf8_x2(svmfloat8x2_t op) STREAMING { // CHECK-CXX-NEXT: [[TMP0:%.*]] = insertvalue { , , } poison, [[OP_COERCE0]], 0 // CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , } [[TMP0]], [[OP_COERCE1]], 1 // CHECK-CXX-NEXT: [[TMP2:%.*]] = insertvalue { , , } [[TMP1]], [[OP_COERCE2]], 2 -// CHECK-CXX-NEXT: ret { , , } [[TMP2]] +// CHECK-CXX-NEXT: [[TMP3:%.*]] = extractvalue { , , } [[TMP2]], 0 +// CHECK-CXX-NEXT: [[TMP4:%.*]] = insertvalue { , , } poison, [[TMP3]], 0 +// CHECK-CXX-NEXT: [[TMP5:%.*]] = extractvalue { , , } [[TMP2]], 1 +// CHECK-CXX-NEXT: [[TMP6:%.*]] = insertvalue { , , } [[TMP4]], [[TMP5]], 1 +// CHECK-CXX-NEXT: [[TMP7:%.*]] = extractvalue { , , } [[TMP2]], 2 +// CHECK-CXX-NEXT: [[TMP8:%.*]] = insertvalue { , , } [[TMP6]], [[TMP7]], 2 +// CHECK-CXX-NEXT: ret { , , } [[TMP8]] // svint8x3_t test_svreinterpret_s8_mf8_x3(svmfloat8x3_t op) STREAMING { return SVE_ACLE_FUNC(svreinterpret_s8, _mf8_x3)(op); @@ -974,7 +1187,13 @@ svint8x3_t test_svreinterpret_s8_mf8_x3(svmfloat8x3_t op) STREAMING { // CHECK-NEXT: [[TMP0:%.*]] = insertvalue { , , } poison, [[OP_COERCE0]], 0 // CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , } [[TMP0]], [[OP_COERCE1]], 1 // CHECK-NEXT: [[TMP2:%.*]] = insertvalue { , , } [[TMP1]], [[OP_COERCE2]], 2 -// CHECK-NEXT: ret { , , } [[TMP2]] +// CHECK-NEXT: [[TMP3:%.*]] = extractvalue { , , } [[TMP2]], 0 +// CHECK-NEXT: [[TMP4:%.*]] = insertvalue { , , } poison, [[TMP3]], 0 +// CHECK-NEXT: [[TMP5:%.*]] = extractvalue { , , } [[TMP2]], 1 +// CHECK-NEXT: [[TMP6:%.*]] = insertvalue { , , } [[TMP4]], [[TMP5]], 1 +// CHECK-NEXT: [[TMP7:%.*]] = extractvalue { , , } [[TMP2]], 2 +// CHECK-NEXT: [[TMP8:%.*]] = insertvalue { , , } [[TMP6]], [[TMP7]], 2 +// CHECK-NEXT: ret { , , } [[TMP8]] // // CHECK-CXX-LABEL: define dso_local { , , } @_Z28test_svreinterpret_u8_mf8_x313svmfloat8x3_t( // CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]]) #[[ATTR0]] { @@ -982,7 +1201,13 @@ svint8x3_t test_svreinterpret_s8_mf8_x3(svmfloat8x3_t op) STREAMING { // CHECK-CXX-NEXT: [[TMP0:%.*]] = insertvalue { , , } poison, [[OP_COERCE0]], 0 // CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , } [[TMP0]], [[OP_COERCE1]], 1 // CHECK-CXX-NEXT: [[TMP2:%.*]] = insertvalue { , , } [[TMP1]], [[OP_COERCE2]], 2 -// CHECK-CXX-NEXT: ret { , , } [[TMP2]] +// CHECK-CXX-NEXT: [[TMP3:%.*]] = extractvalue { , , } [[TMP2]], 0 +// CHECK-CXX-NEXT: [[TMP4:%.*]] = insertvalue { , , } poison, [[TMP3]], 0 +// CHECK-CXX-NEXT: [[TMP5:%.*]] = extractvalue { , , } [[TMP2]], 1 +// CHECK-CXX-NEXT: [[TMP6:%.*]] = insertvalue { , , } [[TMP4]], [[TMP5]], 1 +// CHECK-CXX-NEXT: [[TMP7:%.*]] = extractvalue { , , } [[TMP2]], 2 +// CHECK-CXX-NEXT: [[TMP8:%.*]] = insertvalue { , , } [[TMP6]], [[TMP7]], 2 +// CHECK-CXX-NEXT: ret { , , } [[TMP8]] // svuint8x3_t test_svreinterpret_u8_mf8_x3(svmfloat8x3_t op) STREAMING { return SVE_ACLE_FUNC(svreinterpret_u8, _mf8_x3)(op); @@ -994,7 +1219,13 @@ svuint8x3_t test_svreinterpret_u8_mf8_x3(svmfloat8x3_t op) STREAMING { // CHECK-NEXT: [[TMP0:%.*]] = insertvalue { , , } poison, [[OP_COERCE0]], 0 // CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , } [[TMP0]], [[OP_COERCE1]], 1 // CHECK-NEXT: [[TMP2:%.*]] = insertvalue { , , } [[TMP1]], [[OP_COERCE2]], 2 -// CHECK-NEXT: ret { , , } [[TMP2]] +// CHECK-NEXT: [[TMP3:%.*]] = extractvalue { , , } [[TMP2]], 0 +// CHECK-NEXT: [[TMP4:%.*]] = insertvalue { , , } poison, [[TMP3]], 0 +// CHECK-NEXT: [[TMP5:%.*]] = extractvalue { , , } [[TMP2]], 1 +// CHECK-NEXT: [[TMP6:%.*]] = insertvalue { , , } [[TMP4]], [[TMP5]], 1 +// CHECK-NEXT: [[TMP7:%.*]] = extractvalue { , , } [[TMP2]], 2 +// CHECK-NEXT: [[TMP8:%.*]] = insertvalue { , , } [[TMP6]], [[TMP7]], 2 +// CHECK-NEXT: ret { , , } [[TMP8]] // // CHECK-CXX-LABEL: define dso_local { , , } @_Z28test_svreinterpret_mf8_s8_x310svint8x3_t( // CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]]) #[[ATTR0]] { @@ -1002,7 +1233,13 @@ svuint8x3_t test_svreinterpret_u8_mf8_x3(svmfloat8x3_t op) STREAMING { // CHECK-CXX-NEXT: [[TMP0:%.*]] = insertvalue { , , } poison, [[OP_COERCE0]], 0 // CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , } [[TMP0]], [[OP_COERCE1]], 1 // CHECK-CXX-NEXT: [[TMP2:%.*]] = insertvalue { , , } [[TMP1]], [[OP_COERCE2]], 2 -// CHECK-CXX-NEXT: ret { , , } [[TMP2]] +// CHECK-CXX-NEXT: [[TMP3:%.*]] = extractvalue { , , } [[TMP2]], 0 +// CHECK-CXX-NEXT: [[TMP4:%.*]] = insertvalue { , , } poison, [[TMP3]], 0 +// CHECK-CXX-NEXT: [[TMP5:%.*]] = extractvalue { , , } [[TMP2]], 1 +// CHECK-CXX-NEXT: [[TMP6:%.*]] = insertvalue { , , } [[TMP4]], [[TMP5]], 1 +// CHECK-CXX-NEXT: [[TMP7:%.*]] = extractvalue { , , } [[TMP2]], 2 +// CHECK-CXX-NEXT: [[TMP8:%.*]] = insertvalue { , , } [[TMP6]], [[TMP7]], 2 +// CHECK-CXX-NEXT: ret { , , } [[TMP8]] // svmfloat8x3_t test_svreinterpret_mf8_s8_x3(svint8x3_t op) STREAMING { return SVE_ACLE_FUNC(svreinterpret_mf8, _s8_x3)(op); @@ -1014,7 +1251,13 @@ svmfloat8x3_t test_svreinterpret_mf8_s8_x3(svint8x3_t op) STREAMING { // CHECK-NEXT: [[TMP0:%.*]] = insertvalue { , , } poison, [[OP_COERCE0]], 0 // CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , } [[TMP0]], [[OP_COERCE1]], 1 // CHECK-NEXT: [[TMP2:%.*]] = insertvalue { , , } [[TMP1]], [[OP_COERCE2]], 2 -// CHECK-NEXT: ret { , , } [[TMP2]] +// CHECK-NEXT: [[TMP3:%.*]] = extractvalue { , , } [[TMP2]], 0 +// CHECK-NEXT: [[TMP4:%.*]] = insertvalue { , , } poison, [[TMP3]], 0 +// CHECK-NEXT: [[TMP5:%.*]] = extractvalue { , , } [[TMP2]], 1 +// CHECK-NEXT: [[TMP6:%.*]] = insertvalue { , , } [[TMP4]], [[TMP5]], 1 +// CHECK-NEXT: [[TMP7:%.*]] = extractvalue { , , } [[TMP2]], 2 +// CHECK-NEXT: [[TMP8:%.*]] = insertvalue { , , } [[TMP6]], [[TMP7]], 2 +// CHECK-NEXT: ret { , , } [[TMP8]] // // CHECK-CXX-LABEL: define dso_local { , , } @_Z28test_svreinterpret_mf8_u8_x311svuint8x3_t( // CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]]) #[[ATTR0]] { @@ -1022,7 +1265,13 @@ svmfloat8x3_t test_svreinterpret_mf8_s8_x3(svint8x3_t op) STREAMING { // CHECK-CXX-NEXT: [[TMP0:%.*]] = insertvalue { , , } poison, [[OP_COERCE0]], 0 // CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , } [[TMP0]], [[OP_COERCE1]], 1 // CHECK-CXX-NEXT: [[TMP2:%.*]] = insertvalue { , , } [[TMP1]], [[OP_COERCE2]], 2 -// CHECK-CXX-NEXT: ret { , , } [[TMP2]] +// CHECK-CXX-NEXT: [[TMP3:%.*]] = extractvalue { , , } [[TMP2]], 0 +// CHECK-CXX-NEXT: [[TMP4:%.*]] = insertvalue { , , } poison, [[TMP3]], 0 +// CHECK-CXX-NEXT: [[TMP5:%.*]] = extractvalue { , , } [[TMP2]], 1 +// CHECK-CXX-NEXT: [[TMP6:%.*]] = insertvalue { , , } [[TMP4]], [[TMP5]], 1 +// CHECK-CXX-NEXT: [[TMP7:%.*]] = extractvalue { , , } [[TMP2]], 2 +// CHECK-CXX-NEXT: [[TMP8:%.*]] = insertvalue { , , } [[TMP6]], [[TMP7]], 2 +// CHECK-CXX-NEXT: ret { , , } [[TMP8]] // svmfloat8x3_t test_svreinterpret_mf8_u8_x3(svuint8x3_t op) STREAMING { return SVE_ACLE_FUNC(svreinterpret_mf8, _u8_x3)(op); @@ -1034,7 +1283,13 @@ svmfloat8x3_t test_svreinterpret_mf8_u8_x3(svuint8x3_t op) STREAMING { // CHECK-NEXT: [[TMP0:%.*]] = insertvalue { , , } poison, [[OP_COERCE0]], 0 // CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , } [[TMP0]], [[OP_COERCE1]], 1 // CHECK-NEXT: [[TMP2:%.*]] = insertvalue { , , } [[TMP1]], [[OP_COERCE2]], 2 -// CHECK-NEXT: ret { , , } [[TMP2]] +// CHECK-NEXT: [[TMP3:%.*]] = extractvalue { , , } [[TMP2]], 0 +// CHECK-NEXT: [[TMP4:%.*]] = insertvalue { , , } poison, [[TMP3]], 0 +// CHECK-NEXT: [[TMP5:%.*]] = extractvalue { , , } [[TMP2]], 1 +// CHECK-NEXT: [[TMP6:%.*]] = insertvalue { , , } [[TMP4]], [[TMP5]], 1 +// CHECK-NEXT: [[TMP7:%.*]] = extractvalue { , , } [[TMP2]], 2 +// CHECK-NEXT: [[TMP8:%.*]] = insertvalue { , , } [[TMP6]], [[TMP7]], 2 +// CHECK-NEXT: ret { , , } [[TMP8]] // // CHECK-CXX-LABEL: define dso_local { , , } @_Z29test_svreinterpret_mf8_mf8_x313svmfloat8x3_t( // CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]]) #[[ATTR0]] { @@ -1042,7 +1297,13 @@ svmfloat8x3_t test_svreinterpret_mf8_u8_x3(svuint8x3_t op) STREAMING { // CHECK-CXX-NEXT: [[TMP0:%.*]] = insertvalue { , , } poison, [[OP_COERCE0]], 0 // CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , } [[TMP0]], [[OP_COERCE1]], 1 // CHECK-CXX-NEXT: [[TMP2:%.*]] = insertvalue { , , } [[TMP1]], [[OP_COERCE2]], 2 -// CHECK-CXX-NEXT: ret { , , } [[TMP2]] +// CHECK-CXX-NEXT: [[TMP3:%.*]] = extractvalue { , , } [[TMP2]], 0 +// CHECK-CXX-NEXT: [[TMP4:%.*]] = insertvalue { , , } poison, [[TMP3]], 0 +// CHECK-CXX-NEXT: [[TMP5:%.*]] = extractvalue { , , } [[TMP2]], 1 +// CHECK-CXX-NEXT: [[TMP6:%.*]] = insertvalue { , , } [[TMP4]], [[TMP5]], 1 +// CHECK-CXX-NEXT: [[TMP7:%.*]] = extractvalue { , , } [[TMP2]], 2 +// CHECK-CXX-NEXT: [[TMP8:%.*]] = insertvalue { , , } [[TMP6]], [[TMP7]], 2 +// CHECK-CXX-NEXT: ret { , , } [[TMP8]] // svmfloat8x3_t test_svreinterpret_mf8_mf8_x3(svmfloat8x3_t op) STREAMING { return SVE_ACLE_FUNC(svreinterpret_mf8, _mf8_x3)(op); @@ -1051,24 +1312,36 @@ svmfloat8x3_t test_svreinterpret_mf8_mf8_x3(svmfloat8x3_t op) STREAMING { // CHECK-LABEL: define dso_local { , , } @test_svreinterpret_mf8_s16_x3( // CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]]) #[[ATTR0]] { // CHECK-NEXT: [[ENTRY:.*:]] -// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , } poison, [[TMP0]], 0 -// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , } [[TMP1]], [[TMP2]], 1 -// CHECK-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to -// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , } [[TMP3]], [[TMP4]], 2 -// CHECK-NEXT: ret { , , } [[TMP5]] +// CHECK-NEXT: [[TMP0:%.*]] = insertvalue { , , } poison, [[OP_COERCE0]], 0 +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-NEXT: [[TMP2:%.*]] = insertvalue { , , } [[TMP1]], [[OP_COERCE2]], 2 +// CHECK-NEXT: [[TMP3:%.*]] = extractvalue { , , } [[TMP2]], 0 +// CHECK-NEXT: [[TMP4:%.*]] = bitcast [[TMP3]] to +// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , } poison, [[TMP4]], 0 +// CHECK-NEXT: [[TMP6:%.*]] = extractvalue { , , } [[TMP2]], 1 +// CHECK-NEXT: [[TMP7:%.*]] = bitcast [[TMP6]] to +// CHECK-NEXT: [[TMP8:%.*]] = insertvalue { , , } [[TMP5]], [[TMP7]], 1 +// CHECK-NEXT: [[TMP9:%.*]] = extractvalue { , , } [[TMP2]], 2 +// CHECK-NEXT: [[TMP10:%.*]] = bitcast [[TMP9]] to +// CHECK-NEXT: [[TMP11:%.*]] = insertvalue { , , } [[TMP8]], [[TMP10]], 2 +// CHECK-NEXT: ret { , , } [[TMP11]] // // CHECK-CXX-LABEL: define dso_local { , , } @_Z29test_svreinterpret_mf8_s16_x311svint16x3_t( // CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]]) #[[ATTR0]] { // CHECK-CXX-NEXT: [[ENTRY:.*:]] -// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , } poison, [[TMP0]], 0 -// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , } [[TMP1]], [[TMP2]], 1 -// CHECK-CXX-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to -// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , } [[TMP3]], [[TMP4]], 2 -// CHECK-CXX-NEXT: ret { , , } [[TMP5]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = insertvalue { , , } poison, [[OP_COERCE0]], 0 +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = insertvalue { , , } [[TMP1]], [[OP_COERCE2]], 2 +// CHECK-CXX-NEXT: [[TMP3:%.*]] = extractvalue { , , } [[TMP2]], 0 +// CHECK-CXX-NEXT: [[TMP4:%.*]] = bitcast [[TMP3]] to +// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , } poison, [[TMP4]], 0 +// CHECK-CXX-NEXT: [[TMP6:%.*]] = extractvalue { , , } [[TMP2]], 1 +// CHECK-CXX-NEXT: [[TMP7:%.*]] = bitcast [[TMP6]] to +// CHECK-CXX-NEXT: [[TMP8:%.*]] = insertvalue { , , } [[TMP5]], [[TMP7]], 1 +// CHECK-CXX-NEXT: [[TMP9:%.*]] = extractvalue { , , } [[TMP2]], 2 +// CHECK-CXX-NEXT: [[TMP10:%.*]] = bitcast [[TMP9]] to +// CHECK-CXX-NEXT: [[TMP11:%.*]] = insertvalue { , , } [[TMP8]], [[TMP10]], 2 +// CHECK-CXX-NEXT: ret { , , } [[TMP11]] // svmfloat8x3_t test_svreinterpret_mf8_s16_x3(svint16x3_t op) STREAMING { return SVE_ACLE_FUNC(svreinterpret_mf8, _s16_x3)(op); @@ -1077,24 +1350,36 @@ svmfloat8x3_t test_svreinterpret_mf8_s16_x3(svint16x3_t op) STREAMING { // CHECK-LABEL: define dso_local { , , } @test_svreinterpret_mf8_u16_x3( // CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]]) #[[ATTR0]] { // CHECK-NEXT: [[ENTRY:.*:]] -// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , } poison, [[TMP0]], 0 -// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , } [[TMP1]], [[TMP2]], 1 -// CHECK-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to -// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , } [[TMP3]], [[TMP4]], 2 -// CHECK-NEXT: ret { , , } [[TMP5]] +// CHECK-NEXT: [[TMP0:%.*]] = insertvalue { , , } poison, [[OP_COERCE0]], 0 +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-NEXT: [[TMP2:%.*]] = insertvalue { , , } [[TMP1]], [[OP_COERCE2]], 2 +// CHECK-NEXT: [[TMP3:%.*]] = extractvalue { , , } [[TMP2]], 0 +// CHECK-NEXT: [[TMP4:%.*]] = bitcast [[TMP3]] to +// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , } poison, [[TMP4]], 0 +// CHECK-NEXT: [[TMP6:%.*]] = extractvalue { , , } [[TMP2]], 1 +// CHECK-NEXT: [[TMP7:%.*]] = bitcast [[TMP6]] to +// CHECK-NEXT: [[TMP8:%.*]] = insertvalue { , , } [[TMP5]], [[TMP7]], 1 +// CHECK-NEXT: [[TMP9:%.*]] = extractvalue { , , } [[TMP2]], 2 +// CHECK-NEXT: [[TMP10:%.*]] = bitcast [[TMP9]] to +// CHECK-NEXT: [[TMP11:%.*]] = insertvalue { , , } [[TMP8]], [[TMP10]], 2 +// CHECK-NEXT: ret { , , } [[TMP11]] // // CHECK-CXX-LABEL: define dso_local { , , } @_Z29test_svreinterpret_mf8_u16_x312svuint16x3_t( // CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]]) #[[ATTR0]] { // CHECK-CXX-NEXT: [[ENTRY:.*:]] -// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , } poison, [[TMP0]], 0 -// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , } [[TMP1]], [[TMP2]], 1 -// CHECK-CXX-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to -// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , } [[TMP3]], [[TMP4]], 2 -// CHECK-CXX-NEXT: ret { , , } [[TMP5]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = insertvalue { , , } poison, [[OP_COERCE0]], 0 +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = insertvalue { , , } [[TMP1]], [[OP_COERCE2]], 2 +// CHECK-CXX-NEXT: [[TMP3:%.*]] = extractvalue { , , } [[TMP2]], 0 +// CHECK-CXX-NEXT: [[TMP4:%.*]] = bitcast [[TMP3]] to +// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , } poison, [[TMP4]], 0 +// CHECK-CXX-NEXT: [[TMP6:%.*]] = extractvalue { , , } [[TMP2]], 1 +// CHECK-CXX-NEXT: [[TMP7:%.*]] = bitcast [[TMP6]] to +// CHECK-CXX-NEXT: [[TMP8:%.*]] = insertvalue { , , } [[TMP5]], [[TMP7]], 1 +// CHECK-CXX-NEXT: [[TMP9:%.*]] = extractvalue { , , } [[TMP2]], 2 +// CHECK-CXX-NEXT: [[TMP10:%.*]] = bitcast [[TMP9]] to +// CHECK-CXX-NEXT: [[TMP11:%.*]] = insertvalue { , , } [[TMP8]], [[TMP10]], 2 +// CHECK-CXX-NEXT: ret { , , } [[TMP11]] // svmfloat8x3_t test_svreinterpret_mf8_u16_x3(svuint16x3_t op) STREAMING { return SVE_ACLE_FUNC(svreinterpret_mf8, _u16_x3)(op); @@ -1103,24 +1388,36 @@ svmfloat8x3_t test_svreinterpret_mf8_u16_x3(svuint16x3_t op) STREAMING { // CHECK-LABEL: define dso_local { , , } @test_svreinterpret_mf8_s32_x3( // CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]]) #[[ATTR0]] { // CHECK-NEXT: [[ENTRY:.*:]] -// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , } poison, [[TMP0]], 0 -// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , } [[TMP1]], [[TMP2]], 1 -// CHECK-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to -// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , } [[TMP3]], [[TMP4]], 2 -// CHECK-NEXT: ret { , , } [[TMP5]] +// CHECK-NEXT: [[TMP0:%.*]] = insertvalue { , , } poison, [[OP_COERCE0]], 0 +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-NEXT: [[TMP2:%.*]] = insertvalue { , , } [[TMP1]], [[OP_COERCE2]], 2 +// CHECK-NEXT: [[TMP3:%.*]] = extractvalue { , , } [[TMP2]], 0 +// CHECK-NEXT: [[TMP4:%.*]] = bitcast [[TMP3]] to +// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , } poison, [[TMP4]], 0 +// CHECK-NEXT: [[TMP6:%.*]] = extractvalue { , , } [[TMP2]], 1 +// CHECK-NEXT: [[TMP7:%.*]] = bitcast [[TMP6]] to +// CHECK-NEXT: [[TMP8:%.*]] = insertvalue { , , } [[TMP5]], [[TMP7]], 1 +// CHECK-NEXT: [[TMP9:%.*]] = extractvalue { , , } [[TMP2]], 2 +// CHECK-NEXT: [[TMP10:%.*]] = bitcast [[TMP9]] to +// CHECK-NEXT: [[TMP11:%.*]] = insertvalue { , , } [[TMP8]], [[TMP10]], 2 +// CHECK-NEXT: ret { , , } [[TMP11]] // // CHECK-CXX-LABEL: define dso_local { , , } @_Z29test_svreinterpret_mf8_s32_x311svint32x3_t( // CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]]) #[[ATTR0]] { // CHECK-CXX-NEXT: [[ENTRY:.*:]] -// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , } poison, [[TMP0]], 0 -// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , } [[TMP1]], [[TMP2]], 1 -// CHECK-CXX-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to -// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , } [[TMP3]], [[TMP4]], 2 -// CHECK-CXX-NEXT: ret { , , } [[TMP5]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = insertvalue { , , } poison, [[OP_COERCE0]], 0 +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = insertvalue { , , } [[TMP1]], [[OP_COERCE2]], 2 +// CHECK-CXX-NEXT: [[TMP3:%.*]] = extractvalue { , , } [[TMP2]], 0 +// CHECK-CXX-NEXT: [[TMP4:%.*]] = bitcast [[TMP3]] to +// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , } poison, [[TMP4]], 0 +// CHECK-CXX-NEXT: [[TMP6:%.*]] = extractvalue { , , } [[TMP2]], 1 +// CHECK-CXX-NEXT: [[TMP7:%.*]] = bitcast [[TMP6]] to +// CHECK-CXX-NEXT: [[TMP8:%.*]] = insertvalue { , , } [[TMP5]], [[TMP7]], 1 +// CHECK-CXX-NEXT: [[TMP9:%.*]] = extractvalue { , , } [[TMP2]], 2 +// CHECK-CXX-NEXT: [[TMP10:%.*]] = bitcast [[TMP9]] to +// CHECK-CXX-NEXT: [[TMP11:%.*]] = insertvalue { , , } [[TMP8]], [[TMP10]], 2 +// CHECK-CXX-NEXT: ret { , , } [[TMP11]] // svmfloat8x3_t test_svreinterpret_mf8_s32_x3(svint32x3_t op) STREAMING { return SVE_ACLE_FUNC(svreinterpret_mf8, _s32_x3)(op); @@ -1129,24 +1426,36 @@ svmfloat8x3_t test_svreinterpret_mf8_s32_x3(svint32x3_t op) STREAMING { // CHECK-LABEL: define dso_local { , , } @test_svreinterpret_mf8_u32_x3( // CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]]) #[[ATTR0]] { // CHECK-NEXT: [[ENTRY:.*:]] -// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , } poison, [[TMP0]], 0 -// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , } [[TMP1]], [[TMP2]], 1 -// CHECK-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to -// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , } [[TMP3]], [[TMP4]], 2 -// CHECK-NEXT: ret { , , } [[TMP5]] +// CHECK-NEXT: [[TMP0:%.*]] = insertvalue { , , } poison, [[OP_COERCE0]], 0 +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-NEXT: [[TMP2:%.*]] = insertvalue { , , } [[TMP1]], [[OP_COERCE2]], 2 +// CHECK-NEXT: [[TMP3:%.*]] = extractvalue { , , } [[TMP2]], 0 +// CHECK-NEXT: [[TMP4:%.*]] = bitcast [[TMP3]] to +// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , } poison, [[TMP4]], 0 +// CHECK-NEXT: [[TMP6:%.*]] = extractvalue { , , } [[TMP2]], 1 +// CHECK-NEXT: [[TMP7:%.*]] = bitcast [[TMP6]] to +// CHECK-NEXT: [[TMP8:%.*]] = insertvalue { , , } [[TMP5]], [[TMP7]], 1 +// CHECK-NEXT: [[TMP9:%.*]] = extractvalue { , , } [[TMP2]], 2 +// CHECK-NEXT: [[TMP10:%.*]] = bitcast [[TMP9]] to +// CHECK-NEXT: [[TMP11:%.*]] = insertvalue { , , } [[TMP8]], [[TMP10]], 2 +// CHECK-NEXT: ret { , , } [[TMP11]] // // CHECK-CXX-LABEL: define dso_local { , , } @_Z29test_svreinterpret_mf8_u32_x312svuint32x3_t( // CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]]) #[[ATTR0]] { // CHECK-CXX-NEXT: [[ENTRY:.*:]] -// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , } poison, [[TMP0]], 0 -// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , } [[TMP1]], [[TMP2]], 1 -// CHECK-CXX-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to -// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , } [[TMP3]], [[TMP4]], 2 -// CHECK-CXX-NEXT: ret { , , } [[TMP5]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = insertvalue { , , } poison, [[OP_COERCE0]], 0 +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = insertvalue { , , } [[TMP1]], [[OP_COERCE2]], 2 +// CHECK-CXX-NEXT: [[TMP3:%.*]] = extractvalue { , , } [[TMP2]], 0 +// CHECK-CXX-NEXT: [[TMP4:%.*]] = bitcast [[TMP3]] to +// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , } poison, [[TMP4]], 0 +// CHECK-CXX-NEXT: [[TMP6:%.*]] = extractvalue { , , } [[TMP2]], 1 +// CHECK-CXX-NEXT: [[TMP7:%.*]] = bitcast [[TMP6]] to +// CHECK-CXX-NEXT: [[TMP8:%.*]] = insertvalue { , , } [[TMP5]], [[TMP7]], 1 +// CHECK-CXX-NEXT: [[TMP9:%.*]] = extractvalue { , , } [[TMP2]], 2 +// CHECK-CXX-NEXT: [[TMP10:%.*]] = bitcast [[TMP9]] to +// CHECK-CXX-NEXT: [[TMP11:%.*]] = insertvalue { , , } [[TMP8]], [[TMP10]], 2 +// CHECK-CXX-NEXT: ret { , , } [[TMP11]] // svmfloat8x3_t test_svreinterpret_mf8_u32_x3(svuint32x3_t op) STREAMING { return SVE_ACLE_FUNC(svreinterpret_mf8, _u32_x3)(op); @@ -1155,50 +1464,75 @@ svmfloat8x3_t test_svreinterpret_mf8_u32_x3(svuint32x3_t op) STREAMING { // CHECK-LABEL: define dso_local { , , } @test_svreinterpret_mf8_s64_x3( // CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]]) #[[ATTR0]] { // CHECK-NEXT: [[ENTRY:.*:]] -// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , } poison, [[TMP0]], 0 -// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , } [[TMP1]], [[TMP2]], 1 -// CHECK-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to -// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , } [[TMP3]], [[TMP4]], 2 -// CHECK-NEXT: ret { , , } [[TMP5]] +// CHECK-NEXT: [[TMP0:%.*]] = insertvalue { , , } poison, [[OP_COERCE0]], 0 +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-NEXT: [[TMP2:%.*]] = insertvalue { , , } [[TMP1]], [[OP_COERCE2]], 2 +// CHECK-NEXT: [[TMP3:%.*]] = extractvalue { , , } [[TMP2]], 0 +// CHECK-NEXT: [[TMP4:%.*]] = bitcast [[TMP3]] to +// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , } poison, [[TMP4]], 0 +// CHECK-NEXT: [[TMP6:%.*]] = extractvalue { , , } [[TMP2]], 1 +// CHECK-NEXT: [[TMP7:%.*]] = bitcast [[TMP6]] to +// CHECK-NEXT: [[TMP8:%.*]] = insertvalue { , , } [[TMP5]], [[TMP7]], 1 +// CHECK-NEXT: [[TMP9:%.*]] = extractvalue { , , } [[TMP2]], 2 +// CHECK-NEXT: [[TMP10:%.*]] = bitcast [[TMP9]] to +// CHECK-NEXT: [[TMP11:%.*]] = insertvalue { , , } [[TMP8]], [[TMP10]], 2 +// CHECK-NEXT: ret { , , } [[TMP11]] // // CHECK-CXX-LABEL: define dso_local { , , } @_Z29test_svreinterpret_mf8_s64_x311svint64x3_t( // CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]]) #[[ATTR0]] { // CHECK-CXX-NEXT: [[ENTRY:.*:]] -// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , } poison, [[TMP0]], 0 -// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , } [[TMP1]], [[TMP2]], 1 -// CHECK-CXX-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to -// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , } [[TMP3]], [[TMP4]], 2 -// CHECK-CXX-NEXT: ret { , , } [[TMP5]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = insertvalue { , , } poison, [[OP_COERCE0]], 0 +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = insertvalue { , , } [[TMP1]], [[OP_COERCE2]], 2 +// CHECK-CXX-NEXT: [[TMP3:%.*]] = extractvalue { , , } [[TMP2]], 0 +// CHECK-CXX-NEXT: [[TMP4:%.*]] = bitcast [[TMP3]] to +// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , } poison, [[TMP4]], 0 +// CHECK-CXX-NEXT: [[TMP6:%.*]] = extractvalue { , , } [[TMP2]], 1 +// CHECK-CXX-NEXT: [[TMP7:%.*]] = bitcast [[TMP6]] to +// CHECK-CXX-NEXT: [[TMP8:%.*]] = insertvalue { , , } [[TMP5]], [[TMP7]], 1 +// CHECK-CXX-NEXT: [[TMP9:%.*]] = extractvalue { , , } [[TMP2]], 2 +// CHECK-CXX-NEXT: [[TMP10:%.*]] = bitcast [[TMP9]] to +// CHECK-CXX-NEXT: [[TMP11:%.*]] = insertvalue { , , } [[TMP8]], [[TMP10]], 2 +// CHECK-CXX-NEXT: ret { , , } [[TMP11]] // svmfloat8x3_t test_svreinterpret_mf8_s64_x3(svint64x3_t op) STREAMING { return SVE_ACLE_FUNC(svreinterpret_mf8, _s64_x3)(op); } +// // CHECK-LABEL: define dso_local { , , } @test_svreinterpret_mf8_u64_x3( // CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]]) #[[ATTR0]] { // CHECK-NEXT: [[ENTRY:.*:]] -// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , } poison, [[TMP0]], 0 -// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , } [[TMP1]], [[TMP2]], 1 -// CHECK-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to -// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , } [[TMP3]], [[TMP4]], 2 -// CHECK-NEXT: ret { , , } [[TMP5]] +// CHECK-NEXT: [[TMP0:%.*]] = insertvalue { , , } poison, [[OP_COERCE0]], 0 +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-NEXT: [[TMP2:%.*]] = insertvalue { , , } [[TMP1]], [[OP_COERCE2]], 2 +// CHECK-NEXT: [[TMP3:%.*]] = extractvalue { , , } [[TMP2]], 0 +// CHECK-NEXT: [[TMP4:%.*]] = bitcast [[TMP3]] to +// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , } poison, [[TMP4]], 0 +// CHECK-NEXT: [[TMP6:%.*]] = extractvalue { , , } [[TMP2]], 1 +// CHECK-NEXT: [[TMP7:%.*]] = bitcast [[TMP6]] to +// CHECK-NEXT: [[TMP8:%.*]] = insertvalue { , , } [[TMP5]], [[TMP7]], 1 +// CHECK-NEXT: [[TMP9:%.*]] = extractvalue { , , } [[TMP2]], 2 +// CHECK-NEXT: [[TMP10:%.*]] = bitcast [[TMP9]] to +// CHECK-NEXT: [[TMP11:%.*]] = insertvalue { , , } [[TMP8]], [[TMP10]], 2 +// CHECK-NEXT: ret { , , } [[TMP11]] // // CHECK-CXX-LABEL: define dso_local { , , } @_Z29test_svreinterpret_mf8_u64_x312svuint64x3_t( // CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]]) #[[ATTR0]] { // CHECK-CXX-NEXT: [[ENTRY:.*:]] -// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , } poison, [[TMP0]], 0 -// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , } [[TMP1]], [[TMP2]], 1 -// CHECK-CXX-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to -// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , } [[TMP3]], [[TMP4]], 2 -// CHECK-CXX-NEXT: ret { , , } [[TMP5]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = insertvalue { , , } poison, [[OP_COERCE0]], 0 +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = insertvalue { , , } [[TMP1]], [[OP_COERCE2]], 2 +// CHECK-CXX-NEXT: [[TMP3:%.*]] = extractvalue { , , } [[TMP2]], 0 +// CHECK-CXX-NEXT: [[TMP4:%.*]] = bitcast [[TMP3]] to +// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , } poison, [[TMP4]], 0 +// CHECK-CXX-NEXT: [[TMP6:%.*]] = extractvalue { , , } [[TMP2]], 1 +// CHECK-CXX-NEXT: [[TMP7:%.*]] = bitcast [[TMP6]] to +// CHECK-CXX-NEXT: [[TMP8:%.*]] = insertvalue { , , } [[TMP5]], [[TMP7]], 1 +// CHECK-CXX-NEXT: [[TMP9:%.*]] = extractvalue { , , } [[TMP2]], 2 +// CHECK-CXX-NEXT: [[TMP10:%.*]] = bitcast [[TMP9]] to +// CHECK-CXX-NEXT: [[TMP11:%.*]] = insertvalue { , , } [[TMP8]], [[TMP10]], 2 +// CHECK-CXX-NEXT: ret { , , } [[TMP11]] // svmfloat8x3_t test_svreinterpret_mf8_u64_x3(svuint64x3_t op) STREAMING { return SVE_ACLE_FUNC(svreinterpret_mf8, _u64_x3)(op); @@ -1207,24 +1541,36 @@ svmfloat8x3_t test_svreinterpret_mf8_u64_x3(svuint64x3_t op) STREAMING { // CHECK-LABEL: define dso_local { , , } @test_svreinterpret_mf8_f16_x3( // CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]]) #[[ATTR0]] { // CHECK-NEXT: [[ENTRY:.*:]] -// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , } poison, [[TMP0]], 0 -// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , } [[TMP1]], [[TMP2]], 1 -// CHECK-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to -// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , } [[TMP3]], [[TMP4]], 2 -// CHECK-NEXT: ret { , , } [[TMP5]] +// CHECK-NEXT: [[TMP0:%.*]] = insertvalue { , , } poison, [[OP_COERCE0]], 0 +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-NEXT: [[TMP2:%.*]] = insertvalue { , , } [[TMP1]], [[OP_COERCE2]], 2 +// CHECK-NEXT: [[TMP3:%.*]] = extractvalue { , , } [[TMP2]], 0 +// CHECK-NEXT: [[TMP4:%.*]] = bitcast [[TMP3]] to +// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , } poison, [[TMP4]], 0 +// CHECK-NEXT: [[TMP6:%.*]] = extractvalue { , , } [[TMP2]], 1 +// CHECK-NEXT: [[TMP7:%.*]] = bitcast [[TMP6]] to +// CHECK-NEXT: [[TMP8:%.*]] = insertvalue { , , } [[TMP5]], [[TMP7]], 1 +// CHECK-NEXT: [[TMP9:%.*]] = extractvalue { , , } [[TMP2]], 2 +// CHECK-NEXT: [[TMP10:%.*]] = bitcast [[TMP9]] to +// CHECK-NEXT: [[TMP11:%.*]] = insertvalue { , , } [[TMP8]], [[TMP10]], 2 +// CHECK-NEXT: ret { , , } [[TMP11]] // // CHECK-CXX-LABEL: define dso_local { , , } @_Z29test_svreinterpret_mf8_f16_x313svfloat16x3_t( // CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]]) #[[ATTR0]] { // CHECK-CXX-NEXT: [[ENTRY:.*:]] -// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , } poison, [[TMP0]], 0 -// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , } [[TMP1]], [[TMP2]], 1 -// CHECK-CXX-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to -// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , } [[TMP3]], [[TMP4]], 2 -// CHECK-CXX-NEXT: ret { , , } [[TMP5]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = insertvalue { , , } poison, [[OP_COERCE0]], 0 +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = insertvalue { , , } [[TMP1]], [[OP_COERCE2]], 2 +// CHECK-CXX-NEXT: [[TMP3:%.*]] = extractvalue { , , } [[TMP2]], 0 +// CHECK-CXX-NEXT: [[TMP4:%.*]] = bitcast [[TMP3]] to +// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , } poison, [[TMP4]], 0 +// CHECK-CXX-NEXT: [[TMP6:%.*]] = extractvalue { , , } [[TMP2]], 1 +// CHECK-CXX-NEXT: [[TMP7:%.*]] = bitcast [[TMP6]] to +// CHECK-CXX-NEXT: [[TMP8:%.*]] = insertvalue { , , } [[TMP5]], [[TMP7]], 1 +// CHECK-CXX-NEXT: [[TMP9:%.*]] = extractvalue { , , } [[TMP2]], 2 +// CHECK-CXX-NEXT: [[TMP10:%.*]] = bitcast [[TMP9]] to +// CHECK-CXX-NEXT: [[TMP11:%.*]] = insertvalue { , , } [[TMP8]], [[TMP10]], 2 +// CHECK-CXX-NEXT: ret { , , } [[TMP11]] // svmfloat8x3_t test_svreinterpret_mf8_f16_x3(svfloat16x3_t op) STREAMING { return SVE_ACLE_FUNC(svreinterpret_mf8, _f16_x3)(op); @@ -1233,24 +1579,36 @@ svmfloat8x3_t test_svreinterpret_mf8_f16_x3(svfloat16x3_t op) STREAMING { // CHECK-LABEL: define dso_local { , , } @test_svreinterpret_mf8_bf16_x3( // CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]]) #[[ATTR0]] { // CHECK-NEXT: [[ENTRY:.*:]] -// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , } poison, [[TMP0]], 0 -// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , } [[TMP1]], [[TMP2]], 1 -// CHECK-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to -// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , } [[TMP3]], [[TMP4]], 2 -// CHECK-NEXT: ret { , , } [[TMP5]] +// CHECK-NEXT: [[TMP0:%.*]] = insertvalue { , , } poison, [[OP_COERCE0]], 0 +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-NEXT: [[TMP2:%.*]] = insertvalue { , , } [[TMP1]], [[OP_COERCE2]], 2 +// CHECK-NEXT: [[TMP3:%.*]] = extractvalue { , , } [[TMP2]], 0 +// CHECK-NEXT: [[TMP4:%.*]] = bitcast [[TMP3]] to +// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , } poison, [[TMP4]], 0 +// CHECK-NEXT: [[TMP6:%.*]] = extractvalue { , , } [[TMP2]], 1 +// CHECK-NEXT: [[TMP7:%.*]] = bitcast [[TMP6]] to +// CHECK-NEXT: [[TMP8:%.*]] = insertvalue { , , } [[TMP5]], [[TMP7]], 1 +// CHECK-NEXT: [[TMP9:%.*]] = extractvalue { , , } [[TMP2]], 2 +// CHECK-NEXT: [[TMP10:%.*]] = bitcast [[TMP9]] to +// CHECK-NEXT: [[TMP11:%.*]] = insertvalue { , , } [[TMP8]], [[TMP10]], 2 +// CHECK-NEXT: ret { , , } [[TMP11]] // // CHECK-CXX-LABEL: define dso_local { , , } @_Z30test_svreinterpret_mf8_bf16_x314svbfloat16x3_t( // CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]]) #[[ATTR0]] { // CHECK-CXX-NEXT: [[ENTRY:.*:]] -// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , } poison, [[TMP0]], 0 -// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , } [[TMP1]], [[TMP2]], 1 -// CHECK-CXX-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to -// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , } [[TMP3]], [[TMP4]], 2 -// CHECK-CXX-NEXT: ret { , , } [[TMP5]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = insertvalue { , , } poison, [[OP_COERCE0]], 0 +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = insertvalue { , , } [[TMP1]], [[OP_COERCE2]], 2 +// CHECK-CXX-NEXT: [[TMP3:%.*]] = extractvalue { , , } [[TMP2]], 0 +// CHECK-CXX-NEXT: [[TMP4:%.*]] = bitcast [[TMP3]] to +// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , } poison, [[TMP4]], 0 +// CHECK-CXX-NEXT: [[TMP6:%.*]] = extractvalue { , , } [[TMP2]], 1 +// CHECK-CXX-NEXT: [[TMP7:%.*]] = bitcast [[TMP6]] to +// CHECK-CXX-NEXT: [[TMP8:%.*]] = insertvalue { , , } [[TMP5]], [[TMP7]], 1 +// CHECK-CXX-NEXT: [[TMP9:%.*]] = extractvalue { , , } [[TMP2]], 2 +// CHECK-CXX-NEXT: [[TMP10:%.*]] = bitcast [[TMP9]] to +// CHECK-CXX-NEXT: [[TMP11:%.*]] = insertvalue { , , } [[TMP8]], [[TMP10]], 2 +// CHECK-CXX-NEXT: ret { , , } [[TMP11]] // svmfloat8x3_t test_svreinterpret_mf8_bf16_x3(svbfloat16x3_t op) STREAMING { return SVE_ACLE_FUNC(svreinterpret_mf8, _bf16_x3)(op); @@ -1259,24 +1617,36 @@ svmfloat8x3_t test_svreinterpret_mf8_bf16_x3(svbfloat16x3_t op) STREAMING { // CHECK-LABEL: define dso_local { , , } @test_svreinterpret_mf8_f32_x3( // CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]]) #[[ATTR0]] { // CHECK-NEXT: [[ENTRY:.*:]] -// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , } poison, [[TMP0]], 0 -// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , } [[TMP1]], [[TMP2]], 1 -// CHECK-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to -// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , } [[TMP3]], [[TMP4]], 2 -// CHECK-NEXT: ret { , , } [[TMP5]] +// CHECK-NEXT: [[TMP0:%.*]] = insertvalue { , , } poison, [[OP_COERCE0]], 0 +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-NEXT: [[TMP2:%.*]] = insertvalue { , , } [[TMP1]], [[OP_COERCE2]], 2 +// CHECK-NEXT: [[TMP3:%.*]] = extractvalue { , , } [[TMP2]], 0 +// CHECK-NEXT: [[TMP4:%.*]] = bitcast [[TMP3]] to +// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , } poison, [[TMP4]], 0 +// CHECK-NEXT: [[TMP6:%.*]] = extractvalue { , , } [[TMP2]], 1 +// CHECK-NEXT: [[TMP7:%.*]] = bitcast [[TMP6]] to +// CHECK-NEXT: [[TMP8:%.*]] = insertvalue { , , } [[TMP5]], [[TMP7]], 1 +// CHECK-NEXT: [[TMP9:%.*]] = extractvalue { , , } [[TMP2]], 2 +// CHECK-NEXT: [[TMP10:%.*]] = bitcast [[TMP9]] to +// CHECK-NEXT: [[TMP11:%.*]] = insertvalue { , , } [[TMP8]], [[TMP10]], 2 +// CHECK-NEXT: ret { , , } [[TMP11]] // // CHECK-CXX-LABEL: define dso_local { , , } @_Z29test_svreinterpret_mf8_f32_x313svfloat32x3_t( // CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]]) #[[ATTR0]] { // CHECK-CXX-NEXT: [[ENTRY:.*:]] -// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , } poison, [[TMP0]], 0 -// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , } [[TMP1]], [[TMP2]], 1 -// CHECK-CXX-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to -// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , } [[TMP3]], [[TMP4]], 2 -// CHECK-CXX-NEXT: ret { , , } [[TMP5]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = insertvalue { , , } poison, [[OP_COERCE0]], 0 +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = insertvalue { , , } [[TMP1]], [[OP_COERCE2]], 2 +// CHECK-CXX-NEXT: [[TMP3:%.*]] = extractvalue { , , } [[TMP2]], 0 +// CHECK-CXX-NEXT: [[TMP4:%.*]] = bitcast [[TMP3]] to +// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , } poison, [[TMP4]], 0 +// CHECK-CXX-NEXT: [[TMP6:%.*]] = extractvalue { , , } [[TMP2]], 1 +// CHECK-CXX-NEXT: [[TMP7:%.*]] = bitcast [[TMP6]] to +// CHECK-CXX-NEXT: [[TMP8:%.*]] = insertvalue { , , } [[TMP5]], [[TMP7]], 1 +// CHECK-CXX-NEXT: [[TMP9:%.*]] = extractvalue { , , } [[TMP2]], 2 +// CHECK-CXX-NEXT: [[TMP10:%.*]] = bitcast [[TMP9]] to +// CHECK-CXX-NEXT: [[TMP11:%.*]] = insertvalue { , , } [[TMP8]], [[TMP10]], 2 +// CHECK-CXX-NEXT: ret { , , } [[TMP11]] // svmfloat8x3_t test_svreinterpret_mf8_f32_x3(svfloat32x3_t op) STREAMING { return SVE_ACLE_FUNC(svreinterpret_mf8, _f32_x3)(op); @@ -1285,24 +1655,36 @@ svmfloat8x3_t test_svreinterpret_mf8_f32_x3(svfloat32x3_t op) STREAMING { // CHECK-LABEL: define dso_local { , , } @test_svreinterpret_mf8_f64_x3( // CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]]) #[[ATTR0]] { // CHECK-NEXT: [[ENTRY:.*:]] -// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , } poison, [[TMP0]], 0 -// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , } [[TMP1]], [[TMP2]], 1 -// CHECK-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to -// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , } [[TMP3]], [[TMP4]], 2 -// CHECK-NEXT: ret { , , } [[TMP5]] +// CHECK-NEXT: [[TMP0:%.*]] = insertvalue { , , } poison, [[OP_COERCE0]], 0 +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-NEXT: [[TMP2:%.*]] = insertvalue { , , } [[TMP1]], [[OP_COERCE2]], 2 +// CHECK-NEXT: [[TMP3:%.*]] = extractvalue { , , } [[TMP2]], 0 +// CHECK-NEXT: [[TMP4:%.*]] = bitcast [[TMP3]] to +// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , } poison, [[TMP4]], 0 +// CHECK-NEXT: [[TMP6:%.*]] = extractvalue { , , } [[TMP2]], 1 +// CHECK-NEXT: [[TMP7:%.*]] = bitcast [[TMP6]] to +// CHECK-NEXT: [[TMP8:%.*]] = insertvalue { , , } [[TMP5]], [[TMP7]], 1 +// CHECK-NEXT: [[TMP9:%.*]] = extractvalue { , , } [[TMP2]], 2 +// CHECK-NEXT: [[TMP10:%.*]] = bitcast [[TMP9]] to +// CHECK-NEXT: [[TMP11:%.*]] = insertvalue { , , } [[TMP8]], [[TMP10]], 2 +// CHECK-NEXT: ret { , , } [[TMP11]] // // CHECK-CXX-LABEL: define dso_local { , , } @_Z29test_svreinterpret_mf8_f64_x313svfloat64x3_t( // CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]]) #[[ATTR0]] { // CHECK-CXX-NEXT: [[ENTRY:.*:]] -// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , } poison, [[TMP0]], 0 -// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , } [[TMP1]], [[TMP2]], 1 -// CHECK-CXX-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to -// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , } [[TMP3]], [[TMP4]], 2 -// CHECK-CXX-NEXT: ret { , , } [[TMP5]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = insertvalue { , , } poison, [[OP_COERCE0]], 0 +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = insertvalue { , , } [[TMP1]], [[OP_COERCE2]], 2 +// CHECK-CXX-NEXT: [[TMP3:%.*]] = extractvalue { , , } [[TMP2]], 0 +// CHECK-CXX-NEXT: [[TMP4:%.*]] = bitcast [[TMP3]] to +// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , } poison, [[TMP4]], 0 +// CHECK-CXX-NEXT: [[TMP6:%.*]] = extractvalue { , , } [[TMP2]], 1 +// CHECK-CXX-NEXT: [[TMP7:%.*]] = bitcast [[TMP6]] to +// CHECK-CXX-NEXT: [[TMP8:%.*]] = insertvalue { , , } [[TMP5]], [[TMP7]], 1 +// CHECK-CXX-NEXT: [[TMP9:%.*]] = extractvalue { , , } [[TMP2]], 2 +// CHECK-CXX-NEXT: [[TMP10:%.*]] = bitcast [[TMP9]] to +// CHECK-CXX-NEXT: [[TMP11:%.*]] = insertvalue { , , } [[TMP8]], [[TMP10]], 2 +// CHECK-CXX-NEXT: ret { , , } [[TMP11]] // svmfloat8x3_t test_svreinterpret_mf8_f64_x3(svfloat64x3_t op) STREAMING { return SVE_ACLE_FUNC(svreinterpret_mf8, _f64_x3)(op); @@ -1311,24 +1693,36 @@ svmfloat8x3_t test_svreinterpret_mf8_f64_x3(svfloat64x3_t op) STREAMING { // CHECK-LABEL: define dso_local { , , } @test_svreinterpret_s16_mf8_x3( // CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]]) #[[ATTR0]] { // CHECK-NEXT: [[ENTRY:.*:]] -// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , } poison, [[TMP0]], 0 -// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , } [[TMP1]], [[TMP2]], 1 -// CHECK-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to -// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , } [[TMP3]], [[TMP4]], 2 -// CHECK-NEXT: ret { , , } [[TMP5]] +// CHECK-NEXT: [[TMP0:%.*]] = insertvalue { , , } poison, [[OP_COERCE0]], 0 +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-NEXT: [[TMP2:%.*]] = insertvalue { , , } [[TMP1]], [[OP_COERCE2]], 2 +// CHECK-NEXT: [[TMP3:%.*]] = extractvalue { , , } [[TMP2]], 0 +// CHECK-NEXT: [[TMP4:%.*]] = bitcast [[TMP3]] to +// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , } poison, [[TMP4]], 0 +// CHECK-NEXT: [[TMP6:%.*]] = extractvalue { , , } [[TMP2]], 1 +// CHECK-NEXT: [[TMP7:%.*]] = bitcast [[TMP6]] to +// CHECK-NEXT: [[TMP8:%.*]] = insertvalue { , , } [[TMP5]], [[TMP7]], 1 +// CHECK-NEXT: [[TMP9:%.*]] = extractvalue { , , } [[TMP2]], 2 +// CHECK-NEXT: [[TMP10:%.*]] = bitcast [[TMP9]] to +// CHECK-NEXT: [[TMP11:%.*]] = insertvalue { , , } [[TMP8]], [[TMP10]], 2 +// CHECK-NEXT: ret { , , } [[TMP11]] // // CHECK-CXX-LABEL: define dso_local { , , } @_Z29test_svreinterpret_s16_mf8_x313svmfloat8x3_t( // CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]]) #[[ATTR0]] { // CHECK-CXX-NEXT: [[ENTRY:.*:]] -// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , } poison, [[TMP0]], 0 -// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , } [[TMP1]], [[TMP2]], 1 -// CHECK-CXX-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to -// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , } [[TMP3]], [[TMP4]], 2 -// CHECK-CXX-NEXT: ret { , , } [[TMP5]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = insertvalue { , , } poison, [[OP_COERCE0]], 0 +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = insertvalue { , , } [[TMP1]], [[OP_COERCE2]], 2 +// CHECK-CXX-NEXT: [[TMP3:%.*]] = extractvalue { , , } [[TMP2]], 0 +// CHECK-CXX-NEXT: [[TMP4:%.*]] = bitcast [[TMP3]] to +// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , } poison, [[TMP4]], 0 +// CHECK-CXX-NEXT: [[TMP6:%.*]] = extractvalue { , , } [[TMP2]], 1 +// CHECK-CXX-NEXT: [[TMP7:%.*]] = bitcast [[TMP6]] to +// CHECK-CXX-NEXT: [[TMP8:%.*]] = insertvalue { , , } [[TMP5]], [[TMP7]], 1 +// CHECK-CXX-NEXT: [[TMP9:%.*]] = extractvalue { , , } [[TMP2]], 2 +// CHECK-CXX-NEXT: [[TMP10:%.*]] = bitcast [[TMP9]] to +// CHECK-CXX-NEXT: [[TMP11:%.*]] = insertvalue { , , } [[TMP8]], [[TMP10]], 2 +// CHECK-CXX-NEXT: ret { , , } [[TMP11]] // svint16x3_t test_svreinterpret_s16_mf8_x3(svmfloat8x3_t op) STREAMING { return SVE_ACLE_FUNC(svreinterpret_s16, _mf8_x3)(op); @@ -1337,24 +1731,36 @@ svint16x3_t test_svreinterpret_s16_mf8_x3(svmfloat8x3_t op) STREAMING { // CHECK-LABEL: define dso_local { , , } @test_svreinterpret_u16_mf8_x3( // CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]]) #[[ATTR0]] { // CHECK-NEXT: [[ENTRY:.*:]] -// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , } poison, [[TMP0]], 0 -// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , } [[TMP1]], [[TMP2]], 1 -// CHECK-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to -// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , } [[TMP3]], [[TMP4]], 2 -// CHECK-NEXT: ret { , , } [[TMP5]] +// CHECK-NEXT: [[TMP0:%.*]] = insertvalue { , , } poison, [[OP_COERCE0]], 0 +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-NEXT: [[TMP2:%.*]] = insertvalue { , , } [[TMP1]], [[OP_COERCE2]], 2 +// CHECK-NEXT: [[TMP3:%.*]] = extractvalue { , , } [[TMP2]], 0 +// CHECK-NEXT: [[TMP4:%.*]] = bitcast [[TMP3]] to +// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , } poison, [[TMP4]], 0 +// CHECK-NEXT: [[TMP6:%.*]] = extractvalue { , , } [[TMP2]], 1 +// CHECK-NEXT: [[TMP7:%.*]] = bitcast [[TMP6]] to +// CHECK-NEXT: [[TMP8:%.*]] = insertvalue { , , } [[TMP5]], [[TMP7]], 1 +// CHECK-NEXT: [[TMP9:%.*]] = extractvalue { , , } [[TMP2]], 2 +// CHECK-NEXT: [[TMP10:%.*]] = bitcast [[TMP9]] to +// CHECK-NEXT: [[TMP11:%.*]] = insertvalue { , , } [[TMP8]], [[TMP10]], 2 +// CHECK-NEXT: ret { , , } [[TMP11]] // // CHECK-CXX-LABEL: define dso_local { , , } @_Z29test_svreinterpret_u16_mf8_x313svmfloat8x3_t( // CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]]) #[[ATTR0]] { // CHECK-CXX-NEXT: [[ENTRY:.*:]] -// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , } poison, [[TMP0]], 0 -// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , } [[TMP1]], [[TMP2]], 1 -// CHECK-CXX-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to -// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , } [[TMP3]], [[TMP4]], 2 -// CHECK-CXX-NEXT: ret { , , } [[TMP5]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = insertvalue { , , } poison, [[OP_COERCE0]], 0 +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = insertvalue { , , } [[TMP1]], [[OP_COERCE2]], 2 +// CHECK-CXX-NEXT: [[TMP3:%.*]] = extractvalue { , , } [[TMP2]], 0 +// CHECK-CXX-NEXT: [[TMP4:%.*]] = bitcast [[TMP3]] to +// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , } poison, [[TMP4]], 0 +// CHECK-CXX-NEXT: [[TMP6:%.*]] = extractvalue { , , } [[TMP2]], 1 +// CHECK-CXX-NEXT: [[TMP7:%.*]] = bitcast [[TMP6]] to +// CHECK-CXX-NEXT: [[TMP8:%.*]] = insertvalue { , , } [[TMP5]], [[TMP7]], 1 +// CHECK-CXX-NEXT: [[TMP9:%.*]] = extractvalue { , , } [[TMP2]], 2 +// CHECK-CXX-NEXT: [[TMP10:%.*]] = bitcast [[TMP9]] to +// CHECK-CXX-NEXT: [[TMP11:%.*]] = insertvalue { , , } [[TMP8]], [[TMP10]], 2 +// CHECK-CXX-NEXT: ret { , , } [[TMP11]] // svuint16x3_t test_svreinterpret_u16_mf8_x3(svmfloat8x3_t op) STREAMING { return SVE_ACLE_FUNC(svreinterpret_u16, _mf8_x3)(op); @@ -1363,24 +1769,36 @@ svuint16x3_t test_svreinterpret_u16_mf8_x3(svmfloat8x3_t op) STREAMING { // CHECK-LABEL: define dso_local { , , } @test_svreinterpret_s32_mf8_x3( // CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]]) #[[ATTR0]] { // CHECK-NEXT: [[ENTRY:.*:]] -// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , } poison, [[TMP0]], 0 -// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , } [[TMP1]], [[TMP2]], 1 -// CHECK-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to -// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , } [[TMP3]], [[TMP4]], 2 -// CHECK-NEXT: ret { , , } [[TMP5]] +// CHECK-NEXT: [[TMP0:%.*]] = insertvalue { , , } poison, [[OP_COERCE0]], 0 +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-NEXT: [[TMP2:%.*]] = insertvalue { , , } [[TMP1]], [[OP_COERCE2]], 2 +// CHECK-NEXT: [[TMP3:%.*]] = extractvalue { , , } [[TMP2]], 0 +// CHECK-NEXT: [[TMP4:%.*]] = bitcast [[TMP3]] to +// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , } poison, [[TMP4]], 0 +// CHECK-NEXT: [[TMP6:%.*]] = extractvalue { , , } [[TMP2]], 1 +// CHECK-NEXT: [[TMP7:%.*]] = bitcast [[TMP6]] to +// CHECK-NEXT: [[TMP8:%.*]] = insertvalue { , , } [[TMP5]], [[TMP7]], 1 +// CHECK-NEXT: [[TMP9:%.*]] = extractvalue { , , } [[TMP2]], 2 +// CHECK-NEXT: [[TMP10:%.*]] = bitcast [[TMP9]] to +// CHECK-NEXT: [[TMP11:%.*]] = insertvalue { , , } [[TMP8]], [[TMP10]], 2 +// CHECK-NEXT: ret { , , } [[TMP11]] // // CHECK-CXX-LABEL: define dso_local { , , } @_Z29test_svreinterpret_s32_mf8_x313svmfloat8x3_t( // CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]]) #[[ATTR0]] { // CHECK-CXX-NEXT: [[ENTRY:.*:]] -// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , } poison, [[TMP0]], 0 -// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , } [[TMP1]], [[TMP2]], 1 -// CHECK-CXX-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to -// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , } [[TMP3]], [[TMP4]], 2 -// CHECK-CXX-NEXT: ret { , , } [[TMP5]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = insertvalue { , , } poison, [[OP_COERCE0]], 0 +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = insertvalue { , , } [[TMP1]], [[OP_COERCE2]], 2 +// CHECK-CXX-NEXT: [[TMP3:%.*]] = extractvalue { , , } [[TMP2]], 0 +// CHECK-CXX-NEXT: [[TMP4:%.*]] = bitcast [[TMP3]] to +// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , } poison, [[TMP4]], 0 +// CHECK-CXX-NEXT: [[TMP6:%.*]] = extractvalue { , , } [[TMP2]], 1 +// CHECK-CXX-NEXT: [[TMP7:%.*]] = bitcast [[TMP6]] to +// CHECK-CXX-NEXT: [[TMP8:%.*]] = insertvalue { , , } [[TMP5]], [[TMP7]], 1 +// CHECK-CXX-NEXT: [[TMP9:%.*]] = extractvalue { , , } [[TMP2]], 2 +// CHECK-CXX-NEXT: [[TMP10:%.*]] = bitcast [[TMP9]] to +// CHECK-CXX-NEXT: [[TMP11:%.*]] = insertvalue { , , } [[TMP8]], [[TMP10]], 2 +// CHECK-CXX-NEXT: ret { , , } [[TMP11]] // svint32x3_t test_svreinterpret_s32_mf8_x3(svmfloat8x3_t op) STREAMING { return SVE_ACLE_FUNC(svreinterpret_s32, _mf8_x3)(op); @@ -1389,24 +1807,36 @@ svint32x3_t test_svreinterpret_s32_mf8_x3(svmfloat8x3_t op) STREAMING { // CHECK-LABEL: define dso_local { , , } @test_svreinterpret_u32_mf8_x3( // CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]]) #[[ATTR0]] { // CHECK-NEXT: [[ENTRY:.*:]] -// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , } poison, [[TMP0]], 0 -// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , } [[TMP1]], [[TMP2]], 1 -// CHECK-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to -// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , } [[TMP3]], [[TMP4]], 2 -// CHECK-NEXT: ret { , , } [[TMP5]] +// CHECK-NEXT: [[TMP0:%.*]] = insertvalue { , , } poison, [[OP_COERCE0]], 0 +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-NEXT: [[TMP2:%.*]] = insertvalue { , , } [[TMP1]], [[OP_COERCE2]], 2 +// CHECK-NEXT: [[TMP3:%.*]] = extractvalue { , , } [[TMP2]], 0 +// CHECK-NEXT: [[TMP4:%.*]] = bitcast [[TMP3]] to +// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , } poison, [[TMP4]], 0 +// CHECK-NEXT: [[TMP6:%.*]] = extractvalue { , , } [[TMP2]], 1 +// CHECK-NEXT: [[TMP7:%.*]] = bitcast [[TMP6]] to +// CHECK-NEXT: [[TMP8:%.*]] = insertvalue { , , } [[TMP5]], [[TMP7]], 1 +// CHECK-NEXT: [[TMP9:%.*]] = extractvalue { , , } [[TMP2]], 2 +// CHECK-NEXT: [[TMP10:%.*]] = bitcast [[TMP9]] to +// CHECK-NEXT: [[TMP11:%.*]] = insertvalue { , , } [[TMP8]], [[TMP10]], 2 +// CHECK-NEXT: ret { , , } [[TMP11]] // // CHECK-CXX-LABEL: define dso_local { , , } @_Z29test_svreinterpret_u32_mf8_x313svmfloat8x3_t( // CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]]) #[[ATTR0]] { // CHECK-CXX-NEXT: [[ENTRY:.*:]] -// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , } poison, [[TMP0]], 0 -// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , } [[TMP1]], [[TMP2]], 1 -// CHECK-CXX-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to -// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , } [[TMP3]], [[TMP4]], 2 -// CHECK-CXX-NEXT: ret { , , } [[TMP5]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = insertvalue { , , } poison, [[OP_COERCE0]], 0 +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = insertvalue { , , } [[TMP1]], [[OP_COERCE2]], 2 +// CHECK-CXX-NEXT: [[TMP3:%.*]] = extractvalue { , , } [[TMP2]], 0 +// CHECK-CXX-NEXT: [[TMP4:%.*]] = bitcast [[TMP3]] to +// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , } poison, [[TMP4]], 0 +// CHECK-CXX-NEXT: [[TMP6:%.*]] = extractvalue { , , } [[TMP2]], 1 +// CHECK-CXX-NEXT: [[TMP7:%.*]] = bitcast [[TMP6]] to +// CHECK-CXX-NEXT: [[TMP8:%.*]] = insertvalue { , , } [[TMP5]], [[TMP7]], 1 +// CHECK-CXX-NEXT: [[TMP9:%.*]] = extractvalue { , , } [[TMP2]], 2 +// CHECK-CXX-NEXT: [[TMP10:%.*]] = bitcast [[TMP9]] to +// CHECK-CXX-NEXT: [[TMP11:%.*]] = insertvalue { , , } [[TMP8]], [[TMP10]], 2 +// CHECK-CXX-NEXT: ret { , , } [[TMP11]] // svuint32x3_t test_svreinterpret_u32_mf8_x3(svmfloat8x3_t op) STREAMING { return SVE_ACLE_FUNC(svreinterpret_u32, _mf8_x3)(op); @@ -1415,24 +1845,36 @@ svuint32x3_t test_svreinterpret_u32_mf8_x3(svmfloat8x3_t op) STREAMING { // CHECK-LABEL: define dso_local { , , } @test_svreinterpret_s64_mf8_x3( // CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]]) #[[ATTR0]] { // CHECK-NEXT: [[ENTRY:.*:]] -// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , } poison, [[TMP0]], 0 -// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , } [[TMP1]], [[TMP2]], 1 -// CHECK-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to -// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , } [[TMP3]], [[TMP4]], 2 -// CHECK-NEXT: ret { , , } [[TMP5]] +// CHECK-NEXT: [[TMP0:%.*]] = insertvalue { , , } poison, [[OP_COERCE0]], 0 +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-NEXT: [[TMP2:%.*]] = insertvalue { , , } [[TMP1]], [[OP_COERCE2]], 2 +// CHECK-NEXT: [[TMP3:%.*]] = extractvalue { , , } [[TMP2]], 0 +// CHECK-NEXT: [[TMP4:%.*]] = bitcast [[TMP3]] to +// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , } poison, [[TMP4]], 0 +// CHECK-NEXT: [[TMP6:%.*]] = extractvalue { , , } [[TMP2]], 1 +// CHECK-NEXT: [[TMP7:%.*]] = bitcast [[TMP6]] to +// CHECK-NEXT: [[TMP8:%.*]] = insertvalue { , , } [[TMP5]], [[TMP7]], 1 +// CHECK-NEXT: [[TMP9:%.*]] = extractvalue { , , } [[TMP2]], 2 +// CHECK-NEXT: [[TMP10:%.*]] = bitcast [[TMP9]] to +// CHECK-NEXT: [[TMP11:%.*]] = insertvalue { , , } [[TMP8]], [[TMP10]], 2 +// CHECK-NEXT: ret { , , } [[TMP11]] // // CHECK-CXX-LABEL: define dso_local { , , } @_Z29test_svreinterpret_s64_mf8_x313svmfloat8x3_t( // CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]]) #[[ATTR0]] { // CHECK-CXX-NEXT: [[ENTRY:.*:]] -// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , } poison, [[TMP0]], 0 -// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , } [[TMP1]], [[TMP2]], 1 -// CHECK-CXX-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to -// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , } [[TMP3]], [[TMP4]], 2 -// CHECK-CXX-NEXT: ret { , , } [[TMP5]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = insertvalue { , , } poison, [[OP_COERCE0]], 0 +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = insertvalue { , , } [[TMP1]], [[OP_COERCE2]], 2 +// CHECK-CXX-NEXT: [[TMP3:%.*]] = extractvalue { , , } [[TMP2]], 0 +// CHECK-CXX-NEXT: [[TMP4:%.*]] = bitcast [[TMP3]] to +// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , } poison, [[TMP4]], 0 +// CHECK-CXX-NEXT: [[TMP6:%.*]] = extractvalue { , , } [[TMP2]], 1 +// CHECK-CXX-NEXT: [[TMP7:%.*]] = bitcast [[TMP6]] to +// CHECK-CXX-NEXT: [[TMP8:%.*]] = insertvalue { , , } [[TMP5]], [[TMP7]], 1 +// CHECK-CXX-NEXT: [[TMP9:%.*]] = extractvalue { , , } [[TMP2]], 2 +// CHECK-CXX-NEXT: [[TMP10:%.*]] = bitcast [[TMP9]] to +// CHECK-CXX-NEXT: [[TMP11:%.*]] = insertvalue { , , } [[TMP8]], [[TMP10]], 2 +// CHECK-CXX-NEXT: ret { , , } [[TMP11]] // svint64x3_t test_svreinterpret_s64_mf8_x3(svmfloat8x3_t op) STREAMING { return SVE_ACLE_FUNC(svreinterpret_s64, _mf8_x3)(op); @@ -1441,24 +1883,36 @@ svint64x3_t test_svreinterpret_s64_mf8_x3(svmfloat8x3_t op) STREAMING { // CHECK-LABEL: define dso_local { , , } @test_svreinterpret_u64_mf8_x3( // CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]]) #[[ATTR0]] { // CHECK-NEXT: [[ENTRY:.*:]] -// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , } poison, [[TMP0]], 0 -// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , } [[TMP1]], [[TMP2]], 1 -// CHECK-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to -// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , } [[TMP3]], [[TMP4]], 2 -// CHECK-NEXT: ret { , , } [[TMP5]] +// CHECK-NEXT: [[TMP0:%.*]] = insertvalue { , , } poison, [[OP_COERCE0]], 0 +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-NEXT: [[TMP2:%.*]] = insertvalue { , , } [[TMP1]], [[OP_COERCE2]], 2 +// CHECK-NEXT: [[TMP3:%.*]] = extractvalue { , , } [[TMP2]], 0 +// CHECK-NEXT: [[TMP4:%.*]] = bitcast [[TMP3]] to +// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , } poison, [[TMP4]], 0 +// CHECK-NEXT: [[TMP6:%.*]] = extractvalue { , , } [[TMP2]], 1 +// CHECK-NEXT: [[TMP7:%.*]] = bitcast [[TMP6]] to +// CHECK-NEXT: [[TMP8:%.*]] = insertvalue { , , } [[TMP5]], [[TMP7]], 1 +// CHECK-NEXT: [[TMP9:%.*]] = extractvalue { , , } [[TMP2]], 2 +// CHECK-NEXT: [[TMP10:%.*]] = bitcast [[TMP9]] to +// CHECK-NEXT: [[TMP11:%.*]] = insertvalue { , , } [[TMP8]], [[TMP10]], 2 +// CHECK-NEXT: ret { , , } [[TMP11]] // // CHECK-CXX-LABEL: define dso_local { , , } @_Z29test_svreinterpret_u64_mf8_x313svmfloat8x3_t( // CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]]) #[[ATTR0]] { // CHECK-CXX-NEXT: [[ENTRY:.*:]] -// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , } poison, [[TMP0]], 0 -// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , } [[TMP1]], [[TMP2]], 1 -// CHECK-CXX-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to -// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , } [[TMP3]], [[TMP4]], 2 -// CHECK-CXX-NEXT: ret { , , } [[TMP5]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = insertvalue { , , } poison, [[OP_COERCE0]], 0 +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = insertvalue { , , } [[TMP1]], [[OP_COERCE2]], 2 +// CHECK-CXX-NEXT: [[TMP3:%.*]] = extractvalue { , , } [[TMP2]], 0 +// CHECK-CXX-NEXT: [[TMP4:%.*]] = bitcast [[TMP3]] to +// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , } poison, [[TMP4]], 0 +// CHECK-CXX-NEXT: [[TMP6:%.*]] = extractvalue { , , } [[TMP2]], 1 +// CHECK-CXX-NEXT: [[TMP7:%.*]] = bitcast [[TMP6]] to +// CHECK-CXX-NEXT: [[TMP8:%.*]] = insertvalue { , , } [[TMP5]], [[TMP7]], 1 +// CHECK-CXX-NEXT: [[TMP9:%.*]] = extractvalue { , , } [[TMP2]], 2 +// CHECK-CXX-NEXT: [[TMP10:%.*]] = bitcast [[TMP9]] to +// CHECK-CXX-NEXT: [[TMP11:%.*]] = insertvalue { , , } [[TMP8]], [[TMP10]], 2 +// CHECK-CXX-NEXT: ret { , , } [[TMP11]] // svuint64x3_t test_svreinterpret_u64_mf8_x3(svmfloat8x3_t op) STREAMING { return SVE_ACLE_FUNC(svreinterpret_u64, _mf8_x3)(op); @@ -1467,24 +1921,36 @@ svuint64x3_t test_svreinterpret_u64_mf8_x3(svmfloat8x3_t op) STREAMING { // CHECK-LABEL: define dso_local { , , } @test_svreinterpret_f16_mf8_x3( // CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]]) #[[ATTR0]] { // CHECK-NEXT: [[ENTRY:.*:]] -// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , } poison, [[TMP0]], 0 -// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , } [[TMP1]], [[TMP2]], 1 -// CHECK-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to -// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , } [[TMP3]], [[TMP4]], 2 -// CHECK-NEXT: ret { , , } [[TMP5]] +// CHECK-NEXT: [[TMP0:%.*]] = insertvalue { , , } poison, [[OP_COERCE0]], 0 +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-NEXT: [[TMP2:%.*]] = insertvalue { , , } [[TMP1]], [[OP_COERCE2]], 2 +// CHECK-NEXT: [[TMP3:%.*]] = extractvalue { , , } [[TMP2]], 0 +// CHECK-NEXT: [[TMP4:%.*]] = bitcast [[TMP3]] to +// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , } poison, [[TMP4]], 0 +// CHECK-NEXT: [[TMP6:%.*]] = extractvalue { , , } [[TMP2]], 1 +// CHECK-NEXT: [[TMP7:%.*]] = bitcast [[TMP6]] to +// CHECK-NEXT: [[TMP8:%.*]] = insertvalue { , , } [[TMP5]], [[TMP7]], 1 +// CHECK-NEXT: [[TMP9:%.*]] = extractvalue { , , } [[TMP2]], 2 +// CHECK-NEXT: [[TMP10:%.*]] = bitcast [[TMP9]] to +// CHECK-NEXT: [[TMP11:%.*]] = insertvalue { , , } [[TMP8]], [[TMP10]], 2 +// CHECK-NEXT: ret { , , } [[TMP11]] // // CHECK-CXX-LABEL: define dso_local { , , } @_Z29test_svreinterpret_f16_mf8_x313svmfloat8x3_t( // CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]]) #[[ATTR0]] { // CHECK-CXX-NEXT: [[ENTRY:.*:]] -// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , } poison, [[TMP0]], 0 -// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , } [[TMP1]], [[TMP2]], 1 -// CHECK-CXX-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to -// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , } [[TMP3]], [[TMP4]], 2 -// CHECK-CXX-NEXT: ret { , , } [[TMP5]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = insertvalue { , , } poison, [[OP_COERCE0]], 0 +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = insertvalue { , , } [[TMP1]], [[OP_COERCE2]], 2 +// CHECK-CXX-NEXT: [[TMP3:%.*]] = extractvalue { , , } [[TMP2]], 0 +// CHECK-CXX-NEXT: [[TMP4:%.*]] = bitcast [[TMP3]] to +// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , } poison, [[TMP4]], 0 +// CHECK-CXX-NEXT: [[TMP6:%.*]] = extractvalue { , , } [[TMP2]], 1 +// CHECK-CXX-NEXT: [[TMP7:%.*]] = bitcast [[TMP6]] to +// CHECK-CXX-NEXT: [[TMP8:%.*]] = insertvalue { , , } [[TMP5]], [[TMP7]], 1 +// CHECK-CXX-NEXT: [[TMP9:%.*]] = extractvalue { , , } [[TMP2]], 2 +// CHECK-CXX-NEXT: [[TMP10:%.*]] = bitcast [[TMP9]] to +// CHECK-CXX-NEXT: [[TMP11:%.*]] = insertvalue { , , } [[TMP8]], [[TMP10]], 2 +// CHECK-CXX-NEXT: ret { , , } [[TMP11]] // svfloat16x3_t test_svreinterpret_f16_mf8_x3(svmfloat8x3_t op) STREAMING { return SVE_ACLE_FUNC(svreinterpret_f16, _mf8_x3)(op); @@ -1493,24 +1959,36 @@ svfloat16x3_t test_svreinterpret_f16_mf8_x3(svmfloat8x3_t op) STREAMING { // CHECK-LABEL: define dso_local { , , } @test_svreinterpret_bf16_mf8_x3( // CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]]) #[[ATTR0]] { // CHECK-NEXT: [[ENTRY:.*:]] -// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , } poison, [[TMP0]], 0 -// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , } [[TMP1]], [[TMP2]], 1 -// CHECK-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to -// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , } [[TMP3]], [[TMP4]], 2 -// CHECK-NEXT: ret { , , } [[TMP5]] +// CHECK-NEXT: [[TMP0:%.*]] = insertvalue { , , } poison, [[OP_COERCE0]], 0 +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-NEXT: [[TMP2:%.*]] = insertvalue { , , } [[TMP1]], [[OP_COERCE2]], 2 +// CHECK-NEXT: [[TMP3:%.*]] = extractvalue { , , } [[TMP2]], 0 +// CHECK-NEXT: [[TMP4:%.*]] = bitcast [[TMP3]] to +// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , } poison, [[TMP4]], 0 +// CHECK-NEXT: [[TMP6:%.*]] = extractvalue { , , } [[TMP2]], 1 +// CHECK-NEXT: [[TMP7:%.*]] = bitcast [[TMP6]] to +// CHECK-NEXT: [[TMP8:%.*]] = insertvalue { , , } [[TMP5]], [[TMP7]], 1 +// CHECK-NEXT: [[TMP9:%.*]] = extractvalue { , , } [[TMP2]], 2 +// CHECK-NEXT: [[TMP10:%.*]] = bitcast [[TMP9]] to +// CHECK-NEXT: [[TMP11:%.*]] = insertvalue { , , } [[TMP8]], [[TMP10]], 2 +// CHECK-NEXT: ret { , , } [[TMP11]] // // CHECK-CXX-LABEL: define dso_local { , , } @_Z30test_svreinterpret_bf16_mf8_x313svmfloat8x3_t( // CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]]) #[[ATTR0]] { // CHECK-CXX-NEXT: [[ENTRY:.*:]] -// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , } poison, [[TMP0]], 0 -// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , } [[TMP1]], [[TMP2]], 1 -// CHECK-CXX-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to -// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , } [[TMP3]], [[TMP4]], 2 -// CHECK-CXX-NEXT: ret { , , } [[TMP5]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = insertvalue { , , } poison, [[OP_COERCE0]], 0 +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = insertvalue { , , } [[TMP1]], [[OP_COERCE2]], 2 +// CHECK-CXX-NEXT: [[TMP3:%.*]] = extractvalue { , , } [[TMP2]], 0 +// CHECK-CXX-NEXT: [[TMP4:%.*]] = bitcast [[TMP3]] to +// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , } poison, [[TMP4]], 0 +// CHECK-CXX-NEXT: [[TMP6:%.*]] = extractvalue { , , } [[TMP2]], 1 +// CHECK-CXX-NEXT: [[TMP7:%.*]] = bitcast [[TMP6]] to +// CHECK-CXX-NEXT: [[TMP8:%.*]] = insertvalue { , , } [[TMP5]], [[TMP7]], 1 +// CHECK-CXX-NEXT: [[TMP9:%.*]] = extractvalue { , , } [[TMP2]], 2 +// CHECK-CXX-NEXT: [[TMP10:%.*]] = bitcast [[TMP9]] to +// CHECK-CXX-NEXT: [[TMP11:%.*]] = insertvalue { , , } [[TMP8]], [[TMP10]], 2 +// CHECK-CXX-NEXT: ret { , , } [[TMP11]] // svbfloat16x3_t test_svreinterpret_bf16_mf8_x3(svmfloat8x3_t op) STREAMING { return SVE_ACLE_FUNC(svreinterpret_bf16, _mf8_x3)(op); @@ -1519,24 +1997,36 @@ svbfloat16x3_t test_svreinterpret_bf16_mf8_x3(svmfloat8x3_t op) STREAMING { // CHECK-LABEL: define dso_local { , , } @test_svreinterpret_f32_mf8_x3( // CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]]) #[[ATTR0]] { // CHECK-NEXT: [[ENTRY:.*:]] -// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , } poison, [[TMP0]], 0 -// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , } [[TMP1]], [[TMP2]], 1 -// CHECK-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to -// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , } [[TMP3]], [[TMP4]], 2 -// CHECK-NEXT: ret { , , } [[TMP5]] +// CHECK-NEXT: [[TMP0:%.*]] = insertvalue { , , } poison, [[OP_COERCE0]], 0 +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-NEXT: [[TMP2:%.*]] = insertvalue { , , } [[TMP1]], [[OP_COERCE2]], 2 +// CHECK-NEXT: [[TMP3:%.*]] = extractvalue { , , } [[TMP2]], 0 +// CHECK-NEXT: [[TMP4:%.*]] = bitcast [[TMP3]] to +// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , } poison, [[TMP4]], 0 +// CHECK-NEXT: [[TMP6:%.*]] = extractvalue { , , } [[TMP2]], 1 +// CHECK-NEXT: [[TMP7:%.*]] = bitcast [[TMP6]] to +// CHECK-NEXT: [[TMP8:%.*]] = insertvalue { , , } [[TMP5]], [[TMP7]], 1 +// CHECK-NEXT: [[TMP9:%.*]] = extractvalue { , , } [[TMP2]], 2 +// CHECK-NEXT: [[TMP10:%.*]] = bitcast [[TMP9]] to +// CHECK-NEXT: [[TMP11:%.*]] = insertvalue { , , } [[TMP8]], [[TMP10]], 2 +// CHECK-NEXT: ret { , , } [[TMP11]] // // CHECK-CXX-LABEL: define dso_local { , , } @_Z29test_svreinterpret_f32_mf8_x313svmfloat8x3_t( // CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]]) #[[ATTR0]] { // CHECK-CXX-NEXT: [[ENTRY:.*:]] -// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , } poison, [[TMP0]], 0 -// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , } [[TMP1]], [[TMP2]], 1 -// CHECK-CXX-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to -// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , } [[TMP3]], [[TMP4]], 2 -// CHECK-CXX-NEXT: ret { , , } [[TMP5]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = insertvalue { , , } poison, [[OP_COERCE0]], 0 +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = insertvalue { , , } [[TMP1]], [[OP_COERCE2]], 2 +// CHECK-CXX-NEXT: [[TMP3:%.*]] = extractvalue { , , } [[TMP2]], 0 +// CHECK-CXX-NEXT: [[TMP4:%.*]] = bitcast [[TMP3]] to +// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , } poison, [[TMP4]], 0 +// CHECK-CXX-NEXT: [[TMP6:%.*]] = extractvalue { , , } [[TMP2]], 1 +// CHECK-CXX-NEXT: [[TMP7:%.*]] = bitcast [[TMP6]] to +// CHECK-CXX-NEXT: [[TMP8:%.*]] = insertvalue { , , } [[TMP5]], [[TMP7]], 1 +// CHECK-CXX-NEXT: [[TMP9:%.*]] = extractvalue { , , } [[TMP2]], 2 +// CHECK-CXX-NEXT: [[TMP10:%.*]] = bitcast [[TMP9]] to +// CHECK-CXX-NEXT: [[TMP11:%.*]] = insertvalue { , , } [[TMP8]], [[TMP10]], 2 +// CHECK-CXX-NEXT: ret { , , } [[TMP11]] // svfloat32x3_t test_svreinterpret_f32_mf8_x3(svmfloat8x3_t op) STREAMING { return SVE_ACLE_FUNC(svreinterpret_f32, _mf8_x3)(op); @@ -1545,24 +2035,36 @@ svfloat32x3_t test_svreinterpret_f32_mf8_x3(svmfloat8x3_t op) STREAMING { // CHECK-LABEL: define dso_local { , , } @test_svreinterpret_f64_mf8_x3( // CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]]) #[[ATTR0]] { // CHECK-NEXT: [[ENTRY:.*:]] -// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , } poison, [[TMP0]], 0 -// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , } [[TMP1]], [[TMP2]], 1 -// CHECK-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to -// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , } [[TMP3]], [[TMP4]], 2 -// CHECK-NEXT: ret { , , } [[TMP5]] +// CHECK-NEXT: [[TMP0:%.*]] = insertvalue { , , } poison, [[OP_COERCE0]], 0 +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-NEXT: [[TMP2:%.*]] = insertvalue { , , } [[TMP1]], [[OP_COERCE2]], 2 +// CHECK-NEXT: [[TMP3:%.*]] = extractvalue { , , } [[TMP2]], 0 +// CHECK-NEXT: [[TMP4:%.*]] = bitcast [[TMP3]] to +// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , } poison, [[TMP4]], 0 +// CHECK-NEXT: [[TMP6:%.*]] = extractvalue { , , } [[TMP2]], 1 +// CHECK-NEXT: [[TMP7:%.*]] = bitcast [[TMP6]] to +// CHECK-NEXT: [[TMP8:%.*]] = insertvalue { , , } [[TMP5]], [[TMP7]], 1 +// CHECK-NEXT: [[TMP9:%.*]] = extractvalue { , , } [[TMP2]], 2 +// CHECK-NEXT: [[TMP10:%.*]] = bitcast [[TMP9]] to +// CHECK-NEXT: [[TMP11:%.*]] = insertvalue { , , } [[TMP8]], [[TMP10]], 2 +// CHECK-NEXT: ret { , , } [[TMP11]] // // CHECK-CXX-LABEL: define dso_local { , , } @_Z29test_svreinterpret_f64_mf8_x313svmfloat8x3_t( // CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]]) #[[ATTR0]] { // CHECK-CXX-NEXT: [[ENTRY:.*:]] -// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , } poison, [[TMP0]], 0 -// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , } [[TMP1]], [[TMP2]], 1 -// CHECK-CXX-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to -// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , } [[TMP3]], [[TMP4]], 2 -// CHECK-CXX-NEXT: ret { , , } [[TMP5]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = insertvalue { , , } poison, [[OP_COERCE0]], 0 +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = insertvalue { , , } [[TMP1]], [[OP_COERCE2]], 2 +// CHECK-CXX-NEXT: [[TMP3:%.*]] = extractvalue { , , } [[TMP2]], 0 +// CHECK-CXX-NEXT: [[TMP4:%.*]] = bitcast [[TMP3]] to +// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , } poison, [[TMP4]], 0 +// CHECK-CXX-NEXT: [[TMP6:%.*]] = extractvalue { , , } [[TMP2]], 1 +// CHECK-CXX-NEXT: [[TMP7:%.*]] = bitcast [[TMP6]] to +// CHECK-CXX-NEXT: [[TMP8:%.*]] = insertvalue { , , } [[TMP5]], [[TMP7]], 1 +// CHECK-CXX-NEXT: [[TMP9:%.*]] = extractvalue { , , } [[TMP2]], 2 +// CHECK-CXX-NEXT: [[TMP10:%.*]] = bitcast [[TMP9]] to +// CHECK-CXX-NEXT: [[TMP11:%.*]] = insertvalue { , , } [[TMP8]], [[TMP10]], 2 +// CHECK-CXX-NEXT: ret { , , } [[TMP11]] // svfloat64x3_t test_svreinterpret_f64_mf8_x3(svmfloat8x3_t op) STREAMING { return SVE_ACLE_FUNC(svreinterpret_f64, _mf8_x3)(op); @@ -1575,7 +2077,15 @@ svfloat64x3_t test_svreinterpret_f64_mf8_x3(svmfloat8x3_t op) STREAMING { // CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , , } [[TMP0]], [[OP_COERCE1]], 1 // CHECK-NEXT: [[TMP2:%.*]] = insertvalue { , , , } [[TMP1]], [[OP_COERCE2]], 2 // CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP2]], [[OP_COERCE3]], 3 -// CHECK-NEXT: ret { , , , } [[TMP3]] +// CHECK-NEXT: [[TMP4:%.*]] = extractvalue { , , , } [[TMP3]], 0 +// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , , } poison, [[TMP4]], 0 +// CHECK-NEXT: [[TMP6:%.*]] = extractvalue { , , , } [[TMP3]], 1 +// CHECK-NEXT: [[TMP7:%.*]] = insertvalue { , , , } [[TMP5]], [[TMP6]], 1 +// CHECK-NEXT: [[TMP8:%.*]] = extractvalue { , , , } [[TMP3]], 2 +// CHECK-NEXT: [[TMP9:%.*]] = insertvalue { , , , } [[TMP7]], [[TMP8]], 2 +// CHECK-NEXT: [[TMP10:%.*]] = extractvalue { , , , } [[TMP3]], 3 +// CHECK-NEXT: [[TMP11:%.*]] = insertvalue { , , , } [[TMP9]], [[TMP10]], 3 +// CHECK-NEXT: ret { , , , } [[TMP11]] // // CHECK-CXX-LABEL: define dso_local { , , , } @_Z28test_svreinterpret_s8_mf8_x413svmfloat8x4_t( // CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]], [[OP_COERCE3:%.*]]) #[[ATTR0]] { @@ -1584,7 +2094,15 @@ svfloat64x3_t test_svreinterpret_f64_mf8_x3(svmfloat8x3_t op) STREAMING { // CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , , } [[TMP0]], [[OP_COERCE1]], 1 // CHECK-CXX-NEXT: [[TMP2:%.*]] = insertvalue { , , , } [[TMP1]], [[OP_COERCE2]], 2 // CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP2]], [[OP_COERCE3]], 3 -// CHECK-CXX-NEXT: ret { , , , } [[TMP3]] +// CHECK-CXX-NEXT: [[TMP4:%.*]] = extractvalue { , , , } [[TMP3]], 0 +// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , , } poison, [[TMP4]], 0 +// CHECK-CXX-NEXT: [[TMP6:%.*]] = extractvalue { , , , } [[TMP3]], 1 +// CHECK-CXX-NEXT: [[TMP7:%.*]] = insertvalue { , , , } [[TMP5]], [[TMP6]], 1 +// CHECK-CXX-NEXT: [[TMP8:%.*]] = extractvalue { , , , } [[TMP3]], 2 +// CHECK-CXX-NEXT: [[TMP9:%.*]] = insertvalue { , , , } [[TMP7]], [[TMP8]], 2 +// CHECK-CXX-NEXT: [[TMP10:%.*]] = extractvalue { , , , } [[TMP3]], 3 +// CHECK-CXX-NEXT: [[TMP11:%.*]] = insertvalue { , , , } [[TMP9]], [[TMP10]], 3 +// CHECK-CXX-NEXT: ret { , , , } [[TMP11]] // svint8x4_t test_svreinterpret_s8_mf8_x4(svmfloat8x4_t op) STREAMING { return SVE_ACLE_FUNC(svreinterpret_s8, _mf8_x4)(op); @@ -1597,7 +2115,15 @@ svint8x4_t test_svreinterpret_s8_mf8_x4(svmfloat8x4_t op) STREAMING { // CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , , } [[TMP0]], [[OP_COERCE1]], 1 // CHECK-NEXT: [[TMP2:%.*]] = insertvalue { , , , } [[TMP1]], [[OP_COERCE2]], 2 // CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP2]], [[OP_COERCE3]], 3 -// CHECK-NEXT: ret { , , , } [[TMP3]] +// CHECK-NEXT: [[TMP4:%.*]] = extractvalue { , , , } [[TMP3]], 0 +// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , , } poison, [[TMP4]], 0 +// CHECK-NEXT: [[TMP6:%.*]] = extractvalue { , , , } [[TMP3]], 1 +// CHECK-NEXT: [[TMP7:%.*]] = insertvalue { , , , } [[TMP5]], [[TMP6]], 1 +// CHECK-NEXT: [[TMP8:%.*]] = extractvalue { , , , } [[TMP3]], 2 +// CHECK-NEXT: [[TMP9:%.*]] = insertvalue { , , , } [[TMP7]], [[TMP8]], 2 +// CHECK-NEXT: [[TMP10:%.*]] = extractvalue { , , , } [[TMP3]], 3 +// CHECK-NEXT: [[TMP11:%.*]] = insertvalue { , , , } [[TMP9]], [[TMP10]], 3 +// CHECK-NEXT: ret { , , , } [[TMP11]] // // CHECK-CXX-LABEL: define dso_local { , , , } @_Z28test_svreinterpret_u8_mf8_x413svmfloat8x4_t( // CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]], [[OP_COERCE3:%.*]]) #[[ATTR0]] { @@ -1606,7 +2132,15 @@ svint8x4_t test_svreinterpret_s8_mf8_x4(svmfloat8x4_t op) STREAMING { // CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , , } [[TMP0]], [[OP_COERCE1]], 1 // CHECK-CXX-NEXT: [[TMP2:%.*]] = insertvalue { , , , } [[TMP1]], [[OP_COERCE2]], 2 // CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP2]], [[OP_COERCE3]], 3 -// CHECK-CXX-NEXT: ret { , , , } [[TMP3]] +// CHECK-CXX-NEXT: [[TMP4:%.*]] = extractvalue { , , , } [[TMP3]], 0 +// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , , } poison, [[TMP4]], 0 +// CHECK-CXX-NEXT: [[TMP6:%.*]] = extractvalue { , , , } [[TMP3]], 1 +// CHECK-CXX-NEXT: [[TMP7:%.*]] = insertvalue { , , , } [[TMP5]], [[TMP6]], 1 +// CHECK-CXX-NEXT: [[TMP8:%.*]] = extractvalue { , , , } [[TMP3]], 2 +// CHECK-CXX-NEXT: [[TMP9:%.*]] = insertvalue { , , , } [[TMP7]], [[TMP8]], 2 +// CHECK-CXX-NEXT: [[TMP10:%.*]] = extractvalue { , , , } [[TMP3]], 3 +// CHECK-CXX-NEXT: [[TMP11:%.*]] = insertvalue { , , , } [[TMP9]], [[TMP10]], 3 +// CHECK-CXX-NEXT: ret { , , , } [[TMP11]] // svuint8x4_t test_svreinterpret_u8_mf8_x4(svmfloat8x4_t op) STREAMING { return SVE_ACLE_FUNC(svreinterpret_u8, _mf8_x4)(op); @@ -1619,7 +2153,15 @@ svuint8x4_t test_svreinterpret_u8_mf8_x4(svmfloat8x4_t op) STREAMING { // CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , , } [[TMP0]], [[OP_COERCE1]], 1 // CHECK-NEXT: [[TMP2:%.*]] = insertvalue { , , , } [[TMP1]], [[OP_COERCE2]], 2 // CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP2]], [[OP_COERCE3]], 3 -// CHECK-NEXT: ret { , , , } [[TMP3]] +// CHECK-NEXT: [[TMP4:%.*]] = extractvalue { , , , } [[TMP3]], 0 +// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , , } poison, [[TMP4]], 0 +// CHECK-NEXT: [[TMP6:%.*]] = extractvalue { , , , } [[TMP3]], 1 +// CHECK-NEXT: [[TMP7:%.*]] = insertvalue { , , , } [[TMP5]], [[TMP6]], 1 +// CHECK-NEXT: [[TMP8:%.*]] = extractvalue { , , , } [[TMP3]], 2 +// CHECK-NEXT: [[TMP9:%.*]] = insertvalue { , , , } [[TMP7]], [[TMP8]], 2 +// CHECK-NEXT: [[TMP10:%.*]] = extractvalue { , , , } [[TMP3]], 3 +// CHECK-NEXT: [[TMP11:%.*]] = insertvalue { , , , } [[TMP9]], [[TMP10]], 3 +// CHECK-NEXT: ret { , , , } [[TMP11]] // // CHECK-CXX-LABEL: define dso_local { , , , } @_Z28test_svreinterpret_mf8_s8_x410svint8x4_t( // CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]], [[OP_COERCE3:%.*]]) #[[ATTR0]] { @@ -1628,7 +2170,15 @@ svuint8x4_t test_svreinterpret_u8_mf8_x4(svmfloat8x4_t op) STREAMING { // CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , , } [[TMP0]], [[OP_COERCE1]], 1 // CHECK-CXX-NEXT: [[TMP2:%.*]] = insertvalue { , , , } [[TMP1]], [[OP_COERCE2]], 2 // CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP2]], [[OP_COERCE3]], 3 -// CHECK-CXX-NEXT: ret { , , , } [[TMP3]] +// CHECK-CXX-NEXT: [[TMP4:%.*]] = extractvalue { , , , } [[TMP3]], 0 +// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , , } poison, [[TMP4]], 0 +// CHECK-CXX-NEXT: [[TMP6:%.*]] = extractvalue { , , , } [[TMP3]], 1 +// CHECK-CXX-NEXT: [[TMP7:%.*]] = insertvalue { , , , } [[TMP5]], [[TMP6]], 1 +// CHECK-CXX-NEXT: [[TMP8:%.*]] = extractvalue { , , , } [[TMP3]], 2 +// CHECK-CXX-NEXT: [[TMP9:%.*]] = insertvalue { , , , } [[TMP7]], [[TMP8]], 2 +// CHECK-CXX-NEXT: [[TMP10:%.*]] = extractvalue { , , , } [[TMP3]], 3 +// CHECK-CXX-NEXT: [[TMP11:%.*]] = insertvalue { , , , } [[TMP9]], [[TMP10]], 3 +// CHECK-CXX-NEXT: ret { , , , } [[TMP11]] // svmfloat8x4_t test_svreinterpret_mf8_s8_x4(svint8x4_t op) STREAMING { return SVE_ACLE_FUNC(svreinterpret_mf8, _s8_x4)(op); @@ -1641,7 +2191,15 @@ svmfloat8x4_t test_svreinterpret_mf8_s8_x4(svint8x4_t op) STREAMING { // CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , , } [[TMP0]], [[OP_COERCE1]], 1 // CHECK-NEXT: [[TMP2:%.*]] = insertvalue { , , , } [[TMP1]], [[OP_COERCE2]], 2 // CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP2]], [[OP_COERCE3]], 3 -// CHECK-NEXT: ret { , , , } [[TMP3]] +// CHECK-NEXT: [[TMP4:%.*]] = extractvalue { , , , } [[TMP3]], 0 +// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , , } poison, [[TMP4]], 0 +// CHECK-NEXT: [[TMP6:%.*]] = extractvalue { , , , } [[TMP3]], 1 +// CHECK-NEXT: [[TMP7:%.*]] = insertvalue { , , , } [[TMP5]], [[TMP6]], 1 +// CHECK-NEXT: [[TMP8:%.*]] = extractvalue { , , , } [[TMP3]], 2 +// CHECK-NEXT: [[TMP9:%.*]] = insertvalue { , , , } [[TMP7]], [[TMP8]], 2 +// CHECK-NEXT: [[TMP10:%.*]] = extractvalue { , , , } [[TMP3]], 3 +// CHECK-NEXT: [[TMP11:%.*]] = insertvalue { , , , } [[TMP9]], [[TMP10]], 3 +// CHECK-NEXT: ret { , , , } [[TMP11]] // // CHECK-CXX-LABEL: define dso_local { , , , } @_Z28test_svreinterpret_mf8_u8_x411svuint8x4_t( // CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]], [[OP_COERCE3:%.*]]) #[[ATTR0]] { @@ -1650,7 +2208,15 @@ svmfloat8x4_t test_svreinterpret_mf8_s8_x4(svint8x4_t op) STREAMING { // CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , , } [[TMP0]], [[OP_COERCE1]], 1 // CHECK-CXX-NEXT: [[TMP2:%.*]] = insertvalue { , , , } [[TMP1]], [[OP_COERCE2]], 2 // CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP2]], [[OP_COERCE3]], 3 -// CHECK-CXX-NEXT: ret { , , , } [[TMP3]] +// CHECK-CXX-NEXT: [[TMP4:%.*]] = extractvalue { , , , } [[TMP3]], 0 +// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , , } poison, [[TMP4]], 0 +// CHECK-CXX-NEXT: [[TMP6:%.*]] = extractvalue { , , , } [[TMP3]], 1 +// CHECK-CXX-NEXT: [[TMP7:%.*]] = insertvalue { , , , } [[TMP5]], [[TMP6]], 1 +// CHECK-CXX-NEXT: [[TMP8:%.*]] = extractvalue { , , , } [[TMP3]], 2 +// CHECK-CXX-NEXT: [[TMP9:%.*]] = insertvalue { , , , } [[TMP7]], [[TMP8]], 2 +// CHECK-CXX-NEXT: [[TMP10:%.*]] = extractvalue { , , , } [[TMP3]], 3 +// CHECK-CXX-NEXT: [[TMP11:%.*]] = insertvalue { , , , } [[TMP9]], [[TMP10]], 3 +// CHECK-CXX-NEXT: ret { , , , } [[TMP11]] // svmfloat8x4_t test_svreinterpret_mf8_u8_x4(svuint8x4_t op) STREAMING { return SVE_ACLE_FUNC(svreinterpret_mf8, _u8_x4)(op); @@ -1663,7 +2229,15 @@ svmfloat8x4_t test_svreinterpret_mf8_u8_x4(svuint8x4_t op) STREAMING { // CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , , } [[TMP0]], [[OP_COERCE1]], 1 // CHECK-NEXT: [[TMP2:%.*]] = insertvalue { , , , } [[TMP1]], [[OP_COERCE2]], 2 // CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP2]], [[OP_COERCE3]], 3 -// CHECK-NEXT: ret { , , , } [[TMP3]] +// CHECK-NEXT: [[TMP4:%.*]] = extractvalue { , , , } [[TMP3]], 0 +// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , , } poison, [[TMP4]], 0 +// CHECK-NEXT: [[TMP6:%.*]] = extractvalue { , , , } [[TMP3]], 1 +// CHECK-NEXT: [[TMP7:%.*]] = insertvalue { , , , } [[TMP5]], [[TMP6]], 1 +// CHECK-NEXT: [[TMP8:%.*]] = extractvalue { , , , } [[TMP3]], 2 +// CHECK-NEXT: [[TMP9:%.*]] = insertvalue { , , , } [[TMP7]], [[TMP8]], 2 +// CHECK-NEXT: [[TMP10:%.*]] = extractvalue { , , , } [[TMP3]], 3 +// CHECK-NEXT: [[TMP11:%.*]] = insertvalue { , , , } [[TMP9]], [[TMP10]], 3 +// CHECK-NEXT: ret { , , , } [[TMP11]] // // CHECK-CXX-LABEL: define dso_local { , , , } @_Z29test_svreinterpret_mf8_mf8_x413svmfloat8x4_t( // CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]], [[OP_COERCE3:%.*]]) #[[ATTR0]] { @@ -1672,7 +2246,15 @@ svmfloat8x4_t test_svreinterpret_mf8_u8_x4(svuint8x4_t op) STREAMING { // CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , , } [[TMP0]], [[OP_COERCE1]], 1 // CHECK-CXX-NEXT: [[TMP2:%.*]] = insertvalue { , , , } [[TMP1]], [[OP_COERCE2]], 2 // CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP2]], [[OP_COERCE3]], 3 -// CHECK-CXX-NEXT: ret { , , , } [[TMP3]] +// CHECK-CXX-NEXT: [[TMP4:%.*]] = extractvalue { , , , } [[TMP3]], 0 +// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , , } poison, [[TMP4]], 0 +// CHECK-CXX-NEXT: [[TMP6:%.*]] = extractvalue { , , , } [[TMP3]], 1 +// CHECK-CXX-NEXT: [[TMP7:%.*]] = insertvalue { , , , } [[TMP5]], [[TMP6]], 1 +// CHECK-CXX-NEXT: [[TMP8:%.*]] = extractvalue { , , , } [[TMP3]], 2 +// CHECK-CXX-NEXT: [[TMP9:%.*]] = insertvalue { , , , } [[TMP7]], [[TMP8]], 2 +// CHECK-CXX-NEXT: [[TMP10:%.*]] = extractvalue { , , , } [[TMP3]], 3 +// CHECK-CXX-NEXT: [[TMP11:%.*]] = insertvalue { , , , } [[TMP9]], [[TMP10]], 3 +// CHECK-CXX-NEXT: ret { , , , } [[TMP11]] // svmfloat8x4_t test_svreinterpret_mf8_mf8_x4(svmfloat8x4_t op) STREAMING { return SVE_ACLE_FUNC(svreinterpret_mf8, _mf8_x4)(op); @@ -1681,28 +2263,44 @@ svmfloat8x4_t test_svreinterpret_mf8_mf8_x4(svmfloat8x4_t op) STREAMING { // CHECK-LABEL: define dso_local { , , , } @test_svreinterpret_mf8_s16_x4( // CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]], [[OP_COERCE3:%.*]]) #[[ATTR0]] { // CHECK-NEXT: [[ENTRY:.*:]] -// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , , } poison, [[TMP0]], 0 -// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP1]], [[TMP2]], 1 -// CHECK-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to -// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , , } [[TMP3]], [[TMP4]], 2 -// CHECK-NEXT: [[TMP6:%.*]] = bitcast [[OP_COERCE3]] to -// CHECK-NEXT: [[TMP7:%.*]] = insertvalue { , , , } [[TMP5]], [[TMP6]], 3 -// CHECK-NEXT: ret { , , , } [[TMP7]] +// CHECK-NEXT: [[TMP0:%.*]] = insertvalue { , , , } poison, [[OP_COERCE0]], 0 +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-NEXT: [[TMP2:%.*]] = insertvalue { , , , } [[TMP1]], [[OP_COERCE2]], 2 +// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP2]], [[OP_COERCE3]], 3 +// CHECK-NEXT: [[TMP4:%.*]] = extractvalue { , , , } [[TMP3]], 0 +// CHECK-NEXT: [[TMP5:%.*]] = bitcast [[TMP4]] to +// CHECK-NEXT: [[TMP6:%.*]] = insertvalue { , , , } poison, [[TMP5]], 0 +// CHECK-NEXT: [[TMP7:%.*]] = extractvalue { , , , } [[TMP3]], 1 +// CHECK-NEXT: [[TMP8:%.*]] = bitcast [[TMP7]] to +// CHECK-NEXT: [[TMP9:%.*]] = insertvalue { , , , } [[TMP6]], [[TMP8]], 1 +// CHECK-NEXT: [[TMP10:%.*]] = extractvalue { , , , } [[TMP3]], 2 +// CHECK-NEXT: [[TMP11:%.*]] = bitcast [[TMP10]] to +// CHECK-NEXT: [[TMP12:%.*]] = insertvalue { , , , } [[TMP9]], [[TMP11]], 2 +// CHECK-NEXT: [[TMP13:%.*]] = extractvalue { , , , } [[TMP3]], 3 +// CHECK-NEXT: [[TMP14:%.*]] = bitcast [[TMP13]] to +// CHECK-NEXT: [[TMP15:%.*]] = insertvalue { , , , } [[TMP12]], [[TMP14]], 3 +// CHECK-NEXT: ret { , , , } [[TMP15]] // // CHECK-CXX-LABEL: define dso_local { , , , } @_Z29test_svreinterpret_mf8_s16_x411svint16x4_t( // CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]], [[OP_COERCE3:%.*]]) #[[ATTR0]] { // CHECK-CXX-NEXT: [[ENTRY:.*:]] -// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , , } poison, [[TMP0]], 0 -// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP1]], [[TMP2]], 1 -// CHECK-CXX-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to -// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , , } [[TMP3]], [[TMP4]], 2 -// CHECK-CXX-NEXT: [[TMP6:%.*]] = bitcast [[OP_COERCE3]] to -// CHECK-CXX-NEXT: [[TMP7:%.*]] = insertvalue { , , , } [[TMP5]], [[TMP6]], 3 -// CHECK-CXX-NEXT: ret { , , , } [[TMP7]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = insertvalue { , , , } poison, [[OP_COERCE0]], 0 +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = insertvalue { , , , } [[TMP1]], [[OP_COERCE2]], 2 +// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP2]], [[OP_COERCE3]], 3 +// CHECK-CXX-NEXT: [[TMP4:%.*]] = extractvalue { , , , } [[TMP3]], 0 +// CHECK-CXX-NEXT: [[TMP5:%.*]] = bitcast [[TMP4]] to +// CHECK-CXX-NEXT: [[TMP6:%.*]] = insertvalue { , , , } poison, [[TMP5]], 0 +// CHECK-CXX-NEXT: [[TMP7:%.*]] = extractvalue { , , , } [[TMP3]], 1 +// CHECK-CXX-NEXT: [[TMP8:%.*]] = bitcast [[TMP7]] to +// CHECK-CXX-NEXT: [[TMP9:%.*]] = insertvalue { , , , } [[TMP6]], [[TMP8]], 1 +// CHECK-CXX-NEXT: [[TMP10:%.*]] = extractvalue { , , , } [[TMP3]], 2 +// CHECK-CXX-NEXT: [[TMP11:%.*]] = bitcast [[TMP10]] to +// CHECK-CXX-NEXT: [[TMP12:%.*]] = insertvalue { , , , } [[TMP9]], [[TMP11]], 2 +// CHECK-CXX-NEXT: [[TMP13:%.*]] = extractvalue { , , , } [[TMP3]], 3 +// CHECK-CXX-NEXT: [[TMP14:%.*]] = bitcast [[TMP13]] to +// CHECK-CXX-NEXT: [[TMP15:%.*]] = insertvalue { , , , } [[TMP12]], [[TMP14]], 3 +// CHECK-CXX-NEXT: ret { , , , } [[TMP15]] // svmfloat8x4_t test_svreinterpret_mf8_s16_x4(svint16x4_t op) STREAMING { return SVE_ACLE_FUNC(svreinterpret_mf8, _s16_x4)(op); @@ -1711,28 +2309,44 @@ svmfloat8x4_t test_svreinterpret_mf8_s16_x4(svint16x4_t op) STREAMING { // CHECK-LABEL: define dso_local { , , , } @test_svreinterpret_mf8_u16_x4( // CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]], [[OP_COERCE3:%.*]]) #[[ATTR0]] { // CHECK-NEXT: [[ENTRY:.*:]] -// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , , } poison, [[TMP0]], 0 -// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP1]], [[TMP2]], 1 -// CHECK-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to -// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , , } [[TMP3]], [[TMP4]], 2 -// CHECK-NEXT: [[TMP6:%.*]] = bitcast [[OP_COERCE3]] to -// CHECK-NEXT: [[TMP7:%.*]] = insertvalue { , , , } [[TMP5]], [[TMP6]], 3 -// CHECK-NEXT: ret { , , , } [[TMP7]] +// CHECK-NEXT: [[TMP0:%.*]] = insertvalue { , , , } poison, [[OP_COERCE0]], 0 +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-NEXT: [[TMP2:%.*]] = insertvalue { , , , } [[TMP1]], [[OP_COERCE2]], 2 +// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP2]], [[OP_COERCE3]], 3 +// CHECK-NEXT: [[TMP4:%.*]] = extractvalue { , , , } [[TMP3]], 0 +// CHECK-NEXT: [[TMP5:%.*]] = bitcast [[TMP4]] to +// CHECK-NEXT: [[TMP6:%.*]] = insertvalue { , , , } poison, [[TMP5]], 0 +// CHECK-NEXT: [[TMP7:%.*]] = extractvalue { , , , } [[TMP3]], 1 +// CHECK-NEXT: [[TMP8:%.*]] = bitcast [[TMP7]] to +// CHECK-NEXT: [[TMP9:%.*]] = insertvalue { , , , } [[TMP6]], [[TMP8]], 1 +// CHECK-NEXT: [[TMP10:%.*]] = extractvalue { , , , } [[TMP3]], 2 +// CHECK-NEXT: [[TMP11:%.*]] = bitcast [[TMP10]] to +// CHECK-NEXT: [[TMP12:%.*]] = insertvalue { , , , } [[TMP9]], [[TMP11]], 2 +// CHECK-NEXT: [[TMP13:%.*]] = extractvalue { , , , } [[TMP3]], 3 +// CHECK-NEXT: [[TMP14:%.*]] = bitcast [[TMP13]] to +// CHECK-NEXT: [[TMP15:%.*]] = insertvalue { , , , } [[TMP12]], [[TMP14]], 3 +// CHECK-NEXT: ret { , , , } [[TMP15]] // // CHECK-CXX-LABEL: define dso_local { , , , } @_Z29test_svreinterpret_mf8_u16_x412svuint16x4_t( // CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]], [[OP_COERCE3:%.*]]) #[[ATTR0]] { // CHECK-CXX-NEXT: [[ENTRY:.*:]] -// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , , } poison, [[TMP0]], 0 -// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP1]], [[TMP2]], 1 -// CHECK-CXX-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to -// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , , } [[TMP3]], [[TMP4]], 2 -// CHECK-CXX-NEXT: [[TMP6:%.*]] = bitcast [[OP_COERCE3]] to -// CHECK-CXX-NEXT: [[TMP7:%.*]] = insertvalue { , , , } [[TMP5]], [[TMP6]], 3 -// CHECK-CXX-NEXT: ret { , , , } [[TMP7]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = insertvalue { , , , } poison, [[OP_COERCE0]], 0 +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = insertvalue { , , , } [[TMP1]], [[OP_COERCE2]], 2 +// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP2]], [[OP_COERCE3]], 3 +// CHECK-CXX-NEXT: [[TMP4:%.*]] = extractvalue { , , , } [[TMP3]], 0 +// CHECK-CXX-NEXT: [[TMP5:%.*]] = bitcast [[TMP4]] to +// CHECK-CXX-NEXT: [[TMP6:%.*]] = insertvalue { , , , } poison, [[TMP5]], 0 +// CHECK-CXX-NEXT: [[TMP7:%.*]] = extractvalue { , , , } [[TMP3]], 1 +// CHECK-CXX-NEXT: [[TMP8:%.*]] = bitcast [[TMP7]] to +// CHECK-CXX-NEXT: [[TMP9:%.*]] = insertvalue { , , , } [[TMP6]], [[TMP8]], 1 +// CHECK-CXX-NEXT: [[TMP10:%.*]] = extractvalue { , , , } [[TMP3]], 2 +// CHECK-CXX-NEXT: [[TMP11:%.*]] = bitcast [[TMP10]] to +// CHECK-CXX-NEXT: [[TMP12:%.*]] = insertvalue { , , , } [[TMP9]], [[TMP11]], 2 +// CHECK-CXX-NEXT: [[TMP13:%.*]] = extractvalue { , , , } [[TMP3]], 3 +// CHECK-CXX-NEXT: [[TMP14:%.*]] = bitcast [[TMP13]] to +// CHECK-CXX-NEXT: [[TMP15:%.*]] = insertvalue { , , , } [[TMP12]], [[TMP14]], 3 +// CHECK-CXX-NEXT: ret { , , , } [[TMP15]] // svmfloat8x4_t test_svreinterpret_mf8_u16_x4(svuint16x4_t op) STREAMING { return SVE_ACLE_FUNC(svreinterpret_mf8, _u16_x4)(op); @@ -1741,28 +2355,44 @@ svmfloat8x4_t test_svreinterpret_mf8_u16_x4(svuint16x4_t op) STREAMING { // CHECK-LABEL: define dso_local { , , , } @test_svreinterpret_mf8_s32_x4( // CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]], [[OP_COERCE3:%.*]]) #[[ATTR0]] { // CHECK-NEXT: [[ENTRY:.*:]] -// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , , } poison, [[TMP0]], 0 -// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP1]], [[TMP2]], 1 -// CHECK-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to -// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , , } [[TMP3]], [[TMP4]], 2 -// CHECK-NEXT: [[TMP6:%.*]] = bitcast [[OP_COERCE3]] to -// CHECK-NEXT: [[TMP7:%.*]] = insertvalue { , , , } [[TMP5]], [[TMP6]], 3 -// CHECK-NEXT: ret { , , , } [[TMP7]] +// CHECK-NEXT: [[TMP0:%.*]] = insertvalue { , , , } poison, [[OP_COERCE0]], 0 +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-NEXT: [[TMP2:%.*]] = insertvalue { , , , } [[TMP1]], [[OP_COERCE2]], 2 +// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP2]], [[OP_COERCE3]], 3 +// CHECK-NEXT: [[TMP4:%.*]] = extractvalue { , , , } [[TMP3]], 0 +// CHECK-NEXT: [[TMP5:%.*]] = bitcast [[TMP4]] to +// CHECK-NEXT: [[TMP6:%.*]] = insertvalue { , , , } poison, [[TMP5]], 0 +// CHECK-NEXT: [[TMP7:%.*]] = extractvalue { , , , } [[TMP3]], 1 +// CHECK-NEXT: [[TMP8:%.*]] = bitcast [[TMP7]] to +// CHECK-NEXT: [[TMP9:%.*]] = insertvalue { , , , } [[TMP6]], [[TMP8]], 1 +// CHECK-NEXT: [[TMP10:%.*]] = extractvalue { , , , } [[TMP3]], 2 +// CHECK-NEXT: [[TMP11:%.*]] = bitcast [[TMP10]] to +// CHECK-NEXT: [[TMP12:%.*]] = insertvalue { , , , } [[TMP9]], [[TMP11]], 2 +// CHECK-NEXT: [[TMP13:%.*]] = extractvalue { , , , } [[TMP3]], 3 +// CHECK-NEXT: [[TMP14:%.*]] = bitcast [[TMP13]] to +// CHECK-NEXT: [[TMP15:%.*]] = insertvalue { , , , } [[TMP12]], [[TMP14]], 3 +// CHECK-NEXT: ret { , , , } [[TMP15]] // // CHECK-CXX-LABEL: define dso_local { , , , } @_Z29test_svreinterpret_mf8_s32_x411svint32x4_t( // CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]], [[OP_COERCE3:%.*]]) #[[ATTR0]] { // CHECK-CXX-NEXT: [[ENTRY:.*:]] -// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , , } poison, [[TMP0]], 0 -// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP1]], [[TMP2]], 1 -// CHECK-CXX-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to -// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , , } [[TMP3]], [[TMP4]], 2 -// CHECK-CXX-NEXT: [[TMP6:%.*]] = bitcast [[OP_COERCE3]] to -// CHECK-CXX-NEXT: [[TMP7:%.*]] = insertvalue { , , , } [[TMP5]], [[TMP6]], 3 -// CHECK-CXX-NEXT: ret { , , , } [[TMP7]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = insertvalue { , , , } poison, [[OP_COERCE0]], 0 +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = insertvalue { , , , } [[TMP1]], [[OP_COERCE2]], 2 +// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP2]], [[OP_COERCE3]], 3 +// CHECK-CXX-NEXT: [[TMP4:%.*]] = extractvalue { , , , } [[TMP3]], 0 +// CHECK-CXX-NEXT: [[TMP5:%.*]] = bitcast [[TMP4]] to +// CHECK-CXX-NEXT: [[TMP6:%.*]] = insertvalue { , , , } poison, [[TMP5]], 0 +// CHECK-CXX-NEXT: [[TMP7:%.*]] = extractvalue { , , , } [[TMP3]], 1 +// CHECK-CXX-NEXT: [[TMP8:%.*]] = bitcast [[TMP7]] to +// CHECK-CXX-NEXT: [[TMP9:%.*]] = insertvalue { , , , } [[TMP6]], [[TMP8]], 1 +// CHECK-CXX-NEXT: [[TMP10:%.*]] = extractvalue { , , , } [[TMP3]], 2 +// CHECK-CXX-NEXT: [[TMP11:%.*]] = bitcast [[TMP10]] to +// CHECK-CXX-NEXT: [[TMP12:%.*]] = insertvalue { , , , } [[TMP9]], [[TMP11]], 2 +// CHECK-CXX-NEXT: [[TMP13:%.*]] = extractvalue { , , , } [[TMP3]], 3 +// CHECK-CXX-NEXT: [[TMP14:%.*]] = bitcast [[TMP13]] to +// CHECK-CXX-NEXT: [[TMP15:%.*]] = insertvalue { , , , } [[TMP12]], [[TMP14]], 3 +// CHECK-CXX-NEXT: ret { , , , } [[TMP15]] // svmfloat8x4_t test_svreinterpret_mf8_s32_x4(svint32x4_t op) STREAMING { return SVE_ACLE_FUNC(svreinterpret_mf8, _s32_x4)(op); @@ -1771,28 +2401,44 @@ svmfloat8x4_t test_svreinterpret_mf8_s32_x4(svint32x4_t op) STREAMING { // CHECK-LABEL: define dso_local { , , , } @test_svreinterpret_mf8_u32_x4( // CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]], [[OP_COERCE3:%.*]]) #[[ATTR0]] { // CHECK-NEXT: [[ENTRY:.*:]] -// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , , } poison, [[TMP0]], 0 -// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP1]], [[TMP2]], 1 -// CHECK-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to -// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , , } [[TMP3]], [[TMP4]], 2 -// CHECK-NEXT: [[TMP6:%.*]] = bitcast [[OP_COERCE3]] to -// CHECK-NEXT: [[TMP7:%.*]] = insertvalue { , , , } [[TMP5]], [[TMP6]], 3 -// CHECK-NEXT: ret { , , , } [[TMP7]] +// CHECK-NEXT: [[TMP0:%.*]] = insertvalue { , , , } poison, [[OP_COERCE0]], 0 +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-NEXT: [[TMP2:%.*]] = insertvalue { , , , } [[TMP1]], [[OP_COERCE2]], 2 +// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP2]], [[OP_COERCE3]], 3 +// CHECK-NEXT: [[TMP4:%.*]] = extractvalue { , , , } [[TMP3]], 0 +// CHECK-NEXT: [[TMP5:%.*]] = bitcast [[TMP4]] to +// CHECK-NEXT: [[TMP6:%.*]] = insertvalue { , , , } poison, [[TMP5]], 0 +// CHECK-NEXT: [[TMP7:%.*]] = extractvalue { , , , } [[TMP3]], 1 +// CHECK-NEXT: [[TMP8:%.*]] = bitcast [[TMP7]] to +// CHECK-NEXT: [[TMP9:%.*]] = insertvalue { , , , } [[TMP6]], [[TMP8]], 1 +// CHECK-NEXT: [[TMP10:%.*]] = extractvalue { , , , } [[TMP3]], 2 +// CHECK-NEXT: [[TMP11:%.*]] = bitcast [[TMP10]] to +// CHECK-NEXT: [[TMP12:%.*]] = insertvalue { , , , } [[TMP9]], [[TMP11]], 2 +// CHECK-NEXT: [[TMP13:%.*]] = extractvalue { , , , } [[TMP3]], 3 +// CHECK-NEXT: [[TMP14:%.*]] = bitcast [[TMP13]] to +// CHECK-NEXT: [[TMP15:%.*]] = insertvalue { , , , } [[TMP12]], [[TMP14]], 3 +// CHECK-NEXT: ret { , , , } [[TMP15]] // // CHECK-CXX-LABEL: define dso_local { , , , } @_Z29test_svreinterpret_mf8_u32_x412svuint32x4_t( // CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]], [[OP_COERCE3:%.*]]) #[[ATTR0]] { // CHECK-CXX-NEXT: [[ENTRY:.*:]] -// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , , } poison, [[TMP0]], 0 -// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP1]], [[TMP2]], 1 -// CHECK-CXX-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to -// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , , } [[TMP3]], [[TMP4]], 2 -// CHECK-CXX-NEXT: [[TMP6:%.*]] = bitcast [[OP_COERCE3]] to -// CHECK-CXX-NEXT: [[TMP7:%.*]] = insertvalue { , , , } [[TMP5]], [[TMP6]], 3 -// CHECK-CXX-NEXT: ret { , , , } [[TMP7]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = insertvalue { , , , } poison, [[OP_COERCE0]], 0 +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = insertvalue { , , , } [[TMP1]], [[OP_COERCE2]], 2 +// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP2]], [[OP_COERCE3]], 3 +// CHECK-CXX-NEXT: [[TMP4:%.*]] = extractvalue { , , , } [[TMP3]], 0 +// CHECK-CXX-NEXT: [[TMP5:%.*]] = bitcast [[TMP4]] to +// CHECK-CXX-NEXT: [[TMP6:%.*]] = insertvalue { , , , } poison, [[TMP5]], 0 +// CHECK-CXX-NEXT: [[TMP7:%.*]] = extractvalue { , , , } [[TMP3]], 1 +// CHECK-CXX-NEXT: [[TMP8:%.*]] = bitcast [[TMP7]] to +// CHECK-CXX-NEXT: [[TMP9:%.*]] = insertvalue { , , , } [[TMP6]], [[TMP8]], 1 +// CHECK-CXX-NEXT: [[TMP10:%.*]] = extractvalue { , , , } [[TMP3]], 2 +// CHECK-CXX-NEXT: [[TMP11:%.*]] = bitcast [[TMP10]] to +// CHECK-CXX-NEXT: [[TMP12:%.*]] = insertvalue { , , , } [[TMP9]], [[TMP11]], 2 +// CHECK-CXX-NEXT: [[TMP13:%.*]] = extractvalue { , , , } [[TMP3]], 3 +// CHECK-CXX-NEXT: [[TMP14:%.*]] = bitcast [[TMP13]] to +// CHECK-CXX-NEXT: [[TMP15:%.*]] = insertvalue { , , , } [[TMP12]], [[TMP14]], 3 +// CHECK-CXX-NEXT: ret { , , , } [[TMP15]] // svmfloat8x4_t test_svreinterpret_mf8_u32_x4(svuint32x4_t op) STREAMING { return SVE_ACLE_FUNC(svreinterpret_mf8, _u32_x4)(op); @@ -1801,28 +2447,44 @@ svmfloat8x4_t test_svreinterpret_mf8_u32_x4(svuint32x4_t op) STREAMING { // CHECK-LABEL: define dso_local { , , , } @test_svreinterpret_mf8_s64_x4( // CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]], [[OP_COERCE3:%.*]]) #[[ATTR0]] { // CHECK-NEXT: [[ENTRY:.*:]] -// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , , } poison, [[TMP0]], 0 -// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP1]], [[TMP2]], 1 -// CHECK-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to -// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , , } [[TMP3]], [[TMP4]], 2 -// CHECK-NEXT: [[TMP6:%.*]] = bitcast [[OP_COERCE3]] to -// CHECK-NEXT: [[TMP7:%.*]] = insertvalue { , , , } [[TMP5]], [[TMP6]], 3 -// CHECK-NEXT: ret { , , , } [[TMP7]] +// CHECK-NEXT: [[TMP0:%.*]] = insertvalue { , , , } poison, [[OP_COERCE0]], 0 +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-NEXT: [[TMP2:%.*]] = insertvalue { , , , } [[TMP1]], [[OP_COERCE2]], 2 +// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP2]], [[OP_COERCE3]], 3 +// CHECK-NEXT: [[TMP4:%.*]] = extractvalue { , , , } [[TMP3]], 0 +// CHECK-NEXT: [[TMP5:%.*]] = bitcast [[TMP4]] to +// CHECK-NEXT: [[TMP6:%.*]] = insertvalue { , , , } poison, [[TMP5]], 0 +// CHECK-NEXT: [[TMP7:%.*]] = extractvalue { , , , } [[TMP3]], 1 +// CHECK-NEXT: [[TMP8:%.*]] = bitcast [[TMP7]] to +// CHECK-NEXT: [[TMP9:%.*]] = insertvalue { , , , } [[TMP6]], [[TMP8]], 1 +// CHECK-NEXT: [[TMP10:%.*]] = extractvalue { , , , } [[TMP3]], 2 +// CHECK-NEXT: [[TMP11:%.*]] = bitcast [[TMP10]] to +// CHECK-NEXT: [[TMP12:%.*]] = insertvalue { , , , } [[TMP9]], [[TMP11]], 2 +// CHECK-NEXT: [[TMP13:%.*]] = extractvalue { , , , } [[TMP3]], 3 +// CHECK-NEXT: [[TMP14:%.*]] = bitcast [[TMP13]] to +// CHECK-NEXT: [[TMP15:%.*]] = insertvalue { , , , } [[TMP12]], [[TMP14]], 3 +// CHECK-NEXT: ret { , , , } [[TMP15]] // // CHECK-CXX-LABEL: define dso_local { , , , } @_Z29test_svreinterpret_mf8_s64_x411svint64x4_t( // CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]], [[OP_COERCE3:%.*]]) #[[ATTR0]] { // CHECK-CXX-NEXT: [[ENTRY:.*:]] -// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , , } poison, [[TMP0]], 0 -// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP1]], [[TMP2]], 1 -// CHECK-CXX-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to -// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , , } [[TMP3]], [[TMP4]], 2 -// CHECK-CXX-NEXT: [[TMP6:%.*]] = bitcast [[OP_COERCE3]] to -// CHECK-CXX-NEXT: [[TMP7:%.*]] = insertvalue { , , , } [[TMP5]], [[TMP6]], 3 -// CHECK-CXX-NEXT: ret { , , , } [[TMP7]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = insertvalue { , , , } poison, [[OP_COERCE0]], 0 +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = insertvalue { , , , } [[TMP1]], [[OP_COERCE2]], 2 +// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP2]], [[OP_COERCE3]], 3 +// CHECK-CXX-NEXT: [[TMP4:%.*]] = extractvalue { , , , } [[TMP3]], 0 +// CHECK-CXX-NEXT: [[TMP5:%.*]] = bitcast [[TMP4]] to +// CHECK-CXX-NEXT: [[TMP6:%.*]] = insertvalue { , , , } poison, [[TMP5]], 0 +// CHECK-CXX-NEXT: [[TMP7:%.*]] = extractvalue { , , , } [[TMP3]], 1 +// CHECK-CXX-NEXT: [[TMP8:%.*]] = bitcast [[TMP7]] to +// CHECK-CXX-NEXT: [[TMP9:%.*]] = insertvalue { , , , } [[TMP6]], [[TMP8]], 1 +// CHECK-CXX-NEXT: [[TMP10:%.*]] = extractvalue { , , , } [[TMP3]], 2 +// CHECK-CXX-NEXT: [[TMP11:%.*]] = bitcast [[TMP10]] to +// CHECK-CXX-NEXT: [[TMP12:%.*]] = insertvalue { , , , } [[TMP9]], [[TMP11]], 2 +// CHECK-CXX-NEXT: [[TMP13:%.*]] = extractvalue { , , , } [[TMP3]], 3 +// CHECK-CXX-NEXT: [[TMP14:%.*]] = bitcast [[TMP13]] to +// CHECK-CXX-NEXT: [[TMP15:%.*]] = insertvalue { , , , } [[TMP12]], [[TMP14]], 3 +// CHECK-CXX-NEXT: ret { , , , } [[TMP15]] // svmfloat8x4_t test_svreinterpret_mf8_s64_x4(svint64x4_t op) STREAMING { return SVE_ACLE_FUNC(svreinterpret_mf8, _s64_x4)(op); @@ -1831,58 +2493,91 @@ svmfloat8x4_t test_svreinterpret_mf8_s64_x4(svint64x4_t op) STREAMING { // CHECK-LABEL: define dso_local { , , , } @test_svreinterpret_mf8_u64_x4( // CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]], [[OP_COERCE3:%.*]]) #[[ATTR0]] { // CHECK-NEXT: [[ENTRY:.*:]] -// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , , } poison, [[TMP0]], 0 -// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP1]], [[TMP2]], 1 -// CHECK-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to -// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , , } [[TMP3]], [[TMP4]], 2 -// CHECK-NEXT: [[TMP6:%.*]] = bitcast [[OP_COERCE3]] to -// CHECK-NEXT: [[TMP7:%.*]] = insertvalue { , , , } [[TMP5]], [[TMP6]], 3 -// CHECK-NEXT: ret { , , , } [[TMP7]] +// CHECK-NEXT: [[TMP0:%.*]] = insertvalue { , , , } poison, [[OP_COERCE0]], 0 +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-NEXT: [[TMP2:%.*]] = insertvalue { , , , } [[TMP1]], [[OP_COERCE2]], 2 +// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP2]], [[OP_COERCE3]], 3 +// CHECK-NEXT: [[TMP4:%.*]] = extractvalue { , , , } [[TMP3]], 0 +// CHECK-NEXT: [[TMP5:%.*]] = bitcast [[TMP4]] to +// CHECK-NEXT: [[TMP6:%.*]] = insertvalue { , , , } poison, [[TMP5]], 0 +// CHECK-NEXT: [[TMP7:%.*]] = extractvalue { , , , } [[TMP3]], 1 +// CHECK-NEXT: [[TMP8:%.*]] = bitcast [[TMP7]] to +// CHECK-NEXT: [[TMP9:%.*]] = insertvalue { , , , } [[TMP6]], [[TMP8]], 1 +// CHECK-NEXT: [[TMP10:%.*]] = extractvalue { , , , } [[TMP3]], 2 +// CHECK-NEXT: [[TMP11:%.*]] = bitcast [[TMP10]] to +// CHECK-NEXT: [[TMP12:%.*]] = insertvalue { , , , } [[TMP9]], [[TMP11]], 2 +// CHECK-NEXT: [[TMP13:%.*]] = extractvalue { , , , } [[TMP3]], 3 +// CHECK-NEXT: [[TMP14:%.*]] = bitcast [[TMP13]] to +// CHECK-NEXT: [[TMP15:%.*]] = insertvalue { , , , } [[TMP12]], [[TMP14]], 3 +// CHECK-NEXT: ret { , , , } [[TMP15]] // // CHECK-CXX-LABEL: define dso_local { , , , } @_Z29test_svreinterpret_mf8_u64_x412svuint64x4_t( // CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]], [[OP_COERCE3:%.*]]) #[[ATTR0]] { // CHECK-CXX-NEXT: [[ENTRY:.*:]] -// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , , } poison, [[TMP0]], 0 -// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP1]], [[TMP2]], 1 -// CHECK-CXX-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to -// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , , } [[TMP3]], [[TMP4]], 2 -// CHECK-CXX-NEXT: [[TMP6:%.*]] = bitcast [[OP_COERCE3]] to -// CHECK-CXX-NEXT: [[TMP7:%.*]] = insertvalue { , , , } [[TMP5]], [[TMP6]], 3 -// CHECK-CXX-NEXT: ret { , , , } [[TMP7]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = insertvalue { , , , } poison, [[OP_COERCE0]], 0 +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = insertvalue { , , , } [[TMP1]], [[OP_COERCE2]], 2 +// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP2]], [[OP_COERCE3]], 3 +// CHECK-CXX-NEXT: [[TMP4:%.*]] = extractvalue { , , , } [[TMP3]], 0 +// CHECK-CXX-NEXT: [[TMP5:%.*]] = bitcast [[TMP4]] to +// CHECK-CXX-NEXT: [[TMP6:%.*]] = insertvalue { , , , } poison, [[TMP5]], 0 +// CHECK-CXX-NEXT: [[TMP7:%.*]] = extractvalue { , , , } [[TMP3]], 1 +// CHECK-CXX-NEXT: [[TMP8:%.*]] = bitcast [[TMP7]] to +// CHECK-CXX-NEXT: [[TMP9:%.*]] = insertvalue { , , , } [[TMP6]], [[TMP8]], 1 +// CHECK-CXX-NEXT: [[TMP10:%.*]] = extractvalue { , , , } [[TMP3]], 2 +// CHECK-CXX-NEXT: [[TMP11:%.*]] = bitcast [[TMP10]] to +// CHECK-CXX-NEXT: [[TMP12:%.*]] = insertvalue { , , , } [[TMP9]], [[TMP11]], 2 +// CHECK-CXX-NEXT: [[TMP13:%.*]] = extractvalue { , , , } [[TMP3]], 3 +// CHECK-CXX-NEXT: [[TMP14:%.*]] = bitcast [[TMP13]] to +// CHECK-CXX-NEXT: [[TMP15:%.*]] = insertvalue { , , , } [[TMP12]], [[TMP14]], 3 +// CHECK-CXX-NEXT: ret { , , , } [[TMP15]] // svmfloat8x4_t test_svreinterpret_mf8_u64_x4(svuint64x4_t op) STREAMING { return SVE_ACLE_FUNC(svreinterpret_mf8, _u64_x4)(op); } +// // CHECK-LABEL: define dso_local { , , , } @test_svreinterpret_mf8_f16_x4( // CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]], [[OP_COERCE3:%.*]]) #[[ATTR0]] { // CHECK-NEXT: [[ENTRY:.*:]] -// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , , } poison, [[TMP0]], 0 -// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP1]], [[TMP2]], 1 -// CHECK-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to -// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , , } [[TMP3]], [[TMP4]], 2 -// CHECK-NEXT: [[TMP6:%.*]] = bitcast [[OP_COERCE3]] to -// CHECK-NEXT: [[TMP7:%.*]] = insertvalue { , , , } [[TMP5]], [[TMP6]], 3 -// CHECK-NEXT: ret { , , , } [[TMP7]] +// CHECK-NEXT: [[TMP0:%.*]] = insertvalue { , , , } poison, [[OP_COERCE0]], 0 +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-NEXT: [[TMP2:%.*]] = insertvalue { , , , } [[TMP1]], [[OP_COERCE2]], 2 +// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP2]], [[OP_COERCE3]], 3 +// CHECK-NEXT: [[TMP4:%.*]] = extractvalue { , , , } [[TMP3]], 0 +// CHECK-NEXT: [[TMP5:%.*]] = bitcast [[TMP4]] to +// CHECK-NEXT: [[TMP6:%.*]] = insertvalue { , , , } poison, [[TMP5]], 0 +// CHECK-NEXT: [[TMP7:%.*]] = extractvalue { , , , } [[TMP3]], 1 +// CHECK-NEXT: [[TMP8:%.*]] = bitcast [[TMP7]] to +// CHECK-NEXT: [[TMP9:%.*]] = insertvalue { , , , } [[TMP6]], [[TMP8]], 1 +// CHECK-NEXT: [[TMP10:%.*]] = extractvalue { , , , } [[TMP3]], 2 +// CHECK-NEXT: [[TMP11:%.*]] = bitcast [[TMP10]] to +// CHECK-NEXT: [[TMP12:%.*]] = insertvalue { , , , } [[TMP9]], [[TMP11]], 2 +// CHECK-NEXT: [[TMP13:%.*]] = extractvalue { , , , } [[TMP3]], 3 +// CHECK-NEXT: [[TMP14:%.*]] = bitcast [[TMP13]] to +// CHECK-NEXT: [[TMP15:%.*]] = insertvalue { , , , } [[TMP12]], [[TMP14]], 3 +// CHECK-NEXT: ret { , , , } [[TMP15]] // // CHECK-CXX-LABEL: define dso_local { , , , } @_Z29test_svreinterpret_mf8_f16_x413svfloat16x4_t( // CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]], [[OP_COERCE3:%.*]]) #[[ATTR0]] { // CHECK-CXX-NEXT: [[ENTRY:.*:]] -// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , , } poison, [[TMP0]], 0 -// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP1]], [[TMP2]], 1 -// CHECK-CXX-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to -// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , , } [[TMP3]], [[TMP4]], 2 -// CHECK-CXX-NEXT: [[TMP6:%.*]] = bitcast [[OP_COERCE3]] to -// CHECK-CXX-NEXT: [[TMP7:%.*]] = insertvalue { , , , } [[TMP5]], [[TMP6]], 3 -// CHECK-CXX-NEXT: ret { , , , } [[TMP7]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = insertvalue { , , , } poison, [[OP_COERCE0]], 0 +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = insertvalue { , , , } [[TMP1]], [[OP_COERCE2]], 2 +// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP2]], [[OP_COERCE3]], 3 +// CHECK-CXX-NEXT: [[TMP4:%.*]] = extractvalue { , , , } [[TMP3]], 0 +// CHECK-CXX-NEXT: [[TMP5:%.*]] = bitcast [[TMP4]] to +// CHECK-CXX-NEXT: [[TMP6:%.*]] = insertvalue { , , , } poison, [[TMP5]], 0 +// CHECK-CXX-NEXT: [[TMP7:%.*]] = extractvalue { , , , } [[TMP3]], 1 +// CHECK-CXX-NEXT: [[TMP8:%.*]] = bitcast [[TMP7]] to +// CHECK-CXX-NEXT: [[TMP9:%.*]] = insertvalue { , , , } [[TMP6]], [[TMP8]], 1 +// CHECK-CXX-NEXT: [[TMP10:%.*]] = extractvalue { , , , } [[TMP3]], 2 +// CHECK-CXX-NEXT: [[TMP11:%.*]] = bitcast [[TMP10]] to +// CHECK-CXX-NEXT: [[TMP12:%.*]] = insertvalue { , , , } [[TMP9]], [[TMP11]], 2 +// CHECK-CXX-NEXT: [[TMP13:%.*]] = extractvalue { , , , } [[TMP3]], 3 +// CHECK-CXX-NEXT: [[TMP14:%.*]] = bitcast [[TMP13]] to +// CHECK-CXX-NEXT: [[TMP15:%.*]] = insertvalue { , , , } [[TMP12]], [[TMP14]], 3 +// CHECK-CXX-NEXT: ret { , , , } [[TMP15]] // svmfloat8x4_t test_svreinterpret_mf8_f16_x4(svfloat16x4_t op) STREAMING { return SVE_ACLE_FUNC(svreinterpret_mf8, _f16_x4)(op); @@ -1891,28 +2586,44 @@ svmfloat8x4_t test_svreinterpret_mf8_f16_x4(svfloat16x4_t op) STREAMING { // CHECK-LABEL: define dso_local { , , , } @test_svreinterpret_mf8_bf16_x4( // CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]], [[OP_COERCE3:%.*]]) #[[ATTR0]] { // CHECK-NEXT: [[ENTRY:.*:]] -// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , , } poison, [[TMP0]], 0 -// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP1]], [[TMP2]], 1 -// CHECK-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to -// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , , } [[TMP3]], [[TMP4]], 2 -// CHECK-NEXT: [[TMP6:%.*]] = bitcast [[OP_COERCE3]] to -// CHECK-NEXT: [[TMP7:%.*]] = insertvalue { , , , } [[TMP5]], [[TMP6]], 3 -// CHECK-NEXT: ret { , , , } [[TMP7]] +// CHECK-NEXT: [[TMP0:%.*]] = insertvalue { , , , } poison, [[OP_COERCE0]], 0 +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-NEXT: [[TMP2:%.*]] = insertvalue { , , , } [[TMP1]], [[OP_COERCE2]], 2 +// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP2]], [[OP_COERCE3]], 3 +// CHECK-NEXT: [[TMP4:%.*]] = extractvalue { , , , } [[TMP3]], 0 +// CHECK-NEXT: [[TMP5:%.*]] = bitcast [[TMP4]] to +// CHECK-NEXT: [[TMP6:%.*]] = insertvalue { , , , } poison, [[TMP5]], 0 +// CHECK-NEXT: [[TMP7:%.*]] = extractvalue { , , , } [[TMP3]], 1 +// CHECK-NEXT: [[TMP8:%.*]] = bitcast [[TMP7]] to +// CHECK-NEXT: [[TMP9:%.*]] = insertvalue { , , , } [[TMP6]], [[TMP8]], 1 +// CHECK-NEXT: [[TMP10:%.*]] = extractvalue { , , , } [[TMP3]], 2 +// CHECK-NEXT: [[TMP11:%.*]] = bitcast [[TMP10]] to +// CHECK-NEXT: [[TMP12:%.*]] = insertvalue { , , , } [[TMP9]], [[TMP11]], 2 +// CHECK-NEXT: [[TMP13:%.*]] = extractvalue { , , , } [[TMP3]], 3 +// CHECK-NEXT: [[TMP14:%.*]] = bitcast [[TMP13]] to +// CHECK-NEXT: [[TMP15:%.*]] = insertvalue { , , , } [[TMP12]], [[TMP14]], 3 +// CHECK-NEXT: ret { , , , } [[TMP15]] // // CHECK-CXX-LABEL: define dso_local { , , , } @_Z30test_svreinterpret_mf8_bf16_x414svbfloat16x4_t( // CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]], [[OP_COERCE3:%.*]]) #[[ATTR0]] { // CHECK-CXX-NEXT: [[ENTRY:.*:]] -// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , , } poison, [[TMP0]], 0 -// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP1]], [[TMP2]], 1 -// CHECK-CXX-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to -// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , , } [[TMP3]], [[TMP4]], 2 -// CHECK-CXX-NEXT: [[TMP6:%.*]] = bitcast [[OP_COERCE3]] to -// CHECK-CXX-NEXT: [[TMP7:%.*]] = insertvalue { , , , } [[TMP5]], [[TMP6]], 3 -// CHECK-CXX-NEXT: ret { , , , } [[TMP7]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = insertvalue { , , , } poison, [[OP_COERCE0]], 0 +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = insertvalue { , , , } [[TMP1]], [[OP_COERCE2]], 2 +// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP2]], [[OP_COERCE3]], 3 +// CHECK-CXX-NEXT: [[TMP4:%.*]] = extractvalue { , , , } [[TMP3]], 0 +// CHECK-CXX-NEXT: [[TMP5:%.*]] = bitcast [[TMP4]] to +// CHECK-CXX-NEXT: [[TMP6:%.*]] = insertvalue { , , , } poison, [[TMP5]], 0 +// CHECK-CXX-NEXT: [[TMP7:%.*]] = extractvalue { , , , } [[TMP3]], 1 +// CHECK-CXX-NEXT: [[TMP8:%.*]] = bitcast [[TMP7]] to +// CHECK-CXX-NEXT: [[TMP9:%.*]] = insertvalue { , , , } [[TMP6]], [[TMP8]], 1 +// CHECK-CXX-NEXT: [[TMP10:%.*]] = extractvalue { , , , } [[TMP3]], 2 +// CHECK-CXX-NEXT: [[TMP11:%.*]] = bitcast [[TMP10]] to +// CHECK-CXX-NEXT: [[TMP12:%.*]] = insertvalue { , , , } [[TMP9]], [[TMP11]], 2 +// CHECK-CXX-NEXT: [[TMP13:%.*]] = extractvalue { , , , } [[TMP3]], 3 +// CHECK-CXX-NEXT: [[TMP14:%.*]] = bitcast [[TMP13]] to +// CHECK-CXX-NEXT: [[TMP15:%.*]] = insertvalue { , , , } [[TMP12]], [[TMP14]], 3 +// CHECK-CXX-NEXT: ret { , , , } [[TMP15]] // svmfloat8x4_t test_svreinterpret_mf8_bf16_x4(svbfloat16x4_t op) STREAMING { return SVE_ACLE_FUNC(svreinterpret_mf8, _bf16_x4)(op); @@ -1921,28 +2632,44 @@ svmfloat8x4_t test_svreinterpret_mf8_bf16_x4(svbfloat16x4_t op) STREAMING { // CHECK-LABEL: define dso_local { , , , } @test_svreinterpret_mf8_f32_x4( // CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]], [[OP_COERCE3:%.*]]) #[[ATTR0]] { // CHECK-NEXT: [[ENTRY:.*:]] -// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , , } poison, [[TMP0]], 0 -// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP1]], [[TMP2]], 1 -// CHECK-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to -// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , , } [[TMP3]], [[TMP4]], 2 -// CHECK-NEXT: [[TMP6:%.*]] = bitcast [[OP_COERCE3]] to -// CHECK-NEXT: [[TMP7:%.*]] = insertvalue { , , , } [[TMP5]], [[TMP6]], 3 -// CHECK-NEXT: ret { , , , } [[TMP7]] +// CHECK-NEXT: [[TMP0:%.*]] = insertvalue { , , , } poison, [[OP_COERCE0]], 0 +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-NEXT: [[TMP2:%.*]] = insertvalue { , , , } [[TMP1]], [[OP_COERCE2]], 2 +// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP2]], [[OP_COERCE3]], 3 +// CHECK-NEXT: [[TMP4:%.*]] = extractvalue { , , , } [[TMP3]], 0 +// CHECK-NEXT: [[TMP5:%.*]] = bitcast [[TMP4]] to +// CHECK-NEXT: [[TMP6:%.*]] = insertvalue { , , , } poison, [[TMP5]], 0 +// CHECK-NEXT: [[TMP7:%.*]] = extractvalue { , , , } [[TMP3]], 1 +// CHECK-NEXT: [[TMP8:%.*]] = bitcast [[TMP7]] to +// CHECK-NEXT: [[TMP9:%.*]] = insertvalue { , , , } [[TMP6]], [[TMP8]], 1 +// CHECK-NEXT: [[TMP10:%.*]] = extractvalue { , , , } [[TMP3]], 2 +// CHECK-NEXT: [[TMP11:%.*]] = bitcast [[TMP10]] to +// CHECK-NEXT: [[TMP12:%.*]] = insertvalue { , , , } [[TMP9]], [[TMP11]], 2 +// CHECK-NEXT: [[TMP13:%.*]] = extractvalue { , , , } [[TMP3]], 3 +// CHECK-NEXT: [[TMP14:%.*]] = bitcast [[TMP13]] to +// CHECK-NEXT: [[TMP15:%.*]] = insertvalue { , , , } [[TMP12]], [[TMP14]], 3 +// CHECK-NEXT: ret { , , , } [[TMP15]] // // CHECK-CXX-LABEL: define dso_local { , , , } @_Z29test_svreinterpret_mf8_f32_x413svfloat32x4_t( // CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]], [[OP_COERCE3:%.*]]) #[[ATTR0]] { // CHECK-CXX-NEXT: [[ENTRY:.*:]] -// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , , } poison, [[TMP0]], 0 -// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP1]], [[TMP2]], 1 -// CHECK-CXX-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to -// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , , } [[TMP3]], [[TMP4]], 2 -// CHECK-CXX-NEXT: [[TMP6:%.*]] = bitcast [[OP_COERCE3]] to -// CHECK-CXX-NEXT: [[TMP7:%.*]] = insertvalue { , , , } [[TMP5]], [[TMP6]], 3 -// CHECK-CXX-NEXT: ret { , , , } [[TMP7]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = insertvalue { , , , } poison, [[OP_COERCE0]], 0 +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = insertvalue { , , , } [[TMP1]], [[OP_COERCE2]], 2 +// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP2]], [[OP_COERCE3]], 3 +// CHECK-CXX-NEXT: [[TMP4:%.*]] = extractvalue { , , , } [[TMP3]], 0 +// CHECK-CXX-NEXT: [[TMP5:%.*]] = bitcast [[TMP4]] to +// CHECK-CXX-NEXT: [[TMP6:%.*]] = insertvalue { , , , } poison, [[TMP5]], 0 +// CHECK-CXX-NEXT: [[TMP7:%.*]] = extractvalue { , , , } [[TMP3]], 1 +// CHECK-CXX-NEXT: [[TMP8:%.*]] = bitcast [[TMP7]] to +// CHECK-CXX-NEXT: [[TMP9:%.*]] = insertvalue { , , , } [[TMP6]], [[TMP8]], 1 +// CHECK-CXX-NEXT: [[TMP10:%.*]] = extractvalue { , , , } [[TMP3]], 2 +// CHECK-CXX-NEXT: [[TMP11:%.*]] = bitcast [[TMP10]] to +// CHECK-CXX-NEXT: [[TMP12:%.*]] = insertvalue { , , , } [[TMP9]], [[TMP11]], 2 +// CHECK-CXX-NEXT: [[TMP13:%.*]] = extractvalue { , , , } [[TMP3]], 3 +// CHECK-CXX-NEXT: [[TMP14:%.*]] = bitcast [[TMP13]] to +// CHECK-CXX-NEXT: [[TMP15:%.*]] = insertvalue { , , , } [[TMP12]], [[TMP14]], 3 +// CHECK-CXX-NEXT: ret { , , , } [[TMP15]] // svmfloat8x4_t test_svreinterpret_mf8_f32_x4(svfloat32x4_t op) STREAMING { return SVE_ACLE_FUNC(svreinterpret_mf8, _f32_x4)(op); @@ -1951,28 +2678,44 @@ svmfloat8x4_t test_svreinterpret_mf8_f32_x4(svfloat32x4_t op) STREAMING { // CHECK-LABEL: define dso_local { , , , } @test_svreinterpret_mf8_f64_x4( // CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]], [[OP_COERCE3:%.*]]) #[[ATTR0]] { // CHECK-NEXT: [[ENTRY:.*:]] -// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , , } poison, [[TMP0]], 0 -// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP1]], [[TMP2]], 1 -// CHECK-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to -// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , , } [[TMP3]], [[TMP4]], 2 -// CHECK-NEXT: [[TMP6:%.*]] = bitcast [[OP_COERCE3]] to -// CHECK-NEXT: [[TMP7:%.*]] = insertvalue { , , , } [[TMP5]], [[TMP6]], 3 -// CHECK-NEXT: ret { , , , } [[TMP7]] +// CHECK-NEXT: [[TMP0:%.*]] = insertvalue { , , , } poison, [[OP_COERCE0]], 0 +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-NEXT: [[TMP2:%.*]] = insertvalue { , , , } [[TMP1]], [[OP_COERCE2]], 2 +// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP2]], [[OP_COERCE3]], 3 +// CHECK-NEXT: [[TMP4:%.*]] = extractvalue { , , , } [[TMP3]], 0 +// CHECK-NEXT: [[TMP5:%.*]] = bitcast [[TMP4]] to +// CHECK-NEXT: [[TMP6:%.*]] = insertvalue { , , , } poison, [[TMP5]], 0 +// CHECK-NEXT: [[TMP7:%.*]] = extractvalue { , , , } [[TMP3]], 1 +// CHECK-NEXT: [[TMP8:%.*]] = bitcast [[TMP7]] to +// CHECK-NEXT: [[TMP9:%.*]] = insertvalue { , , , } [[TMP6]], [[TMP8]], 1 +// CHECK-NEXT: [[TMP10:%.*]] = extractvalue { , , , } [[TMP3]], 2 +// CHECK-NEXT: [[TMP11:%.*]] = bitcast [[TMP10]] to +// CHECK-NEXT: [[TMP12:%.*]] = insertvalue { , , , } [[TMP9]], [[TMP11]], 2 +// CHECK-NEXT: [[TMP13:%.*]] = extractvalue { , , , } [[TMP3]], 3 +// CHECK-NEXT: [[TMP14:%.*]] = bitcast [[TMP13]] to +// CHECK-NEXT: [[TMP15:%.*]] = insertvalue { , , , } [[TMP12]], [[TMP14]], 3 +// CHECK-NEXT: ret { , , , } [[TMP15]] // // CHECK-CXX-LABEL: define dso_local { , , , } @_Z29test_svreinterpret_mf8_f64_x413svfloat64x4_t( // CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]], [[OP_COERCE3:%.*]]) #[[ATTR0]] { // CHECK-CXX-NEXT: [[ENTRY:.*:]] -// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , , } poison, [[TMP0]], 0 -// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP1]], [[TMP2]], 1 -// CHECK-CXX-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to -// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , , } [[TMP3]], [[TMP4]], 2 -// CHECK-CXX-NEXT: [[TMP6:%.*]] = bitcast [[OP_COERCE3]] to -// CHECK-CXX-NEXT: [[TMP7:%.*]] = insertvalue { , , , } [[TMP5]], [[TMP6]], 3 -// CHECK-CXX-NEXT: ret { , , , } [[TMP7]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = insertvalue { , , , } poison, [[OP_COERCE0]], 0 +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = insertvalue { , , , } [[TMP1]], [[OP_COERCE2]], 2 +// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP2]], [[OP_COERCE3]], 3 +// CHECK-CXX-NEXT: [[TMP4:%.*]] = extractvalue { , , , } [[TMP3]], 0 +// CHECK-CXX-NEXT: [[TMP5:%.*]] = bitcast [[TMP4]] to +// CHECK-CXX-NEXT: [[TMP6:%.*]] = insertvalue { , , , } poison, [[TMP5]], 0 +// CHECK-CXX-NEXT: [[TMP7:%.*]] = extractvalue { , , , } [[TMP3]], 1 +// CHECK-CXX-NEXT: [[TMP8:%.*]] = bitcast [[TMP7]] to +// CHECK-CXX-NEXT: [[TMP9:%.*]] = insertvalue { , , , } [[TMP6]], [[TMP8]], 1 +// CHECK-CXX-NEXT: [[TMP10:%.*]] = extractvalue { , , , } [[TMP3]], 2 +// CHECK-CXX-NEXT: [[TMP11:%.*]] = bitcast [[TMP10]] to +// CHECK-CXX-NEXT: [[TMP12:%.*]] = insertvalue { , , , } [[TMP9]], [[TMP11]], 2 +// CHECK-CXX-NEXT: [[TMP13:%.*]] = extractvalue { , , , } [[TMP3]], 3 +// CHECK-CXX-NEXT: [[TMP14:%.*]] = bitcast [[TMP13]] to +// CHECK-CXX-NEXT: [[TMP15:%.*]] = insertvalue { , , , } [[TMP12]], [[TMP14]], 3 +// CHECK-CXX-NEXT: ret { , , , } [[TMP15]] // svmfloat8x4_t test_svreinterpret_mf8_f64_x4(svfloat64x4_t op) STREAMING { return SVE_ACLE_FUNC(svreinterpret_mf8, _f64_x4)(op); @@ -1981,28 +2724,44 @@ svmfloat8x4_t test_svreinterpret_mf8_f64_x4(svfloat64x4_t op) STREAMING { // CHECK-LABEL: define dso_local { , , , } @test_svreinterpret_s16_mf8_x4( // CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]], [[OP_COERCE3:%.*]]) #[[ATTR0]] { // CHECK-NEXT: [[ENTRY:.*:]] -// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , , } poison, [[TMP0]], 0 -// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP1]], [[TMP2]], 1 -// CHECK-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to -// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , , } [[TMP3]], [[TMP4]], 2 -// CHECK-NEXT: [[TMP6:%.*]] = bitcast [[OP_COERCE3]] to -// CHECK-NEXT: [[TMP7:%.*]] = insertvalue { , , , } [[TMP5]], [[TMP6]], 3 -// CHECK-NEXT: ret { , , , } [[TMP7]] +// CHECK-NEXT: [[TMP0:%.*]] = insertvalue { , , , } poison, [[OP_COERCE0]], 0 +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-NEXT: [[TMP2:%.*]] = insertvalue { , , , } [[TMP1]], [[OP_COERCE2]], 2 +// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP2]], [[OP_COERCE3]], 3 +// CHECK-NEXT: [[TMP4:%.*]] = extractvalue { , , , } [[TMP3]], 0 +// CHECK-NEXT: [[TMP5:%.*]] = bitcast [[TMP4]] to +// CHECK-NEXT: [[TMP6:%.*]] = insertvalue { , , , } poison, [[TMP5]], 0 +// CHECK-NEXT: [[TMP7:%.*]] = extractvalue { , , , } [[TMP3]], 1 +// CHECK-NEXT: [[TMP8:%.*]] = bitcast [[TMP7]] to +// CHECK-NEXT: [[TMP9:%.*]] = insertvalue { , , , } [[TMP6]], [[TMP8]], 1 +// CHECK-NEXT: [[TMP10:%.*]] = extractvalue { , , , } [[TMP3]], 2 +// CHECK-NEXT: [[TMP11:%.*]] = bitcast [[TMP10]] to +// CHECK-NEXT: [[TMP12:%.*]] = insertvalue { , , , } [[TMP9]], [[TMP11]], 2 +// CHECK-NEXT: [[TMP13:%.*]] = extractvalue { , , , } [[TMP3]], 3 +// CHECK-NEXT: [[TMP14:%.*]] = bitcast [[TMP13]] to +// CHECK-NEXT: [[TMP15:%.*]] = insertvalue { , , , } [[TMP12]], [[TMP14]], 3 +// CHECK-NEXT: ret { , , , } [[TMP15]] // // CHECK-CXX-LABEL: define dso_local { , , , } @_Z29test_svreinterpret_s16_mf8_x413svmfloat8x4_t( // CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]], [[OP_COERCE3:%.*]]) #[[ATTR0]] { // CHECK-CXX-NEXT: [[ENTRY:.*:]] -// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , , } poison, [[TMP0]], 0 -// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP1]], [[TMP2]], 1 -// CHECK-CXX-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to -// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , , } [[TMP3]], [[TMP4]], 2 -// CHECK-CXX-NEXT: [[TMP6:%.*]] = bitcast [[OP_COERCE3]] to -// CHECK-CXX-NEXT: [[TMP7:%.*]] = insertvalue { , , , } [[TMP5]], [[TMP6]], 3 -// CHECK-CXX-NEXT: ret { , , , } [[TMP7]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = insertvalue { , , , } poison, [[OP_COERCE0]], 0 +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = insertvalue { , , , } [[TMP1]], [[OP_COERCE2]], 2 +// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP2]], [[OP_COERCE3]], 3 +// CHECK-CXX-NEXT: [[TMP4:%.*]] = extractvalue { , , , } [[TMP3]], 0 +// CHECK-CXX-NEXT: [[TMP5:%.*]] = bitcast [[TMP4]] to +// CHECK-CXX-NEXT: [[TMP6:%.*]] = insertvalue { , , , } poison, [[TMP5]], 0 +// CHECK-CXX-NEXT: [[TMP7:%.*]] = extractvalue { , , , } [[TMP3]], 1 +// CHECK-CXX-NEXT: [[TMP8:%.*]] = bitcast [[TMP7]] to +// CHECK-CXX-NEXT: [[TMP9:%.*]] = insertvalue { , , , } [[TMP6]], [[TMP8]], 1 +// CHECK-CXX-NEXT: [[TMP10:%.*]] = extractvalue { , , , } [[TMP3]], 2 +// CHECK-CXX-NEXT: [[TMP11:%.*]] = bitcast [[TMP10]] to +// CHECK-CXX-NEXT: [[TMP12:%.*]] = insertvalue { , , , } [[TMP9]], [[TMP11]], 2 +// CHECK-CXX-NEXT: [[TMP13:%.*]] = extractvalue { , , , } [[TMP3]], 3 +// CHECK-CXX-NEXT: [[TMP14:%.*]] = bitcast [[TMP13]] to +// CHECK-CXX-NEXT: [[TMP15:%.*]] = insertvalue { , , , } [[TMP12]], [[TMP14]], 3 +// CHECK-CXX-NEXT: ret { , , , } [[TMP15]] // svint16x4_t test_svreinterpret_s16_mf8_x4(svmfloat8x4_t op) STREAMING { return SVE_ACLE_FUNC(svreinterpret_s16, _mf8_x4)(op); @@ -2011,28 +2770,44 @@ svint16x4_t test_svreinterpret_s16_mf8_x4(svmfloat8x4_t op) STREAMING { // CHECK-LABEL: define dso_local { , , , } @test_svreinterpret_u16_mf8_x4( // CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]], [[OP_COERCE3:%.*]]) #[[ATTR0]] { // CHECK-NEXT: [[ENTRY:.*:]] -// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , , } poison, [[TMP0]], 0 -// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP1]], [[TMP2]], 1 -// CHECK-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to -// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , , } [[TMP3]], [[TMP4]], 2 -// CHECK-NEXT: [[TMP6:%.*]] = bitcast [[OP_COERCE3]] to -// CHECK-NEXT: [[TMP7:%.*]] = insertvalue { , , , } [[TMP5]], [[TMP6]], 3 -// CHECK-NEXT: ret { , , , } [[TMP7]] +// CHECK-NEXT: [[TMP0:%.*]] = insertvalue { , , , } poison, [[OP_COERCE0]], 0 +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-NEXT: [[TMP2:%.*]] = insertvalue { , , , } [[TMP1]], [[OP_COERCE2]], 2 +// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP2]], [[OP_COERCE3]], 3 +// CHECK-NEXT: [[TMP4:%.*]] = extractvalue { , , , } [[TMP3]], 0 +// CHECK-NEXT: [[TMP5:%.*]] = bitcast [[TMP4]] to +// CHECK-NEXT: [[TMP6:%.*]] = insertvalue { , , , } poison, [[TMP5]], 0 +// CHECK-NEXT: [[TMP7:%.*]] = extractvalue { , , , } [[TMP3]], 1 +// CHECK-NEXT: [[TMP8:%.*]] = bitcast [[TMP7]] to +// CHECK-NEXT: [[TMP9:%.*]] = insertvalue { , , , } [[TMP6]], [[TMP8]], 1 +// CHECK-NEXT: [[TMP10:%.*]] = extractvalue { , , , } [[TMP3]], 2 +// CHECK-NEXT: [[TMP11:%.*]] = bitcast [[TMP10]] to +// CHECK-NEXT: [[TMP12:%.*]] = insertvalue { , , , } [[TMP9]], [[TMP11]], 2 +// CHECK-NEXT: [[TMP13:%.*]] = extractvalue { , , , } [[TMP3]], 3 +// CHECK-NEXT: [[TMP14:%.*]] = bitcast [[TMP13]] to +// CHECK-NEXT: [[TMP15:%.*]] = insertvalue { , , , } [[TMP12]], [[TMP14]], 3 +// CHECK-NEXT: ret { , , , } [[TMP15]] // // CHECK-CXX-LABEL: define dso_local { , , , } @_Z29test_svreinterpret_u16_mf8_x413svmfloat8x4_t( // CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]], [[OP_COERCE3:%.*]]) #[[ATTR0]] { // CHECK-CXX-NEXT: [[ENTRY:.*:]] -// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , , } poison, [[TMP0]], 0 -// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP1]], [[TMP2]], 1 -// CHECK-CXX-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to -// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , , } [[TMP3]], [[TMP4]], 2 -// CHECK-CXX-NEXT: [[TMP6:%.*]] = bitcast [[OP_COERCE3]] to -// CHECK-CXX-NEXT: [[TMP7:%.*]] = insertvalue { , , , } [[TMP5]], [[TMP6]], 3 -// CHECK-CXX-NEXT: ret { , , , } [[TMP7]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = insertvalue { , , , } poison, [[OP_COERCE0]], 0 +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = insertvalue { , , , } [[TMP1]], [[OP_COERCE2]], 2 +// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP2]], [[OP_COERCE3]], 3 +// CHECK-CXX-NEXT: [[TMP4:%.*]] = extractvalue { , , , } [[TMP3]], 0 +// CHECK-CXX-NEXT: [[TMP5:%.*]] = bitcast [[TMP4]] to +// CHECK-CXX-NEXT: [[TMP6:%.*]] = insertvalue { , , , } poison, [[TMP5]], 0 +// CHECK-CXX-NEXT: [[TMP7:%.*]] = extractvalue { , , , } [[TMP3]], 1 +// CHECK-CXX-NEXT: [[TMP8:%.*]] = bitcast [[TMP7]] to +// CHECK-CXX-NEXT: [[TMP9:%.*]] = insertvalue { , , , } [[TMP6]], [[TMP8]], 1 +// CHECK-CXX-NEXT: [[TMP10:%.*]] = extractvalue { , , , } [[TMP3]], 2 +// CHECK-CXX-NEXT: [[TMP11:%.*]] = bitcast [[TMP10]] to +// CHECK-CXX-NEXT: [[TMP12:%.*]] = insertvalue { , , , } [[TMP9]], [[TMP11]], 2 +// CHECK-CXX-NEXT: [[TMP13:%.*]] = extractvalue { , , , } [[TMP3]], 3 +// CHECK-CXX-NEXT: [[TMP14:%.*]] = bitcast [[TMP13]] to +// CHECK-CXX-NEXT: [[TMP15:%.*]] = insertvalue { , , , } [[TMP12]], [[TMP14]], 3 +// CHECK-CXX-NEXT: ret { , , , } [[TMP15]] // svuint16x4_t test_svreinterpret_u16_mf8_x4(svmfloat8x4_t op) STREAMING { return SVE_ACLE_FUNC(svreinterpret_u16, _mf8_x4)(op); @@ -2041,28 +2816,44 @@ svuint16x4_t test_svreinterpret_u16_mf8_x4(svmfloat8x4_t op) STREAMING { // CHECK-LABEL: define dso_local { , , , } @test_svreinterpret_s32_mf8_x4( // CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]], [[OP_COERCE3:%.*]]) #[[ATTR0]] { // CHECK-NEXT: [[ENTRY:.*:]] -// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , , } poison, [[TMP0]], 0 -// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP1]], [[TMP2]], 1 -// CHECK-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to -// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , , } [[TMP3]], [[TMP4]], 2 -// CHECK-NEXT: [[TMP6:%.*]] = bitcast [[OP_COERCE3]] to -// CHECK-NEXT: [[TMP7:%.*]] = insertvalue { , , , } [[TMP5]], [[TMP6]], 3 -// CHECK-NEXT: ret { , , , } [[TMP7]] +// CHECK-NEXT: [[TMP0:%.*]] = insertvalue { , , , } poison, [[OP_COERCE0]], 0 +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-NEXT: [[TMP2:%.*]] = insertvalue { , , , } [[TMP1]], [[OP_COERCE2]], 2 +// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP2]], [[OP_COERCE3]], 3 +// CHECK-NEXT: [[TMP4:%.*]] = extractvalue { , , , } [[TMP3]], 0 +// CHECK-NEXT: [[TMP5:%.*]] = bitcast [[TMP4]] to +// CHECK-NEXT: [[TMP6:%.*]] = insertvalue { , , , } poison, [[TMP5]], 0 +// CHECK-NEXT: [[TMP7:%.*]] = extractvalue { , , , } [[TMP3]], 1 +// CHECK-NEXT: [[TMP8:%.*]] = bitcast [[TMP7]] to +// CHECK-NEXT: [[TMP9:%.*]] = insertvalue { , , , } [[TMP6]], [[TMP8]], 1 +// CHECK-NEXT: [[TMP10:%.*]] = extractvalue { , , , } [[TMP3]], 2 +// CHECK-NEXT: [[TMP11:%.*]] = bitcast [[TMP10]] to +// CHECK-NEXT: [[TMP12:%.*]] = insertvalue { , , , } [[TMP9]], [[TMP11]], 2 +// CHECK-NEXT: [[TMP13:%.*]] = extractvalue { , , , } [[TMP3]], 3 +// CHECK-NEXT: [[TMP14:%.*]] = bitcast [[TMP13]] to +// CHECK-NEXT: [[TMP15:%.*]] = insertvalue { , , , } [[TMP12]], [[TMP14]], 3 +// CHECK-NEXT: ret { , , , } [[TMP15]] // // CHECK-CXX-LABEL: define dso_local { , , , } @_Z29test_svreinterpret_s32_mf8_x413svmfloat8x4_t( // CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]], [[OP_COERCE3:%.*]]) #[[ATTR0]] { // CHECK-CXX-NEXT: [[ENTRY:.*:]] -// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , , } poison, [[TMP0]], 0 -// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP1]], [[TMP2]], 1 -// CHECK-CXX-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to -// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , , } [[TMP3]], [[TMP4]], 2 -// CHECK-CXX-NEXT: [[TMP6:%.*]] = bitcast [[OP_COERCE3]] to -// CHECK-CXX-NEXT: [[TMP7:%.*]] = insertvalue { , , , } [[TMP5]], [[TMP6]], 3 -// CHECK-CXX-NEXT: ret { , , , } [[TMP7]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = insertvalue { , , , } poison, [[OP_COERCE0]], 0 +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = insertvalue { , , , } [[TMP1]], [[OP_COERCE2]], 2 +// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP2]], [[OP_COERCE3]], 3 +// CHECK-CXX-NEXT: [[TMP4:%.*]] = extractvalue { , , , } [[TMP3]], 0 +// CHECK-CXX-NEXT: [[TMP5:%.*]] = bitcast [[TMP4]] to +// CHECK-CXX-NEXT: [[TMP6:%.*]] = insertvalue { , , , } poison, [[TMP5]], 0 +// CHECK-CXX-NEXT: [[TMP7:%.*]] = extractvalue { , , , } [[TMP3]], 1 +// CHECK-CXX-NEXT: [[TMP8:%.*]] = bitcast [[TMP7]] to +// CHECK-CXX-NEXT: [[TMP9:%.*]] = insertvalue { , , , } [[TMP6]], [[TMP8]], 1 +// CHECK-CXX-NEXT: [[TMP10:%.*]] = extractvalue { , , , } [[TMP3]], 2 +// CHECK-CXX-NEXT: [[TMP11:%.*]] = bitcast [[TMP10]] to +// CHECK-CXX-NEXT: [[TMP12:%.*]] = insertvalue { , , , } [[TMP9]], [[TMP11]], 2 +// CHECK-CXX-NEXT: [[TMP13:%.*]] = extractvalue { , , , } [[TMP3]], 3 +// CHECK-CXX-NEXT: [[TMP14:%.*]] = bitcast [[TMP13]] to +// CHECK-CXX-NEXT: [[TMP15:%.*]] = insertvalue { , , , } [[TMP12]], [[TMP14]], 3 +// CHECK-CXX-NEXT: ret { , , , } [[TMP15]] // svint32x4_t test_svreinterpret_s32_mf8_x4(svmfloat8x4_t op) STREAMING { return SVE_ACLE_FUNC(svreinterpret_s32, _mf8_x4)(op); @@ -2071,28 +2862,44 @@ svint32x4_t test_svreinterpret_s32_mf8_x4(svmfloat8x4_t op) STREAMING { // CHECK-LABEL: define dso_local { , , , } @test_svreinterpret_u32_mf8_x4( // CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]], [[OP_COERCE3:%.*]]) #[[ATTR0]] { // CHECK-NEXT: [[ENTRY:.*:]] -// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , , } poison, [[TMP0]], 0 -// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP1]], [[TMP2]], 1 -// CHECK-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to -// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , , } [[TMP3]], [[TMP4]], 2 -// CHECK-NEXT: [[TMP6:%.*]] = bitcast [[OP_COERCE3]] to -// CHECK-NEXT: [[TMP7:%.*]] = insertvalue { , , , } [[TMP5]], [[TMP6]], 3 -// CHECK-NEXT: ret { , , , } [[TMP7]] +// CHECK-NEXT: [[TMP0:%.*]] = insertvalue { , , , } poison, [[OP_COERCE0]], 0 +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-NEXT: [[TMP2:%.*]] = insertvalue { , , , } [[TMP1]], [[OP_COERCE2]], 2 +// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP2]], [[OP_COERCE3]], 3 +// CHECK-NEXT: [[TMP4:%.*]] = extractvalue { , , , } [[TMP3]], 0 +// CHECK-NEXT: [[TMP5:%.*]] = bitcast [[TMP4]] to +// CHECK-NEXT: [[TMP6:%.*]] = insertvalue { , , , } poison, [[TMP5]], 0 +// CHECK-NEXT: [[TMP7:%.*]] = extractvalue { , , , } [[TMP3]], 1 +// CHECK-NEXT: [[TMP8:%.*]] = bitcast [[TMP7]] to +// CHECK-NEXT: [[TMP9:%.*]] = insertvalue { , , , } [[TMP6]], [[TMP8]], 1 +// CHECK-NEXT: [[TMP10:%.*]] = extractvalue { , , , } [[TMP3]], 2 +// CHECK-NEXT: [[TMP11:%.*]] = bitcast [[TMP10]] to +// CHECK-NEXT: [[TMP12:%.*]] = insertvalue { , , , } [[TMP9]], [[TMP11]], 2 +// CHECK-NEXT: [[TMP13:%.*]] = extractvalue { , , , } [[TMP3]], 3 +// CHECK-NEXT: [[TMP14:%.*]] = bitcast [[TMP13]] to +// CHECK-NEXT: [[TMP15:%.*]] = insertvalue { , , , } [[TMP12]], [[TMP14]], 3 +// CHECK-NEXT: ret { , , , } [[TMP15]] // // CHECK-CXX-LABEL: define dso_local { , , , } @_Z29test_svreinterpret_u32_mf8_x413svmfloat8x4_t( // CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]], [[OP_COERCE3:%.*]]) #[[ATTR0]] { // CHECK-CXX-NEXT: [[ENTRY:.*:]] -// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , , } poison, [[TMP0]], 0 -// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP1]], [[TMP2]], 1 -// CHECK-CXX-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to -// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , , } [[TMP3]], [[TMP4]], 2 -// CHECK-CXX-NEXT: [[TMP6:%.*]] = bitcast [[OP_COERCE3]] to -// CHECK-CXX-NEXT: [[TMP7:%.*]] = insertvalue { , , , } [[TMP5]], [[TMP6]], 3 -// CHECK-CXX-NEXT: ret { , , , } [[TMP7]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = insertvalue { , , , } poison, [[OP_COERCE0]], 0 +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = insertvalue { , , , } [[TMP1]], [[OP_COERCE2]], 2 +// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP2]], [[OP_COERCE3]], 3 +// CHECK-CXX-NEXT: [[TMP4:%.*]] = extractvalue { , , , } [[TMP3]], 0 +// CHECK-CXX-NEXT: [[TMP5:%.*]] = bitcast [[TMP4]] to +// CHECK-CXX-NEXT: [[TMP6:%.*]] = insertvalue { , , , } poison, [[TMP5]], 0 +// CHECK-CXX-NEXT: [[TMP7:%.*]] = extractvalue { , , , } [[TMP3]], 1 +// CHECK-CXX-NEXT: [[TMP8:%.*]] = bitcast [[TMP7]] to +// CHECK-CXX-NEXT: [[TMP9:%.*]] = insertvalue { , , , } [[TMP6]], [[TMP8]], 1 +// CHECK-CXX-NEXT: [[TMP10:%.*]] = extractvalue { , , , } [[TMP3]], 2 +// CHECK-CXX-NEXT: [[TMP11:%.*]] = bitcast [[TMP10]] to +// CHECK-CXX-NEXT: [[TMP12:%.*]] = insertvalue { , , , } [[TMP9]], [[TMP11]], 2 +// CHECK-CXX-NEXT: [[TMP13:%.*]] = extractvalue { , , , } [[TMP3]], 3 +// CHECK-CXX-NEXT: [[TMP14:%.*]] = bitcast [[TMP13]] to +// CHECK-CXX-NEXT: [[TMP15:%.*]] = insertvalue { , , , } [[TMP12]], [[TMP14]], 3 +// CHECK-CXX-NEXT: ret { , , , } [[TMP15]] // svuint32x4_t test_svreinterpret_u32_mf8_x4(svmfloat8x4_t op) STREAMING { return SVE_ACLE_FUNC(svreinterpret_u32, _mf8_x4)(op); @@ -2101,28 +2908,44 @@ svuint32x4_t test_svreinterpret_u32_mf8_x4(svmfloat8x4_t op) STREAMING { // CHECK-LABEL: define dso_local { , , , } @test_svreinterpret_s64_mf8_x4( // CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]], [[OP_COERCE3:%.*]]) #[[ATTR0]] { // CHECK-NEXT: [[ENTRY:.*:]] -// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , , } poison, [[TMP0]], 0 -// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP1]], [[TMP2]], 1 -// CHECK-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to -// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , , } [[TMP3]], [[TMP4]], 2 -// CHECK-NEXT: [[TMP6:%.*]] = bitcast [[OP_COERCE3]] to -// CHECK-NEXT: [[TMP7:%.*]] = insertvalue { , , , } [[TMP5]], [[TMP6]], 3 -// CHECK-NEXT: ret { , , , } [[TMP7]] +// CHECK-NEXT: [[TMP0:%.*]] = insertvalue { , , , } poison, [[OP_COERCE0]], 0 +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-NEXT: [[TMP2:%.*]] = insertvalue { , , , } [[TMP1]], [[OP_COERCE2]], 2 +// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP2]], [[OP_COERCE3]], 3 +// CHECK-NEXT: [[TMP4:%.*]] = extractvalue { , , , } [[TMP3]], 0 +// CHECK-NEXT: [[TMP5:%.*]] = bitcast [[TMP4]] to +// CHECK-NEXT: [[TMP6:%.*]] = insertvalue { , , , } poison, [[TMP5]], 0 +// CHECK-NEXT: [[TMP7:%.*]] = extractvalue { , , , } [[TMP3]], 1 +// CHECK-NEXT: [[TMP8:%.*]] = bitcast [[TMP7]] to +// CHECK-NEXT: [[TMP9:%.*]] = insertvalue { , , , } [[TMP6]], [[TMP8]], 1 +// CHECK-NEXT: [[TMP10:%.*]] = extractvalue { , , , } [[TMP3]], 2 +// CHECK-NEXT: [[TMP11:%.*]] = bitcast [[TMP10]] to +// CHECK-NEXT: [[TMP12:%.*]] = insertvalue { , , , } [[TMP9]], [[TMP11]], 2 +// CHECK-NEXT: [[TMP13:%.*]] = extractvalue { , , , } [[TMP3]], 3 +// CHECK-NEXT: [[TMP14:%.*]] = bitcast [[TMP13]] to +// CHECK-NEXT: [[TMP15:%.*]] = insertvalue { , , , } [[TMP12]], [[TMP14]], 3 +// CHECK-NEXT: ret { , , , } [[TMP15]] // // CHECK-CXX-LABEL: define dso_local { , , , } @_Z29test_svreinterpret_s64_mf8_x413svmfloat8x4_t( // CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]], [[OP_COERCE3:%.*]]) #[[ATTR0]] { // CHECK-CXX-NEXT: [[ENTRY:.*:]] -// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , , } poison, [[TMP0]], 0 -// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP1]], [[TMP2]], 1 -// CHECK-CXX-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to -// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , , } [[TMP3]], [[TMP4]], 2 -// CHECK-CXX-NEXT: [[TMP6:%.*]] = bitcast [[OP_COERCE3]] to -// CHECK-CXX-NEXT: [[TMP7:%.*]] = insertvalue { , , , } [[TMP5]], [[TMP6]], 3 -// CHECK-CXX-NEXT: ret { , , , } [[TMP7]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = insertvalue { , , , } poison, [[OP_COERCE0]], 0 +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = insertvalue { , , , } [[TMP1]], [[OP_COERCE2]], 2 +// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP2]], [[OP_COERCE3]], 3 +// CHECK-CXX-NEXT: [[TMP4:%.*]] = extractvalue { , , , } [[TMP3]], 0 +// CHECK-CXX-NEXT: [[TMP5:%.*]] = bitcast [[TMP4]] to +// CHECK-CXX-NEXT: [[TMP6:%.*]] = insertvalue { , , , } poison, [[TMP5]], 0 +// CHECK-CXX-NEXT: [[TMP7:%.*]] = extractvalue { , , , } [[TMP3]], 1 +// CHECK-CXX-NEXT: [[TMP8:%.*]] = bitcast [[TMP7]] to +// CHECK-CXX-NEXT: [[TMP9:%.*]] = insertvalue { , , , } [[TMP6]], [[TMP8]], 1 +// CHECK-CXX-NEXT: [[TMP10:%.*]] = extractvalue { , , , } [[TMP3]], 2 +// CHECK-CXX-NEXT: [[TMP11:%.*]] = bitcast [[TMP10]] to +// CHECK-CXX-NEXT: [[TMP12:%.*]] = insertvalue { , , , } [[TMP9]], [[TMP11]], 2 +// CHECK-CXX-NEXT: [[TMP13:%.*]] = extractvalue { , , , } [[TMP3]], 3 +// CHECK-CXX-NEXT: [[TMP14:%.*]] = bitcast [[TMP13]] to +// CHECK-CXX-NEXT: [[TMP15:%.*]] = insertvalue { , , , } [[TMP12]], [[TMP14]], 3 +// CHECK-CXX-NEXT: ret { , , , } [[TMP15]] // svint64x4_t test_svreinterpret_s64_mf8_x4(svmfloat8x4_t op) STREAMING { return SVE_ACLE_FUNC(svreinterpret_s64, _mf8_x4)(op); @@ -2131,28 +2954,44 @@ svint64x4_t test_svreinterpret_s64_mf8_x4(svmfloat8x4_t op) STREAMING { // CHECK-LABEL: define dso_local { , , , } @test_svreinterpret_u64_mf8_x4( // CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]], [[OP_COERCE3:%.*]]) #[[ATTR0]] { // CHECK-NEXT: [[ENTRY:.*:]] -// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , , } poison, [[TMP0]], 0 -// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP1]], [[TMP2]], 1 -// CHECK-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to -// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , , } [[TMP3]], [[TMP4]], 2 -// CHECK-NEXT: [[TMP6:%.*]] = bitcast [[OP_COERCE3]] to -// CHECK-NEXT: [[TMP7:%.*]] = insertvalue { , , , } [[TMP5]], [[TMP6]], 3 -// CHECK-NEXT: ret { , , , } [[TMP7]] +// CHECK-NEXT: [[TMP0:%.*]] = insertvalue { , , , } poison, [[OP_COERCE0]], 0 +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-NEXT: [[TMP2:%.*]] = insertvalue { , , , } [[TMP1]], [[OP_COERCE2]], 2 +// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP2]], [[OP_COERCE3]], 3 +// CHECK-NEXT: [[TMP4:%.*]] = extractvalue { , , , } [[TMP3]], 0 +// CHECK-NEXT: [[TMP5:%.*]] = bitcast [[TMP4]] to +// CHECK-NEXT: [[TMP6:%.*]] = insertvalue { , , , } poison, [[TMP5]], 0 +// CHECK-NEXT: [[TMP7:%.*]] = extractvalue { , , , } [[TMP3]], 1 +// CHECK-NEXT: [[TMP8:%.*]] = bitcast [[TMP7]] to +// CHECK-NEXT: [[TMP9:%.*]] = insertvalue { , , , } [[TMP6]], [[TMP8]], 1 +// CHECK-NEXT: [[TMP10:%.*]] = extractvalue { , , , } [[TMP3]], 2 +// CHECK-NEXT: [[TMP11:%.*]] = bitcast [[TMP10]] to +// CHECK-NEXT: [[TMP12:%.*]] = insertvalue { , , , } [[TMP9]], [[TMP11]], 2 +// CHECK-NEXT: [[TMP13:%.*]] = extractvalue { , , , } [[TMP3]], 3 +// CHECK-NEXT: [[TMP14:%.*]] = bitcast [[TMP13]] to +// CHECK-NEXT: [[TMP15:%.*]] = insertvalue { , , , } [[TMP12]], [[TMP14]], 3 +// CHECK-NEXT: ret { , , , } [[TMP15]] // // CHECK-CXX-LABEL: define dso_local { , , , } @_Z29test_svreinterpret_u64_mf8_x413svmfloat8x4_t( // CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]], [[OP_COERCE3:%.*]]) #[[ATTR0]] { // CHECK-CXX-NEXT: [[ENTRY:.*:]] -// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , , } poison, [[TMP0]], 0 -// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP1]], [[TMP2]], 1 -// CHECK-CXX-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to -// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , , } [[TMP3]], [[TMP4]], 2 -// CHECK-CXX-NEXT: [[TMP6:%.*]] = bitcast [[OP_COERCE3]] to -// CHECK-CXX-NEXT: [[TMP7:%.*]] = insertvalue { , , , } [[TMP5]], [[TMP6]], 3 -// CHECK-CXX-NEXT: ret { , , , } [[TMP7]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = insertvalue { , , , } poison, [[OP_COERCE0]], 0 +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = insertvalue { , , , } [[TMP1]], [[OP_COERCE2]], 2 +// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP2]], [[OP_COERCE3]], 3 +// CHECK-CXX-NEXT: [[TMP4:%.*]] = extractvalue { , , , } [[TMP3]], 0 +// CHECK-CXX-NEXT: [[TMP5:%.*]] = bitcast [[TMP4]] to +// CHECK-CXX-NEXT: [[TMP6:%.*]] = insertvalue { , , , } poison, [[TMP5]], 0 +// CHECK-CXX-NEXT: [[TMP7:%.*]] = extractvalue { , , , } [[TMP3]], 1 +// CHECK-CXX-NEXT: [[TMP8:%.*]] = bitcast [[TMP7]] to +// CHECK-CXX-NEXT: [[TMP9:%.*]] = insertvalue { , , , } [[TMP6]], [[TMP8]], 1 +// CHECK-CXX-NEXT: [[TMP10:%.*]] = extractvalue { , , , } [[TMP3]], 2 +// CHECK-CXX-NEXT: [[TMP11:%.*]] = bitcast [[TMP10]] to +// CHECK-CXX-NEXT: [[TMP12:%.*]] = insertvalue { , , , } [[TMP9]], [[TMP11]], 2 +// CHECK-CXX-NEXT: [[TMP13:%.*]] = extractvalue { , , , } [[TMP3]], 3 +// CHECK-CXX-NEXT: [[TMP14:%.*]] = bitcast [[TMP13]] to +// CHECK-CXX-NEXT: [[TMP15:%.*]] = insertvalue { , , , } [[TMP12]], [[TMP14]], 3 +// CHECK-CXX-NEXT: ret { , , , } [[TMP15]] // svuint64x4_t test_svreinterpret_u64_mf8_x4(svmfloat8x4_t op) STREAMING { return SVE_ACLE_FUNC(svreinterpret_u64, _mf8_x4)(op); @@ -2161,28 +3000,44 @@ svuint64x4_t test_svreinterpret_u64_mf8_x4(svmfloat8x4_t op) STREAMING { // CHECK-LABEL: define dso_local { , , , } @test_svreinterpret_f16_mf8_x4( // CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]], [[OP_COERCE3:%.*]]) #[[ATTR0]] { // CHECK-NEXT: [[ENTRY:.*:]] -// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , , } poison, [[TMP0]], 0 -// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP1]], [[TMP2]], 1 -// CHECK-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to -// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , , } [[TMP3]], [[TMP4]], 2 -// CHECK-NEXT: [[TMP6:%.*]] = bitcast [[OP_COERCE3]] to -// CHECK-NEXT: [[TMP7:%.*]] = insertvalue { , , , } [[TMP5]], [[TMP6]], 3 -// CHECK-NEXT: ret { , , , } [[TMP7]] +// CHECK-NEXT: [[TMP0:%.*]] = insertvalue { , , , } poison, [[OP_COERCE0]], 0 +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-NEXT: [[TMP2:%.*]] = insertvalue { , , , } [[TMP1]], [[OP_COERCE2]], 2 +// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP2]], [[OP_COERCE3]], 3 +// CHECK-NEXT: [[TMP4:%.*]] = extractvalue { , , , } [[TMP3]], 0 +// CHECK-NEXT: [[TMP5:%.*]] = bitcast [[TMP4]] to +// CHECK-NEXT: [[TMP6:%.*]] = insertvalue { , , , } poison, [[TMP5]], 0 +// CHECK-NEXT: [[TMP7:%.*]] = extractvalue { , , , } [[TMP3]], 1 +// CHECK-NEXT: [[TMP8:%.*]] = bitcast [[TMP7]] to +// CHECK-NEXT: [[TMP9:%.*]] = insertvalue { , , , } [[TMP6]], [[TMP8]], 1 +// CHECK-NEXT: [[TMP10:%.*]] = extractvalue { , , , } [[TMP3]], 2 +// CHECK-NEXT: [[TMP11:%.*]] = bitcast [[TMP10]] to +// CHECK-NEXT: [[TMP12:%.*]] = insertvalue { , , , } [[TMP9]], [[TMP11]], 2 +// CHECK-NEXT: [[TMP13:%.*]] = extractvalue { , , , } [[TMP3]], 3 +// CHECK-NEXT: [[TMP14:%.*]] = bitcast [[TMP13]] to +// CHECK-NEXT: [[TMP15:%.*]] = insertvalue { , , , } [[TMP12]], [[TMP14]], 3 +// CHECK-NEXT: ret { , , , } [[TMP15]] // // CHECK-CXX-LABEL: define dso_local { , , , } @_Z29test_svreinterpret_f16_mf8_x413svmfloat8x4_t( // CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]], [[OP_COERCE3:%.*]]) #[[ATTR0]] { // CHECK-CXX-NEXT: [[ENTRY:.*:]] -// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , , } poison, [[TMP0]], 0 -// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP1]], [[TMP2]], 1 -// CHECK-CXX-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to -// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , , } [[TMP3]], [[TMP4]], 2 -// CHECK-CXX-NEXT: [[TMP6:%.*]] = bitcast [[OP_COERCE3]] to -// CHECK-CXX-NEXT: [[TMP7:%.*]] = insertvalue { , , , } [[TMP5]], [[TMP6]], 3 -// CHECK-CXX-NEXT: ret { , , , } [[TMP7]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = insertvalue { , , , } poison, [[OP_COERCE0]], 0 +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = insertvalue { , , , } [[TMP1]], [[OP_COERCE2]], 2 +// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP2]], [[OP_COERCE3]], 3 +// CHECK-CXX-NEXT: [[TMP4:%.*]] = extractvalue { , , , } [[TMP3]], 0 +// CHECK-CXX-NEXT: [[TMP5:%.*]] = bitcast [[TMP4]] to +// CHECK-CXX-NEXT: [[TMP6:%.*]] = insertvalue { , , , } poison, [[TMP5]], 0 +// CHECK-CXX-NEXT: [[TMP7:%.*]] = extractvalue { , , , } [[TMP3]], 1 +// CHECK-CXX-NEXT: [[TMP8:%.*]] = bitcast [[TMP7]] to +// CHECK-CXX-NEXT: [[TMP9:%.*]] = insertvalue { , , , } [[TMP6]], [[TMP8]], 1 +// CHECK-CXX-NEXT: [[TMP10:%.*]] = extractvalue { , , , } [[TMP3]], 2 +// CHECK-CXX-NEXT: [[TMP11:%.*]] = bitcast [[TMP10]] to +// CHECK-CXX-NEXT: [[TMP12:%.*]] = insertvalue { , , , } [[TMP9]], [[TMP11]], 2 +// CHECK-CXX-NEXT: [[TMP13:%.*]] = extractvalue { , , , } [[TMP3]], 3 +// CHECK-CXX-NEXT: [[TMP14:%.*]] = bitcast [[TMP13]] to +// CHECK-CXX-NEXT: [[TMP15:%.*]] = insertvalue { , , , } [[TMP12]], [[TMP14]], 3 +// CHECK-CXX-NEXT: ret { , , , } [[TMP15]] // svfloat16x4_t test_svreinterpret_f16_mf8_x4(svmfloat8x4_t op) STREAMING { return SVE_ACLE_FUNC(svreinterpret_f16, _mf8_x4)(op); @@ -2191,28 +3046,44 @@ svfloat16x4_t test_svreinterpret_f16_mf8_x4(svmfloat8x4_t op) STREAMING { // CHECK-LABEL: define dso_local { , , , } @test_svreinterpret_bf16_mf8_x4( // CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]], [[OP_COERCE3:%.*]]) #[[ATTR0]] { // CHECK-NEXT: [[ENTRY:.*:]] -// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , , } poison, [[TMP0]], 0 -// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP1]], [[TMP2]], 1 -// CHECK-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to -// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , , } [[TMP3]], [[TMP4]], 2 -// CHECK-NEXT: [[TMP6:%.*]] = bitcast [[OP_COERCE3]] to -// CHECK-NEXT: [[TMP7:%.*]] = insertvalue { , , , } [[TMP5]], [[TMP6]], 3 -// CHECK-NEXT: ret { , , , } [[TMP7]] +// CHECK-NEXT: [[TMP0:%.*]] = insertvalue { , , , } poison, [[OP_COERCE0]], 0 +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-NEXT: [[TMP2:%.*]] = insertvalue { , , , } [[TMP1]], [[OP_COERCE2]], 2 +// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP2]], [[OP_COERCE3]], 3 +// CHECK-NEXT: [[TMP4:%.*]] = extractvalue { , , , } [[TMP3]], 0 +// CHECK-NEXT: [[TMP5:%.*]] = bitcast [[TMP4]] to +// CHECK-NEXT: [[TMP6:%.*]] = insertvalue { , , , } poison, [[TMP5]], 0 +// CHECK-NEXT: [[TMP7:%.*]] = extractvalue { , , , } [[TMP3]], 1 +// CHECK-NEXT: [[TMP8:%.*]] = bitcast [[TMP7]] to +// CHECK-NEXT: [[TMP9:%.*]] = insertvalue { , , , } [[TMP6]], [[TMP8]], 1 +// CHECK-NEXT: [[TMP10:%.*]] = extractvalue { , , , } [[TMP3]], 2 +// CHECK-NEXT: [[TMP11:%.*]] = bitcast [[TMP10]] to +// CHECK-NEXT: [[TMP12:%.*]] = insertvalue { , , , } [[TMP9]], [[TMP11]], 2 +// CHECK-NEXT: [[TMP13:%.*]] = extractvalue { , , , } [[TMP3]], 3 +// CHECK-NEXT: [[TMP14:%.*]] = bitcast [[TMP13]] to +// CHECK-NEXT: [[TMP15:%.*]] = insertvalue { , , , } [[TMP12]], [[TMP14]], 3 +// CHECK-NEXT: ret { , , , } [[TMP15]] // // CHECK-CXX-LABEL: define dso_local { , , , } @_Z30test_svreinterpret_bf16_mf8_x413svmfloat8x4_t( // CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]], [[OP_COERCE3:%.*]]) #[[ATTR0]] { // CHECK-CXX-NEXT: [[ENTRY:.*:]] -// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , , } poison, [[TMP0]], 0 -// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP1]], [[TMP2]], 1 -// CHECK-CXX-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to -// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , , } [[TMP3]], [[TMP4]], 2 -// CHECK-CXX-NEXT: [[TMP6:%.*]] = bitcast [[OP_COERCE3]] to -// CHECK-CXX-NEXT: [[TMP7:%.*]] = insertvalue { , , , } [[TMP5]], [[TMP6]], 3 -// CHECK-CXX-NEXT: ret { , , , } [[TMP7]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = insertvalue { , , , } poison, [[OP_COERCE0]], 0 +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = insertvalue { , , , } [[TMP1]], [[OP_COERCE2]], 2 +// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP2]], [[OP_COERCE3]], 3 +// CHECK-CXX-NEXT: [[TMP4:%.*]] = extractvalue { , , , } [[TMP3]], 0 +// CHECK-CXX-NEXT: [[TMP5:%.*]] = bitcast [[TMP4]] to +// CHECK-CXX-NEXT: [[TMP6:%.*]] = insertvalue { , , , } poison, [[TMP5]], 0 +// CHECK-CXX-NEXT: [[TMP7:%.*]] = extractvalue { , , , } [[TMP3]], 1 +// CHECK-CXX-NEXT: [[TMP8:%.*]] = bitcast [[TMP7]] to +// CHECK-CXX-NEXT: [[TMP9:%.*]] = insertvalue { , , , } [[TMP6]], [[TMP8]], 1 +// CHECK-CXX-NEXT: [[TMP10:%.*]] = extractvalue { , , , } [[TMP3]], 2 +// CHECK-CXX-NEXT: [[TMP11:%.*]] = bitcast [[TMP10]] to +// CHECK-CXX-NEXT: [[TMP12:%.*]] = insertvalue { , , , } [[TMP9]], [[TMP11]], 2 +// CHECK-CXX-NEXT: [[TMP13:%.*]] = extractvalue { , , , } [[TMP3]], 3 +// CHECK-CXX-NEXT: [[TMP14:%.*]] = bitcast [[TMP13]] to +// CHECK-CXX-NEXT: [[TMP15:%.*]] = insertvalue { , , , } [[TMP12]], [[TMP14]], 3 +// CHECK-CXX-NEXT: ret { , , , } [[TMP15]] // svbfloat16x4_t test_svreinterpret_bf16_mf8_x4(svmfloat8x4_t op) STREAMING { return SVE_ACLE_FUNC(svreinterpret_bf16, _mf8_x4)(op); @@ -2221,28 +3092,44 @@ svbfloat16x4_t test_svreinterpret_bf16_mf8_x4(svmfloat8x4_t op) STREAMING { // CHECK-LABEL: define dso_local { , , , } @test_svreinterpret_f32_mf8_x4( // CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]], [[OP_COERCE3:%.*]]) #[[ATTR0]] { // CHECK-NEXT: [[ENTRY:.*:]] -// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , , } poison, [[TMP0]], 0 -// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP1]], [[TMP2]], 1 -// CHECK-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to -// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , , } [[TMP3]], [[TMP4]], 2 -// CHECK-NEXT: [[TMP6:%.*]] = bitcast [[OP_COERCE3]] to -// CHECK-NEXT: [[TMP7:%.*]] = insertvalue { , , , } [[TMP5]], [[TMP6]], 3 -// CHECK-NEXT: ret { , , , } [[TMP7]] +// CHECK-NEXT: [[TMP0:%.*]] = insertvalue { , , , } poison, [[OP_COERCE0]], 0 +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-NEXT: [[TMP2:%.*]] = insertvalue { , , , } [[TMP1]], [[OP_COERCE2]], 2 +// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP2]], [[OP_COERCE3]], 3 +// CHECK-NEXT: [[TMP4:%.*]] = extractvalue { , , , } [[TMP3]], 0 +// CHECK-NEXT: [[TMP5:%.*]] = bitcast [[TMP4]] to +// CHECK-NEXT: [[TMP6:%.*]] = insertvalue { , , , } poison, [[TMP5]], 0 +// CHECK-NEXT: [[TMP7:%.*]] = extractvalue { , , , } [[TMP3]], 1 +// CHECK-NEXT: [[TMP8:%.*]] = bitcast [[TMP7]] to +// CHECK-NEXT: [[TMP9:%.*]] = insertvalue { , , , } [[TMP6]], [[TMP8]], 1 +// CHECK-NEXT: [[TMP10:%.*]] = extractvalue { , , , } [[TMP3]], 2 +// CHECK-NEXT: [[TMP11:%.*]] = bitcast [[TMP10]] to +// CHECK-NEXT: [[TMP12:%.*]] = insertvalue { , , , } [[TMP9]], [[TMP11]], 2 +// CHECK-NEXT: [[TMP13:%.*]] = extractvalue { , , , } [[TMP3]], 3 +// CHECK-NEXT: [[TMP14:%.*]] = bitcast [[TMP13]] to +// CHECK-NEXT: [[TMP15:%.*]] = insertvalue { , , , } [[TMP12]], [[TMP14]], 3 +// CHECK-NEXT: ret { , , , } [[TMP15]] // // CHECK-CXX-LABEL: define dso_local { , , , } @_Z29test_svreinterpret_f32_mf8_x413svmfloat8x4_t( // CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]], [[OP_COERCE3:%.*]]) #[[ATTR0]] { // CHECK-CXX-NEXT: [[ENTRY:.*:]] -// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , , } poison, [[TMP0]], 0 -// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP1]], [[TMP2]], 1 -// CHECK-CXX-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to -// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , , } [[TMP3]], [[TMP4]], 2 -// CHECK-CXX-NEXT: [[TMP6:%.*]] = bitcast [[OP_COERCE3]] to -// CHECK-CXX-NEXT: [[TMP7:%.*]] = insertvalue { , , , } [[TMP5]], [[TMP6]], 3 -// CHECK-CXX-NEXT: ret { , , , } [[TMP7]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = insertvalue { , , , } poison, [[OP_COERCE0]], 0 +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = insertvalue { , , , } [[TMP1]], [[OP_COERCE2]], 2 +// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP2]], [[OP_COERCE3]], 3 +// CHECK-CXX-NEXT: [[TMP4:%.*]] = extractvalue { , , , } [[TMP3]], 0 +// CHECK-CXX-NEXT: [[TMP5:%.*]] = bitcast [[TMP4]] to +// CHECK-CXX-NEXT: [[TMP6:%.*]] = insertvalue { , , , } poison, [[TMP5]], 0 +// CHECK-CXX-NEXT: [[TMP7:%.*]] = extractvalue { , , , } [[TMP3]], 1 +// CHECK-CXX-NEXT: [[TMP8:%.*]] = bitcast [[TMP7]] to +// CHECK-CXX-NEXT: [[TMP9:%.*]] = insertvalue { , , , } [[TMP6]], [[TMP8]], 1 +// CHECK-CXX-NEXT: [[TMP10:%.*]] = extractvalue { , , , } [[TMP3]], 2 +// CHECK-CXX-NEXT: [[TMP11:%.*]] = bitcast [[TMP10]] to +// CHECK-CXX-NEXT: [[TMP12:%.*]] = insertvalue { , , , } [[TMP9]], [[TMP11]], 2 +// CHECK-CXX-NEXT: [[TMP13:%.*]] = extractvalue { , , , } [[TMP3]], 3 +// CHECK-CXX-NEXT: [[TMP14:%.*]] = bitcast [[TMP13]] to +// CHECK-CXX-NEXT: [[TMP15:%.*]] = insertvalue { , , , } [[TMP12]], [[TMP14]], 3 +// CHECK-CXX-NEXT: ret { , , , } [[TMP15]] // svfloat32x4_t test_svreinterpret_f32_mf8_x4(svmfloat8x4_t op) STREAMING { return SVE_ACLE_FUNC(svreinterpret_f32, _mf8_x4)(op); @@ -2251,28 +3138,44 @@ svfloat32x4_t test_svreinterpret_f32_mf8_x4(svmfloat8x4_t op) STREAMING { // CHECK-LABEL: define dso_local { , , , } @test_svreinterpret_f64_mf8_x4( // CHECK-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]], [[OP_COERCE3:%.*]]) #[[ATTR0]] { // CHECK-NEXT: [[ENTRY:.*:]] -// CHECK-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , , } poison, [[TMP0]], 0 -// CHECK-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP1]], [[TMP2]], 1 -// CHECK-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to -// CHECK-NEXT: [[TMP5:%.*]] = insertvalue { , , , } [[TMP3]], [[TMP4]], 2 -// CHECK-NEXT: [[TMP6:%.*]] = bitcast [[OP_COERCE3]] to -// CHECK-NEXT: [[TMP7:%.*]] = insertvalue { , , , } [[TMP5]], [[TMP6]], 3 -// CHECK-NEXT: ret { , , , } [[TMP7]] +// CHECK-NEXT: [[TMP0:%.*]] = insertvalue { , , , } poison, [[OP_COERCE0]], 0 +// CHECK-NEXT: [[TMP1:%.*]] = insertvalue { , , , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-NEXT: [[TMP2:%.*]] = insertvalue { , , , } [[TMP1]], [[OP_COERCE2]], 2 +// CHECK-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP2]], [[OP_COERCE3]], 3 +// CHECK-NEXT: [[TMP4:%.*]] = extractvalue { , , , } [[TMP3]], 0 +// CHECK-NEXT: [[TMP5:%.*]] = bitcast [[TMP4]] to +// CHECK-NEXT: [[TMP6:%.*]] = insertvalue { , , , } poison, [[TMP5]], 0 +// CHECK-NEXT: [[TMP7:%.*]] = extractvalue { , , , } [[TMP3]], 1 +// CHECK-NEXT: [[TMP8:%.*]] = bitcast [[TMP7]] to +// CHECK-NEXT: [[TMP9:%.*]] = insertvalue { , , , } [[TMP6]], [[TMP8]], 1 +// CHECK-NEXT: [[TMP10:%.*]] = extractvalue { , , , } [[TMP3]], 2 +// CHECK-NEXT: [[TMP11:%.*]] = bitcast [[TMP10]] to +// CHECK-NEXT: [[TMP12:%.*]] = insertvalue { , , , } [[TMP9]], [[TMP11]], 2 +// CHECK-NEXT: [[TMP13:%.*]] = extractvalue { , , , } [[TMP3]], 3 +// CHECK-NEXT: [[TMP14:%.*]] = bitcast [[TMP13]] to +// CHECK-NEXT: [[TMP15:%.*]] = insertvalue { , , , } [[TMP12]], [[TMP14]], 3 +// CHECK-NEXT: ret { , , , } [[TMP15]] // // CHECK-CXX-LABEL: define dso_local { , , , } @_Z29test_svreinterpret_f64_mf8_x413svmfloat8x4_t( // CHECK-CXX-SAME: [[OP_COERCE0:%.*]], [[OP_COERCE1:%.*]], [[OP_COERCE2:%.*]], [[OP_COERCE3:%.*]]) #[[ATTR0]] { // CHECK-CXX-NEXT: [[ENTRY:.*:]] -// CHECK-CXX-NEXT: [[TMP0:%.*]] = bitcast [[OP_COERCE0]] to -// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , , } poison, [[TMP0]], 0 -// CHECK-CXX-NEXT: [[TMP2:%.*]] = bitcast [[OP_COERCE1]] to -// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP1]], [[TMP2]], 1 -// CHECK-CXX-NEXT: [[TMP4:%.*]] = bitcast [[OP_COERCE2]] to -// CHECK-CXX-NEXT: [[TMP5:%.*]] = insertvalue { , , , } [[TMP3]], [[TMP4]], 2 -// CHECK-CXX-NEXT: [[TMP6:%.*]] = bitcast [[OP_COERCE3]] to -// CHECK-CXX-NEXT: [[TMP7:%.*]] = insertvalue { , , , } [[TMP5]], [[TMP6]], 3 -// CHECK-CXX-NEXT: ret { , , , } [[TMP7]] +// CHECK-CXX-NEXT: [[TMP0:%.*]] = insertvalue { , , , } poison, [[OP_COERCE0]], 0 +// CHECK-CXX-NEXT: [[TMP1:%.*]] = insertvalue { , , , } [[TMP0]], [[OP_COERCE1]], 1 +// CHECK-CXX-NEXT: [[TMP2:%.*]] = insertvalue { , , , } [[TMP1]], [[OP_COERCE2]], 2 +// CHECK-CXX-NEXT: [[TMP3:%.*]] = insertvalue { , , , } [[TMP2]], [[OP_COERCE3]], 3 +// CHECK-CXX-NEXT: [[TMP4:%.*]] = extractvalue { , , , } [[TMP3]], 0 +// CHECK-CXX-NEXT: [[TMP5:%.*]] = bitcast [[TMP4]] to +// CHECK-CXX-NEXT: [[TMP6:%.*]] = insertvalue { , , , } poison, [[TMP5]], 0 +// CHECK-CXX-NEXT: [[TMP7:%.*]] = extractvalue { , , , } [[TMP3]], 1 +// CHECK-CXX-NEXT: [[TMP8:%.*]] = bitcast [[TMP7]] to +// CHECK-CXX-NEXT: [[TMP9:%.*]] = insertvalue { , , , } [[TMP6]], [[TMP8]], 1 +// CHECK-CXX-NEXT: [[TMP10:%.*]] = extractvalue { , , , } [[TMP3]], 2 +// CHECK-CXX-NEXT: [[TMP11:%.*]] = bitcast [[TMP10]] to +// CHECK-CXX-NEXT: [[TMP12:%.*]] = insertvalue { , , , } [[TMP9]], [[TMP11]], 2 +// CHECK-CXX-NEXT: [[TMP13:%.*]] = extractvalue { , , , } [[TMP3]], 3 +// CHECK-CXX-NEXT: [[TMP14:%.*]] = bitcast [[TMP13]] to +// CHECK-CXX-NEXT: [[TMP15:%.*]] = insertvalue { , , , } [[TMP12]], [[TMP14]], 3 +// CHECK-CXX-NEXT: ret { , , , } [[TMP15]] // svfloat64x4_t test_svreinterpret_f64_mf8_x4(svmfloat8x4_t op) STREAMING { return SVE_ACLE_FUNC(svreinterpret_f64, _mf8_x4)(op);