diff options
| -rw-r--r-- | llvm/lib/Target/X86/X86FixupLEAs.cpp | 3 | ||||
| -rw-r--r-- | llvm/test/CodeGen/X86/leaFixup32.mir | 2 | ||||
| -rw-r--r-- | llvm/test/CodeGen/X86/leaFixup64.mir | 2 | 
3 files changed, 4 insertions, 3 deletions
diff --git a/llvm/lib/Target/X86/X86FixupLEAs.cpp b/llvm/lib/Target/X86/X86FixupLEAs.cpp index b41bf99f19b..64678c062ee 100644 --- a/llvm/lib/Target/X86/X86FixupLEAs.cpp +++ b/llvm/lib/Target/X86/X86FixupLEAs.cpp @@ -548,7 +548,8 @@ FixupLEAPass::processInstrForSlow3OpLEA(MachineInstr &MI,    // lea (%base,%index,1), %dst => mov %base,%dst; add %index,%dst    if (IsScale1 && !hasLEAOffset(Offset)) { -    TII->copyPhysReg(*MFI, MI, DL, DstR, BaseR, Base.isKill()); +    bool BIK = Base.isKill() && BaseR != IndexR; +    TII->copyPhysReg(*MFI, MI, DL, DstR, BaseR, BIK);      DEBUG(MI.getPrevNode()->dump(););      MachineInstr *NewMI = diff --git a/llvm/test/CodeGen/X86/leaFixup32.mir b/llvm/test/CodeGen/X86/leaFixup32.mir index d8e52802f56..b7de88f1a41 100644 --- a/llvm/test/CodeGen/X86/leaFixup32.mir +++ b/llvm/test/CodeGen/X86/leaFixup32.mir @@ -354,7 +354,7 @@ body:             |      ; CHECK: %ebx = MOV32rr  %ebp      ; CHECK: %ebx = ADD32rr %ebx, %ebp -    %ebx = LEA32r %ebp, 1, %ebp, 0, %noreg +    %ebx = LEA32r killed %ebp, 1, %ebp, 0, %noreg      RETQ %ebx  ... diff --git a/llvm/test/CodeGen/X86/leaFixup64.mir b/llvm/test/CodeGen/X86/leaFixup64.mir index ad86d4ba27f..48989dfd772 100644 --- a/llvm/test/CodeGen/X86/leaFixup64.mir +++ b/llvm/test/CodeGen/X86/leaFixup64.mir @@ -810,7 +810,7 @@ body:             |      ; CHECK: %rbx = MOV64rr %rbp      ; CHECK: %rbx = ADD64rr %rbx, %rbp -    %rbx = LEA64r %rbp, 1, %rbp, 0, %noreg +    %rbx = LEA64r killed %rbp, 1, %rbp, 0, %noreg      RETQ %ebx  ...  | 

