Run DCE after a LoopFlatten test to reduce spurious output [nfc]
[llvm-project.git] / llvm / test / CodeGen / RISCV / rvv / vaesem.ll
blob0f35ce017c28c979ce4d291cd1b6ac62fa7ca66f
1 ; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py UTC_ARGS: --version 2
2 ; RUN: sed 's/iXLen/i32/g' %s | llc -mtriple=riscv32 -mattr=+v,+experimental-zvkned \
3 ; RUN:   -verify-machineinstrs | FileCheck %s --check-prefixes=CHECK
4 ; RUN: sed 's/iXLen/i64/g' %s | llc -mtriple=riscv64 -mattr=+v,+experimental-zvkned \
5 ; RUN:   -verify-machineinstrs | FileCheck %s --check-prefixes=CHECK
7 declare <vscale x 4 x i32> @llvm.riscv.vaesem.vv.nxv4i32(
8   <vscale x 4 x i32>,
9   <vscale x 4 x i32>,
10   iXLen, iXLen);
12 define <vscale x 4 x i32> @intrinsic_vaesem_vv_nxv4i32(<vscale x 4 x i32> %0, <vscale x 4 x i32> %1, iXLen %2) nounwind {
13 ; CHECK-LABEL: intrinsic_vaesem_vv_nxv4i32:
14 ; CHECK:       # %bb.0: # %entry
15 ; CHECK-NEXT:    vsetvli zero, a0, e32, m2, tu, ma
16 ; CHECK-NEXT:    vaesem.vv v8, v10
17 ; CHECK-NEXT:    ret
18 entry:
19   %a = call <vscale x 4 x i32> @llvm.riscv.vaesem.vv.nxv4i32(
20     <vscale x 4 x i32> %0,
21     <vscale x 4 x i32> %1,
22     iXLen %2, iXLen 2)
24   ret <vscale x 4 x i32> %a
27 declare <vscale x 8 x i32> @llvm.riscv.vaesem.vv.nxv8i32(
28   <vscale x 8 x i32>,
29   <vscale x 8 x i32>,
30   iXLen, iXLen);
32 define <vscale x 8 x i32> @intrinsic_vaesem_vv_nxv8i32(<vscale x 8 x i32> %0, <vscale x 8 x i32> %1, iXLen %2) nounwind {
33 ; CHECK-LABEL: intrinsic_vaesem_vv_nxv8i32:
34 ; CHECK:       # %bb.0: # %entry
35 ; CHECK-NEXT:    vsetvli zero, a0, e32, m4, tu, ma
36 ; CHECK-NEXT:    vaesem.vv v8, v12
37 ; CHECK-NEXT:    ret
38 entry:
39   %a = call <vscale x 8 x i32> @llvm.riscv.vaesem.vv.nxv8i32(
40     <vscale x 8 x i32> %0,
41     <vscale x 8 x i32> %1,
42     iXLen %2, iXLen 2)
44   ret <vscale x 8 x i32> %a
47 declare <vscale x 16 x i32> @llvm.riscv.vaesem.vv.nxv16i32(
48   <vscale x 16 x i32>,
49   <vscale x 16 x i32>,
50   iXLen, iXLen);
52 define <vscale x 16 x i32> @intrinsic_vaesem_vv_nxv16i32(<vscale x 16 x i32> %0, <vscale x 16 x i32> %1, iXLen %2) nounwind {
53 ; CHECK-LABEL: intrinsic_vaesem_vv_nxv16i32:
54 ; CHECK:       # %bb.0: # %entry
55 ; CHECK-NEXT:    vsetvli zero, a0, e32, m8, tu, ma
56 ; CHECK-NEXT:    vaesem.vv v8, v16
57 ; CHECK-NEXT:    ret
58 entry:
59   %a = call <vscale x 16 x i32> @llvm.riscv.vaesem.vv.nxv16i32(
60     <vscale x 16 x i32> %0,
61     <vscale x 16 x i32> %1,
62     iXLen %2, iXLen 2)
64   ret <vscale x 16 x i32> %a
67 declare <vscale x 4 x i32> @llvm.riscv.vaesem.vs.nxv4i32.nxv4i32(
68   <vscale x 4 x i32>,
69   <vscale x 4 x i32>,
70   iXLen, iXLen);
72 define <vscale x 4 x i32> @intrinsic_vaesem_vs_nxv4i32(<vscale x 4 x i32> %0, <vscale x 4 x i32> %1, iXLen %2) nounwind {
73 ; CHECK-LABEL: intrinsic_vaesem_vs_nxv4i32:
74 ; CHECK:       # %bb.0: # %entry
75 ; CHECK-NEXT:    vsetvli zero, a0, e32, m2, tu, ma
76 ; CHECK-NEXT:    vaesem.vs v8, v10
77 ; CHECK-NEXT:    ret
78 entry:
79   %a = call <vscale x 4 x i32> @llvm.riscv.vaesem.vs.nxv4i32.nxv4i32(
80     <vscale x 4 x i32> %0,
81     <vscale x 4 x i32> %1,
82     iXLen %2, iXLen 2)
84   ret <vscale x 4 x i32> %a
87 declare <vscale x 8 x i32> @llvm.riscv.vaesem.vs.nxv8i32.nxv4i32(
88   <vscale x 8 x i32>,
89   <vscale x 4 x i32>,
90   iXLen, iXLen);
92 define <vscale x 8 x i32> @intrinsic_vaesem_vs_nxv8i32(<vscale x 8 x i32> %0, <vscale x 4 x i32> %1, iXLen %2) nounwind {
93 ; CHECK-LABEL: intrinsic_vaesem_vs_nxv8i32:
94 ; CHECK:       # %bb.0: # %entry
95 ; CHECK-NEXT:    vsetvli zero, a0, e32, m4, tu, ma
96 ; CHECK-NEXT:    vaesem.vs v8, v12
97 ; CHECK-NEXT:    ret
98 entry:
99   %a = call <vscale x 8 x i32> @llvm.riscv.vaesem.vs.nxv8i32.nxv4i32(
100     <vscale x 8 x i32> %0,
101     <vscale x 4 x i32> %1,
102     iXLen %2, iXLen 2)
104   ret <vscale x 8 x i32> %a
107 declare <vscale x 16 x i32> @llvm.riscv.vaesem.vs.nxv16i32.nxv4i32(
108   <vscale x 16 x i32>,
109   <vscale x 4 x i32>,
110   iXLen, iXLen);
112 define <vscale x 16 x i32> @intrinsic_vaesem_vs_nxv16i32(<vscale x 16 x i32> %0, <vscale x 4 x i32> %1, iXLen %2) nounwind {
113 ; CHECK-LABEL: intrinsic_vaesem_vs_nxv16i32:
114 ; CHECK:       # %bb.0: # %entry
115 ; CHECK-NEXT:    vsetvli zero, a0, e32, m8, tu, ma
116 ; CHECK-NEXT:    vaesem.vs v8, v16
117 ; CHECK-NEXT:    ret
118 entry:
119   %a = call <vscale x 16 x i32> @llvm.riscv.vaesem.vs.nxv16i32.nxv4i32(
120     <vscale x 16 x i32> %0,
121     <vscale x 4 x i32> %1,
122     iXLen %2, iXLen 2)
124   ret <vscale x 16 x i32> %a