Skip to content

Commit 7c7e302

Browse files
committed
mingw: add a helper function to attach GDB to the current process
When debugging Git, the criss-cross spawning of processes can make things quite a bit difficult, especially when a Unix shell script is thrown in the mix that calls a `git.exe` that then segfaults. To help debugging such things, we introduce the `open_in_gdb()` function which can be called at a code location where the segfault happens (or as close as one can get); This will open a new MinTTY window with a GDB that already attached to the current process. Inspired by Derrick Stolee. Signed-off-by: Johannes Schindelin <[email protected]>
1 parent e1dfaac commit 7c7e302

File tree

2 files changed

+23
-0
lines changed

2 files changed

+23
-0
lines changed

compat/mingw.c

Lines changed: 13 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -14,6 +14,19 @@
1414

1515
#define HCAST(type, handle) ((type)(intptr_t)handle)
1616

17+
void open_in_gdb(void)
18+
{
19+
static struct child_process cp = CHILD_PROCESS_INIT;
20+
extern char *_pgmptr;
21+
22+
argv_array_pushl(&cp.args, "mintty", "gdb", NULL);
23+
argv_array_pushf(&cp.args, "--pid=%d", getpid());
24+
cp.clean_on_exit = 1;
25+
if (start_command(&cp) < 0)
26+
die_errno("Could not start gdb");
27+
sleep(1);
28+
}
29+
1730
int err_win_to_posix(DWORD winerr)
1831
{
1932
int error = ENOSYS;

compat/mingw.h

Lines changed: 10 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -691,6 +691,16 @@ extern CRITICAL_SECTION pinfo_cs;
691691
int wmain(int argc, const wchar_t **w_argv);
692692
int main(int argc, const char **argv);
693693

694+
/*
695+
* For debugging: if a problem occurs, say, in a Git process that is spawned
696+
* from another Git process which in turn is spawned from yet another Git
697+
* process, it can be quite daunting to figure out what is going on.
698+
*
699+
* Call this function to open a new MinTTY (this assumes you are in Git for
700+
* Windows' SDK) with a GDB that attaches to the current process right away.
701+
*/
702+
extern void open_in_gdb(void);
703+
694704
/*
695705
* Used by Pthread API implementation for Windows
696706
*/

0 commit comments

Comments
 (0)