1# NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py 2# RUN: llc -mtriple=i386-linux-gnu -run-pass=legalizer %s -o - | FileCheck %s --check-prefix=X32 3# RUN: llc -mtriple=x86_64-linux-gnu -run-pass=legalizer %s -o - | FileCheck %s --check-prefix=X64 4--- | 5 6 define i8 @test_zext_i1toi8(i1 %a) { 7 %r = zext i1 %a to i8 8 ret i8 %r 9 } 10 11 define i16 @test_zext_i1toi16(i1 %a) { 12 %r = zext i1 %a to i16 13 ret i16 %r 14 } 15 16 define i32 @test_zext_i1(i8 %a) { 17 %val = trunc i8 %a to i1 18 %r = zext i1 %val to i32 19 ret i32 %r 20 } 21 22 define i16 @test_zext_i8toi16(i8 %val) { 23 %r = zext i8 %val to i16 24 ret i16 %r 25 } 26 27 define i32 @test_zext_i8(i8 %val) { 28 %r = zext i8 %val to i32 29 ret i32 %r 30 } 31 32 define i32 @test_zext_i16(i16 %val) { 33 %r = zext i16 %val to i32 34 ret i32 %r 35 } 36 37 define i8 @test_sext_i1toi8(i1 %a) { 38 %r = sext i1 %a to i8 39 ret i8 %r 40 } 41 42 define i16 @test_sext_i1toi16(i1 %a) { 43 %r = sext i1 %a to i16 44 ret i16 %r 45 } 46 47 define i32 @test_sext_i1(i8 %a) { 48 %val = trunc i8 %a to i1 49 %r = sext i1 %val to i32 50 ret i32 %r 51 } 52 53 define i16 @test_sext_i8toi16(i8 %val) { 54 %r = sext i8 %val to i16 55 ret i16 %r 56 } 57 58 define i32 @test_sext_i8(i8 %val) { 59 %r = sext i8 %val to i32 60 ret i32 %r 61 } 62 63 define i32 @test_sext_i16(i16 %val) { 64 %r = sext i16 %val to i32 65 ret i32 %r 66 } 67 68 define void @test_anyext_i1toi8(i1 %a) { 69 ret void 70 } 71 72 define void @test_anyext_i1toi16(i1 %a) { 73 ret void 74 } 75 76 define void @test_anyext_i1(i8 %a) { 77 ret void 78 } 79 80 define void @test_anyext_i8toi16(i8 %val) { 81 ret void 82 } 83 84 define void @test_anyext_i8(i8 %val) { 85 ret void 86 } 87 88 define void @test_anyext_i16(i16 %val) { 89 ret void 90 } 91 92... 93--- 94name: test_zext_i1toi8 95alignment: 16 96legalized: false 97regBankSelected: false 98registers: 99 - { id: 0, class: _, preferred-register: '' } 100 - { id: 1, class: _, preferred-register: '' } 101 - { id: 2, class: _, preferred-register: '' } 102body: | 103 bb.1 (%ir-block.0): 104 liveins: $edi 105 106 ; X32-LABEL: name: test_zext_i1toi8 107 ; X32: [[COPY:%[0-9]+]]:_(s32) = COPY $edi 108 ; X32: [[C:%[0-9]+]]:_(s8) = G_CONSTANT i8 1 109 ; X32: [[TRUNC:%[0-9]+]]:_(s8) = G_TRUNC [[COPY]](s32) 110 ; X32: [[AND:%[0-9]+]]:_(s8) = G_AND [[TRUNC]], [[C]] 111 ; X32: $al = COPY [[AND]](s8) 112 ; X32: RET 0, implicit $al 113 ; X64-LABEL: name: test_zext_i1toi8 114 ; X64: [[COPY:%[0-9]+]]:_(s32) = COPY $edi 115 ; X64: [[C:%[0-9]+]]:_(s8) = G_CONSTANT i8 1 116 ; X64: [[TRUNC:%[0-9]+]]:_(s8) = G_TRUNC [[COPY]](s32) 117 ; X64: [[AND:%[0-9]+]]:_(s8) = G_AND [[TRUNC]], [[C]] 118 ; X64: $al = COPY [[AND]](s8) 119 ; X64: RET 0, implicit $al 120 %1:_(s32) = COPY $edi 121 %0:_(s1) = G_TRUNC %1(s32) 122 %2:_(s8) = G_ZEXT %0(s1) 123 $al = COPY %2(s8) 124 RET 0, implicit $al 125 126... 127--- 128name: test_zext_i1toi16 129alignment: 16 130legalized: false 131regBankSelected: false 132registers: 133 - { id: 0, class: _, preferred-register: '' } 134 - { id: 1, class: _, preferred-register: '' } 135body: | 136 bb.1 (%ir-block.0): 137 liveins: $edi 138 139 ; X32-LABEL: name: test_zext_i1toi16 140 ; X32: [[COPY:%[0-9]+]]:_(s32) = COPY $edi 141 ; X32: [[C:%[0-9]+]]:_(s16) = G_CONSTANT i16 1 142 ; X32: [[TRUNC:%[0-9]+]]:_(s16) = G_TRUNC [[COPY]](s32) 143 ; X32: [[AND:%[0-9]+]]:_(s16) = G_AND [[TRUNC]], [[C]] 144 ; X32: $ax = COPY [[AND]](s16) 145 ; X32: RET 0, implicit $ax 146 ; X64-LABEL: name: test_zext_i1toi16 147 ; X64: [[COPY:%[0-9]+]]:_(s32) = COPY $edi 148 ; X64: [[C:%[0-9]+]]:_(s16) = G_CONSTANT i16 1 149 ; X64: [[TRUNC:%[0-9]+]]:_(s16) = G_TRUNC [[COPY]](s32) 150 ; X64: [[AND:%[0-9]+]]:_(s16) = G_AND [[TRUNC]], [[C]] 151 ; X64: $ax = COPY [[AND]](s16) 152 ; X64: RET 0, implicit $ax 153 %1:_(s32) = COPY $edi 154 %0:_(s1) = G_TRUNC %1(s32) 155 %2:_(s16) = G_ZEXT %0(s1) 156 $ax = COPY %2(s16) 157 RET 0, implicit $ax 158 159... 160--- 161name: test_zext_i1 162alignment: 16 163legalized: false 164regBankSelected: false 165registers: 166 - { id: 0, class: _ } 167 - { id: 1, class: _ } 168 - { id: 2, class: _ } 169body: | 170 bb.1 (%ir-block.0): 171 liveins: $edi 172 173 ; X32-LABEL: name: test_zext_i1 174 ; X32: [[COPY:%[0-9]+]]:_(s8) = COPY $dil 175 ; X32: [[C:%[0-9]+]]:_(s32) = G_CONSTANT i32 1 176 ; X32: [[ANYEXT:%[0-9]+]]:_(s32) = G_ANYEXT [[COPY]](s8) 177 ; X32: [[AND:%[0-9]+]]:_(s32) = G_AND [[ANYEXT]], [[C]] 178 ; X32: $eax = COPY [[AND]](s32) 179 ; X32: RET 0, implicit $eax 180 ; X64-LABEL: name: test_zext_i1 181 ; X64: [[COPY:%[0-9]+]]:_(s8) = COPY $dil 182 ; X64: [[C:%[0-9]+]]:_(s32) = G_CONSTANT i32 1 183 ; X64: [[ANYEXT:%[0-9]+]]:_(s32) = G_ANYEXT [[COPY]](s8) 184 ; X64: [[AND:%[0-9]+]]:_(s32) = G_AND [[ANYEXT]], [[C]] 185 ; X64: $eax = COPY [[AND]](s32) 186 ; X64: RET 0, implicit $eax 187 %0(s8) = COPY $dil 188 %1(s1) = G_TRUNC %0(s8) 189 %2(s32) = G_ZEXT %1(s1) 190 $eax = COPY %2(s32) 191 RET 0, implicit $eax 192 193... 194--- 195name: test_zext_i8toi16 196alignment: 16 197legalized: false 198regBankSelected: false 199registers: 200 - { id: 0, class: _, preferred-register: '' } 201 - { id: 1, class: _, preferred-register: '' } 202body: | 203 bb.1 (%ir-block.0): 204 liveins: $edi 205 206 ; X32-LABEL: name: test_zext_i8toi16 207 ; X32: [[COPY:%[0-9]+]]:_(s8) = COPY $dil 208 ; X32: [[ZEXT:%[0-9]+]]:_(s16) = G_ZEXT [[COPY]](s8) 209 ; X32: $ax = COPY [[ZEXT]](s16) 210 ; X32: RET 0, implicit $ax 211 ; X64-LABEL: name: test_zext_i8toi16 212 ; X64: [[COPY:%[0-9]+]]:_(s8) = COPY $dil 213 ; X64: [[ZEXT:%[0-9]+]]:_(s16) = G_ZEXT [[COPY]](s8) 214 ; X64: $ax = COPY [[ZEXT]](s16) 215 ; X64: RET 0, implicit $ax 216 %0(s8) = COPY $dil 217 %1(s16) = G_ZEXT %0(s8) 218 $ax = COPY %1(s16) 219 RET 0, implicit $ax 220 221... 222--- 223name: test_zext_i8 224alignment: 16 225legalized: false 226regBankSelected: false 227registers: 228 - { id: 0, class: _ } 229 - { id: 1, class: _ } 230body: | 231 bb.1 (%ir-block.0): 232 liveins: $edi 233 234 ; X32-LABEL: name: test_zext_i8 235 ; X32: [[COPY:%[0-9]+]]:_(s8) = COPY $dil 236 ; X32: [[ZEXT:%[0-9]+]]:_(s32) = G_ZEXT [[COPY]](s8) 237 ; X32: $eax = COPY [[ZEXT]](s32) 238 ; X32: RET 0, implicit $eax 239 ; X64-LABEL: name: test_zext_i8 240 ; X64: [[COPY:%[0-9]+]]:_(s8) = COPY $dil 241 ; X64: [[ZEXT:%[0-9]+]]:_(s32) = G_ZEXT [[COPY]](s8) 242 ; X64: $eax = COPY [[ZEXT]](s32) 243 ; X64: RET 0, implicit $eax 244 %0(s8) = COPY $dil 245 %1(s32) = G_ZEXT %0(s8) 246 $eax = COPY %1(s32) 247 RET 0, implicit $eax 248 249... 250--- 251name: test_zext_i16 252alignment: 16 253legalized: false 254regBankSelected: false 255registers: 256 - { id: 0, class: _ } 257 - { id: 1, class: _ } 258body: | 259 bb.1 (%ir-block.0): 260 liveins: $edi 261 262 ; X32-LABEL: name: test_zext_i16 263 ; X32: [[COPY:%[0-9]+]]:_(s16) = COPY $di 264 ; X32: [[ZEXT:%[0-9]+]]:_(s32) = G_ZEXT [[COPY]](s16) 265 ; X32: $eax = COPY [[ZEXT]](s32) 266 ; X32: RET 0, implicit $eax 267 ; X64-LABEL: name: test_zext_i16 268 ; X64: [[COPY:%[0-9]+]]:_(s16) = COPY $di 269 ; X64: [[ZEXT:%[0-9]+]]:_(s32) = G_ZEXT [[COPY]](s16) 270 ; X64: $eax = COPY [[ZEXT]](s32) 271 ; X64: RET 0, implicit $eax 272 %0(s16) = COPY $di 273 %1(s32) = G_ZEXT %0(s16) 274 $eax = COPY %1(s32) 275 RET 0, implicit $eax 276 277... 278--- 279name: test_sext_i1toi8 280alignment: 16 281legalized: false 282regBankSelected: false 283registers: 284 - { id: 0, class: _, preferred-register: '' } 285 - { id: 1, class: _, preferred-register: '' } 286body: | 287 bb.1 (%ir-block.0): 288 liveins: $edi 289 290 ; X32-LABEL: name: test_sext_i1toi8 291 ; X32: [[C:%[0-9]+]]:_(s8) = G_CONSTANT i8 0 292 ; X32: $al = COPY [[C]](s8) 293 ; X32: RET 0, implicit $al 294 ; X64-LABEL: name: test_sext_i1toi8 295 ; X64: [[C:%[0-9]+]]:_(s8) = G_CONSTANT i8 0 296 ; X64: $al = COPY [[C]](s8) 297 ; X64: RET 0, implicit $al 298 %0(s1) = G_IMPLICIT_DEF 299 %1(s8) = G_SEXT %0(s1) 300 $al = COPY %1(s8) 301 RET 0, implicit $al 302 303... 304--- 305name: test_sext_i1toi16 306alignment: 16 307legalized: false 308regBankSelected: false 309registers: 310 - { id: 0, class: _, preferred-register: '' } 311 - { id: 1, class: _, preferred-register: '' } 312body: | 313 bb.1 (%ir-block.0): 314 liveins: $edi 315 316 ; X32-LABEL: name: test_sext_i1toi16 317 ; X32: [[C:%[0-9]+]]:_(s16) = G_CONSTANT i16 0 318 ; X32: $ax = COPY [[C]](s16) 319 ; X32: RET 0, implicit $ax 320 ; X64-LABEL: name: test_sext_i1toi16 321 ; X64: [[C:%[0-9]+]]:_(s16) = G_CONSTANT i16 0 322 ; X64: $ax = COPY [[C]](s16) 323 ; X64: RET 0, implicit $ax 324 %0(s1) = G_IMPLICIT_DEF 325 %1(s16) = G_SEXT %0(s1) 326 $ax = COPY %1(s16) 327 RET 0, implicit $ax 328 329... 330--- 331name: test_sext_i1 332alignment: 16 333legalized: false 334regBankSelected: false 335registers: 336 - { id: 0, class: _ } 337 - { id: 1, class: _ } 338 - { id: 2, class: _ } 339body: | 340 bb.1 (%ir-block.0): 341 liveins: $edi 342 343 ; X32-LABEL: name: test_sext_i1 344 ; X32: [[C:%[0-9]+]]:_(s32) = G_CONSTANT i32 0 345 ; X32: $eax = COPY [[C]](s32) 346 ; X32: RET 0, implicit $eax 347 ; X64-LABEL: name: test_sext_i1 348 ; X64: [[C:%[0-9]+]]:_(s32) = G_CONSTANT i32 0 349 ; X64: $eax = COPY [[C]](s32) 350 ; X64: RET 0, implicit $eax 351 %0(s1) = G_IMPLICIT_DEF 352 %2(s32) = G_SEXT %0(s1) 353 $eax = COPY %2(s32) 354 RET 0, implicit $eax 355 356... 357--- 358name: test_sext_i8toi16 359alignment: 16 360legalized: false 361regBankSelected: false 362registers: 363 - { id: 0, class: _, preferred-register: '' } 364 - { id: 1, class: _, preferred-register: '' } 365body: | 366 bb.1 (%ir-block.0): 367 liveins: $edi 368 369 ; X32-LABEL: name: test_sext_i8toi16 370 ; X32: [[COPY:%[0-9]+]]:_(s8) = COPY $dil 371 ; X32: [[SEXT:%[0-9]+]]:_(s16) = G_SEXT [[COPY]](s8) 372 ; X32: $ax = COPY [[SEXT]](s16) 373 ; X32: RET 0, implicit $ax 374 ; X64-LABEL: name: test_sext_i8toi16 375 ; X64: [[COPY:%[0-9]+]]:_(s8) = COPY $dil 376 ; X64: [[SEXT:%[0-9]+]]:_(s16) = G_SEXT [[COPY]](s8) 377 ; X64: $ax = COPY [[SEXT]](s16) 378 ; X64: RET 0, implicit $ax 379 %0(s8) = COPY $dil 380 %1(s16) = G_SEXT %0(s8) 381 $ax = COPY %1(s16) 382 RET 0, implicit $ax 383 384... 385--- 386name: test_sext_i8 387alignment: 16 388legalized: false 389regBankSelected: false 390registers: 391 - { id: 0, class: _ } 392 - { id: 1, class: _ } 393body: | 394 bb.1 (%ir-block.0): 395 liveins: $edi 396 397 ; X32-LABEL: name: test_sext_i8 398 ; X32: [[COPY:%[0-9]+]]:_(s8) = COPY $dil 399 ; X32: [[SEXT:%[0-9]+]]:_(s32) = G_SEXT [[COPY]](s8) 400 ; X32: $eax = COPY [[SEXT]](s32) 401 ; X32: RET 0, implicit $eax 402 ; X64-LABEL: name: test_sext_i8 403 ; X64: [[COPY:%[0-9]+]]:_(s8) = COPY $dil 404 ; X64: [[SEXT:%[0-9]+]]:_(s32) = G_SEXT [[COPY]](s8) 405 ; X64: $eax = COPY [[SEXT]](s32) 406 ; X64: RET 0, implicit $eax 407 %0(s8) = COPY $dil 408 %1(s32) = G_SEXT %0(s8) 409 $eax = COPY %1(s32) 410 RET 0, implicit $eax 411 412... 413--- 414name: test_sext_i16 415alignment: 16 416legalized: false 417regBankSelected: false 418registers: 419 - { id: 0, class: _ } 420 - { id: 1, class: _ } 421body: | 422 bb.1 (%ir-block.0): 423 liveins: $edi 424 425 ; X32-LABEL: name: test_sext_i16 426 ; X32: [[COPY:%[0-9]+]]:_(s16) = COPY $di 427 ; X32: [[SEXT:%[0-9]+]]:_(s32) = G_SEXT [[COPY]](s16) 428 ; X32: $eax = COPY [[SEXT]](s32) 429 ; X32: RET 0, implicit $eax 430 ; X64-LABEL: name: test_sext_i16 431 ; X64: [[COPY:%[0-9]+]]:_(s16) = COPY $di 432 ; X64: [[SEXT:%[0-9]+]]:_(s32) = G_SEXT [[COPY]](s16) 433 ; X64: $eax = COPY [[SEXT]](s32) 434 ; X64: RET 0, implicit $eax 435 %0(s16) = COPY $di 436 %1(s32) = G_SEXT %0(s16) 437 $eax = COPY %1(s32) 438 RET 0, implicit $eax 439 440... 441--- 442name: test_anyext_i1toi8 443alignment: 16 444legalized: false 445regBankSelected: false 446registers: 447 - { id: 0, class: _, preferred-register: '' } 448 - { id: 1, class: _, preferred-register: '' } 449 - { id: 2, class: _, preferred-register: '' } 450body: | 451 bb.1 (%ir-block.0): 452 liveins: $edi 453 454 ; X32-LABEL: name: test_anyext_i1toi8 455 ; X32: [[COPY:%[0-9]+]]:_(s32) = COPY $edi 456 ; X32: [[TRUNC:%[0-9]+]]:_(s8) = G_TRUNC [[COPY]](s32) 457 ; X32: $al = COPY [[TRUNC]](s8) 458 ; X32: RET 0, implicit $al 459 ; X64-LABEL: name: test_anyext_i1toi8 460 ; X64: [[COPY:%[0-9]+]]:_(s32) = COPY $edi 461 ; X64: [[TRUNC:%[0-9]+]]:_(s8) = G_TRUNC [[COPY]](s32) 462 ; X64: $al = COPY [[TRUNC]](s8) 463 ; X64: RET 0, implicit $al 464 %0(s32) = COPY $edi 465 %1(s1) = G_TRUNC %0(s32) 466 %2(s8) = G_ANYEXT %1(s1) 467 $al = COPY %2(s8) 468 RET 0, implicit $al 469 470... 471--- 472name: test_anyext_i1toi16 473alignment: 16 474legalized: false 475regBankSelected: false 476registers: 477 - { id: 0, class: _, preferred-register: '' } 478 - { id: 1, class: _, preferred-register: '' } 479 - { id: 2, class: _, preferred-register: '' } 480body: | 481 bb.1 (%ir-block.0): 482 liveins: $edi 483 484 ; X32-LABEL: name: test_anyext_i1toi16 485 ; X32: [[COPY:%[0-9]+]]:_(s32) = COPY $edi 486 ; X32: [[TRUNC:%[0-9]+]]:_(s16) = G_TRUNC [[COPY]](s32) 487 ; X32: $ax = COPY [[TRUNC]](s16) 488 ; X32: RET 0, implicit $ax 489 ; X64-LABEL: name: test_anyext_i1toi16 490 ; X64: [[COPY:%[0-9]+]]:_(s32) = COPY $edi 491 ; X64: [[TRUNC:%[0-9]+]]:_(s16) = G_TRUNC [[COPY]](s32) 492 ; X64: $ax = COPY [[TRUNC]](s16) 493 ; X64: RET 0, implicit $ax 494 %0(s32) = COPY $edi 495 %1(s1) = G_TRUNC %0(s32) 496 %2(s16) = G_ANYEXT %1(s1) 497 $ax = COPY %2(s16) 498 RET 0, implicit $ax 499 500... 501--- 502name: test_anyext_i1 503alignment: 16 504legalized: false 505regBankSelected: false 506registers: 507 - { id: 0, class: _ } 508 - { id: 1, class: _ } 509 - { id: 2, class: _ } 510body: | 511 bb.1 (%ir-block.0): 512 liveins: $edi 513 514 ; X32-LABEL: name: test_anyext_i1 515 ; X32: [[COPY:%[0-9]+]]:_(s8) = COPY $dil 516 ; X32: [[ANYEXT:%[0-9]+]]:_(s32) = G_ANYEXT [[COPY]](s8) 517 ; X32: $eax = COPY [[ANYEXT]](s32) 518 ; X32: RET 0, implicit $eax 519 ; X64-LABEL: name: test_anyext_i1 520 ; X64: [[COPY:%[0-9]+]]:_(s8) = COPY $dil 521 ; X64: [[ANYEXT:%[0-9]+]]:_(s32) = G_ANYEXT [[COPY]](s8) 522 ; X64: $eax = COPY [[ANYEXT]](s32) 523 ; X64: RET 0, implicit $eax 524 %0(s8) = COPY $dil 525 %1(s1) = G_TRUNC %0(s8) 526 %2(s32) = G_ANYEXT %1(s1) 527 $eax = COPY %2(s32) 528 RET 0, implicit $eax 529 530... 531--- 532name: test_anyext_i8toi16 533alignment: 16 534legalized: false 535regBankSelected: false 536registers: 537 - { id: 0, class: _, preferred-register: '' } 538 - { id: 1, class: _, preferred-register: '' } 539body: | 540 bb.1 (%ir-block.0): 541 liveins: $edi 542 543 ; X32-LABEL: name: test_anyext_i8toi16 544 ; X32: [[COPY:%[0-9]+]]:_(s8) = COPY $dil 545 ; X32: [[ANYEXT:%[0-9]+]]:_(s16) = G_ANYEXT [[COPY]](s8) 546 ; X32: $ax = COPY [[ANYEXT]](s16) 547 ; X32: RET 0, implicit $ax 548 ; X64-LABEL: name: test_anyext_i8toi16 549 ; X64: [[COPY:%[0-9]+]]:_(s8) = COPY $dil 550 ; X64: [[ANYEXT:%[0-9]+]]:_(s16) = G_ANYEXT [[COPY]](s8) 551 ; X64: $ax = COPY [[ANYEXT]](s16) 552 ; X64: RET 0, implicit $ax 553 %0(s8) = COPY $dil 554 %1(s16) = G_ANYEXT %0(s8) 555 $ax = COPY %1(s16) 556 RET 0, implicit $ax 557 558... 559--- 560name: test_anyext_i8 561alignment: 16 562legalized: false 563regBankSelected: false 564registers: 565 - { id: 0, class: _ } 566 - { id: 1, class: _ } 567body: | 568 bb.1 (%ir-block.0): 569 liveins: $edi 570 571 ; X32-LABEL: name: test_anyext_i8 572 ; X32: [[COPY:%[0-9]+]]:_(s8) = COPY $dil 573 ; X32: [[ANYEXT:%[0-9]+]]:_(s32) = G_ANYEXT [[COPY]](s8) 574 ; X32: $eax = COPY [[ANYEXT]](s32) 575 ; X32: RET 0, implicit $eax 576 ; X64-LABEL: name: test_anyext_i8 577 ; X64: [[COPY:%[0-9]+]]:_(s8) = COPY $dil 578 ; X64: [[ANYEXT:%[0-9]+]]:_(s32) = G_ANYEXT [[COPY]](s8) 579 ; X64: $eax = COPY [[ANYEXT]](s32) 580 ; X64: RET 0, implicit $eax 581 %0(s8) = COPY $dil 582 %1(s32) = G_ANYEXT %0(s8) 583 $eax = COPY %1(s32) 584 RET 0, implicit $eax 585 586... 587--- 588name: test_anyext_i16 589alignment: 16 590legalized: false 591regBankSelected: false 592registers: 593 - { id: 0, class: _ } 594 - { id: 1, class: _ } 595body: | 596 bb.1 (%ir-block.0): 597 liveins: $edi 598 599 ; X32-LABEL: name: test_anyext_i16 600 ; X32: [[COPY:%[0-9]+]]:_(s16) = COPY $di 601 ; X32: [[ANYEXT:%[0-9]+]]:_(s32) = G_ANYEXT [[COPY]](s16) 602 ; X32: $eax = COPY [[ANYEXT]](s32) 603 ; X32: RET 0, implicit $eax 604 ; X64-LABEL: name: test_anyext_i16 605 ; X64: [[COPY:%[0-9]+]]:_(s16) = COPY $di 606 ; X64: [[ANYEXT:%[0-9]+]]:_(s32) = G_ANYEXT [[COPY]](s16) 607 ; X64: $eax = COPY [[ANYEXT]](s32) 608 ; X64: RET 0, implicit $eax 609 %0(s16) = COPY $di 610 %1(s32) = G_ANYEXT %0(s16) 611 $eax = COPY %1(s32) 612 RET 0, implicit $eax 613 614... 615