1042 lines
26 KiB
Plaintext
1042 lines
26 KiB
Plaintext
|
# RUN: llc -run-pass x86-fixup-LEAs -mtriple=x86_64-gnu-unknown -verify-machineinstrs -mcpu=corei7-avx -o - %s | FileCheck %s
|
||
|
--- |
|
||
|
; ModuleID = 'lea-2.ll'
|
||
|
source_filename = "lea-2.ll"
|
||
|
target datalayout = "e-m:e-i64:64-f80:128-n8:16:32:64-S128"
|
||
|
;generated using: llc -stop-after x86-pad-short-functions lea-2.ll > leaFinxup64.mir
|
||
|
|
||
|
;testleaadd_64_32_1: 3 operands LEA64_32r cannot be replaced with 2 add instructions
|
||
|
; but can be replaced with 1 lea + 1 add
|
||
|
define i32 @testleaadd_64_32_1() {
|
||
|
ret i32 0
|
||
|
}
|
||
|
|
||
|
;testleaadd_rbp_64_32_1: 3 operands LEA64_32r cannot be replaced with 2 add instructions
|
||
|
; where the base is rbp/r13/ebp register but it can be replaced with 1 lea + 1 add
|
||
|
define i32 @testleaadd_rbp_64_32_1() {
|
||
|
ret i32 0
|
||
|
}
|
||
|
|
||
|
;test1lea_rbp_64_32_1: 2 operands LEA64_32r where base register is rbp/r13/ebp and can not
|
||
|
; be replaced with an add instruction but can be replaced with 1 lea instruction
|
||
|
define i32 @test1lea_rbp_64_32_1() {
|
||
|
ret i32 0
|
||
|
}
|
||
|
|
||
|
;test2add_64: 3 operands LEA64r that can be replaced with 2 add instructions
|
||
|
define i32 @test2add_64() {
|
||
|
ret i32 0
|
||
|
}
|
||
|
|
||
|
;test2add_rbp_64: 3 operands LEA64r that can be replaced with 2 add instructions
|
||
|
; where the base is rbp/r13/ebp register
|
||
|
define i32 @test2add_rbp_64() {
|
||
|
ret i32 0
|
||
|
}
|
||
|
|
||
|
;test1add_rbp_64: 2 operands LEA64r where base register is rbp/r13/ebp and can be replaced
|
||
|
; with an add instruction
|
||
|
define i32 @test1add_rbp_64() {
|
||
|
ret i32 0
|
||
|
}
|
||
|
|
||
|
;testleaadd_64_32: 3 operands LEA64_32r that can be replaced with 1 lea 1 add instructions
|
||
|
define i32 @testleaadd_64_32() {
|
||
|
ret i32 0
|
||
|
}
|
||
|
|
||
|
;testleaadd_rbp_64_32: 3 operands LEA64_32r that can be replaced with 1 lea 1 add instructions
|
||
|
; where the base is rbp/r13/ebp register
|
||
|
define i32 @testleaadd_rbp_64_32() {
|
||
|
ret i32 0
|
||
|
}
|
||
|
|
||
|
;test1lea_rbp_64_32: 2 operands LEA64_32r where base register is rbp/r13/ebp and can be replaced
|
||
|
; with a lea instruction
|
||
|
define i32 @test1lea_rbp_64_32() {
|
||
|
ret i32 0
|
||
|
}
|
||
|
|
||
|
;testleaadd_64: 3 operands LEA64r that can be replaced with 1 lea 1 add instructions
|
||
|
define i32 @testleaadd_64() {
|
||
|
ret i32 0
|
||
|
}
|
||
|
|
||
|
;testleaadd_rbp_64: 3 operands LEA64r that can be replaced with 1 lea 1 add instructions
|
||
|
; where the base is rbp/r13/ebp register
|
||
|
define i32 @testleaadd_rbp_64() {
|
||
|
ret i32 0
|
||
|
}
|
||
|
|
||
|
;test1lea_rbp_64: 2 operands LEA64r wher base register is rbp/r13/ebp and can be replaced
|
||
|
; with a lea instruction
|
||
|
define i32 @test1lea_rbp_64() {
|
||
|
ret i32 0
|
||
|
}
|
||
|
|
||
|
;test8: dst = base & scale!=1, can't optimize
|
||
|
define i32 @test8() {
|
||
|
ret i32 0
|
||
|
}
|
||
|
|
||
|
;testleaaddi32_64_32: 3 operands LEA64_32r that can be replaced with 1 lea + 1 add instructions where
|
||
|
; ADD64ri32 is chosen
|
||
|
define i32 @testleaaddi32_64_32() {
|
||
|
ret i32 0
|
||
|
}
|
||
|
|
||
|
;test1mov1add_rbp_64_32: 2 operands LEA64_32r cannot be replaced with 1 add 1 mov instructions
|
||
|
; where the base is rbp/r13/ebp register
|
||
|
define i32 @test1mov1add_rbp_64_32() {
|
||
|
ret i32 0
|
||
|
}
|
||
|
|
||
|
;testleaadd_rbp_index_64_32: 3 operands LEA64_32r that cannot replaced with 1 lea 1 add instructions
|
||
|
; where the base and the index are ebp register and there is offset
|
||
|
define i32 @testleaadd_rbp_index_64_32() {
|
||
|
ret i32 0
|
||
|
}
|
||
|
|
||
|
;testleaadd_rbp_index2_64_32: 3 operands LEA64_32r that cannot replaced with 1 lea 1 add instructions
|
||
|
; where the base and the index are ebp register and there is scale
|
||
|
define i32 @testleaadd_rbp_index2_64_32() {
|
||
|
ret i32 0
|
||
|
}
|
||
|
|
||
|
;test2addi32_64: 3 operands LEA64r that can be replaced with 2 add instructions where ADD64ri32
|
||
|
; is chosen
|
||
|
define i32 @test2addi32_64() {
|
||
|
ret i32 0
|
||
|
}
|
||
|
|
||
|
;test1mov1add_rbp_64: 2 operands LEA64r that can be replaced with 1 add 1 mov instructions
|
||
|
; where the base is rbp/r13/ebp register
|
||
|
define i32 @test1mov1add_rbp_64() {
|
||
|
ret i32 0
|
||
|
}
|
||
|
|
||
|
;testleaadd_rbp_index_64: 3 operands LEA64r that can be replaced with 1 lea 1 add instructions
|
||
|
; where the base and the index are ebp register and there is offset
|
||
|
define i32 @testleaadd_rbp_index_64() {
|
||
|
ret i32 0
|
||
|
}
|
||
|
|
||
|
;testleaadd_rbp_index2_64: 3 operands LEA64r that can be replaced with 1 lea 1 add instructions
|
||
|
; where the base and the index are ebp register and there is scale
|
||
|
define i32 @testleaadd_rbp_index2_64() {
|
||
|
ret i32 0
|
||
|
}
|
||
|
|
||
|
;test_skip_opt_64: 3 operands LEA64r that can not be replaced with 2 instructions
|
||
|
define i32 @test_skip_opt_64() {
|
||
|
ret i32 0
|
||
|
}
|
||
|
|
||
|
;test_skip_eflags_64: LEA64r that cannot be replaced since its not safe to clobber eflags
|
||
|
define i32 @test_skip_eflags_64() {
|
||
|
ret i32 0
|
||
|
}
|
||
|
|
||
|
;test_skip_opt_64_32: 3 operands LEA64_32r that can not be replaced with 2 instructions
|
||
|
define i32 @test_skip_opt_64_32() {
|
||
|
ret i32 0
|
||
|
}
|
||
|
|
||
|
;test_skip_eflags_64_32: LEA64_32r that cannot be replaced since its not safe to clobber eflags
|
||
|
define i32 @test_skip_eflags_64_32() {
|
||
|
ret i32 0
|
||
|
}
|
||
|
|
||
|
|
||
|
...
|
||
|
---
|
||
|
name: testleaadd_64_32_1
|
||
|
alignment: 4
|
||
|
exposesReturnsTwice: false
|
||
|
legalized: false
|
||
|
regBankSelected: false
|
||
|
selected: false
|
||
|
tracksRegLiveness: true
|
||
|
liveins:
|
||
|
- { reg: '%rax' }
|
||
|
- { reg: '%rbp' }
|
||
|
frameInfo:
|
||
|
isFrameAddressTaken: false
|
||
|
isReturnAddressTaken: false
|
||
|
hasStackMap: false
|
||
|
hasPatchPoint: false
|
||
|
stackSize: 0
|
||
|
offsetAdjustment: 0
|
||
|
maxAlignment: 0
|
||
|
adjustsStack: false
|
||
|
hasCalls: false
|
||
|
maxCallFrameSize: 0
|
||
|
hasOpaqueSPAdjustment: false
|
||
|
hasVAStart: false
|
||
|
hasMustTailInVarArgFunc: false
|
||
|
body: |
|
||
|
bb.0 (%ir-block.0):
|
||
|
liveins: %rax, %rbp
|
||
|
; CHECK: %eax = LEA64_32r killed %rax, 1, killed %rbp, 0
|
||
|
; CHECK: %eax = ADD32ri8 %eax, -5
|
||
|
|
||
|
%eax = LEA64_32r killed %rax, 1, killed %rbp, -5, %noreg
|
||
|
RETQ %eax
|
||
|
|
||
|
...
|
||
|
---
|
||
|
name: testleaadd_rbp_64_32_1
|
||
|
alignment: 4
|
||
|
exposesReturnsTwice: false
|
||
|
legalized: false
|
||
|
regBankSelected: false
|
||
|
selected: false
|
||
|
tracksRegLiveness: true
|
||
|
liveins:
|
||
|
- { reg: '%rax' }
|
||
|
- { reg: '%rbp' }
|
||
|
frameInfo:
|
||
|
isFrameAddressTaken: false
|
||
|
isReturnAddressTaken: false
|
||
|
hasStackMap: false
|
||
|
hasPatchPoint: false
|
||
|
stackSize: 0
|
||
|
offsetAdjustment: 0
|
||
|
maxAlignment: 0
|
||
|
adjustsStack: false
|
||
|
hasCalls: false
|
||
|
maxCallFrameSize: 0
|
||
|
hasOpaqueSPAdjustment: false
|
||
|
hasVAStart: false
|
||
|
hasMustTailInVarArgFunc: false
|
||
|
body: |
|
||
|
bb.0 (%ir-block.0):
|
||
|
liveins: %rax, %rbp
|
||
|
; CHECK: %ebp = LEA64_32r killed %rax, 1, killed %rbp, 0
|
||
|
; CHECK: %ebp = ADD32ri8 %ebp, -5
|
||
|
|
||
|
%ebp = LEA64_32r killed %rbp, 1, killed %rax, -5, %noreg
|
||
|
RETQ %ebp
|
||
|
|
||
|
...
|
||
|
---
|
||
|
name: test1lea_rbp_64_32_1
|
||
|
alignment: 4
|
||
|
exposesReturnsTwice: false
|
||
|
legalized: false
|
||
|
regBankSelected: false
|
||
|
selected: false
|
||
|
tracksRegLiveness: true
|
||
|
liveins:
|
||
|
- { reg: '%rax' }
|
||
|
- { reg: '%rbp' }
|
||
|
frameInfo:
|
||
|
isFrameAddressTaken: false
|
||
|
isReturnAddressTaken: false
|
||
|
hasStackMap: false
|
||
|
hasPatchPoint: false
|
||
|
stackSize: 0
|
||
|
offsetAdjustment: 0
|
||
|
maxAlignment: 0
|
||
|
adjustsStack: false
|
||
|
hasCalls: false
|
||
|
maxCallFrameSize: 0
|
||
|
hasOpaqueSPAdjustment: false
|
||
|
hasVAStart: false
|
||
|
hasMustTailInVarArgFunc: false
|
||
|
body: |
|
||
|
bb.0 (%ir-block.0):
|
||
|
liveins: %rax, %rbp
|
||
|
; CHECK: %ebp = LEA64_32r killed %rax, 1, killed %rbp, 0
|
||
|
|
||
|
%ebp = LEA64_32r killed %rbp, 1, killed %rax, 0, %noreg
|
||
|
RETQ %ebp
|
||
|
|
||
|
...
|
||
|
---
|
||
|
name: test2add_64
|
||
|
alignment: 4
|
||
|
exposesReturnsTwice: false
|
||
|
legalized: false
|
||
|
regBankSelected: false
|
||
|
selected: false
|
||
|
tracksRegLiveness: true
|
||
|
liveins:
|
||
|
- { reg: '%rax' }
|
||
|
- { reg: '%rbp' }
|
||
|
frameInfo:
|
||
|
isFrameAddressTaken: false
|
||
|
isReturnAddressTaken: false
|
||
|
hasStackMap: false
|
||
|
hasPatchPoint: false
|
||
|
stackSize: 0
|
||
|
offsetAdjustment: 0
|
||
|
maxAlignment: 0
|
||
|
adjustsStack: false
|
||
|
hasCalls: false
|
||
|
maxCallFrameSize: 0
|
||
|
hasOpaqueSPAdjustment: false
|
||
|
hasVAStart: false
|
||
|
hasMustTailInVarArgFunc: false
|
||
|
body: |
|
||
|
bb.0 (%ir-block.0):
|
||
|
liveins: %rax, %rbp
|
||
|
; CHECK: %rax = ADD64rr %rax, killed %rbp
|
||
|
; CHECK: %rax = ADD64ri8 %rax, -5
|
||
|
|
||
|
%rax = LEA64r killed %rax, 1, killed %rbp, -5, %noreg
|
||
|
RETQ %eax
|
||
|
|
||
|
...
|
||
|
---
|
||
|
name: test2add_rbp_64
|
||
|
alignment: 4
|
||
|
exposesReturnsTwice: false
|
||
|
legalized: false
|
||
|
regBankSelected: false
|
||
|
selected: false
|
||
|
tracksRegLiveness: true
|
||
|
liveins:
|
||
|
- { reg: '%rax' }
|
||
|
- { reg: '%rbp' }
|
||
|
frameInfo:
|
||
|
isFrameAddressTaken: false
|
||
|
isReturnAddressTaken: false
|
||
|
hasStackMap: false
|
||
|
hasPatchPoint: false
|
||
|
stackSize: 0
|
||
|
offsetAdjustment: 0
|
||
|
maxAlignment: 0
|
||
|
adjustsStack: false
|
||
|
hasCalls: false
|
||
|
maxCallFrameSize: 0
|
||
|
hasOpaqueSPAdjustment: false
|
||
|
hasVAStart: false
|
||
|
hasMustTailInVarArgFunc: false
|
||
|
body: |
|
||
|
bb.0 (%ir-block.0):
|
||
|
liveins: %rax, %rbp
|
||
|
; CHECK: %rbp = ADD64rr %rbp, killed %rax
|
||
|
; CHECK: %rbp = ADD64ri8 %rbp, -5
|
||
|
|
||
|
%rbp = LEA64r killed %rbp, 1, killed %rax, -5, %noreg
|
||
|
RETQ %ebp
|
||
|
|
||
|
...
|
||
|
---
|
||
|
name: test1add_rbp_64
|
||
|
alignment: 4
|
||
|
exposesReturnsTwice: false
|
||
|
legalized: false
|
||
|
regBankSelected: false
|
||
|
selected: false
|
||
|
tracksRegLiveness: true
|
||
|
liveins:
|
||
|
- { reg: '%rax' }
|
||
|
- { reg: '%rbp' }
|
||
|
frameInfo:
|
||
|
isFrameAddressTaken: false
|
||
|
isReturnAddressTaken: false
|
||
|
hasStackMap: false
|
||
|
hasPatchPoint: false
|
||
|
stackSize: 0
|
||
|
offsetAdjustment: 0
|
||
|
maxAlignment: 0
|
||
|
adjustsStack: false
|
||
|
hasCalls: false
|
||
|
maxCallFrameSize: 0
|
||
|
hasOpaqueSPAdjustment: false
|
||
|
hasVAStart: false
|
||
|
hasMustTailInVarArgFunc: false
|
||
|
body: |
|
||
|
bb.0 (%ir-block.0):
|
||
|
liveins: %rax, %rbp
|
||
|
; CHECK: %rbp = ADD64rr %rbp, killed %rax
|
||
|
|
||
|
%rbp = LEA64r killed %rbp, 1, killed %rax, 0, %noreg
|
||
|
RETQ %ebp
|
||
|
|
||
|
...
|
||
|
---
|
||
|
name: testleaadd_64_32
|
||
|
alignment: 4
|
||
|
exposesReturnsTwice: false
|
||
|
legalized: false
|
||
|
regBankSelected: false
|
||
|
selected: false
|
||
|
tracksRegLiveness: true
|
||
|
liveins:
|
||
|
- { reg: '%rax' }
|
||
|
- { reg: '%rbp' }
|
||
|
- { reg: '%rbx' }
|
||
|
frameInfo:
|
||
|
isFrameAddressTaken: false
|
||
|
isReturnAddressTaken: false
|
||
|
hasStackMap: false
|
||
|
hasPatchPoint: false
|
||
|
stackSize: 0
|
||
|
offsetAdjustment: 0
|
||
|
maxAlignment: 0
|
||
|
adjustsStack: false
|
||
|
hasCalls: false
|
||
|
maxCallFrameSize: 0
|
||
|
hasOpaqueSPAdjustment: false
|
||
|
hasVAStart: false
|
||
|
hasMustTailInVarArgFunc: false
|
||
|
body: |
|
||
|
bb.0 (%ir-block.0):
|
||
|
liveins: %rax, %rbp
|
||
|
; CHECK: %ebx = LEA64_32r killed %rax, 1, killed %rbp, 0, %noreg
|
||
|
; CHECK: %ebx = ADD32ri8 %ebx, -5
|
||
|
|
||
|
%ebx = LEA64_32r killed %rax, 1, killed %rbp, -5, %noreg
|
||
|
RETQ %ebx
|
||
|
|
||
|
...
|
||
|
---
|
||
|
name: testleaadd_rbp_64_32
|
||
|
alignment: 4
|
||
|
exposesReturnsTwice: false
|
||
|
legalized: false
|
||
|
regBankSelected: false
|
||
|
selected: false
|
||
|
tracksRegLiveness: true
|
||
|
liveins:
|
||
|
- { reg: '%rax' }
|
||
|
- { reg: '%rbp' }
|
||
|
- { reg: '%rbx' }
|
||
|
frameInfo:
|
||
|
isFrameAddressTaken: false
|
||
|
isReturnAddressTaken: false
|
||
|
hasStackMap: false
|
||
|
hasPatchPoint: false
|
||
|
stackSize: 0
|
||
|
offsetAdjustment: 0
|
||
|
maxAlignment: 0
|
||
|
adjustsStack: false
|
||
|
hasCalls: false
|
||
|
maxCallFrameSize: 0
|
||
|
hasOpaqueSPAdjustment: false
|
||
|
hasVAStart: false
|
||
|
hasMustTailInVarArgFunc: false
|
||
|
body: |
|
||
|
bb.0 (%ir-block.0):
|
||
|
liveins: %rax, %rbp
|
||
|
; CHECK: %ebx = LEA64_32r killed %rax, 1, killed %rbp, 0, %noreg
|
||
|
; CHECK: %ebx = ADD32ri8 %ebx, -5
|
||
|
|
||
|
%ebx = LEA64_32r killed %rbp, 1, killed %rax, -5, %noreg
|
||
|
RETQ %ebx
|
||
|
|
||
|
...
|
||
|
---
|
||
|
name: test1lea_rbp_64_32
|
||
|
alignment: 4
|
||
|
exposesReturnsTwice: false
|
||
|
legalized: false
|
||
|
regBankSelected: false
|
||
|
selected: false
|
||
|
tracksRegLiveness: true
|
||
|
liveins:
|
||
|
- { reg: '%rax' }
|
||
|
- { reg: '%rbp' }
|
||
|
- { reg: '%rbx' }
|
||
|
frameInfo:
|
||
|
isFrameAddressTaken: false
|
||
|
isReturnAddressTaken: false
|
||
|
hasStackMap: false
|
||
|
hasPatchPoint: false
|
||
|
stackSize: 0
|
||
|
offsetAdjustment: 0
|
||
|
maxAlignment: 0
|
||
|
adjustsStack: false
|
||
|
hasCalls: false
|
||
|
maxCallFrameSize: 0
|
||
|
hasOpaqueSPAdjustment: false
|
||
|
hasVAStart: false
|
||
|
hasMustTailInVarArgFunc: false
|
||
|
body: |
|
||
|
bb.0 (%ir-block.0):
|
||
|
liveins: %rax, %rbp
|
||
|
; CHECK: %ebx = LEA64_32r killed %rax, 1, killed %rbp, 0, %noreg
|
||
|
|
||
|
%ebx = LEA64_32r killed %rbp, 1, killed %rax, 0, %noreg
|
||
|
RETQ %ebx
|
||
|
|
||
|
...
|
||
|
---
|
||
|
name: testleaadd_64
|
||
|
alignment: 4
|
||
|
exposesReturnsTwice: false
|
||
|
legalized: false
|
||
|
regBankSelected: false
|
||
|
selected: false
|
||
|
tracksRegLiveness: true
|
||
|
liveins:
|
||
|
- { reg: '%rax' }
|
||
|
- { reg: '%rbp' }
|
||
|
- { reg: '%rbx' }
|
||
|
frameInfo:
|
||
|
isFrameAddressTaken: false
|
||
|
isReturnAddressTaken: false
|
||
|
hasStackMap: false
|
||
|
hasPatchPoint: false
|
||
|
stackSize: 0
|
||
|
offsetAdjustment: 0
|
||
|
maxAlignment: 0
|
||
|
adjustsStack: false
|
||
|
hasCalls: false
|
||
|
maxCallFrameSize: 0
|
||
|
hasOpaqueSPAdjustment: false
|
||
|
hasVAStart: false
|
||
|
hasMustTailInVarArgFunc: false
|
||
|
body: |
|
||
|
bb.0 (%ir-block.0):
|
||
|
liveins: %rax, %rbp
|
||
|
; CHECK: %rbx = LEA64r killed %rax, 1, killed %rbp, 0, %noreg
|
||
|
; CHECK: %rbx = ADD64ri8 %rbx, -5
|
||
|
|
||
|
%rbx = LEA64r killed %rax, 1, killed %rbp, -5, %noreg
|
||
|
RETQ %ebx
|
||
|
|
||
|
...
|
||
|
---
|
||
|
name: testleaadd_rbp_64
|
||
|
alignment: 4
|
||
|
exposesReturnsTwice: false
|
||
|
legalized: false
|
||
|
regBankSelected: false
|
||
|
selected: false
|
||
|
tracksRegLiveness: true
|
||
|
liveins:
|
||
|
- { reg: '%rax' }
|
||
|
- { reg: '%rbp' }
|
||
|
- { reg: '%rbx' }
|
||
|
frameInfo:
|
||
|
isFrameAddressTaken: false
|
||
|
isReturnAddressTaken: false
|
||
|
hasStackMap: false
|
||
|
hasPatchPoint: false
|
||
|
stackSize: 0
|
||
|
offsetAdjustment: 0
|
||
|
maxAlignment: 0
|
||
|
adjustsStack: false
|
||
|
hasCalls: false
|
||
|
maxCallFrameSize: 0
|
||
|
hasOpaqueSPAdjustment: false
|
||
|
hasVAStart: false
|
||
|
hasMustTailInVarArgFunc: false
|
||
|
body: |
|
||
|
bb.0 (%ir-block.0):
|
||
|
liveins: %rax, %rbp
|
||
|
; CHECK: %rbx = LEA64r killed %rax, 1, killed %rbp, 0, %noreg
|
||
|
; CHECK: %rbx = ADD64ri8 %rbx, -5
|
||
|
|
||
|
%rbx = LEA64r killed %rbp, 1, killed %rax, -5, %noreg
|
||
|
RETQ %ebx
|
||
|
|
||
|
...
|
||
|
---
|
||
|
name: test1lea_rbp_64
|
||
|
alignment: 4
|
||
|
exposesReturnsTwice: false
|
||
|
legalized: false
|
||
|
regBankSelected: false
|
||
|
selected: false
|
||
|
tracksRegLiveness: true
|
||
|
liveins:
|
||
|
- { reg: '%rax' }
|
||
|
- { reg: '%rbp' }
|
||
|
- { reg: '%rbx' }
|
||
|
frameInfo:
|
||
|
isFrameAddressTaken: false
|
||
|
isReturnAddressTaken: false
|
||
|
hasStackMap: false
|
||
|
hasPatchPoint: false
|
||
|
stackSize: 0
|
||
|
offsetAdjustment: 0
|
||
|
maxAlignment: 0
|
||
|
adjustsStack: false
|
||
|
hasCalls: false
|
||
|
maxCallFrameSize: 0
|
||
|
hasOpaqueSPAdjustment: false
|
||
|
hasVAStart: false
|
||
|
hasMustTailInVarArgFunc: false
|
||
|
body: |
|
||
|
bb.0 (%ir-block.0):
|
||
|
liveins: %rax, %rbp
|
||
|
; CHECK: %rbx = LEA64r killed %rax, 1, killed %rbp, 0, %noreg
|
||
|
|
||
|
%rbx = LEA64r killed %rbp, 1, killed %rax, 0, %noreg
|
||
|
RETQ %ebx
|
||
|
|
||
|
...
|
||
|
---
|
||
|
name: test8
|
||
|
alignment: 4
|
||
|
exposesReturnsTwice: false
|
||
|
legalized: false
|
||
|
regBankSelected: false
|
||
|
selected: false
|
||
|
tracksRegLiveness: true
|
||
|
liveins:
|
||
|
- { reg: '%rdi' }
|
||
|
- { reg: '%rbp' }
|
||
|
frameInfo:
|
||
|
isFrameAddressTaken: false
|
||
|
isReturnAddressTaken: false
|
||
|
hasStackMap: false
|
||
|
hasPatchPoint: false
|
||
|
stackSize: 0
|
||
|
offsetAdjustment: 0
|
||
|
maxAlignment: 0
|
||
|
adjustsStack: false
|
||
|
hasCalls: false
|
||
|
maxCallFrameSize: 0
|
||
|
hasOpaqueSPAdjustment: false
|
||
|
hasVAStart: false
|
||
|
hasMustTailInVarArgFunc: false
|
||
|
body: |
|
||
|
bb.0 (%ir-block.0):
|
||
|
liveins: %rdi, %rbp
|
||
|
; CHECK: %r12 = LEA64r %noreg, 2, killed %r13, 5, %noreg
|
||
|
; CHECK: %r12 = ADD64rr %r12, killed %rbp
|
||
|
%rbp = KILL %rbp, implicit-def %rbp
|
||
|
%r13 = KILL %rdi, implicit-def %r13
|
||
|
%r12 = LEA64r killed %rbp, 2, killed %r13, 5, %noreg
|
||
|
RETQ %r12
|
||
|
|
||
|
...
|
||
|
---
|
||
|
name: testleaaddi32_64_32
|
||
|
alignment: 4
|
||
|
exposesReturnsTwice: false
|
||
|
legalized: false
|
||
|
regBankSelected: false
|
||
|
selected: false
|
||
|
tracksRegLiveness: true
|
||
|
liveins:
|
||
|
- { reg: '%rax' }
|
||
|
- { reg: '%rbp' }
|
||
|
frameInfo:
|
||
|
isFrameAddressTaken: false
|
||
|
isReturnAddressTaken: false
|
||
|
hasStackMap: false
|
||
|
hasPatchPoint: false
|
||
|
stackSize: 0
|
||
|
offsetAdjustment: 0
|
||
|
maxAlignment: 0
|
||
|
adjustsStack: false
|
||
|
hasCalls: false
|
||
|
maxCallFrameSize: 0
|
||
|
hasOpaqueSPAdjustment: false
|
||
|
hasVAStart: false
|
||
|
hasMustTailInVarArgFunc: false
|
||
|
body: |
|
||
|
bb.0 (%ir-block.0):
|
||
|
liveins: %rax, %rbp
|
||
|
; CHECK: %eax = LEA64_32r killed %rax, 1, killed %rbp, 0
|
||
|
; CHECK: %eax = ADD32ri %eax, 129
|
||
|
|
||
|
%eax = LEA64_32r killed %rax, 1, killed %rbp, 129, %noreg
|
||
|
RETQ %eax
|
||
|
|
||
|
...
|
||
|
---
|
||
|
name: test1mov1add_rbp_64_32
|
||
|
alignment: 4
|
||
|
exposesReturnsTwice: false
|
||
|
legalized: false
|
||
|
regBankSelected: false
|
||
|
selected: false
|
||
|
tracksRegLiveness: true
|
||
|
liveins:
|
||
|
- { reg: '%rax' }
|
||
|
- { reg: '%rbp' }
|
||
|
frameInfo:
|
||
|
isFrameAddressTaken: false
|
||
|
isReturnAddressTaken: false
|
||
|
hasStackMap: false
|
||
|
hasPatchPoint: false
|
||
|
stackSize: 0
|
||
|
offsetAdjustment: 0
|
||
|
maxAlignment: 0
|
||
|
adjustsStack: false
|
||
|
hasCalls: false
|
||
|
maxCallFrameSize: 0
|
||
|
hasOpaqueSPAdjustment: false
|
||
|
hasVAStart: false
|
||
|
hasMustTailInVarArgFunc: false
|
||
|
body: |
|
||
|
bb.0 (%ir-block.0):
|
||
|
liveins: %rax, %rbp, %rbx
|
||
|
; CHECK: %ebx = LEA64_32r killed %rbp, 1, killed %rbp, 0, %noreg
|
||
|
|
||
|
%ebx = LEA64_32r killed %rbp, 1, killed %rbp, 0, %noreg
|
||
|
RETQ %ebx
|
||
|
|
||
|
...
|
||
|
---
|
||
|
name: testleaadd_rbp_index_64_32
|
||
|
alignment: 4
|
||
|
exposesReturnsTwice: false
|
||
|
legalized: false
|
||
|
regBankSelected: false
|
||
|
selected: false
|
||
|
tracksRegLiveness: true
|
||
|
liveins:
|
||
|
- { reg: '%rbx' }
|
||
|
- { reg: '%rbp' }
|
||
|
frameInfo:
|
||
|
isFrameAddressTaken: false
|
||
|
isReturnAddressTaken: false
|
||
|
hasStackMap: false
|
||
|
hasPatchPoint: false
|
||
|
stackSize: 0
|
||
|
offsetAdjustment: 0
|
||
|
maxAlignment: 0
|
||
|
adjustsStack: false
|
||
|
hasCalls: false
|
||
|
maxCallFrameSize: 0
|
||
|
hasOpaqueSPAdjustment: false
|
||
|
hasVAStart: false
|
||
|
hasMustTailInVarArgFunc: false
|
||
|
body: |
|
||
|
bb.0 (%ir-block.0):
|
||
|
liveins: %rax, %rbp, %rbx
|
||
|
; CHECK: %ebx = LEA64_32r killed %rbp, 1, killed %rbp, 5, %noreg
|
||
|
|
||
|
%ebx = LEA64_32r killed %rbp, 1, killed %rbp, 5, %noreg
|
||
|
RETQ %ebx
|
||
|
|
||
|
...
|
||
|
---
|
||
|
name: testleaadd_rbp_index2_64_32
|
||
|
alignment: 4
|
||
|
exposesReturnsTwice: false
|
||
|
legalized: false
|
||
|
regBankSelected: false
|
||
|
selected: false
|
||
|
tracksRegLiveness: true
|
||
|
liveins:
|
||
|
- { reg: '%rbx' }
|
||
|
- { reg: '%rbp' }
|
||
|
frameInfo:
|
||
|
isFrameAddressTaken: false
|
||
|
isReturnAddressTaken: false
|
||
|
hasStackMap: false
|
||
|
hasPatchPoint: false
|
||
|
stackSize: 0
|
||
|
offsetAdjustment: 0
|
||
|
maxAlignment: 0
|
||
|
adjustsStack: false
|
||
|
hasCalls: false
|
||
|
maxCallFrameSize: 0
|
||
|
hasOpaqueSPAdjustment: false
|
||
|
hasVAStart: false
|
||
|
hasMustTailInVarArgFunc: false
|
||
|
body: |
|
||
|
bb.0 (%ir-block.0):
|
||
|
liveins: %eax, %ebp, %ebx
|
||
|
; CHECK: %ebx = LEA64_32r killed %rbp, 4, killed %rbp, 5, %noreg
|
||
|
|
||
|
%ebx = LEA64_32r killed %rbp, 4, killed %rbp, 5, %noreg
|
||
|
RETQ %ebx
|
||
|
|
||
|
...
|
||
|
---
|
||
|
name: test2addi32_64
|
||
|
alignment: 4
|
||
|
exposesReturnsTwice: false
|
||
|
legalized: false
|
||
|
regBankSelected: false
|
||
|
selected: false
|
||
|
tracksRegLiveness: true
|
||
|
liveins:
|
||
|
- { reg: '%rax' }
|
||
|
- { reg: '%rbp' }
|
||
|
frameInfo:
|
||
|
isFrameAddressTaken: false
|
||
|
isReturnAddressTaken: false
|
||
|
hasStackMap: false
|
||
|
hasPatchPoint: false
|
||
|
stackSize: 0
|
||
|
offsetAdjustment: 0
|
||
|
maxAlignment: 0
|
||
|
adjustsStack: false
|
||
|
hasCalls: false
|
||
|
maxCallFrameSize: 0
|
||
|
hasOpaqueSPAdjustment: false
|
||
|
hasVAStart: false
|
||
|
hasMustTailInVarArgFunc: false
|
||
|
body: |
|
||
|
bb.0 (%ir-block.0):
|
||
|
liveins: %rax, %rbp
|
||
|
; CHECK: %rax = ADD64rr %rax, killed %rbp
|
||
|
; CHECK: %rax = ADD64ri32 %rax, 129
|
||
|
|
||
|
%rax = LEA64r killed %rax, 1, killed %rbp, 129, %noreg
|
||
|
RETQ %eax
|
||
|
|
||
|
...
|
||
|
---
|
||
|
name: test1mov1add_rbp_64
|
||
|
alignment: 4
|
||
|
exposesReturnsTwice: false
|
||
|
legalized: false
|
||
|
regBankSelected: false
|
||
|
selected: false
|
||
|
tracksRegLiveness: true
|
||
|
liveins:
|
||
|
- { reg: '%rax' }
|
||
|
- { reg: '%rbp' }
|
||
|
frameInfo:
|
||
|
isFrameAddressTaken: false
|
||
|
isReturnAddressTaken: false
|
||
|
hasStackMap: false
|
||
|
hasPatchPoint: false
|
||
|
stackSize: 0
|
||
|
offsetAdjustment: 0
|
||
|
maxAlignment: 0
|
||
|
adjustsStack: false
|
||
|
hasCalls: false
|
||
|
maxCallFrameSize: 0
|
||
|
hasOpaqueSPAdjustment: false
|
||
|
hasVAStart: false
|
||
|
hasMustTailInVarArgFunc: false
|
||
|
body: |
|
||
|
bb.0 (%ir-block.0):
|
||
|
liveins: %rax, %rbp, %rbx
|
||
|
; CHECK: %rbx = MOV64rr %rbp
|
||
|
; CHECK: %rbx = ADD64rr %rbx, %rbp
|
||
|
|
||
|
%rbx = LEA64r %rbp, 1, %rbp, 0, %noreg
|
||
|
RETQ %ebx
|
||
|
|
||
|
...
|
||
|
---
|
||
|
name: testleaadd_rbp_index_64
|
||
|
alignment: 4
|
||
|
exposesReturnsTwice: false
|
||
|
legalized: false
|
||
|
regBankSelected: false
|
||
|
selected: false
|
||
|
tracksRegLiveness: true
|
||
|
liveins:
|
||
|
- { reg: '%rbx' }
|
||
|
- { reg: '%rbp' }
|
||
|
frameInfo:
|
||
|
isFrameAddressTaken: false
|
||
|
isReturnAddressTaken: false
|
||
|
hasStackMap: false
|
||
|
hasPatchPoint: false
|
||
|
stackSize: 0
|
||
|
offsetAdjustment: 0
|
||
|
maxAlignment: 0
|
||
|
adjustsStack: false
|
||
|
hasCalls: false
|
||
|
maxCallFrameSize: 0
|
||
|
hasOpaqueSPAdjustment: false
|
||
|
hasVAStart: false
|
||
|
hasMustTailInVarArgFunc: false
|
||
|
body: |
|
||
|
bb.0 (%ir-block.0):
|
||
|
liveins: %rax, %rbp, %rbx
|
||
|
; CHECK: %rbx = LEA64r %noreg, 1, %rbp, 5, %noreg
|
||
|
; CHECK: %rbx = ADD64rr %rbx, %rbp
|
||
|
|
||
|
%rbx = LEA64r %rbp, 1, %rbp, 5, %noreg
|
||
|
RETQ %ebx
|
||
|
|
||
|
...
|
||
|
---
|
||
|
name: testleaadd_rbp_index2_64
|
||
|
alignment: 4
|
||
|
exposesReturnsTwice: false
|
||
|
legalized: false
|
||
|
regBankSelected: false
|
||
|
selected: false
|
||
|
tracksRegLiveness: true
|
||
|
liveins:
|
||
|
- { reg: '%rbx' }
|
||
|
- { reg: '%rbp' }
|
||
|
frameInfo:
|
||
|
isFrameAddressTaken: false
|
||
|
isReturnAddressTaken: false
|
||
|
hasStackMap: false
|
||
|
hasPatchPoint: false
|
||
|
stackSize: 0
|
||
|
offsetAdjustment: 0
|
||
|
maxAlignment: 0
|
||
|
adjustsStack: false
|
||
|
hasCalls: false
|
||
|
maxCallFrameSize: 0
|
||
|
hasOpaqueSPAdjustment: false
|
||
|
hasVAStart: false
|
||
|
hasMustTailInVarArgFunc: false
|
||
|
body: |
|
||
|
bb.0 (%ir-block.0):
|
||
|
liveins: %rax, %rbp, %rbx
|
||
|
; CHECK: %rbx = LEA64r %noreg, 4, %rbp, 5, %noreg
|
||
|
; CHECK: %rbx = ADD64rr %rbx, %rbp
|
||
|
|
||
|
%rbx = LEA64r %rbp, 4, %rbp, 5, %noreg
|
||
|
RETQ %ebx
|
||
|
|
||
|
...
|
||
|
---
|
||
|
name: test_skip_opt_64
|
||
|
alignment: 4
|
||
|
exposesReturnsTwice: false
|
||
|
legalized: false
|
||
|
regBankSelected: false
|
||
|
selected: false
|
||
|
tracksRegLiveness: true
|
||
|
liveins:
|
||
|
- { reg: '%rbx' }
|
||
|
- { reg: '%rbp' }
|
||
|
frameInfo:
|
||
|
isFrameAddressTaken: false
|
||
|
isReturnAddressTaken: false
|
||
|
hasStackMap: false
|
||
|
hasPatchPoint: false
|
||
|
stackSize: 0
|
||
|
offsetAdjustment: 0
|
||
|
maxAlignment: 0
|
||
|
adjustsStack: false
|
||
|
hasCalls: false
|
||
|
maxCallFrameSize: 0
|
||
|
hasOpaqueSPAdjustment: false
|
||
|
hasVAStart: false
|
||
|
hasMustTailInVarArgFunc: false
|
||
|
body: |
|
||
|
bb.0 (%ir-block.0):
|
||
|
liveins: %rax, %rbp, %rbx
|
||
|
; CHECK: %rbp = LEA64r killed %rbp, 4, killed %rbp, 0, %noreg
|
||
|
|
||
|
%rbp = LEA64r killed %rbp, 4, killed %rbp, 0, %noreg
|
||
|
RETQ %ebp
|
||
|
|
||
|
...
|
||
|
---
|
||
|
name: test_skip_eflags_64
|
||
|
alignment: 4
|
||
|
exposesReturnsTwice: false
|
||
|
legalized: false
|
||
|
regBankSelected: false
|
||
|
selected: false
|
||
|
tracksRegLiveness: true
|
||
|
liveins:
|
||
|
- { reg: '%rbp' }
|
||
|
- { reg: '%rax' }
|
||
|
frameInfo:
|
||
|
isFrameAddressTaken: false
|
||
|
isReturnAddressTaken: false
|
||
|
hasStackMap: false
|
||
|
hasPatchPoint: false
|
||
|
stackSize: 0
|
||
|
offsetAdjustment: 0
|
||
|
maxAlignment: 0
|
||
|
adjustsStack: false
|
||
|
hasCalls: false
|
||
|
maxCallFrameSize: 0
|
||
|
hasOpaqueSPAdjustment: false
|
||
|
hasVAStart: false
|
||
|
hasMustTailInVarArgFunc: false
|
||
|
body: |
|
||
|
bb.0 (%ir-block.0):
|
||
|
liveins: %rax, %rbp, %rbx
|
||
|
; CHECK: %rbx = LEA64r killed %rax, 4, killed %rax, 5, %noreg
|
||
|
; CHECK: %rbp = LEA64r killed %rbx, 4, killed %rbx, 0, %noreg
|
||
|
; CHECK: %rbp = ADD64ri8 %rbp, 5
|
||
|
|
||
|
CMP64rr %rax, killed %rbx, implicit-def %eflags
|
||
|
%rbx = LEA64r killed %rax, 4, killed %rax, 5, %noreg
|
||
|
JE_1 %bb.1, implicit %eflags
|
||
|
RETQ %ebx
|
||
|
bb.1:
|
||
|
liveins: %rax, %rbp, %rbx
|
||
|
%rbp = LEA64r killed %rbx, 4, killed %rbx, 5, %noreg
|
||
|
RETQ %ebp
|
||
|
|
||
|
...
|
||
|
---
|
||
|
name: test_skip_opt_64_32
|
||
|
alignment: 4
|
||
|
exposesReturnsTwice: false
|
||
|
legalized: false
|
||
|
regBankSelected: false
|
||
|
selected: false
|
||
|
tracksRegLiveness: true
|
||
|
liveins:
|
||
|
- { reg: '%rbx' }
|
||
|
- { reg: '%rbp' }
|
||
|
frameInfo:
|
||
|
isFrameAddressTaken: false
|
||
|
isReturnAddressTaken: false
|
||
|
hasStackMap: false
|
||
|
hasPatchPoint: false
|
||
|
stackSize: 0
|
||
|
offsetAdjustment: 0
|
||
|
maxAlignment: 0
|
||
|
adjustsStack: false
|
||
|
hasCalls: false
|
||
|
maxCallFrameSize: 0
|
||
|
hasOpaqueSPAdjustment: false
|
||
|
hasVAStart: false
|
||
|
hasMustTailInVarArgFunc: false
|
||
|
body: |
|
||
|
bb.0 (%ir-block.0):
|
||
|
liveins: %rax, %rbp, %rbx
|
||
|
; CHECK: %ebp = LEA64_32r killed %rbp, 4, killed %rbp, 0, %noreg
|
||
|
|
||
|
%ebp = LEA64_32r killed %rbp, 4, killed %rbp, 0, %noreg
|
||
|
RETQ %ebp
|
||
|
|
||
|
...
|
||
|
---
|
||
|
name: test_skip_eflags_64_32
|
||
|
alignment: 4
|
||
|
exposesReturnsTwice: false
|
||
|
legalized: false
|
||
|
regBankSelected: false
|
||
|
selected: false
|
||
|
tracksRegLiveness: true
|
||
|
liveins:
|
||
|
- { reg: '%rbp' }
|
||
|
- { reg: '%rax' }
|
||
|
frameInfo:
|
||
|
isFrameAddressTaken: false
|
||
|
isReturnAddressTaken: false
|
||
|
hasStackMap: false
|
||
|
hasPatchPoint: false
|
||
|
stackSize: 0
|
||
|
offsetAdjustment: 0
|
||
|
maxAlignment: 0
|
||
|
adjustsStack: false
|
||
|
hasCalls: false
|
||
|
maxCallFrameSize: 0
|
||
|
hasOpaqueSPAdjustment: false
|
||
|
hasVAStart: false
|
||
|
hasMustTailInVarArgFunc: false
|
||
|
body: |
|
||
|
bb.0 (%ir-block.0):
|
||
|
liveins: %rax, %rbp, %rbx
|
||
|
; CHECK: %ebx = LEA64_32r killed %rax, 4, killed %rax, 5, %noreg
|
||
|
; CHECK: %ebp = LEA64_32r killed %rbx, 4, killed %rbx, 0, %noreg
|
||
|
; CHECK: %ebp = ADD32ri8 %ebp, 5
|
||
|
|
||
|
CMP64rr %rax, killed %rbx, implicit-def %eflags
|
||
|
%ebx = LEA64_32r killed %rax, 4, killed %rax, 5, %noreg
|
||
|
JE_1 %bb.1, implicit %eflags
|
||
|
RETQ %ebx
|
||
|
bb.1:
|
||
|
liveins: %rax, %rbp, %rbx
|
||
|
%ebp = LEA64_32r killed %rbx, 4, killed %rbx, 5, %noreg
|
||
|
RETQ %ebp
|
||
|
|
||
|
...
|
||
|
|
||
|
|
||
|
|