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