diff options
author | Devang Patel <dpatel@apple.com> | 2008-03-04 19:22:54 +0000 |
---|---|---|
committer | Devang Patel <dpatel@apple.com> | 2008-03-04 19:22:54 +0000 |
commit | 297ea0de75d73306f175ab509e9d22c058ecf77d (patch) | |
tree | 40f50d860750563c5224e28023ed6d72845e6a15 /llvm/lib/Transforms | |
parent | 748c77f530c753fd8803daa036ed9a058c72cad9 (diff) | |
download | bcm5719-llvm-297ea0de75d73306f175ab509e9d22c058ecf77d.tar.gz bcm5719-llvm-297ea0de75d73306f175ab509e9d22c058ecf77d.zip |
Use appropriate index to get the result value.
llvm-svn: 47897
Diffstat (limited to 'llvm/lib/Transforms')
-rw-r--r-- | llvm/lib/Transforms/IPO/StructRetPromotion.cpp | 4 |
1 files changed, 3 insertions, 1 deletions
diff --git a/llvm/lib/Transforms/IPO/StructRetPromotion.cpp b/llvm/lib/Transforms/IPO/StructRetPromotion.cpp index 2d1ddfb98d8..7ea85493ee8 100644 --- a/llvm/lib/Transforms/IPO/StructRetPromotion.cpp +++ b/llvm/lib/Transforms/IPO/StructRetPromotion.cpp @@ -302,7 +302,9 @@ void SRETPromotion::updateCallSites(Function *F, Function *NF) { if (C2 && (C2 == Call)) continue; else if (GetElementPtrInst *UGEP = dyn_cast<GetElementPtrInst>(U2)) { - Value *GR = new GetResultInst(New, 5, "xxx", UGEP); + ConstantInt *Idx = dyn_cast<ConstantInt>(UGEP->getOperand(2)); + assert (Idx && "Unexpected getelementptr index!"); + Value *GR = new GetResultInst(New, Idx->getZExtValue(), "gr", UGEP); for (Value::use_iterator GI = UGEP->use_begin(), GE = UGEP->use_end(); GI != GE; ++GI) { if (LoadInst *L = dyn_cast<LoadInst>(*GI)) { |