diff options
Diffstat (limited to 'include/llvm/Support')
-rw-r--r-- | include/llvm/Support/ErrorHandling.h | 19 | ||||
-rw-r--r-- | include/llvm/Support/InstVisitor.h | 2 | ||||
-rw-r--r-- | include/llvm/Support/PassNameParser.h | 2 |
3 files changed, 12 insertions, 11 deletions
diff --git a/include/llvm/Support/ErrorHandling.h b/include/llvm/Support/ErrorHandling.h index c14eed9885..bdee5b1c24 100644 --- a/include/llvm/Support/ErrorHandling.h +++ b/include/llvm/Support/ErrorHandling.h @@ -47,19 +47,20 @@ namespace llvm { void llvm_report_error(const std::string &reason) NORETURN; /// This function calls abort(), and prints the optional message to stderr. - /// Call this instead of assert(0), so that compiler knows the path is not - /// reachable even for NDEBUG builds. - /// Use the LLVM_UNREACHABLE macro instead that adds location info. - void llvm_unreachable(const char *msg=0, const char *file=0, - unsigned line=0) NORETURN; + /// Use the llvm_unreachable macro (that adds location info), instead of + /// calling this function directly. + void llvm_unreachable_internal(const char *msg=0, const char *file=0, + unsigned line=0) NORETURN; } -/// Macro that calls llvm_unreachable with location info and message in -/// debug mode. In NDEBUG mode it calls llvm_unreachable with no message. +/// Prints the message and location info to stderr in !NDEBUG builds. +/// In NDEBUG mode it only prints "UNREACHABLE executed". +/// Use this instead of assert(0), so that the compiler knows this path +/// is not reachable even for NDEBUG builds. #ifndef NDEBUG -#define LLVM_UNREACHABLE(msg) llvm_unreachable(msg, __FILE__, __LINE__) +#define llvm_unreachable(msg) llvm_unreachable_internal(msg, __FILE__, __LINE__) #else -#define LLVM_UNREACHABLE(msg) llvm_unreachable() +#define llvm_unreachable(msg) llvm_unreachable_internal() #endif #endif diff --git a/include/llvm/Support/InstVisitor.h b/include/llvm/Support/InstVisitor.h index 2fa8c4793c..7c8f85a065 100644 --- a/include/llvm/Support/InstVisitor.h +++ b/include/llvm/Support/InstVisitor.h @@ -114,7 +114,7 @@ public: // RetTy visit(Instruction &I) { switch (I.getOpcode()) { - default: LLVM_UNREACHABLE("Unknown instruction type encountered!"); + default: llvm_unreachable("Unknown instruction type encountered!"); // Build the switch statement using the Instruction.def file... #define HANDLE_INST(NUM, OPCODE, CLASS) \ case Instruction::OPCODE: return \ diff --git a/include/llvm/Support/PassNameParser.h b/include/llvm/Support/PassNameParser.h index 559dfd3e97..a437e2048e 100644 --- a/include/llvm/Support/PassNameParser.h +++ b/include/llvm/Support/PassNameParser.h @@ -68,7 +68,7 @@ public: if (findOption(P->getPassArgument()) != getNumOptions()) { cerr << "Two passes with the same argument (-" << P->getPassArgument() << ") attempted to be registered!\n"; - LLVM_UNREACHABLE(0); + llvm_unreachable(0); } addLiteralOption(P->getPassArgument(), P, P->getPassName()); } |