; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py UTC_ARGS: --version 5 ; RUN: llc -mattr=+sve < %s | FileCheck %s --check-prefixes=CHECK,SVE ; RUN: llc -mattr=+sme -force-streaming < %s | FileCheck %s --check-prefixes=CHECK,STREAMING-SVE target datalayout = "e-m:e-i8:8:32-i16:16:32-i64:64-i128:128-n32:64-S128" target triple = "aarch64-none-linux-gnu" define @test_zeroinit_2xi64() { ; SVE-LABEL: test_zeroinit_2xi64: ; SVE: // %bb.0: ; SVE-NEXT: movi v0.2d, #0000000000000000 ; SVE-NEXT: ret ; ; STREAMING-SVE-LABEL: test_zeroinit_2xi64: ; STREAMING-SVE: // %bb.0: ; STREAMING-SVE-NEXT: mov z0.d, #0 // =0x0 ; STREAMING-SVE-NEXT: ret ret zeroinitializer } define @test_zeroinit_4xi32() { ; SVE-LABEL: test_zeroinit_4xi32: ; SVE: // %bb.0: ; SVE-NEXT: movi v0.2d, #0000000000000000 ; SVE-NEXT: ret ; ; STREAMING-SVE-LABEL: test_zeroinit_4xi32: ; STREAMING-SVE: // %bb.0: ; STREAMING-SVE-NEXT: mov z0.s, #0 // =0x0 ; STREAMING-SVE-NEXT: ret ret zeroinitializer } define @test_zeroinit_8xi16() { ; SVE-LABEL: test_zeroinit_8xi16: ; SVE: // %bb.0: ; SVE-NEXT: movi v0.2d, #0000000000000000 ; SVE-NEXT: ret ; ; STREAMING-SVE-LABEL: test_zeroinit_8xi16: ; STREAMING-SVE: // %bb.0: ; STREAMING-SVE-NEXT: mov z0.h, #0 // =0x0 ; STREAMING-SVE-NEXT: ret ret zeroinitializer } define @test_zeroinit_16xi8() { ; SVE-LABEL: test_zeroinit_16xi8: ; SVE: // %bb.0: ; SVE-NEXT: movi v0.2d, #0000000000000000 ; SVE-NEXT: ret ; ; STREAMING-SVE-LABEL: test_zeroinit_16xi8: ; STREAMING-SVE: // %bb.0: ; STREAMING-SVE-NEXT: mov z0.b, #0 // =0x0 ; STREAMING-SVE-NEXT: ret ret zeroinitializer } define @test_zeroinit_2xf64() { ; SVE-LABEL: test_zeroinit_2xf64: ; SVE: // %bb.0: ; SVE-NEXT: movi v0.2d, #0000000000000000 ; SVE-NEXT: ret ; ; STREAMING-SVE-LABEL: test_zeroinit_2xf64: ; STREAMING-SVE: // %bb.0: ; STREAMING-SVE-NEXT: mov z0.d, #0 // =0x0 ; STREAMING-SVE-NEXT: ret ret zeroinitializer } define @test_zeroinit_4xf32() { ; SVE-LABEL: test_zeroinit_4xf32: ; SVE: // %bb.0: ; SVE-NEXT: movi v0.2d, #0000000000000000 ; SVE-NEXT: ret ; ; STREAMING-SVE-LABEL: test_zeroinit_4xf32: ; STREAMING-SVE: // %bb.0: ; STREAMING-SVE-NEXT: mov z0.s, #0 // =0x0 ; STREAMING-SVE-NEXT: ret ret zeroinitializer } define @test_zeroinit_8xf16() { ; SVE-LABEL: test_zeroinit_8xf16: ; SVE: // %bb.0: ; SVE-NEXT: movi v0.2d, #0000000000000000 ; SVE-NEXT: ret ; ; STREAMING-SVE-LABEL: test_zeroinit_8xf16: ; STREAMING-SVE: // %bb.0: ; STREAMING-SVE-NEXT: mov z0.h, #0 // =0x0 ; STREAMING-SVE-NEXT: ret ret zeroinitializer } define @test_zeroinit_1xi1() { ; CHECK-LABEL: test_zeroinit_1xi1: ; CHECK: // %bb.0: ; CHECK-NEXT: pfalse p0.b ; CHECK-NEXT: ret ret zeroinitializer } define @test_zeroinit_2xi1() { ; CHECK-LABEL: test_zeroinit_2xi1: ; CHECK: // %bb.0: ; CHECK-NEXT: pfalse p0.b ; CHECK-NEXT: ret ret zeroinitializer } define @test_zeroinit_4xi1() { ; CHECK-LABEL: test_zeroinit_4xi1: ; CHECK: // %bb.0: ; CHECK-NEXT: pfalse p0.b ; CHECK-NEXT: ret ret zeroinitializer } define @test_zeroinit_8xi1() { ; CHECK-LABEL: test_zeroinit_8xi1: ; CHECK: // %bb.0: ; CHECK-NEXT: pfalse p0.b ; CHECK-NEXT: ret ret zeroinitializer } define @test_zeroinit_16xi1() { ; CHECK-LABEL: test_zeroinit_16xi1: ; CHECK: // %bb.0: ; CHECK-NEXT: pfalse p0.b ; CHECK-NEXT: ret ret zeroinitializer } define target("aarch64.svcount") @test_zeroinit_svcount() "target-features"="+sme2" { ; CHECK-LABEL: test_zeroinit_svcount: ; CHECK: // %bb.0: ; CHECK-NEXT: pfalse p0.b ; CHECK-NEXT: ret ret target("aarch64.svcount") zeroinitializer }