; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py UTC_ARGS: --version 4 ; RUN: llc -force-streaming -verify-machineinstrs < %s | FileCheck %s target triple = "aarch64-linux" define void @stmopa_za32_s8( %zn1, %zn2, %zm, %zk) #0 { ; CHECK-LABEL: stmopa_za32_s8: ; CHECK: // %bb.0: ; CHECK-NEXT: mov z28.d, z3.d ; CHECK-NEXT: // kill: def $z1 killed $z1 killed $z0_z1 def $z0_z1 ; CHECK-NEXT: // kill: def $z0 killed $z0 killed $z0_z1 def $z0_z1 ; CHECK-NEXT: stmopa za0.s, { z0.b, z1.b }, z2.b, z28[0] ; CHECK-NEXT: ret call void @llvm.aarch64.sme.stmopa.za32.nxv16i8(i32 0, %zn1, %zn2, %zm, %zk, i32 0) ret void } define void @utmopa_za32_u8( %zn1, %zn2, %zm, %zk) #0 { ; CHECK-LABEL: utmopa_za32_u8: ; CHECK: // %bb.0: ; CHECK-NEXT: mov z28.d, z3.d ; CHECK-NEXT: // kill: def $z1 killed $z1 killed $z0_z1 def $z0_z1 ; CHECK-NEXT: // kill: def $z0 killed $z0 killed $z0_z1 def $z0_z1 ; CHECK-NEXT: utmopa za0.s, { z0.b, z1.b }, z2.b, z28[0] ; CHECK-NEXT: ret call void @llvm.aarch64.sme.utmopa.za32.nxv16i8(i32 0, %zn1, %zn2, %zm, %zk, i32 0) ret void } define void @ustmopa_za32_u8_s8( %zn1, %zn2, %zm, %zk) #0 { ; CHECK-LABEL: ustmopa_za32_u8_s8: ; CHECK: // %bb.0: ; CHECK-NEXT: mov z28.d, z3.d ; CHECK-NEXT: // kill: def $z1 killed $z1 killed $z0_z1 def $z0_z1 ; CHECK-NEXT: // kill: def $z0 killed $z0 killed $z0_z1 def $z0_z1 ; CHECK-NEXT: ustmopa za0.s, { z0.b, z1.b }, z2.b, z28[0] ; CHECK-NEXT: ret call void @llvm.aarch64.sme.ustmopa.za32.nxv16i8(i32 0, %zn1, %zn2, %zm, %zk, i32 0) ret void } define void @sutmopa_za32_s8_u8( %zn1, %zn2, %zm, %zk) #0 { ; CHECK-LABEL: sutmopa_za32_s8_u8: ; CHECK: // %bb.0: ; CHECK-NEXT: mov z28.d, z3.d ; CHECK-NEXT: // kill: def $z1 killed $z1 killed $z0_z1 def $z0_z1 ; CHECK-NEXT: // kill: def $z0 killed $z0 killed $z0_z1 def $z0_z1 ; CHECK-NEXT: sutmopa za0.s, { z0.b, z1.b }, z2.b, z28[0] ; CHECK-NEXT: ret call void @llvm.aarch64.sme.sutmopa.za32.nxv16i8(i32 0, %zn1, %zn2, %zm, %zk, i32 0) ret void } define void @stmopa_za32_s16( %zn1, %zn2, %zm, %zk) #0 { ; CHECK-LABEL: stmopa_za32_s16: ; CHECK: // %bb.0: ; CHECK-NEXT: mov z28.d, z3.d ; CHECK-NEXT: // kill: def $z1 killed $z1 killed $z0_z1 def $z0_z1 ; CHECK-NEXT: // kill: def $z0 killed $z0 killed $z0_z1 def $z0_z1 ; CHECK-NEXT: stmopa za0.s, { z0.h, z1.h }, z2.h, z28[0] ; CHECK-NEXT: ret call void @llvm.aarch64.sme.stmopa.za32.nxv8i16(i32 0, %zn1, %zn2, %zm, %zk, i32 0) ret void } define void @utmopa_za32_u16( %zn1, %zn2, %zm, %zk) #0 { ; CHECK-LABEL: utmopa_za32_u16: ; CHECK: // %bb.0: ; CHECK-NEXT: mov z28.d, z3.d ; CHECK-NEXT: // kill: def $z1 killed $z1 killed $z0_z1 def $z0_z1 ; CHECK-NEXT: // kill: def $z0 killed $z0 killed $z0_z1 def $z0_z1 ; CHECK-NEXT: utmopa za0.s, { z0.h, z1.h }, z2.h, z28[0] ; CHECK-NEXT: ret call void @llvm.aarch64.sme.utmopa.za32.nxv8i16(i32 0, %zn1, %zn2, %zm, %zk, i32 0) ret void } define void @ftmopa_za32_f16( %zn1, %zn2, %zm, %zk) #0 { ; CHECK-LABEL: ftmopa_za32_f16: ; CHECK: // %bb.0: ; CHECK-NEXT: mov z28.d, z3.d ; CHECK-NEXT: // kill: def $z1 killed $z1 killed $z0_z1 def $z0_z1 ; CHECK-NEXT: // kill: def $z0 killed $z0 killed $z0_z1 def $z0_z1 ; CHECK-NEXT: ftmopa za0.s, { z0.h, z1.h }, z2.h, z28[0] ; CHECK-NEXT: ret call void @llvm.aarch64.sme.ftmopa.za32.nxv8f16(i32 0, %zn1, %zn2, %zm, %zk, i32 0) ret void } define void @bftmopa_za32_bf16( %zn1, %zn2, %zm, %zk) #0 { ; CHECK-LABEL: bftmopa_za32_bf16: ; CHECK: // %bb.0: ; CHECK-NEXT: mov z28.d, z3.d ; CHECK-NEXT: // kill: def $z1 killed $z1 killed $z0_z1 def $z0_z1 ; CHECK-NEXT: // kill: def $z0 killed $z0 killed $z0_z1 def $z0_z1 ; CHECK-NEXT: bftmopa za0.s, { z0.h, z1.h }, z2.h, z28[0] ; CHECK-NEXT: ret call void @llvm.aarch64.sme.ftmopa.za32.nxv8bf16(i32 0, %zn1, %zn2, %zm, %zk, i32 0) ret void } define void @ftmopa_za32_f32( %zn1, %zn2, %zm, %zk) #0 { ; CHECK-LABEL: ftmopa_za32_f32: ; CHECK: // %bb.0: ; CHECK-NEXT: mov z28.d, z3.d ; CHECK-NEXT: // kill: def $z1 killed $z1 killed $z0_z1 def $z0_z1 ; CHECK-NEXT: // kill: def $z0 killed $z0 killed $z0_z1 def $z0_z1 ; CHECK-NEXT: ftmopa za0.s, { z0.s, z1.s }, z2.s, z28[0] ; CHECK-NEXT: ret call void @llvm.aarch64.sme.ftmopa.za32.nxv4f32(i32 0, %zn1, %zn2, %zm, %zk, i32 0) ret void } define void @ftmopa_za16_f16( %zn1, %zn2, %zm, %zk) #0 { ; CHECK-LABEL: ftmopa_za16_f16: ; CHECK: // %bb.0: ; CHECK-NEXT: mov z28.d, z3.d ; CHECK-NEXT: // kill: def $z1 killed $z1 killed $z0_z1 def $z0_z1 ; CHECK-NEXT: // kill: def $z0 killed $z0 killed $z0_z1 def $z0_z1 ; CHECK-NEXT: ftmopa za0.h, { z0.h, z1.h }, z2.h, z28[0] ; CHECK-NEXT: ret call void @llvm.aarch64.sme.ftmopa.za16.nxv8f16(i32 0, %zn1, %zn2, %zm, %zk, i32 0) ret void } define void @bftmopa_za16_bf16( %zn1, %zn2, %zm, %zk) #0 { ; CHECK-LABEL: bftmopa_za16_bf16: ; CHECK: // %bb.0: ; CHECK-NEXT: mov z28.d, z3.d ; CHECK-NEXT: // kill: def $z1 killed $z1 killed $z0_z1 def $z0_z1 ; CHECK-NEXT: // kill: def $z0 killed $z0 killed $z0_z1 def $z0_z1 ; CHECK-NEXT: bftmopa za0.h, { z0.h, z1.h }, z2.h, z28[0] ; CHECK-NEXT: ret call void @llvm.aarch64.sme.ftmopa.za16.nxv8bf16(i32 0, %zn1, %zn2, %zm, %zk, i32 0) ret void } define void @ftmopa_za16_f8( %zn1, %zn2, %zm, %zk) #0 { ; CHECK-LABEL: ftmopa_za16_f8: ; CHECK: // %bb.0: ; CHECK-NEXT: mov z28.d, z3.d ; CHECK-NEXT: // kill: def $z1 killed $z1 killed $z0_z1 def $z0_z1 ; CHECK-NEXT: // kill: def $z0 killed $z0 killed $z0_z1 def $z0_z1 ; CHECK-NEXT: ftmopa za0.h, { z0.b, z1.b }, z2.b, z28[0] ; CHECK-NEXT: ret call void @llvm.aarch64.sme.ftmopa.za16.nxv16i8(i32 0, %zn1, %zn2, %zm, %zk, i32 0) ret void } define void @ftmopa_za32_f8( %zn1, %zn2, %zm, %zk) #0 { ; CHECK-LABEL: ftmopa_za32_f8: ; CHECK: // %bb.0: ; CHECK-NEXT: mov z28.d, z3.d ; CHECK-NEXT: // kill: def $z1 killed $z1 killed $z0_z1 def $z0_z1 ; CHECK-NEXT: // kill: def $z0 killed $z0 killed $z0_z1 def $z0_z1 ; CHECK-NEXT: ftmopa za0.s, { z0.b, z1.b }, z2.b, z28[0] ; CHECK-NEXT: ret call void @llvm.aarch64.sme.ftmopa.za32.nxv16i8(i32 0, %zn1, %zn2, %zm, %zk, i32 0) ret void } attributes #0 = {nounwind "target-features" = "+sme2,+sme-tmop,+sme-f16f16,+sme-b16b16,+sme-f8f16,+sme-f8f32,+sme2p1,+bf16" }