GDB Ctrl-C Interrupt Fails WORKAROUND

Pedro Alves pedro_alves@portugalmail.pt
Thu Mar 1 00:16:00 GMT 2007


Christopher Layne escreveu:
> On Thu, Jun 15, 2006 at 11:04:56AM -0400, Christopher Faylor wrote:
>>> I'm happy for you that CTRL-C works for you.  It does not work for me.
>>>
>>> I'm almost never running gdb from a genuine DOS command prompt.   
>>> Sometimes via ssh, sometimes via a terminal emulator.  CTRL-C doesn't  
>>> work in those.
>>>
>>> Also, if you have "tty" in your CYGWIN variable it doesn't work even  
>> >from a DOS command prompt.
>>
>> Which is exactly what I theorized above.  So, characterizing CTRL-C as
>> not working in gdb is rather an overstatement without more details.
>>
>> Now you know that you can use a standard console window for debugging
>> and all will be well.
>>
>>> Lacking the ability to interrupt a running program severely limits  
>>> gdb's usefulness.  Fortunately there's a workaround available.
>> Yep.  Use a console window.
>>

Is there a reason DebugBreakProcess can't be used from inside
gdb if sending a ctrl-c with GenerateConsoleCtrlEvent (CTRL_C_EVENT, pid)
doesn't work?

> 
> Where in the cygwin source tree would the best place be to look for
> where SIGINT handling is being done at the tty/pty level so that I can
> remove this pointless limitation from my builds?
> 


See gdb/win32-nat.c:win32_stop

and also:
http://sourceware.org/ml/gdb-patches/2007-02/msg00294.html
Look for win32_send_signal in the patch.

Note that DebugBreakProcess only exists on XP or Windows 2003
server onwards.  For WinNT < XP, it should be possible to simulate
it with CreateRemoteThread with entry point set to
DebugBreak or something similar.  The worst case would be that a dll
would have to be injected to load a function that does the
DebugBreak in the debuggee's address space.

Cheers,
Pedro Alves



--
Unsubscribe info:      http://cygwin.com/ml/#unsubscribe-simple
Problem reports:       http://cygwin.com/problems.html
Documentation:         http://cygwin.com/docs.html
FAQ:                   http://cygwin.com/faq/



More information about the Cygwin mailing list