X-Git-Url: http://git.efficios.com/?a=blobdiff_plain;f=gdb%2Fgdb_select.h;h=69021ac28eae234dcf530018f4f6f8a835b76f3c;hb=d16c467a501547e37b111f775396e28f8bf27c1e;hp=e8a7d98c9aa1845aeb31dc541715b3ef24f2acf0;hpb=4c38e0a4fcb69f8586d8db0b9cdb8dbab5980811;p=deliverable%2Fbinutils-gdb.git diff --git a/gdb/gdb_select.h b/gdb/gdb_select.h index e8a7d98c9a..69021ac28e 100644 --- a/gdb/gdb_select.h +++ b/gdb/gdb_select.h @@ -1,6 +1,6 @@ /* Slightly more portable version of . - Copyright (C) 2006, 2007, 2008, 2009, 2010 Free Software Foundation, Inc. + Copyright (C) 2006-2020 Free Software Foundation, Inc. This file is part of GDB. @@ -23,7 +23,7 @@ #ifdef HAVE_SYS_SELECT_H #include #else -#include +#include "gdbsupport/gdb_sys_time.h" #endif #ifdef USE_WIN32API @@ -33,4 +33,19 @@ extern int gdb_select (int n, fd_set *readfds, fd_set *writefds, fd_set *exceptfds, struct timeval *timeout); +/* Convenience wrapper around gdb_select that returns -1/EINTR if + set_quit_flag is set, either on entry or from a signal handler or + from a different thread while select is blocked. The quit flag is + not cleared on exit -- the caller is responsible to check it with + check_quit_flag or QUIT. + + Note this does NOT return -1/EINTR if any signal handler other than + SIGINT runs, nor if the current SIGINT handler does not call + set_quit_flag. */ +extern int interruptible_select (int n, + fd_set *readfds, + fd_set *writefds, + fd_set *exceptfds, + struct timeval *timeout); + #endif /* !defined(GDB_SELECT_H) */