summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAndrei Elovikov <andrei.elovikov@intel.com>2018-01-30 14:25:12 +0000
committerAndrei Elovikov <andrei.elovikov@intel.com>2018-01-30 14:25:12 +0000
commitce256fd5f76a0613abe29172c3225cf77c0dc2f4 (patch)
treed8e456c9b9860f222145b63167c3df5382421fab
parent0b69b5ed85c298ca72150b81849c4f57d30e355e (diff)
downloadbcm5719-llvm-ce256fd5f76a0613abe29172c3225cf77c0dc2f4.tar.gz
bcm5719-llvm-ce256fd5f76a0613abe29172c3225cf77c0dc2f4.zip
[X86FixupBWInsts] mir-simplify fixup-bw-inst.mir test. NFC.
llvm-svn: 323762
-rw-r--r--llvm/test/CodeGen/X86/fixup-bw-inst.mir104
1 files changed, 5 insertions, 99 deletions
diff --git a/llvm/test/CodeGen/X86/fixup-bw-inst.mir b/llvm/test/CodeGen/X86/fixup-bw-inst.mir
index 46ffcd3b170..e26fa7292fa 100644
--- a/llvm/test/CodeGen/X86/fixup-bw-inst.mir
+++ b/llvm/test/CodeGen/X86/fixup-bw-inst.mir
@@ -34,24 +34,15 @@
}
define void @test5() {ret void}
+
...
---
# CHECK-LABEL: name: test1
name: test1
alignment: 4
-exposesReturnsTwice: false
-legalized: false
-regBankSelected: false
-selected: false
tracksRegLiveness: true
-registers:
liveins:
- { reg: '%rax' }
-frameInfo:
- stackSize: 0
-fixedStack:
-stack:
-constants:
# Verify that "movw (%rax), %ax" is changed to "movzwl (%rax), %rax".
#
# For that to happen, the liveness information after the MOV16rm
@@ -71,19 +62,9 @@ body: |
# CHECK-LABEL: name: test2
name: test2
alignment: 4
-exposesReturnsTwice: false
-legalized: false
-regBankSelected: false
-selected: false
tracksRegLiveness: true
-registers:
liveins:
- { reg: '%rax' }
-frameInfo:
- stackSize: 0
-fixedStack:
-stack:
-constants:
# Imp-use of any super-register means the register is live before the MOV
body: |
bb.0:
@@ -102,34 +83,9 @@ body: |
# CHECK-LABEL: name: test3
name: test3
alignment: 4
-exposesReturnsTwice: false
-legalized: false
-regBankSelected: false
-selected: false
tracksRegLiveness: true
-registers:
liveins:
- - { reg: '%rdi', virtual-reg: '' }
-frameInfo:
- isFrameAddressTaken: false
- isReturnAddressTaken: false
- hasStackMap: false
- hasPatchPoint: false
- stackSize: 0
- offsetAdjustment: 0
- maxAlignment: 0
- adjustsStack: false
- hasCalls: false
- stackProtector: ''
- maxCallFrameSize: 0
- hasOpaqueSPAdjustment: false
- hasVAStart: false
- hasMustTailInVarArgFunc: false
- savePoint: ''
- restorePoint: ''
-fixedStack:
-stack:
-constants:
+ - { reg: '%rdi' }
# After MOV16rm the whole %eax is not *really* live, as can be seen by
# missing implicit-uses of it in that MOV. Make sure that MOV is
# transformed into MOVZX.
@@ -161,86 +117,36 @@ body: |
# CHECK-LABEL: name: test4
name: test4
alignment: 4
-exposesReturnsTwice: false
-legalized: false
-regBankSelected: false
-selected: false
tracksRegLiveness: true
-registers:
liveins:
- { reg: '%r9d' }
-frameInfo:
- isFrameAddressTaken: false
- isReturnAddressTaken: false
- hasStackMap: false
- hasPatchPoint: false
- stackSize: 0
- offsetAdjustment: 0
- maxAlignment: 0
- adjustsStack: false
- hasCalls: false
- stackProtector: ''
- maxCallFrameSize: 0
- hasOpaqueSPAdjustment: false
- hasVAStart: false
- hasMustTailInVarArgFunc: false
- savePoint: ''
- restorePoint: ''
-fixedStack:
-stack:
-constants:
# This code copies r10b into r9b and then uses r9w. We would like to promote
# the copy to a 32-bit copy, but because r9w is used this is not acceptable.
body: |
bb.0.entry:
- successors:
liveins: %r9d
%r9b = MOV8rr undef %r10b, implicit-def %r9d, implicit killed %r9d, implicit-def %eflags
; CHECK: %r9b = MOV8rr undef %r10b, implicit-def %r9d, implicit killed %r9d, implicit-def %eflags
+
%ax = OR16rr undef %ax, %r9w, implicit-def %eflags
RETQ %ax
-...
+...
---
# CHECK-LABEL: name: test5
name: test5
alignment: 4
-exposesReturnsTwice: false
-legalized: false
-regBankSelected: false
-selected: false
tracksRegLiveness: true
-registers:
liveins:
- { reg: '%ch', reg: '%bl' }
-frameInfo:
- isFrameAddressTaken: false
- isReturnAddressTaken: false
- hasStackMap: false
- hasPatchPoint: false
- stackSize: 0
- offsetAdjustment: 0
- maxAlignment: 0
- adjustsStack: false
- hasCalls: false
- stackProtector: ''
- maxCallFrameSize: 0
- hasOpaqueSPAdjustment: false
- hasVAStart: false
- hasMustTailInVarArgFunc: false
- savePoint: ''
- restorePoint: ''
-fixedStack:
-stack:
-constants:
body: |
bb.0:
- successors:
liveins: %ch, %bl
%cl = MOV8rr %bl, implicit-def %cx, implicit killed %ch, implicit-def %eflags
; CHECK: %cl = MOV8rr %bl, implicit-def %cx, implicit killed %ch, implicit-def %eflags
RETQ %cx
+
...
OpenPOWER on IntegriCloud