1 ; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
2 ; RUN: llc -mtriple=aarch64-linux-gnu -mattr=+sve2p1 -mattr=+b16b16 -mattr=+use-experimental-zeroing-pseudos -verify-machineinstrs < %s \
5 define <vscale x 8 x bfloat> @bfmaxnm_pred(<vscale x 8 x i1> %pg, <vscale x 8 x bfloat> %a, <vscale x 8 x bfloat> %b){
6 ; CHECK-LABEL: bfmaxnm_pred:
8 ; CHECK-NEXT: bfmaxnm z0.h, p0/m, z0.h, z1.h
10 %res = call <vscale x 8 x bfloat> @llvm.aarch64.sve.fmaxnm.nxv8bf16(<vscale x 8 x i1> %pg, <vscale x 8 x bfloat> %a, <vscale x 8 x bfloat> %b)
11 ret <vscale x 8 x bfloat> %res
14 define <vscale x 8 x bfloat> @bfmaxnm(<vscale x 8 x bfloat> %a, <vscale x 8 x bfloat> %b){
15 ; CHECK-LABEL: bfmaxnm:
17 ; CHECK-NEXT: ptrue p0.h
18 ; CHECK-NEXT: bfmaxnm z0.h, p0/m, z0.h, z1.h
20 %elt = call <vscale x 8 x i1> @llvm.aarch64.sve.ptrue.nxv8i1(i32 31)
21 %res = call <vscale x 8 x bfloat> @llvm.aarch64.sve.fmaxnm.nxv8bf16(<vscale x 8 x i1> %elt, <vscale x 8 x bfloat> %a, <vscale x 8 x bfloat> %b)
22 ret <vscale x 8 x bfloat> %res
25 define <vscale x 8 x bfloat> @bfmaxnm_zeroing(<vscale x 8 x i1> %pg, <vscale x 8 x bfloat> %a, <vscale x 8 x bfloat> %b) {
26 ; CHECK-LABEL: bfmaxnm_zeroing:
28 ; CHECK-NEXT: movprfx z0.h, p0/z, z0.h
29 ; CHECK-NEXT: bfmaxnm z0.h, p0/m, z0.h, z1.h
31 %a_z = select <vscale x 8 x i1> %pg, <vscale x 8 x bfloat> %a, <vscale x 8 x bfloat> zeroinitializer
32 %out = call <vscale x 8 x bfloat> @llvm.aarch64.sve.fmaxnm.nxv8bf16(<vscale x 8 x i1> %pg,
33 <vscale x 8 x bfloat> %a_z,
34 <vscale x 8 x bfloat> %b)
35 ret <vscale x 8 x bfloat> %out
38 define <vscale x 8 x bfloat> @bfmaxnm_u_pred(<vscale x 8 x i1> %pg, <vscale x 8 x bfloat> %a, <vscale x 8 x bfloat> %b){
39 ; CHECK-LABEL: bfmaxnm_u_pred:
41 ; CHECK-NEXT: bfmaxnm z0.h, p0/m, z0.h, z1.h
43 %res = call <vscale x 8 x bfloat> @llvm.aarch64.sve.fmaxnm.u.nxv8bf16(<vscale x 8 x i1> %pg, <vscale x 8 x bfloat> %a, <vscale x 8 x bfloat> %b)
44 ret <vscale x 8 x bfloat> %res
47 define <vscale x 8 x bfloat> @bfmaxnm_u(<vscale x 8 x bfloat> %a, <vscale x 8 x bfloat> %b){
48 ; CHECK-LABEL: bfmaxnm_u:
50 ; CHECK-NEXT: ptrue p0.h
51 ; CHECK-NEXT: bfmaxnm z0.h, p0/m, z0.h, z1.h
53 %elt = call <vscale x 8 x i1> @llvm.aarch64.sve.ptrue.nxv8i1(i32 31)
54 %res = call <vscale x 8 x bfloat> @llvm.aarch64.sve.fmaxnm.u.nxv8bf16(<vscale x 8 x i1> %elt, <vscale x 8 x bfloat> %a, <vscale x 8 x bfloat> %b)
55 ret <vscale x 8 x bfloat> %res
58 define <vscale x 8 x bfloat> @bfmaxnm_u_zeroing(<vscale x 8 x i1> %pg, <vscale x 8 x bfloat> %a, <vscale x 8 x bfloat> %b) {
59 ; CHECK-LABEL: bfmaxnm_u_zeroing:
61 ; CHECK-NEXT: mov z2.h, #0 // =0x0
62 ; CHECK-NEXT: sel z0.h, p0, z0.h, z2.h
63 ; CHECK-NEXT: bfmaxnm z0.h, p0/m, z0.h, z1.h
65 %a_z = select <vscale x 8 x i1> %pg, <vscale x 8 x bfloat> %a, <vscale x 8 x bfloat> zeroinitializer
66 %out = call <vscale x 8 x bfloat> @llvm.aarch64.sve.fmaxnm.u.nxv8bf16(<vscale x 8 x i1> %pg,
67 <vscale x 8 x bfloat> %a_z,
68 <vscale x 8 x bfloat> %b)
69 ret <vscale x 8 x bfloat> %out
72 declare <vscale x 8 x bfloat> @llvm.aarch64.sve.fmaxnm.nxv8bf16(<vscale x 8 x i1>, <vscale x 8 x bfloat>, <vscale x 8 x bfloat>)
73 declare <vscale x 8 x bfloat> @llvm.aarch64.sve.fmaxnm.u.nxv8bf16(<vscale x 8 x i1>, <vscale x 8 x bfloat>, <vscale x 8 x bfloat>)
74 declare <vscale x 8 x i1> @llvm.aarch64.sve.ptrue.nxv8i1(i32 immarg)