[TableGen] Add TreePatternNode::children and use it in for loops (NFC) (#119877)
[llvm-project.git] / llvm / test / CodeGen / RISCV / GlobalISel / regbankselect / minmax-rv64.mir
blob2fb680fd15d8fec0f54d0e11182f350fcf884523
1 # NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py
2 # RUN: llc -mtriple=riscv64 -mattr=+zbb -run-pass=regbankselect \
3 # RUN:   -simplify-mir -verify-machineinstrs %s \
4 # RUN:   -o - | FileCheck -check-prefix=RV64I %s
6 ---
7 name:            smax_i64
8 legalized:       true
9 body:             |
10   bb.0.entry:
11     ; RV64I-LABEL: name: smax_i64
12     ; RV64I: [[COPY:%[0-9]+]]:gprb(s64) = COPY $x10
13     ; RV64I-NEXT: [[COPY1:%[0-9]+]]:gprb(s64) = COPY $x11
14     ; RV64I-NEXT: [[SMAX:%[0-9]+]]:gprb(s64) = G_SMAX [[COPY]], [[COPY1]]
15     ; RV64I-NEXT: $x10 = COPY [[SMAX]](s64)
16     ; RV64I-NEXT: PseudoRET implicit $x10
17     %0:_(s64) = COPY $x10
18     %1:_(s64) = COPY $x11
19     %2:_(s64) = G_SMAX %0, %1
20     $x10 = COPY %2(s64)
21     PseudoRET implicit $x10
23 ...
24 ---
25 name:            smin_i64
26 legalized:       true
27 body:             |
28   bb.0.entry:
29     ; RV64I-LABEL: name: smin_i64
30     ; RV64I: [[COPY:%[0-9]+]]:gprb(s64) = COPY $x10
31     ; RV64I-NEXT: [[COPY1:%[0-9]+]]:gprb(s64) = COPY $x11
32     ; RV64I-NEXT: [[SMIN:%[0-9]+]]:gprb(s64) = G_SMIN [[COPY]], [[COPY1]]
33     ; RV64I-NEXT: $x10 = COPY [[SMIN]](s64)
34     ; RV64I-NEXT: PseudoRET implicit $x10
35     %0:_(s64) = COPY $x10
36     %1:_(s64) = COPY $x11
37     %2:_(s64) = G_SMIN %0, %1
38     $x10 = COPY %2(s64)
39     PseudoRET implicit $x10
41 ...
42 ---
43 name:            umax_i64
44 legalized:       true
45 body:             |
46   bb.0.entry:
47     ; RV64I-LABEL: name: umax_i64
48     ; RV64I: [[COPY:%[0-9]+]]:gprb(s64) = COPY $x10
49     ; RV64I-NEXT: [[COPY1:%[0-9]+]]:gprb(s64) = COPY $x11
50     ; RV64I-NEXT: [[UMAX:%[0-9]+]]:gprb(s64) = G_UMAX [[COPY]], [[COPY1]]
51     ; RV64I-NEXT: $x10 = COPY [[UMAX]](s64)
52     ; RV64I-NEXT: PseudoRET implicit $x10
53     %0:_(s64) = COPY $x10
54     %1:_(s64) = COPY $x11
55     %2:_(s64) = G_UMAX %0, %1
56     $x10 = COPY %2(s64)
57     PseudoRET implicit $x10
59 ...
60 ---
61 name:            umin_i64
62 legalized:       true
63 body:             |
64   bb.0.entry:
65     ; RV64I-LABEL: name: umin_i64
66     ; RV64I: [[COPY:%[0-9]+]]:gprb(s64) = COPY $x10
67     ; RV64I-NEXT: [[COPY1:%[0-9]+]]:gprb(s64) = COPY $x11
68     ; RV64I-NEXT: [[UMIN:%[0-9]+]]:gprb(s64) = G_UMIN [[COPY]], [[COPY1]]
69     ; RV64I-NEXT: $x10 = COPY [[UMIN]](s64)
70     ; RV64I-NEXT: PseudoRET implicit $x10
71     %0:_(s64) = COPY $x10
72     %1:_(s64) = COPY $x11
73     %2:_(s64) = G_UMIN %0, %1
74     $x10 = COPY %2(s64)
75     PseudoRET implicit $x10
77 ...