xref: /llvm-project/llvm/test/CodeGen/ARM/aes.ll (revision 5f058398ab7a6c2cf3555daf190d3d13d68f78f5)
1; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py UTC_ARGS: --version 4
2; RUN: llc %s -o - -mtriple=armv8-none-eabi -mattr=+aes | FileCheck %s
3
4declare <16 x i8> @llvm.arm.neon.aese(<16 x i8> %d, <16 x i8> %k)
5declare <16 x i8> @llvm.arm.neon.aesd(<16 x i8> %d, <16 x i8> %k)
6
7define arm_aapcs_vfpcc <16 x i8> @aese(<16 x i8> %a, <16 x i8> %b) {
8; CHECK-LABEL: aese:
9; CHECK:       @ %bb.0:
10; CHECK-NEXT:    aese.8 q0, q1
11; CHECK-NEXT:    bx lr
12  %r = call <16 x i8> @llvm.arm.neon.aese(<16 x i8> %a, <16 x i8> %b)
13  ret <16 x i8> %r
14}
15
16define arm_aapcs_vfpcc <16 x i8> @aese_c(<16 x i8> %a, <16 x i8> %b) {
17; CHECK-LABEL: aese_c:
18; CHECK:       @ %bb.0:
19; CHECK-NEXT:    aese.8 q0, q1
20; CHECK-NEXT:    bx lr
21  %r = call <16 x i8> @llvm.arm.neon.aese(<16 x i8> %b, <16 x i8> %a)
22  ret <16 x i8> %r
23}
24
25define arm_aapcs_vfpcc <16 x i8> @aesd(<16 x i8> %a, <16 x i8> %b) {
26; CHECK-LABEL: aesd:
27; CHECK:       @ %bb.0:
28; CHECK-NEXT:    aesd.8 q0, q1
29; CHECK-NEXT:    bx lr
30  %r = call <16 x i8> @llvm.arm.neon.aesd(<16 x i8> %a, <16 x i8> %b)
31  ret <16 x i8> %r
32}
33
34define arm_aapcs_vfpcc <16 x i8> @aesd_c(<16 x i8> %a, <16 x i8> %b) {
35; CHECK-LABEL: aesd_c:
36; CHECK:       @ %bb.0:
37; CHECK-NEXT:    aesd.8 q0, q1
38; CHECK-NEXT:    bx lr
39  %r = call <16 x i8> @llvm.arm.neon.aesd(<16 x i8> %b, <16 x i8> %a)
40  ret <16 x i8> %r
41}
42