[clang][modules] Don't prevent translation of FW_Private includes when explicitly...
[llvm-project.git] / llvm / test / CodeGen / AArch64 / sve-zeroinit.ll
blobeab39d0ef402526b0fe6a90900a2cbf846128a4a
1 ; RUN: llc -mtriple=aarch64-linux-gnu -mattr=+sve < %s | FileCheck %s
3 target datalayout = "e-m:e-i8:8:32-i16:16:32-i64:64-i128:128-n32:64-S128"
4 target triple = "aarch64-none-linux-gnu"
6 define <vscale x 2 x i64> @test_zeroinit_2xi64() {
7 ; CHECK-LABEL: test_zeroinit_2xi64
8 ; CHECK:       mov z0.d, #0
9 ; CHECK-NEXT:  ret
10   ret <vscale x 2 x i64> zeroinitializer
13 define <vscale x 4 x i32> @test_zeroinit_4xi32() {
14 ; CHECK-LABEL: test_zeroinit_4xi32
15 ; CHECK:       mov z0.s, #0
16 ; CHECK-NEXT:  ret
17   ret <vscale x 4 x i32> zeroinitializer
20 define <vscale x 8 x i16> @test_zeroinit_8xi16() {
21 ; CHECK-LABEL: test_zeroinit_8xi16
22 ; CHECK:       mov z0.h, #0
23 ; CHECK-NEXT:  ret
24   ret <vscale x 8 x i16> zeroinitializer
27 define <vscale x 16 x i8> @test_zeroinit_16xi8() {
28 ; CHECK-LABEL: test_zeroinit_16xi8
29 ; CHECK:       mov z0.b, #0
30 ; CHECK-NEXT:  ret
31   ret <vscale x 16 x i8> zeroinitializer
34 define <vscale x 2 x double> @test_zeroinit_2xf64() {
35 ; CHECK-LABEL: test_zeroinit_2xf64
36 ; CHECK:       mov z0.d, #0
37 ; CHECK-NEXT:  ret
38   ret <vscale x 2 x double> zeroinitializer
41 define <vscale x 4 x float> @test_zeroinit_4xf32() {
42 ; CHECK-LABEL: test_zeroinit_4xf32
43 ; CHECK:       mov z0.s, #0
44 ; CHECK-NEXT:  ret
45   ret <vscale x 4 x float> zeroinitializer
48 define <vscale x 8 x half> @test_zeroinit_8xf16() {
49 ; CHECK-LABEL: test_zeroinit_8xf16
50 ; CHECK:       mov z0.h, #0
51 ; CHECK-NEXT:  ret
52   ret <vscale x 8 x half> zeroinitializer
55 define <vscale x 1 x i1> @test_zeroinit_1xi1() {
56 ; CHECK-LABEL: test_zeroinit_1xi1
57 ; CHECK:       pfalse p0.b
58 ; CHECK-NEXT:  ret
59   ret <vscale x 1 x i1> zeroinitializer
62 define <vscale x 2 x i1> @test_zeroinit_2xi1() {
63 ; CHECK-LABEL: test_zeroinit_2xi1
64 ; CHECK:       pfalse p0.b
65 ; CHECK-NEXT:  ret
66   ret <vscale x 2 x i1> zeroinitializer
69 define <vscale x 4 x i1> @test_zeroinit_4xi1() {
70 ; CHECK-LABEL: test_zeroinit_4xi1
71 ; CHECK:       pfalse p0.b
72 ; CHECK-NEXT:  ret
73   ret <vscale x 4 x i1> zeroinitializer
76 define <vscale x 8 x i1> @test_zeroinit_8xi1() {
77 ; CHECK-LABEL: test_zeroinit_8xi1
78 ; CHECK:       pfalse p0.b
79 ; CHECK-NEXT:  ret
80   ret <vscale x 8 x i1> zeroinitializer
83 define <vscale x 16 x i1> @test_zeroinit_16xi1() {
84 ; CHECK-LABEL: test_zeroinit_16xi1
85 ; CHECK:       pfalse p0.b
86 ; CHECK-NEXT:  ret
87   ret <vscale x 16 x i1> zeroinitializer
90 define target("aarch64.svcount") @test_zeroinit_svcount() "target-features"="+sme2" {
91 ; CHECK-LABEL: test_zeroinit_svcount
92 ; CHECK:       pfalse p0.b
93 ; CHECK-NEXT:  ret
94   ret target("aarch64.svcount") zeroinitializer