Skip to content
  • Jakob Stoklund Olesen's avatar
    Fix Bug 4657: register scavenger asserts with subreg lowering · 5d8ace09
    Jakob Stoklund Olesen authored
    When LowerSubregsInstructionPass::LowerInsert eliminates an INSERT_SUBREG
    instriction because it is an identity copy, make sure that the same registers
    are alive before and after the elimination.
    
    When the super-register is marked <undef> this requires inserting an
    IMPLICIT_DEF instruction to make sure the super register is live.
    
    Fix a related bug where a kill flag on the inserted sub-register was not transferred properly.
    
    Finally, clear the undef flag in MachineInstr::addRegisterKilled. Undef implies dead and kill implies live, so they cant both be valid.
    
    llvm-svn: 77989
    5d8ace09
Loading