12c92335eSCraig Topper; NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py UTC_ARGS: --version 5 22c92335eSCraig Topper; RUN: llc < %s -mtriple=riscv64 -verify-machineinstrs -stop-after=finalize-isel | FileCheck %s 32c92335eSCraig Topper 42c92335eSCraig Topperdefine i32 @_ZNK2cv12LMSolverImpl3runERKNS_17_InputOutputArrayE(i1 %cmp436) { 52c92335eSCraig Topper ; CHECK-LABEL: name: _ZNK2cv12LMSolverImpl3runERKNS_17_InputOutputArrayE 62c92335eSCraig Topper ; CHECK: bb.0.entry: 72c92335eSCraig Topper ; CHECK-NEXT: successors: %bb.1(0x80000000) 82c92335eSCraig Topper ; CHECK-NEXT: liveins: $x10 92c92335eSCraig Topper ; CHECK-NEXT: {{ $}} 102c92335eSCraig Topper ; CHECK-NEXT: [[COPY:%[0-9]+]]:gpr = COPY $x10 112c92335eSCraig Topper ; CHECK-NEXT: [[COPY1:%[0-9]+]]:gpr = COPY [[COPY]] 122c92335eSCraig Topper ; CHECK-NEXT: {{ $}} 132c92335eSCraig Topper ; CHECK-NEXT: bb.1.for.cond: 142c92335eSCraig Topper ; CHECK-NEXT: successors: %bb.2(0x40000000), %bb.3(0x40000000) 152c92335eSCraig Topper ; CHECK-NEXT: {{ $}} 162c92335eSCraig Topper ; CHECK-NEXT: [[ANDI:%[0-9]+]]:gpr = ANDI [[COPY1]], 1 172c92335eSCraig Topper ; CHECK-NEXT: ADJCALLSTACKDOWN 8, 0, implicit-def dead $x2, implicit $x2 182c92335eSCraig Topper ; CHECK-NEXT: [[COPY2:%[0-9]+]]:gpr = COPY $x2 192c92335eSCraig Topper ; CHECK-NEXT: [[COPY3:%[0-9]+]]:gprjalr = COPY $x0 20*8ed18edeSCraig Topper ; CHECK-NEXT: SD [[COPY3]], [[COPY2]], 0 :: (store (s64) into stack) 212c92335eSCraig Topper ; CHECK-NEXT: [[ADDI:%[0-9]+]]:gpr = ADDI $x0, 1 222c92335eSCraig Topper ; CHECK-NEXT: [[ADDI1:%[0-9]+]]:gpr = ADDI $x0, 32 232c92335eSCraig Topper ; CHECK-NEXT: BNE [[ANDI]], $x0, %bb.3 242c92335eSCraig Topper ; CHECK-NEXT: {{ $}} 252c92335eSCraig Topper ; CHECK-NEXT: bb.2.for.cond (call-frame-size 8): 262c92335eSCraig Topper ; CHECK-NEXT: successors: %bb.3(0x80000000) 272c92335eSCraig Topper ; CHECK-NEXT: {{ $}} 282c92335eSCraig Topper ; CHECK-NEXT: bb.3.for.cond (call-frame-size 8): 292c92335eSCraig Topper ; CHECK-NEXT: successors: %bb.1(0x80000000) 302c92335eSCraig Topper ; CHECK-NEXT: {{ $}} 312c92335eSCraig Topper ; CHECK-NEXT: [[PHI:%[0-9]+]]:gpr = PHI [[ADDI1]], %bb.1, [[ADDI]], %bb.2 322c92335eSCraig Topper ; CHECK-NEXT: $x10 = COPY [[COPY3]] 332c92335eSCraig Topper ; CHECK-NEXT: $x11 = COPY [[PHI]] 342c92335eSCraig Topper ; CHECK-NEXT: $x12 = COPY [[COPY3]] 352c92335eSCraig Topper ; CHECK-NEXT: $x13 = COPY [[COPY3]] 362c92335eSCraig Topper ; CHECK-NEXT: $x14 = COPY [[COPY3]] 372c92335eSCraig Topper ; CHECK-NEXT: $x15 = COPY [[COPY3]] 382c92335eSCraig Topper ; CHECK-NEXT: $x16 = COPY [[COPY3]] 392c92335eSCraig Topper ; CHECK-NEXT: $x17 = COPY [[COPY3]] 402c92335eSCraig Topper ; CHECK-NEXT: PseudoCALLIndirect [[COPY3]], csr_ilp32_lp64, implicit-def dead $x1, implicit $x10, implicit $x11, implicit $x12, implicit $x13, implicit $x14, implicit $x15, implicit $x16, implicit $x17, implicit-def $x2, implicit-def $x10 412c92335eSCraig Topper ; CHECK-NEXT: ADJCALLSTACKUP 8, 0, implicit-def dead $x2, implicit $x2 422c92335eSCraig Topper ; CHECK-NEXT: [[COPY4:%[0-9]+]]:gpr = COPY $x10 432c92335eSCraig Topper ; CHECK-NEXT: PseudoBR %bb.1 442c92335eSCraig Topperentry: 452c92335eSCraig Topper br label %for.cond 462c92335eSCraig Topper 472c92335eSCraig Topperfor.cond: ; preds = %for.cond, %entry 482c92335eSCraig Topper %conv = select i1 %cmp436, i32 32, i32 1 492c92335eSCraig Topper %call479 = call i32 (ptr, ...) null(ptr null, i32 %conv, i32 0, i32 0, double 0.000000e+00, double 0.000000e+00, double 0.000000e+00, double 0.000000e+00, double 0.000000e+00) 502c92335eSCraig Topper br label %for.cond 512c92335eSCraig Topper} 52