blob: 727f5ea525d4bf8dfab26a646db9f195f23f0ecd [file] [log] [blame]
Nick Lewycky1a4021a2011-02-20 08:38:20 +00001//===- Local.cpp - Unit tests for Local -----------------------------------===//
2//
3// The LLVM Compiler Infrastructure
4//
5// This file is distributed under the University of Illinois Open Source
6// License. See LICENSE.TXT for details.
7//
8//===----------------------------------------------------------------------===//
9
Nick Lewycky1a4021a2011-02-20 08:38:20 +000010#include "llvm/BasicBlock.h"
Chandler Carruth06cb8ed2012-06-29 12:38:19 +000011#include "llvm/IRBuilder.h"
Nick Lewycky1a4021a2011-02-20 08:38:20 +000012#include "llvm/Instructions.h"
13#include "llvm/LLVMContext.h"
Nick Lewycky1a4021a2011-02-20 08:38:20 +000014#include "llvm/Transforms/Utils/Local.h"
15
Chandler Carruth06cb8ed2012-06-29 12:38:19 +000016#include "gtest/gtest.h"
17
Nick Lewycky1a4021a2011-02-20 08:38:20 +000018using namespace llvm;
19
20TEST(Local, RecursivelyDeleteDeadPHINodes) {
21 LLVMContext &C(getGlobalContext());
22
23 IRBuilder<> builder(C);
24
25 // Make blocks
26 BasicBlock *bb0 = BasicBlock::Create(C);
27 BasicBlock *bb1 = BasicBlock::Create(C);
28
29 builder.SetInsertPoint(bb0);
Jay Foad3ecfc862011-03-30 11:28:46 +000030 PHINode *phi = builder.CreatePHI(Type::getInt32Ty(C), 2);
Nick Lewycky1a4021a2011-02-20 08:38:20 +000031 BranchInst *br0 = builder.CreateCondBr(builder.getTrue(), bb0, bb1);
32
33 builder.SetInsertPoint(bb1);
34 BranchInst *br1 = builder.CreateBr(bb0);
35
36 phi->addIncoming(phi, bb0);
37 phi->addIncoming(phi, bb1);
38
39 // The PHI will be removed
40 EXPECT_TRUE(RecursivelyDeleteDeadPHINode(phi));
41
42 // Make sure the blocks only contain the branches
43 EXPECT_EQ(&bb0->front(), br0);
44 EXPECT_EQ(&bb1->front(), br1);
45
Nick Lewyckyeff5e692011-02-20 18:05:56 +000046 builder.SetInsertPoint(bb0);
Jay Foad3ecfc862011-03-30 11:28:46 +000047 phi = builder.CreatePHI(Type::getInt32Ty(C), 0);
Nick Lewyckyeff5e692011-02-20 18:05:56 +000048
49 EXPECT_TRUE(RecursivelyDeleteDeadPHINode(phi));
50
Duncan Sandsb4098ba2011-02-21 16:27:36 +000051 builder.SetInsertPoint(bb0);
Jay Foad3ecfc862011-03-30 11:28:46 +000052 phi = builder.CreatePHI(Type::getInt32Ty(C), 0);
Duncan Sandsb4098ba2011-02-21 16:27:36 +000053 builder.CreateAdd(phi, phi);
54
55 EXPECT_TRUE(RecursivelyDeleteDeadPHINode(phi));
56
Nick Lewycky1a4021a2011-02-20 08:38:20 +000057 bb0->dropAllReferences();
58 bb1->dropAllReferences();
59 delete bb0;
60 delete bb1;
61}