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