1
1
// NOTE: Assertions have been autogenerated by utils/update_cc_test_checks.py
2
2
// REQUIRES: aarch64-registered-target
3
3
// 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
4
5
// 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
5
6
// 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
6
7
// 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
7
8
// 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
8
10
#include <arm_sve.h>
9
11
10
12
#ifdef SVE_OVERLOADED_FORMS
14
16
#define SVE_ACLE_FUNC (A1 ,A2 ,A3 ,A4 ) A1##A2##A3##A4
15
17
#endif
16
18
19
+ #ifdef __ARM_FEATURE_SME
20
+ #define STREAMING __arm_streaming
21
+ #else
22
+ #define STREAMING
23
+ #endif
24
+
17
25
// CHECK-LABEL: @test_svexpa_f16(
18
26
// CHECK-NEXT: entry:
19
27
// CHECK-NEXT: [[TMP0:%.*]] = tail call <vscale x 8 x half> @llvm.aarch64.sve.fexpa.x.nxv8f16(<vscale x 8 x i16> [[OP:%.*]])
24
32
// CPP-CHECK-NEXT: [[TMP0:%.*]] = tail call <vscale x 8 x half> @llvm.aarch64.sve.fexpa.x.nxv8f16(<vscale x 8 x i16> [[OP:%.*]])
25
33
// CPP-CHECK-NEXT: ret <vscale x 8 x half> [[TMP0]]
26
34
//
27
- svfloat16_t test_svexpa_f16 (svuint16_t op )
35
+ svfloat16_t test_svexpa_f16 (svuint16_t op ) STREAMING
28
36
{
29
37
return SVE_ACLE_FUNC (svexpa ,_f16 ,,)(op );
30
38
}
@@ -39,7 +47,7 @@ svfloat16_t test_svexpa_f16(svuint16_t op)
39
47
// CPP-CHECK-NEXT: [[TMP0:%.*]] = tail call <vscale x 4 x float> @llvm.aarch64.sve.fexpa.x.nxv4f32(<vscale x 4 x i32> [[OP:%.*]])
40
48
// CPP-CHECK-NEXT: ret <vscale x 4 x float> [[TMP0]]
41
49
//
42
- svfloat32_t test_svexpa_f32 (svuint32_t op )
50
+ svfloat32_t test_svexpa_f32 (svuint32_t op ) STREAMING
43
51
{
44
52
return SVE_ACLE_FUNC (svexpa ,_f32 ,,)(op );
45
53
}
@@ -54,7 +62,7 @@ svfloat32_t test_svexpa_f32(svuint32_t op)
54
62
// CPP-CHECK-NEXT: [[TMP0:%.*]] = tail call <vscale x 2 x double> @llvm.aarch64.sve.fexpa.x.nxv2f64(<vscale x 2 x i64> [[OP:%.*]])
55
63
// CPP-CHECK-NEXT: ret <vscale x 2 x double> [[TMP0]]
56
64
//
57
- svfloat64_t test_svexpa_f64 (svuint64_t op )
65
+ svfloat64_t test_svexpa_f64 (svuint64_t op ) STREAMING
58
66
{
59
67
return SVE_ACLE_FUNC (svexpa ,_f64 ,,)(op );
60
68
}
0 commit comments