summaryrefslogtreecommitdiffstats
path: root/llvm/lib
diff options
context:
space:
mode:
authorKrzysztof Parzyszek <kparzysz@codeaurora.org>2016-04-28 15:09:19 +0000
committerKrzysztof Parzyszek <kparzysz@codeaurora.org>2016-04-28 15:09:19 +0000
commitefd72857a341d62a344dbeaf8baae56454ea4437 (patch)
tree0e816c638243af3c631f7f9085836d30a3f82697 /llvm/lib
parent354fac2a69574ac668c3f7d56ca22f7c9aa91344 (diff)
downloadbcm5719-llvm-efd72857a341d62a344dbeaf8baae56454ea4437.tar.gz
bcm5719-llvm-efd72857a341d62a344dbeaf8baae56454ea4437.zip
[RDF] Handle undefined registers in RDF copy propagation
When updating the graph, make sure that new uses without reaching defs are handled correctly. llvm-svn: 267891
Diffstat (limited to 'llvm/lib')
-rw-r--r--llvm/lib/Target/Hexagon/RDFCopy.cpp7
1 files changed, 6 insertions, 1 deletions
diff --git a/llvm/lib/Target/Hexagon/RDFCopy.cpp b/llvm/lib/Target/Hexagon/RDFCopy.cpp
index 251e175e228..c777878df30 100644
--- a/llvm/lib/Target/Hexagon/RDFCopy.cpp
+++ b/llvm/lib/Target/Hexagon/RDFCopy.cpp
@@ -218,7 +218,12 @@ bool CopyPropagation::run() {
Op.setReg(SR.Reg);
Op.setSubReg(SR.Sub);
DFG.unlinkUse(UA, false);
- UA.Addr->linkToDef(UA.Id, DFG.addr<DefNode*>(RDefSR_SA));
+ if (RDefSR_SA != 0) {
+ UA.Addr->linkToDef(UA.Id, DFG.addr<DefNode*>(RDefSR_SA));
+ } else {
+ UA.Addr->setReachingDef(0);
+ UA.Addr->setSibling(0);
+ }
Changed = true;
#ifndef NDEBUG
OpenPOWER on IntegriCloud