1# NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py 2# RUN: llc -mtriple=aarch64-unknown-unknown -run-pass=instruction-select -verify-machineinstrs %s -o - | FileCheck %s 3--- 4name: test_128_fpr_truncation 5alignment: 4 6legalized: true 7regBankSelected: true 8tracksRegLiveness: true 9body: | 10 ; CHECK-LABEL: name: test_128_fpr_truncation 11 ; CHECK: bb.0: 12 ; CHECK: successors: %bb.1(0x80000000) 13 ; CHECK: liveins: $x0 14 ; CHECK: [[COPY:%[0-9]+]]:gpr64sp = COPY $x0 15 ; CHECK: [[LDRQui:%[0-9]+]]:fpr128 = LDRQui [[COPY]], 0 :: (load (s128)) 16 ; CHECK: [[COPY1:%[0-9]+]]:gpr32all = COPY [[LDRQui]].ssub 17 ; CHECK: [[COPY2:%[0-9]+]]:gpr32 = COPY [[COPY1]] 18 ; CHECK: TBNZW [[COPY2]], 0, %bb.1 19 ; CHECK: bb.1: 20 ; CHECK: RET_ReallyLR 21 bb.0: 22 liveins: $x0 23 %1:gpr(p0) = COPY $x0 24 %3:gpr(s64) = G_CONSTANT i64 1 25 %5:gpr(s64) = G_CONSTANT i64 0 26 %0:fpr(s128) = G_LOAD %1:gpr(p0) :: (load (s128)) 27 %2:fpr(s64) = G_TRUNC %0:fpr(s128) 28 %8:gpr(s64) = COPY %2:fpr(s64) 29 %4:gpr(s64) = G_AND %8:gpr, %3:gpr 30 %7:gpr(s32) = G_ICMP intpred(ne), %4:gpr(s64), %5:gpr 31 G_BRCOND %7, %bb.1 32 33 bb.1: 34 RET_ReallyLR 35... 36--- 37name: no_trunc 38alignment: 4 39legalized: true 40regBankSelected: true 41tracksRegLiveness: true 42body: | 43 ; CHECK-LABEL: name: no_trunc 44 ; CHECK: bb.0: 45 ; CHECK: successors: %bb.1(0x80000000) 46 ; CHECK: liveins: $x0 47 ; CHECK: [[COPY:%[0-9]+]]:gpr64sp = COPY $x0 48 ; CHECK: [[LDRQui:%[0-9]+]]:fpr128 = LDRQui [[COPY]], 0 :: (load (s128)) 49 ; CHECK: [[COPY1:%[0-9]+]]:gpr64all = COPY [[LDRQui]].dsub 50 ; CHECK: [[COPY2:%[0-9]+]]:gpr64 = COPY [[COPY1]] 51 ; CHECK: TBNZX [[COPY2]], 33, %bb.1 52 ; CHECK: bb.1: 53 ; CHECK: RET_ReallyLR 54 bb.0: 55 liveins: $x0 56 %1:gpr(p0) = COPY $x0 57 %3:gpr(s64) = G_CONSTANT i64 8589934592 58 %5:gpr(s64) = G_CONSTANT i64 0 59 %0:fpr(s128) = G_LOAD %1:gpr(p0) :: (load (s128)) 60 %2:fpr(s64) = G_TRUNC %0:fpr(s128) 61 %8:gpr(s64) = COPY %2:fpr(s64) 62 %4:gpr(s64) = G_AND %8:gpr, %3:gpr 63 %7:gpr(s32) = G_ICMP intpred(ne), %4:gpr(s64), %5:gpr 64 G_BRCOND %7, %bb.1 65 bb.1: 66 RET_ReallyLR 67