11// NOTE: Assertions have been autogenerated by utils/update_cc_test_checks.py
22// REQUIRES: aarch64-registered-target
33// RUN: %clang_cc1 -triple aarch64 -target-feature +sve -disable-O0-optnone -Werror -Wall -emit-llvm -o - %s | opt -S -passes=mem2reg,tailcallelim | FileCheck %s
4+ // RUN: %clang_cc1 -triple aarch64 -target-feature +ssve-fexpa -target-feature +sme2 -target-feature +sme -disable-O0-optnone -Werror -Wall -emit-llvm -o - %s | opt -S -passes=mem2reg,tailcallelim | FileCheck %s
45// RUN: %clang_cc1 -triple aarch64 -target-feature +sve -disable-O0-optnone -Werror -Wall -emit-llvm -o - -x c++ %s | opt -S -passes=mem2reg,tailcallelim | FileCheck %s -check-prefix=CPP-CHECK
56// RUN: %clang_cc1 -DSVE_OVERLOADED_FORMS -triple aarch64 -target-feature +sve -disable-O0-optnone -Werror -Wall -emit-llvm -o - %s | opt -S -passes=mem2reg,tailcallelim | FileCheck %s
67// RUN: %clang_cc1 -DSVE_OVERLOADED_FORMS -triple aarch64 -target-feature +sve -disable-O0-optnone -Werror -Wall -emit-llvm -o - -x c++ %s | opt -S -passes=mem2reg,tailcallelim | FileCheck %s -check-prefix=CPP-CHECK
78// RUN: %clang_cc1 -triple aarch64 -target-feature +sve -S -disable-O0-optnone -Werror -Wall -o /dev/null %s
9+ // RUN: %clang_cc1 -triple aarch64 -target-feature +ssve-fexpa -target-feature +sme2 -target-feature +sme -S -disable-O0-optnone -Werror -Wall -o /dev/null %s
810#include <arm_sve.h>
911
1012#ifdef SVE_OVERLOADED_FORMS
1416#define SVE_ACLE_FUNC (A1 ,A2 ,A3 ,A4 ) A1##A2##A3##A4
1517#endif
1618
19+ #ifdef __ARM_FEATURE_SME
20+ #define STREAMING __arm_streaming
21+ #else
22+ #define STREAMING
23+ #endif
24+
1725// CHECK-LABEL: @test_svexpa_f16(
1826// CHECK-NEXT: entry:
1927// CHECK-NEXT: [[TMP0:%.*]] = tail call <vscale x 8 x half> @llvm.aarch64.sve.fexpa.x.nxv8f16(<vscale x 8 x i16> [[OP:%.*]])
2432// CPP-CHECK-NEXT: [[TMP0:%.*]] = tail call <vscale x 8 x half> @llvm.aarch64.sve.fexpa.x.nxv8f16(<vscale x 8 x i16> [[OP:%.*]])
2533// CPP-CHECK-NEXT: ret <vscale x 8 x half> [[TMP0]]
2634//
27- svfloat16_t test_svexpa_f16 (svuint16_t op )
35+ svfloat16_t test_svexpa_f16 (svuint16_t op ) STREAMING
2836{
2937 return SVE_ACLE_FUNC (svexpa ,_f16 ,,)(op );
3038}
@@ -39,7 +47,7 @@ svfloat16_t test_svexpa_f16(svuint16_t op)
3947// CPP-CHECK-NEXT: [[TMP0:%.*]] = tail call <vscale x 4 x float> @llvm.aarch64.sve.fexpa.x.nxv4f32(<vscale x 4 x i32> [[OP:%.*]])
4048// CPP-CHECK-NEXT: ret <vscale x 4 x float> [[TMP0]]
4149//
42- svfloat32_t test_svexpa_f32 (svuint32_t op )
50+ svfloat32_t test_svexpa_f32 (svuint32_t op ) STREAMING
4351{
4452 return SVE_ACLE_FUNC (svexpa ,_f32 ,,)(op );
4553}
@@ -54,7 +62,7 @@ svfloat32_t test_svexpa_f32(svuint32_t op)
5462// CPP-CHECK-NEXT: [[TMP0:%.*]] = tail call <vscale x 2 x double> @llvm.aarch64.sve.fexpa.x.nxv2f64(<vscale x 2 x i64> [[OP:%.*]])
5563// CPP-CHECK-NEXT: ret <vscale x 2 x double> [[TMP0]]
5664//
57- svfloat64_t test_svexpa_f64 (svuint64_t op )
65+ svfloat64_t test_svexpa_f64 (svuint64_t op ) STREAMING
5866{
5967 return SVE_ACLE_FUNC (svexpa ,_f64 ,,)(op );
6068}
0 commit comments