llvm-mirror/test/CodeGen/X86/fixup-bw-copy.mir
Puyan Lotfi d4c615be8c Followup on Proposal to move MIR physical register namespace to '$' sigil.
Discussed here:

http://lists.llvm.org/pipermail/llvm-dev/2018-January/120320.html

In preparation for adding support for named vregs we are changing the sigil for
physical registers in MIR to '$' from '%'. This will prevent name clashes of
named physical register with named vregs.

llvm-svn: 323922
2018-01-31 22:04:26 +00:00

143 lines
2.6 KiB
YAML

# 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
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
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
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
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
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
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
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
...