summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDan Gohman <gohman@apple.com>2008-08-13 21:22:48 +0000
committerDan Gohman <gohman@apple.com>2008-08-13 21:22:48 +0000
commit8ded5d588455e7ab64ddd25d9ba1509b49746c3b (patch)
tree5147e16b6092ad8b1f533bbdaa9c094080de7063
parentcaefa24c767831291c775ba57cb19e08bef8c3d5 (diff)
downloadbcm5719-llvm-8ded5d588455e7ab64ddd25d9ba1509b49746c3b.tar.gz
bcm5719-llvm-8ded5d588455e7ab64ddd25d9ba1509b49746c3b.zip
Fix SCCP's handling of struct value loads and stores. SCCP doesn't
track individual leaf values in such cases, so it needs to treat struct values as normal values in this case. llvm-svn: 54760
-rw-r--r--llvm/lib/Transforms/Scalar/SCCP.cpp2
-rw-r--r--llvm/test/Transforms/SCCP/empty-struct.ll20
2 files changed, 20 insertions, 2 deletions
diff --git a/llvm/lib/Transforms/Scalar/SCCP.cpp b/llvm/lib/Transforms/Scalar/SCCP.cpp
index d52cef607c4..8c64d8ff7c9 100644
--- a/llvm/lib/Transforms/Scalar/SCCP.cpp
+++ b/llvm/lib/Transforms/Scalar/SCCP.cpp
@@ -1583,7 +1583,6 @@ bool SCCP::runOnFunction(Function &F) {
for (BasicBlock::iterator BI = BB->begin(), E = BB->end(); BI != E; ) {
Instruction *Inst = BI++;
if (Inst->getType() == Type::VoidTy ||
- isa<StructType>(Inst->getType()) ||
isa<TerminatorInst>(Inst))
continue;
@@ -1760,7 +1759,6 @@ bool IPSCCP::runOnModule(Module &M) {
for (BasicBlock::iterator BI = BB->begin(), E = BB->end(); BI != E; ) {
Instruction *Inst = BI++;
if (Inst->getType() == Type::VoidTy ||
- isa<StructType>(Inst->getType()) ||
isa<TerminatorInst>(Inst))
continue;
diff --git a/llvm/test/Transforms/SCCP/empty-struct.ll b/llvm/test/Transforms/SCCP/empty-struct.ll
new file mode 100644
index 00000000000..4e3dc69514e
--- /dev/null
+++ b/llvm/test/Transforms/SCCP/empty-struct.ll
@@ -0,0 +1,20 @@
+; RUN: llvm-as < %s > %t.bc
+; RUN: llvm-ld %t.bc -o %t.sh
+; PR2612
+
+@current_foo = internal global { } zeroinitializer
+
+define i32 @main(...) {
+entry:
+ %retval = alloca i32 ; <i32*> [#uses=2]
+ store i32 0, i32* %retval
+ %local_foo = alloca { } ; <{ }*> [#uses=1]
+ load { }* @current_foo ; <{ }>:0 [#uses=1]
+ store { } %0, { }* %local_foo
+ br label %return
+
+return: ; preds = %entry
+ load i32* %retval ; <i32>:1 [#uses=1]
+ ret i32 %1
+}
+
OpenPOWER on IntegriCloud