1# NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py 2# RUN: llc -mtriple=x86_64-linux-gnu -run-pass=instruction-select -verify-machineinstrs %s -o - | FileCheck %s --check-prefix=CHECK 3 4--- | 5 define i8 @const_i8() { 6 ret i8 2 7 } 8 9 define i16 @const_i16() { 10 ret i16 3 11 } 12 13 define i32 @const_i32() { 14 ret i32 4 15 } 16 17 define i32 @const_i32_0() { 18 ret i32 0 19 } 20 21 define i64 @const_i64() { 22 ret i64 68719476720 23 } 24 25 define i64 @const_i64_u32() { 26 ret i64 1879048192 27 } 28 29 define i64 @const_i64_i32() { 30 ret i64 -1 31 } 32 33 define void @main(i32** %data) { 34 store i32* null, i32** %data, align 8 35 ret void 36 } 37 38... 39--- 40name: const_i8 41legalized: true 42regBankSelected: true 43selected: false 44registers: 45 - { id: 0, class: gpr } 46body: | 47 bb.1 (%ir-block.0): 48 ; CHECK-LABEL: name: const_i8 49 ; CHECK: [[MOV8ri:%[0-9]+]]:gr8 = MOV8ri 2 50 ; CHECK: $al = COPY [[MOV8ri]] 51 ; CHECK: RET 0, implicit $al 52 %0(s8) = G_CONSTANT i8 2 53 $al = COPY %0(s8) 54 RET 0, implicit $al 55 56... 57--- 58name: const_i16 59legalized: true 60regBankSelected: true 61selected: false 62registers: 63 - { id: 0, class: gpr } 64body: | 65 bb.1 (%ir-block.0): 66 ; CHECK-LABEL: name: const_i16 67 ; CHECK: [[MOV16ri:%[0-9]+]]:gr16 = MOV16ri 3 68 ; CHECK: $ax = COPY [[MOV16ri]] 69 ; CHECK: RET 0, implicit $ax 70 %0(s16) = G_CONSTANT i16 3 71 $ax = COPY %0(s16) 72 RET 0, implicit $ax 73 74... 75--- 76name: const_i32 77legalized: true 78regBankSelected: true 79selected: false 80registers: 81 - { id: 0, class: gpr } 82body: | 83 bb.1 (%ir-block.0): 84 ; CHECK-LABEL: name: const_i32 85 ; CHECK: [[MOV32ri:%[0-9]+]]:gr32 = MOV32ri 4 86 ; CHECK: $eax = COPY [[MOV32ri]] 87 ; CHECK: RET 0, implicit $eax 88 %0(s32) = G_CONSTANT i32 4 89 $eax = COPY %0(s32) 90 RET 0, implicit $eax 91 92... 93--- 94name: const_i32_0 95legalized: true 96regBankSelected: true 97registers: 98 - { id: 0, class: gpr } 99body: | 100 bb.1 (%ir-block.0): 101 ; CHECK-LABEL: name: const_i32_0 102 ; CHECK: [[MOV32r0_:%[0-9]+]]:gr32 = MOV32r0 implicit-def $eflags 103 ; CHECK: $eax = COPY [[MOV32r0_]] 104 ; CHECK: RET 0, implicit $eax 105 %0(s32) = G_CONSTANT i32 0 106 $eax = COPY %0(s32) 107 RET 0, implicit $eax 108 109... 110--- 111name: const_i64 112legalized: true 113regBankSelected: true 114selected: false 115registers: 116 - { id: 0, class: gpr } 117body: | 118 bb.1 (%ir-block.0): 119 ; CHECK-LABEL: name: const_i64 120 ; CHECK: [[MOV64ri:%[0-9]+]]:gr64 = MOV64ri 68719476720 121 ; CHECK: $rax = COPY [[MOV64ri]] 122 ; CHECK: RET 0, implicit $rax 123 %0(s64) = G_CONSTANT i64 68719476720 124 $rax = COPY %0(s64) 125 RET 0, implicit $rax 126 127... 128--- 129name: const_i64_u32 130alignment: 16 131legalized: true 132regBankSelected: true 133selected: false 134registers: 135 - { id: 0, class: gpr } 136body: | 137 bb.1 (%ir-block.0): 138 ; CHECK-LABEL: name: const_i64_u32 139 ; CHECK: [[MOV32ri64_:%[0-9]+]]:gr64 = MOV32ri64 1879048192 140 ; CHECK: $rax = COPY [[MOV32ri64_]] 141 ; CHECK: RET 0, implicit $rax 142 %0(s64) = G_CONSTANT i64 1879048192 143 $rax = COPY %0(s64) 144 RET 0, implicit $rax 145 146... 147--- 148name: const_i64_i32 149legalized: true 150regBankSelected: true 151selected: false 152registers: 153 - { id: 0, class: gpr } 154body: | 155 bb.1 (%ir-block.0): 156 ; CHECK-LABEL: name: const_i64_i32 157 ; CHECK: [[MOV64ri32_:%[0-9]+]]:gr64 = MOV64ri32 -1 158 ; CHECK: $rax = COPY [[MOV64ri32_]] 159 ; CHECK: RET 0, implicit $rax 160 %0(s64) = G_CONSTANT i64 -1 161 $rax = COPY %0(s64) 162 RET 0, implicit $rax 163 164... 165--- 166name: main 167alignment: 16 168legalized: true 169regBankSelected: true 170registers: 171 - { id: 0, class: gpr, preferred-register: '' } 172 - { id: 1, class: gpr, preferred-register: '' } 173body: | 174 bb.1 (%ir-block.0): 175 liveins: $rdi 176 177 ; CHECK-LABEL: name: main 178 ; CHECK: [[COPY:%[0-9]+]]:gr64 = COPY $rdi 179 ; CHECK: [[MOV64ri32_:%[0-9]+]]:gr64 = MOV64ri32 0 180 ; CHECK: MOV64mr [[COPY]], 1, $noreg, 0, $noreg, [[MOV64ri32_]] :: (store 8 into %ir.data) 181 ; CHECK: RET 0 182 %0(p0) = COPY $rdi 183 %1(p0) = G_CONSTANT i64 0 184 G_STORE %1(p0), %0(p0) :: (store 8 into %ir.data) 185 RET 0 186 187... 188