summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJose Fonseca <jfonseca@vmware.com>2015-07-01 16:00:39 +0100
committerJose Fonseca <jfonseca@vmware.com>2015-07-01 16:00:39 +0100
commitd046dfad19bd0f5c0f8ff0165e86f5cad78c28dd (patch)
treefad6aae33c2bfbb2a6a4fa0b73c5bd218b35573a
parent49192a4e48d080e44a0d66f059e6897f07cf67f8 (diff)
retrace: Ensure MSVS C/C++ runtime assertions go to stderr.
Instead of dialog boxes.
-rw-r--r--CMakeLists.txt1
-rw-r--r--common/os_crtdbg.cpp92
-rw-r--r--common/os_crtdbg.hpp57
-rw-r--r--retrace/retrace_main.cpp3
4 files changed, 153 insertions, 0 deletions
diff --git a/CMakeLists.txt b/CMakeLists.txt
index e9d06b85..1ec85228 100644
--- a/CMakeLists.txt
+++ b/CMakeLists.txt
@@ -507,6 +507,7 @@ add_convenience_library (common
common/trace_option.cpp
common/${os}
common/os_backtrace.cpp
+ common/os_crtdbg.cpp
common/highlight.cpp
)
diff --git a/common/os_crtdbg.cpp b/common/os_crtdbg.cpp
new file mode 100644
index 00000000..21dec6ec
--- /dev/null
+++ b/common/os_crtdbg.cpp
@@ -0,0 +1,92 @@
+/**************************************************************************
+ *
+ * Copyright 2015 VMware, Inc
+ * All Rights Reserved.
+ *
+ * Permission is hereby granted, free of charge, to any person obtaining a copy
+ * of this software and associated documentation files (the "Software"), to deal
+ * in the Software without restriction, including without limitation the rights
+ * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
+ * copies of the Software, and to permit persons to whom the Software is
+ * furnished to do so, subject to the following conditions:
+ *
+ * The above copyright notice and this permission notice shall be included in
+ * all copies or substantial portions of the Software.
+ *
+ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+ * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+ * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
+ * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
+ * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
+ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
+ * THE SOFTWARE.
+ *
+ **************************************************************************/
+
+
+#include "os_crtdbg.hpp"
+
+#include <assert.h>
+#include <stdio.h>
+
+#ifdef _WIN32
+#include <windows.h>
+#include <crtdbg.h>
+#endif
+
+#include "os.hpp"
+
+
+namespace os {
+
+
+#ifdef _WIN32
+
+static void
+invalidParameterHandler(const wchar_t* expression,
+ const wchar_t* function,
+ const wchar_t* file,
+ unsigned int line,
+ uintptr_t pReserved)
+{
+ fprintf(stderr, "Invalid parameter detected in function %S. File: %S Line: %d\n", function, file, line);
+ fprintf(stderr, "Expression: %S\n", expression);
+ if (IsDebuggerPresent()) {
+ os::breakpoint();
+ }
+ os::abort();
+}
+
+#endif // _WIN32
+
+
+void
+setDebugOutput(Output output)
+{
+
+#ifdef _WIN32
+ // Disable assertion failure message box
+ // http://msdn.microsoft.com/en-us/library/sas1dkb2.aspx
+ _set_error_mode(_OUT_TO_STDERR);
+#ifdef _MSC_VER
+ // Disable abort message box
+ // http://msdn.microsoft.com/en-us/library/e631wekh.aspx
+ _set_abort_behavior(0, _WRITE_ABORT_MSG);
+ // Direct debug reports to stderr
+ // https://msdn.microsoft.com/en-us/library/1y71x448.aspx
+ for (int reportType = 0; reportType < _CRT_ERRCNT; ++reportType) {
+ _CrtSetReportMode(reportType, _CRTDBG_MODE_FILE);
+ _CrtSetReportFile(reportType, _CRTDBG_FILE_STDERR);
+ }
+#endif /* _MSC_VER */
+ // Set our own invalid_parameter handler
+ // https://msdn.microsoft.com/en-us/library/a9yf33zb.aspx
+ _set_invalid_parameter_handler(invalidParameterHandler);
+#endif /* _WIN32 */
+
+
+ assert(output == OUTPUT_STDERR);
+}
+
+
+} /* namespace os */
diff --git a/common/os_crtdbg.hpp b/common/os_crtdbg.hpp
new file mode 100644
index 00000000..87a018ba
--- /dev/null
+++ b/common/os_crtdbg.hpp
@@ -0,0 +1,57 @@
+/**************************************************************************
+ *
+ * Copyright 2015 VMware, Inc.
+ * All Rights Reserved.
+ *
+ * Permission is hereby granted, free of charge, to any person obtaining a copy
+ * of this software and associated documentation files (the "Software"), to deal
+ * in the Software without restriction, including without limitation the rights
+ * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
+ * copies of the Software, and to permit persons to whom the Software is
+ * furnished to do so, subject to the following conditions:
+ *
+ * The above copyright notice and this permission notice shall be included in
+ * all copies or substantial portions of the Software.
+ *
+ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+ * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+ * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
+ * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
+ * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
+ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
+ * THE SOFTWARE.
+ *
+ **************************************************************************/
+
+/*
+ * Abstrations to force where CRT debug output should go.
+ */
+
+#pragma once
+
+
+#include <stdio.h>
+
+#ifdef _WIN32
+#include <assert.h>
+
+#include <fcntl.h>
+#include <io.h>
+#endif
+
+
+namespace os {
+
+
+enum Output {
+ OUTPUT_STDERR,
+ OUTPUT_OUTDBG
+};
+
+
+void
+setDebugOutput(Output output);
+
+
+} /* namespace os */
+
diff --git a/retrace/retrace_main.cpp b/retrace/retrace_main.cpp
index f2da147d..5b3ab43c 100644
--- a/retrace/retrace_main.cpp
+++ b/retrace/retrace_main.cpp
@@ -35,6 +35,7 @@
#endif
#include "os_binary.hpp"
+#include "os_crtdbg.hpp"
#include "os_time.hpp"
#include "os_thread.hpp"
#include "image.hpp"
@@ -710,6 +711,8 @@ int main(int argc, char **argv)
using namespace retrace;
int i;
+ os::setDebugOutput(os::OUTPUT_STDERR);
+
assert(snapshotFrequency.empty());
int opt;