summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDiego Novillo <dnovillo@google.com>2014-03-03 20:06:18 +0000
committerDiego Novillo <dnovillo@google.com>2014-03-03 20:06:18 +0000
commitb56be645998ba11706b0b23dbfb8311f4fb06ca2 (patch)
tree53bad856029fc5be3a43e782e0b8dc8a0a992058
parentef78566162feaf4731f05b6661754ebc20156d34 (diff)
downloadbcm5719-llvm-b56be645998ba11706b0b23dbfb8311f4fb06ca2.tar.gz
bcm5719-llvm-b56be645998ba11706b0b23dbfb8311f4fb06ca2.zip
Schedule discriminator pass.
This needs to modify a line table test to account for the new lexical block created to hold the new discriminator value. llvm-svn: 202754
-rw-r--r--clang/lib/CodeGen/BackendUtil.cpp8
-rw-r--r--clang/test/CodeGenCXX/linetable-eh.cpp3
2 files changed, 10 insertions, 1 deletions
diff --git a/clang/lib/CodeGen/BackendUtil.cpp b/clang/lib/CodeGen/BackendUtil.cpp
index 809333aaa15..478993a9f0f 100644
--- a/clang/lib/CodeGen/BackendUtil.cpp
+++ b/clang/lib/CodeGen/BackendUtil.cpp
@@ -166,6 +166,11 @@ static void addSampleProfileLoaderPass(const PassManagerBuilder &Builder,
PM.add(createSampleProfileLoaderPass(CGOpts.SampleProfileFile));
}
+static void addAddDiscriminatorsPass(const PassManagerBuilder &Builder,
+ PassManagerBase &PM) {
+ PM.add(createAddDiscriminatorsPass());
+}
+
static void addBoundsCheckingPass(const PassManagerBuilder &Builder,
PassManagerBase &PM) {
PM.add(createBoundsCheckingPass());
@@ -246,6 +251,9 @@ void EmitAssemblyHelper::CreatePasses() {
PMBuilder.DisableUnrollLoops = !CodeGenOpts.UnrollLoops;
PMBuilder.RerollLoops = CodeGenOpts.RerollLoops;
+ PMBuilder.addExtension(PassManagerBuilder::EP_EarlyAsPossible,
+ addAddDiscriminatorsPass);
+
if (!CodeGenOpts.SampleProfileFile.empty())
PMBuilder.addExtension(PassManagerBuilder::EP_EarlyAsPossible,
addSampleProfileLoaderPass);
diff --git a/clang/test/CodeGenCXX/linetable-eh.cpp b/clang/test/CodeGenCXX/linetable-eh.cpp
index d190c64c01d..14a5067cf3e 100644
--- a/clang/test/CodeGenCXX/linetable-eh.cpp
+++ b/clang/test/CodeGenCXX/linetable-eh.cpp
@@ -6,7 +6,7 @@
// CHECK: call void @llvm.dbg.declare
// CHECK: call void @llvm.dbg.declare(metadata !{{{.*}}}, metadata ![[CURRENT_ADDR:.*]]), !dbg ![[DBG1:.*]]
// CHECK: unwind label %{{.*}}, !dbg ![[DBG1]]
-// CHECK: store i64 %{{.*}}, i64* %current_address, align 8, !dbg ![[DBG1]]
+// CHECK: store i64 %{{.*}}, i64* %current_address, align 8, !dbg ![[DBG4:.*]]
// CHECK-NEXT: call void @llvm.dbg.declare(metadata !{{{.*}}}, metadata ![[FOUND_IT:.*]]), !dbg ![[DBG2:.*]]
// CHECK: = landingpad
// CHECK-NEXT: cleanup, !dbg ![[DBG3:.*]]
@@ -15,6 +15,7 @@
// CHECK-DAG: ![[DBG1]] = metadata !{i32 256,
// CHECK-DAG: ![[DBG2]] = metadata !{i32 257,
// CHECK-DAG: ![[DBG3]] = metadata !{i32 268,
+// CHECK-DAG: ![[DBG4]] = metadata !{i32 256,
typedef unsigned long long uint64_t;
template<class _Tp> class shared_ptr {
public:
OpenPOWER on IntegriCloud