| ; 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(<vscale x 16 x i8> %zn1, <vscale x 16 x i8> %zn2, <vscale x 16 x i8> %zm, <vscale x 16 x i8> %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, <vscale x 16 x i8> %zn1, <vscale x 16 x i8> %zn2, <vscale x 16 x i8> %zm, <vscale x 16 x i8> %zk, i32 0) |
| ret void |
| } |
| |
| define void @utmopa_za32_u8(<vscale x 16 x i8> %zn1, <vscale x 16 x i8> %zn2, <vscale x 16 x i8> %zm, <vscale x 16 x i8> %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, <vscale x 16 x i8> %zn1, <vscale x 16 x i8> %zn2, <vscale x 16 x i8> %zm, <vscale x 16 x i8> %zk, i32 0) |
| ret void |
| } |
| |
| define void @ustmopa_za32_u8_s8(<vscale x 16 x i8> %zn1, <vscale x 16 x i8> %zn2, <vscale x 16 x i8> %zm, <vscale x 16 x i8> %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, <vscale x 16 x i8> %zn1, <vscale x 16 x i8> %zn2, <vscale x 16 x i8> %zm, <vscale x 16 x i8> %zk, i32 0) |
| ret void |
| } |
| |
| define void @sutmopa_za32_s8_u8(<vscale x 16 x i8> %zn1, <vscale x 16 x i8> %zn2, <vscale x 16 x i8> %zm, <vscale x 16 x i8> %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, <vscale x 16 x i8> %zn1, <vscale x 16 x i8> %zn2, <vscale x 16 x i8> %zm, <vscale x 16 x i8> %zk, i32 0) |
| ret void |
| } |
| |
| define void @stmopa_za32_s16(<vscale x 8 x i16> %zn1, <vscale x 8 x i16> %zn2, <vscale x 8 x i16> %zm, <vscale x 16 x i8> %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, <vscale x 8 x i16> %zn1, <vscale x 8 x i16> %zn2, <vscale x 8 x i16> %zm, <vscale x 16 x i8> %zk, i32 0) |
| ret void |
| } |
| |
| define void @utmopa_za32_u16(<vscale x 8 x i16> %zn1, <vscale x 8 x i16> %zn2, <vscale x 8 x i16> %zm, <vscale x 16 x i8> %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, <vscale x 8 x i16> %zn1, <vscale x 8 x i16> %zn2, <vscale x 8 x i16> %zm, <vscale x 16 x i8> %zk, i32 0) |
| ret void |
| } |
| |
| define void @ftmopa_za32_f16(<vscale x 8 x half> %zn1, <vscale x 8 x half> %zn2, <vscale x 8 x half> %zm, <vscale x 16 x i8> %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, <vscale x 8 x half> %zn1, <vscale x 8 x half> %zn2, <vscale x 8 x half> %zm, <vscale x 16 x i8> %zk, i32 0) |
| ret void |
| } |
| |
| define void @bftmopa_za32_bf16(<vscale x 8 x bfloat> %zn1, <vscale x 8 x bfloat> %zn2, <vscale x 8 x bfloat> %zm, <vscale x 16 x i8> %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, <vscale x 8 x bfloat> %zn1, <vscale x 8 x bfloat> %zn2, <vscale x 8 x bfloat> %zm, <vscale x 16 x i8> %zk, i32 0) |
| ret void |
| } |
| |
| define void @ftmopa_za32_f32(<vscale x 4 x float> %zn1, <vscale x 4 x float> %zn2, <vscale x 4 x float> %zm, <vscale x 16 x i8> %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, <vscale x 4 x float> %zn1, <vscale x 4 x float> %zn2, <vscale x 4 x float> %zm, <vscale x 16 x i8> %zk, i32 0) |
| ret void |
| } |
| |
| define void @ftmopa_za16_f16(<vscale x 8 x half> %zn1, <vscale x 8 x half> %zn2, <vscale x 8 x half> %zm, <vscale x 16 x i8> %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, <vscale x 8 x half> %zn1, <vscale x 8 x half> %zn2, <vscale x 8 x half> %zm, <vscale x 16 x i8> %zk, i32 0) |
| ret void |
| } |
| |
| define void @bftmopa_za16_bf16(<vscale x 8 x bfloat> %zn1, <vscale x 8 x bfloat> %zn2, <vscale x 8 x bfloat> %zm, <vscale x 16 x i8> %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, <vscale x 8 x bfloat> %zn1, <vscale x 8 x bfloat> %zn2, <vscale x 8 x bfloat> %zm, <vscale x 16 x i8> %zk, i32 0) |
| ret void |
| } |
| |
| define void @ftmopa_za16_f8(<vscale x 16 x i8> %zn1, <vscale x 16 x i8> %zn2, <vscale x 16 x i8> %zm, <vscale x 16 x i8> %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, <vscale x 16 x i8> %zn1, <vscale x 16 x i8> %zn2, <vscale x 16 x i8> %zm, <vscale x 16 x i8> %zk, i32 0) |
| ret void |
| } |
| |
| define void @ftmopa_za32_f8(<vscale x 16 x i8> %zn1, <vscale x 16 x i8> %zn2, <vscale x 16 x i8> %zm, <vscale x 16 x i8> %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, <vscale x 16 x i8> %zn1, <vscale x 16 x i8> %zn2, <vscale x 16 x i8> %zm, <vscale x 16 x i8> %zk, i32 0) |
| ret void |
| } |
| |
| attributes #0 = {nounwind "target-features" = "+sme2,+sme-tmop,+sme-f16f16,+sme-b16b16,+sme-f8f16,+sme-f8f32,+sme2p1,+bf16" } |