xref: /llvm-project/llvm/test/CodeGen/RISCV/pr97304.ll (revision 8ed18eded9550ba1c079ddf169e657b0673e11c9)
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