Add support for conditionally compiling the debug_server to hand off crashed

teams to the native debugger instead. This assumes the latter is installed
in /boot/system/apps.



git-svn-id: file:///srv/svn/repos/haiku/haiku/trunk@42445 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
Rene Gollent 2011-07-17 15:26:56 +00:00
parent b353a9a30a
commit de6f745cde

View File

@ -27,6 +27,9 @@
#include <util/DoublyLinkedList.h> #include <util/DoublyLinkedList.h>
#define HANDOVER_USE_GDB 1
//#define HANDOVER_USE_DEBUGGER 1
#define USE_GUI true #define USE_GUI true
// define to false if the debug server shouldn't use GUI (i.e. an alert) // define to false if the debug server shouldn't use GUI (i.e. an alert)
@ -45,9 +48,13 @@ using std::nothrow;
static const char *kSignature = "application/x-vnd.Haiku-debug_server"; static const char *kSignature = "application/x-vnd.Haiku-debug_server";
// paths to the apps used for debugging // paths to the apps used for debugging
#ifdef HANDOVER_USE_GDB
static const char *kConsoledPath = "/bin/consoled"; static const char *kConsoledPath = "/bin/consoled";
static const char *kTerminalPath = "/boot/system/apps/Terminal"; static const char *kTerminalPath = "/boot/system/apps/Terminal";
static const char *kGDBPath = "/bin/gdb"; static const char *kGDBPath = "/bin/gdb";
#elif defined(HANDOVER_USE_DEBUGGER)
static const char *kDebuggerPath = "/boot/system/apps/Debugger";
#endif
static void static void
@ -434,8 +441,6 @@ TeamDebugHandler::_EnterDebugger()
TRACE(("debug_server: TeamDebugHandler::_EnterDebugger(): team %ld\n", TRACE(("debug_server: TeamDebugHandler::_EnterDebugger(): team %ld\n",
fTeam)); fTeam));
bool debugInConsoled = _IsGUIServer() || !_AreGUIServersAlive();
// prepare a debugger handover // prepare a debugger handover
TRACE(("debug_server: TeamDebugHandler::_EnterDebugger(): preparing " TRACE(("debug_server: TeamDebugHandler::_EnterDebugger(): preparing "
"debugger handover for team %ld...\n", fTeam)); "debugger handover for team %ld...\n", fTeam));
@ -448,15 +453,17 @@ TeamDebugHandler::_EnterDebugger()
return error; return error;
} }
// prepare the argument vector const char *argv[16];
int argc = 0;
char teamString[32]; char teamString[32];
#ifdef HANDOVER_USE_GDB
bool debugInConsoled = _IsGUIServer() || !_AreGUIServersAlive();
// prepare the argument vector
snprintf(teamString, sizeof(teamString), "--pid=%ld", fTeam); snprintf(teamString, sizeof(teamString), "--pid=%ld", fTeam);
const char *terminal = (debugInConsoled ? kConsoledPath : kTerminalPath); const char *terminal = (debugInConsoled ? kConsoledPath : kTerminalPath);
const char *argv[16];
int argc = 0;
argv[argc++] = terminal; argv[argc++] = terminal;
if (!debugInConsoled) { if (!debugInConsoled) {
@ -477,9 +484,24 @@ TeamDebugHandler::_EnterDebugger()
TRACE(("debug_server: TeamDebugHandler::_EnterDebugger(): starting " TRACE(("debug_server: TeamDebugHandler::_EnterDebugger(): starting "
"terminal (debugger) for team %ld...\n", fTeam)); "terminal (debugger) for team %ld...\n", fTeam));
#elif defined(HANDOVER_USE_DEBUGGER)
// prepare the argument vector
snprintf(teamString, sizeof(teamString), "%ld", fTeam);
argv[argc++] = kDebuggerPath;
argv[argc++] = "--team";
argv[argc++] = teamString;
argv[argc] = NULL;
// start the debugger
TRACE(("debug_server: TeamDebugHandler::_EnterDebugger(): starting "
"graphical debugger for team %ld...\n", fTeam));
#endif
thread_id thread = load_image(argc, argv, (const char**)environ); thread_id thread = load_image(argc, argv, (const char**)environ);
if (thread < 0) { if (thread < 0) {
debug_printf("debug_server: Failed to start consoled + gdb: %s\n", debug_printf("debug_server: Failed to start debugger: %s\n",
strerror(thread)); strerror(thread));
return thread; return thread;
} }