summaryrefslogtreecommitdiffstats
path: root/clang
diff options
context:
space:
mode:
authorDaniel Dunbar <daniel@zuster.org>2010-08-17 22:32:48 +0000
committerDaniel Dunbar <daniel@zuster.org>2010-08-17 22:32:48 +0000
commitf2cf329ccd1bf43d7464dab760e907775e414cab (patch)
tree8966cb10bd2e5d22f5cc11e51f3ad77c303bab87 /clang
parentb613ffc1aa1fb3da5626656f8be8d6f365635591 (diff)
downloadbcm5719-llvm-f2cf329ccd1bf43d7464dab760e907775e414cab.tar.gz
bcm5719-llvm-f2cf329ccd1bf43d7464dab760e907775e414cab.zip
Lex: Add #pragma clang __debug {llvm_fatal_error, llvm_unreachable}, for testing
those crash paths. llvm-svn: 111311
Diffstat (limited to 'clang')
-rw-r--r--clang/include/clang/Basic/DiagnosticLexKinds.td3
-rw-r--r--clang/lib/Lex/Pragma.cpp20
2 files changed, 16 insertions, 7 deletions
diff --git a/clang/include/clang/Basic/DiagnosticLexKinds.td b/clang/include/clang/Basic/DiagnosticLexKinds.td
index 5068a055e86..08ba1c43ccf 100644
--- a/clang/include/clang/Basic/DiagnosticLexKinds.td
+++ b/clang/include/clang/Basic/DiagnosticLexKinds.td
@@ -268,6 +268,9 @@ def warn_pragma_diagnostic_invalid_token :
def warn_pragma_diagnostic_unknown_warning :
ExtWarn<"unknown warning group '%0', ignored">,
InGroup<UnknownPragmas>;
+// - #pragma __debug
+def warn_pragma_debug_unexpected_command : Warning<
+ "unexpected debug command '%0'">;
def err_pragma_comment_unknown_kind : Error<"unknown kind of pragma comment">;
def err_defined_macro_name : Error<"'defined' cannot be used as a macro name">;
diff --git a/clang/lib/Lex/Pragma.cpp b/clang/lib/Lex/Pragma.cpp
index eec1d1d6eea..0ef87b96d3b 100644
--- a/clang/lib/Lex/Pragma.cpp
+++ b/clang/lib/Lex/Pragma.cpp
@@ -20,6 +20,7 @@
#include "clang/Lex/LexDiagnostic.h"
#include "clang/Basic/FileManager.h"
#include "clang/Basic/SourceManager.h"
+#include "llvm/Support/ErrorHandling.h"
#include <algorithm>
using namespace clang;
@@ -697,20 +698,25 @@ struct PragmaDebugHandler : public PragmaHandler {
}
IdentifierInfo *II = Tok.getIdentifierInfo();
- if (II->isStr("overflow_stack")) {
- DebugOverflowStack();
+ if (II->isStr("assert")) {
+ assert(0 && "This is an assertion!");
} else if (II->isStr("crash")) {
- DebugCrash();
+ *(volatile int*) 0x11 = 0;
+ } else if (II->isStr("llvm_fatal_error")) {
+ llvm::report_fatal_error("#pragma clang __debug llvm_fatal_error");
+ } else if (II->isStr("llvm_unreachable")) {
+ llvm_unreachable("#pragma clang __debug llvm_unreachable");
+ } else if (II->isStr("overflow_stack")) {
+ DebugOverflowStack();
+ } else {
+ PP.Diag(Tok, diag::warn_pragma_debug_unexpected_command)
+ << II->getName();
}
}
void DebugOverflowStack() {
DebugOverflowStack();
}
-
- void DebugCrash() {
- *(volatile int*) 0x11 = 0;
- }
};
/// PragmaDiagnosticHandler - e.g. '#pragma GCC diagnostic ignored "-Wformat"'
OpenPOWER on IntegriCloud