xref: /llvm-project/llvm/test/CodeGen/AArch64/aes.ll (revision d458a1931769aa4bcdb3fcd537c4ee946507ff1a)
1; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py UTC_ARGS: --version 4
2; RUN: llc %s -o - -mtriple=aarch64 -mattr=+aes | FileCheck %s
3
4declare <16 x i8> @llvm.aarch64.crypto.aese(<16 x i8> %d, <16 x i8> %k)
5declare <16 x i8> @llvm.aarch64.crypto.aesd(<16 x i8> %d, <16 x i8> %k)
6
7define <16 x i8> @aese(<16 x i8> %a, <16 x i8> %b) {
8; CHECK-LABEL: aese:
9; CHECK:       // %bb.0:
10; CHECK-NEXT:    aese v0.16b, v1.16b
11; CHECK-NEXT:    ret
12  %r = call <16 x i8> @llvm.aarch64.crypto.aese(<16 x i8> %a, <16 x i8> %b)
13  ret <16 x i8> %r
14}
15
16define <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 v0.16b, v1.16b
20; CHECK-NEXT:    ret
21  %r = call <16 x i8> @llvm.aarch64.crypto.aese(<16 x i8> %b, <16 x i8> %a)
22  ret <16 x i8> %r
23}
24
25define <16 x i8> @aesd(<16 x i8> %a, <16 x i8> %b) {
26; CHECK-LABEL: aesd:
27; CHECK:       // %bb.0:
28; CHECK-NEXT:    aesd v0.16b, v1.16b
29; CHECK-NEXT:    ret
30  %r = call <16 x i8> @llvm.aarch64.crypto.aesd(<16 x i8> %a, <16 x i8> %b)
31  ret <16 x i8> %r
32}
33
34define <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 v0.16b, v1.16b
38; CHECK-NEXT:    ret
39  %r = call <16 x i8> @llvm.aarch64.crypto.aesd(<16 x i8> %b, <16 x i8> %a)
40  ret <16 x i8> %r
41}
42