2006-02-10 21:53:51 +00:00
|
|
|
/* Host support routines for MinGW, for GDB, the GNU debugger.
|
|
|
|
|
2023-01-01 16:49:04 +04:00
|
|
|
Copyright (C) 2006-2023 Free Software Foundation, Inc.
|
2006-02-10 21:53:51 +00:00
|
|
|
|
|
|
|
This file is part of GDB.
|
|
|
|
|
|
|
|
This program is free software; you can redistribute it and/or modify
|
|
|
|
it under the terms of the GNU General Public License as published by
|
2007-08-23 18:08:50 +00:00
|
|
|
the Free Software Foundation; either version 3 of the License, or
|
2006-02-10 21:53:51 +00:00
|
|
|
(at your option) any later version.
|
|
|
|
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
GNU General Public License for more details.
|
|
|
|
|
|
|
|
You should have received a copy of the GNU General Public License
|
2007-08-23 18:08:50 +00:00
|
|
|
along with this program. If not, see <http://www.gnu.org/licenses/>. */
|
2006-02-10 21:53:51 +00:00
|
|
|
|
|
|
|
#include "defs.h"
|
2020-04-13 12:42:59 -06:00
|
|
|
#include "gdbsupport/event-loop.h"
|
2020-04-13 12:42:59 -06:00
|
|
|
#include "gdbsupport/gdb_select.h"
|
2022-12-05 11:15:09 -07:00
|
|
|
#include "inferior.h"
|
Fix control-c handling on Windows
As Hannes pointed out, the Windows target-async patches broke C-c
handling there. Looking into this, I found a few oddities, fixed
here.
First, windows_nat_target::interrupt calls GenerateConsoleCtrlEvent.
I think this event can be ignored by the inferior, so it's not a great
way to interrupt. Instead, using DebugBreakProcess (or a more
complicated thing for Wow64) seems better.
Second, windows_nat_target did not implement the pass_ctrlc method.
Implementing this lets us remove the special code to call
SetConsoleCtrlHandler and instead integrate into gdb's approach to C-c
handling. I believe that this should also fix the race that's
described in the comment that's being removed.
Initially, I thought a simpler version of this patch would work.
However, I think what happens is that some other library (I'm not sure
what) calls SetConsoleCtrlHandler while gdb is running, and this
intercepts and handles C-c -- so that the gdb SIGINT handler is not
called. C-break continues to work, presumably because whatever
handler is installed ignores it.
This patch works around this issue by ensuring that the gdb handler
always comes first.
2022-12-05 10:56:23 -07:00
|
|
|
#include <signal.h>
|
* NEWS: Mention native Windows support.
* Makefile.in (gdb_select_h, ser_tcp_h): New.
(ALLDEPFILES): Add ser-mingw.c.
(event-loop.o, inflow.o, mingw-hdep.o, posix-hdep.o, ser-base.o)
(ser-tcp.o, ser-unix.o): Update.
(ser-mingw.o): New rule.
* configure: Regenerated.
* configure.ac: Add ser-mingw.o for mingw32.
* ser-mingw.c: New file.
* event-loop.c: Include "gdb_select.h".
(gdb_select): Remove, moved to mingw-hdep.c and posix-hdep.c.
* ser-base.c: Include "gdb_select.h".
(ser_base_wait_for): Use gdb_select.
* serial.c (serial_for_fd): New function.
(serial_fdopen): Try "terminal" before "hardwire". Initialize
the allocated struct serial.
(serial_wait_handle): New function.
* serial.h (serial_for_fd, serial_wait_handle): New prototypes.
(struct serial_ops) [USE_WIN32API]: Add wait_handle.
* gdb_select.h: New file.
* ser-tcp.c: Include "ser-tcp.h". Remove unused "ser-unix.h" include.
(net_close, net_read_prim, net_write_prim): Make global.
(net_open): Likewise. Pass an exception set to select. Whitespace fix.
Document why we can not use gdb_select.
(_initialize_ser_tcp) [USE_WIN32API]: Do not register TCP support here.
* ser-tcp.h: New file.
* inflow.c (gdb_has_a_terminal): Don't initialize stdin_serial here.
(handle_sigio): Use gdb_select.
(initialize_stdin_serial): New function.
* terminal.h (initialize_stdin_serial): New prototype.
* top.c (gdb_init): Call initialize_stdin_serial.
* mingw-hdep.c (gdb_select): New function, moved from gdb_select in
event-loop.c. Add exception condition support. Use serial_for_fd
and serial_wait_handle. Fix timeout handling.
* posix-hdep.c: Include "gdb_select.h".
(gdb_select): New function.
* remote-st.c (connect_command): Use gdb_select.
* ser-unix.c: Include "gdb_select.h".
(hardwire_send_break, wait_for): Use gdb_select.
2006-02-10 22:01:43 +00:00
|
|
|
|
|
|
|
/* Wrapper for select. Nothing special needed on POSIX platforms. */
|
|
|
|
|
|
|
|
int
|
|
|
|
gdb_select (int n, fd_set *readfds, fd_set *writefds, fd_set *exceptfds,
|
|
|
|
struct timeval *timeout)
|
|
|
|
{
|
|
|
|
return select (n, readfds, writefds, exceptfds, timeout);
|
|
|
|
}
|
2019-03-09 08:44:56 +02:00
|
|
|
|
|
|
|
/* Host-dependent console fputs method. POSIX platforms always return
|
|
|
|
zero, to use the default C 'fputs'. */
|
|
|
|
int
|
|
|
|
gdb_console_fputs (const char *buf, FILE *f)
|
|
|
|
{
|
|
|
|
return 0;
|
|
|
|
}
|
2022-12-05 11:15:09 -07:00
|
|
|
|
|
|
|
/* See inferior.h. */
|
|
|
|
|
|
|
|
tribool
|
|
|
|
sharing_input_terminal (int pid)
|
|
|
|
{
|
|
|
|
/* Using host-dependent code here is fine, because the
|
|
|
|
child_terminal_foo functions are meant to be used by child/native
|
|
|
|
targets. */
|
|
|
|
#if defined (__linux__) || defined (__sun__)
|
|
|
|
char buf[100];
|
|
|
|
|
|
|
|
xsnprintf (buf, sizeof (buf), "/proc/%d/fd/0", pid);
|
|
|
|
return is_gdb_terminal (buf);
|
|
|
|
#else
|
|
|
|
return TRIBOOL_UNKNOWN;
|
|
|
|
#endif
|
|
|
|
}
|
Fix control-c handling on Windows
As Hannes pointed out, the Windows target-async patches broke C-c
handling there. Looking into this, I found a few oddities, fixed
here.
First, windows_nat_target::interrupt calls GenerateConsoleCtrlEvent.
I think this event can be ignored by the inferior, so it's not a great
way to interrupt. Instead, using DebugBreakProcess (or a more
complicated thing for Wow64) seems better.
Second, windows_nat_target did not implement the pass_ctrlc method.
Implementing this lets us remove the special code to call
SetConsoleCtrlHandler and instead integrate into gdb's approach to C-c
handling. I believe that this should also fix the race that's
described in the comment that's being removed.
Initially, I thought a simpler version of this patch would work.
However, I think what happens is that some other library (I'm not sure
what) calls SetConsoleCtrlHandler while gdb is running, and this
intercepts and handles C-c -- so that the gdb SIGINT handler is not
called. C-break continues to work, presumably because whatever
handler is installed ignores it.
This patch works around this issue by ensuring that the gdb handler
always comes first.
2022-12-05 10:56:23 -07:00
|
|
|
|
|
|
|
/* Current C-c handler. */
|
|
|
|
static c_c_handler_ftype *current_handler;
|
|
|
|
|
|
|
|
/* A wrapper that reinstalls the current signal handler. */
|
|
|
|
static void
|
|
|
|
handler_wrapper (int num)
|
|
|
|
{
|
|
|
|
signal (num, handler_wrapper);
|
|
|
|
if (current_handler != SIG_IGN)
|
|
|
|
current_handler (num);
|
|
|
|
}
|
|
|
|
|
|
|
|
/* See inferior.h. */
|
|
|
|
|
|
|
|
c_c_handler_ftype *
|
|
|
|
install_sigint_handler (c_c_handler_ftype *fn)
|
|
|
|
{
|
|
|
|
signal (SIGINT, handler_wrapper);
|
|
|
|
c_c_handler_ftype *result = current_handler;
|
|
|
|
current_handler = fn;
|
|
|
|
return result;
|
|
|
|
}
|