; RUN: llc -mtriple=aarch64-linux-gnu -mattr=+sve < %s | FileCheck %s 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() { ; CHECK-LABEL: test_zeroinit_2xi64 ; CHECK: mov z0.d, #0 ; CHECK-NEXT: ret ret zeroinitializer } define @test_zeroinit_4xi32() { ; CHECK-LABEL: test_zeroinit_4xi32 ; CHECK: mov z0.s, #0 ; CHECK-NEXT: ret ret zeroinitializer } define @test_zeroinit_8xi16() { ; CHECK-LABEL: test_zeroinit_8xi16 ; CHECK: mov z0.h, #0 ; CHECK-NEXT: ret ret zeroinitializer } define @test_zeroinit_16xi8() { ; CHECK-LABEL: test_zeroinit_16xi8 ; CHECK: mov z0.b, #0 ; CHECK-NEXT: ret ret zeroinitializer } define @test_zeroinit_2xf64() { ; CHECK-LABEL: test_zeroinit_2xf64 ; CHECK: mov z0.d, #0 ; CHECK-NEXT: ret ret zeroinitializer } define @test_zeroinit_4xf32() { ; CHECK-LABEL: test_zeroinit_4xf32 ; CHECK: mov z0.s, #0 ; CHECK-NEXT: ret ret zeroinitializer } define @test_zeroinit_8xf16() { ; CHECK-LABEL: test_zeroinit_8xf16 ; CHECK: mov z0.h, #0 ; CHECK-NEXT: ret ret zeroinitializer } define @test_zeroinit_1xi1() { ; CHECK-LABEL: test_zeroinit_1xi1 ; CHECK: pfalse p0.b ; CHECK-NEXT: ret ret zeroinitializer } define @test_zeroinit_2xi1() { ; CHECK-LABEL: test_zeroinit_2xi1 ; CHECK: pfalse p0.b ; CHECK-NEXT: ret ret zeroinitializer } define @test_zeroinit_4xi1() { ; CHECK-LABEL: test_zeroinit_4xi1 ; CHECK: pfalse p0.b ; CHECK-NEXT: ret ret zeroinitializer } define @test_zeroinit_8xi1() { ; CHECK-LABEL: test_zeroinit_8xi1 ; CHECK: pfalse p0.b ; CHECK-NEXT: ret ret zeroinitializer } define @test_zeroinit_16xi1() { ; CHECK-LABEL: test_zeroinit_16xi1 ; CHECK: pfalse p0.b ; CHECK-NEXT: ret ret zeroinitializer } define target("aarch64.svcount") @test_zeroinit_svcount() "target-features"="+sme2" { ; CHECK-LABEL: test_zeroinit_svcount ; CHECK: pfalse p0.b ; CHECK-NEXT: ret ret target("aarch64.svcount") zeroinitializer }