; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py ; RUN: llc -mtriple=aarch64-linux-gnu -mattr=+sme-i16i64 -verify-machineinstrs < %s | FileCheck %s define void @addha_s( %pn, %pm, %zn) { ; CHECK-LABEL: addha_s: ; CHECK: // %bb.0: ; CHECK-NEXT: addha za0.s, p0/m, p1/m, z0.s ; CHECK-NEXT: ret call void @llvm.aarch64.sme.addha.nxv4i32(i32 0, %pn, %pm, %zn) ret void } define void @addva_s( %pn, %pm, %zn) { ; CHECK-LABEL: addva_s: ; CHECK: // %bb.0: ; CHECK-NEXT: addva za3.s, p0/m, p1/m, z0.s ; CHECK-NEXT: ret call void @llvm.aarch64.sme.addva.nxv4i32(i32 3, %pn, %pm, %zn) ret void } define void @addha_d( %pn, %pm, %zn) { ; CHECK-LABEL: addha_d: ; CHECK: // %bb.0: ; CHECK-NEXT: addha za0.d, p0/m, p1/m, z0.d ; CHECK-NEXT: ret call void @llvm.aarch64.sme.addha.nxv2i64(i32 0, %pn, %pm, %zn) ret void } define void @addva_d( %pn, %pm, %zn) { ; CHECK-LABEL: addva_d: ; CHECK: // %bb.0: ; CHECK-NEXT: addva za7.d, p0/m, p1/m, z0.d ; CHECK-NEXT: ret call void @llvm.aarch64.sme.addva.nxv2i64(i32 7, %pn, %pm, %zn) ret void } declare void @llvm.aarch64.sme.addha.nxv4i32(i32, , , ) declare void @llvm.aarch64.sme.addha.nxv2i64(i32, , , ) declare void @llvm.aarch64.sme.addva.nxv4i32(i32, , , ) declare void @llvm.aarch64.sme.addva.nxv2i64(i32, , , )