mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-06-14 14:24:05 +00:00
Erase constant dbgloc on reuse in PHI node
Basic block selection involves checking successor BBs for PHI nodes that depend on the current BB. In case such BBs are found, the value being selected is a constant and such constant already exists in current BB, it's value is reused. This might lead to wrong locations in some situations, especially if same constant value ends up being materialized twice in two different ways, which discards that sharing and leaves us with wrong debug location in the successor BB. In code this involves the following sequence of calls: SelectionDAGBuilder::HandlePHINodesInSuccessorBlocks -> SelectionDAGBuilder::CopyValueToVirtualRegister -> SelectionDAGBuilder::getNonRegisterValue git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@239089 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
@ -1002,7 +1002,16 @@ bool SelectionDAGBuilder::findValue(const Value *V) const {
|
||||
SDValue SelectionDAGBuilder::getNonRegisterValue(const Value *V) {
|
||||
// If we already have an SDValue for this value, use it.
|
||||
SDValue &N = NodeMap[V];
|
||||
if (N.getNode()) return N;
|
||||
if (N.getNode()) {
|
||||
if (isa<ConstantSDNode>(N) || isa<ConstantFPSDNode>(N)) {
|
||||
// Remove the debug location from the node as the node is about to be used
|
||||
// in a location which may differ from the original debug location. This
|
||||
// is relevant to Constant and ConstantFP nodes because they can appear
|
||||
// as constant expressions inside PHI nodes.
|
||||
N->setDebugLoc(DebugLoc());
|
||||
}
|
||||
return N;
|
||||
}
|
||||
|
||||
// Otherwise create a new SDValue and remember it.
|
||||
SDValue Val = getValueImpl(V);
|
||||
|
Reference in New Issue
Block a user