# RUN: llc -run-pass x86-fixup-bw-insts -mtriple=x86_64-- -o - %s | FileCheck %s

# Verify that we correctly deal with the flag edge cases when replacing
# copies by bigger copies, which is a pretty unusual transform.

--- |
  target datalayout = "e-m:o-i64:64-f80:128-n8:16:32:64-S128"

  define i8 @test_movb_killed(i8 %a0) {
    ret i8 %a0
  }

  define i8 @test_movb_impuse(i8 %a0) {
    ret i8 %a0
  }

  define i8 @test_movb_impdef_gr64(i8 %a0) {
    ret i8 %a0
  }

  define i8 @test_movb_impdef_gr32(i8 %a0) {
    ret i8 %a0
  }

  define i8 @test_movb_impdef_gr16(i8 %a0) {
    ret i8 %a0
  }

  define i16 @test_movw_impdef_gr32(i16 %a0) {
    ret i16 %a0
  }

  define i16 @test_movw_impdef_gr64(i16 %a0) {
    ret i16 %a0
  }

...

---
name:            test_movb_killed
allVRegsAllocated: true
isSSA:           false
tracksRegLiveness: true
liveins:
  - { reg: '%edi' }
body:             |
  bb.0 (%ir-block.0):
    liveins: %edi

    ; CHECK: %eax = MOV32rr undef %edi, implicit %dil
    %al = MOV8rr killed %dil
    RETQ killed %al

...

---
name:            test_movb_impuse
allVRegsAllocated: true
isSSA:           false
tracksRegLiveness: true
liveins:
  - { reg: '%edi' }
body:             |
  bb.0 (%ir-block.0):
    liveins: %edi

    ; CHECK: %eax = MOV32rr undef %edi, implicit %dil
    %al = MOV8rr %dil, implicit %edi
    RETQ killed %al

...

---
name:            test_movb_impdef_gr64
allVRegsAllocated: true
isSSA:           false
tracksRegLiveness: true
liveins:
  - { reg: '%edi' }
body:             |
  bb.0 (%ir-block.0):
    liveins: %edi

    ; CHECK: %eax = MOV32rr undef %edi, implicit %dil, implicit-def %rax
    %al = MOV8rr %dil, implicit-def %rax
    RETQ killed %al

...

---
name:            test_movb_impdef_gr32
allVRegsAllocated: true
isSSA:           false
tracksRegLiveness: true
liveins:
  - { reg: '%edi' }
body:             |
  bb.0 (%ir-block.0):
    liveins: %edi

    ; CHECK: %eax = MOV32rr undef %edi, implicit %dil
    %al = MOV8rr %dil, implicit-def %eax
    RETQ killed %al

...

---
name:            test_movb_impdef_gr16
allVRegsAllocated: true
isSSA:           false
tracksRegLiveness: true
liveins:
  - { reg: '%edi' }
body:             |
  bb.0 (%ir-block.0):
    liveins: %edi

    ; CHECK: %eax = MOV32rr undef %edi, implicit %dil
    %al = MOV8rr %dil, implicit-def %ax
    RETQ killed %al

...

---
name:            test_movw_impdef_gr32
allVRegsAllocated: true
isSSA:           false
tracksRegLiveness: true
liveins:
  - { reg: '%edi' }
body:             |
  bb.0 (%ir-block.0):
    liveins: %edi

    ; CHECK: %eax = MOV32rr undef %edi, implicit %di
    %ax = MOV16rr %di, implicit-def %eax
    RETQ killed %ax

...

---
name:            test_movw_impdef_gr64
allVRegsAllocated: true
isSSA:           false
tracksRegLiveness: true
liveins:
  - { reg: '%edi' }
body:             |
  bb.0 (%ir-block.0):
    liveins: %edi

    ; CHECK: %eax = MOV32rr undef %edi, implicit %di, implicit-def %rax
    %ax = MOV16rr %di, implicit-def %rax
    RETQ killed %ax

...