binutils-gdb/gdb/ser-event.h
Joel Brobecker 61baf725ec update copyright year range in GDB files
This applies the second part of GDB's End of Year Procedure, which
updates the copyright year range in all of GDB's files.

gdb/ChangeLog:

        Update copyright year range in all GDB files.
2017-01-01 10:52:34 +04:00

52 lines
2.0 KiB
C

/* Serial interface for a selectable event.
Copyright (C) 2016-2017 Free Software Foundation, Inc.
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
the Free Software Foundation; either version 3 of the License, or
(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
along with this program. If not, see <http://www.gnu.org/licenses/>. */
#ifndef SER_EVENT_H
#define SER_EVENT_H
/* This is used to be able to signal the event loop (or any other
select/poll) of events, in a race-free manner.
For example, a signal handler can defer non-async-signal-safe work
to the event loop, by having the signal handler set a struct
serial_event object, and having the event loop wait for that same
object to the readable. Once readable, the event loop breaks out
of select/poll and calls a registered callback that does the
deferred work. */
struct serial_event;
/* Make a new serial_event object. */
struct serial_event *make_serial_event (void);
/* Return the FD that can be used by select/poll to wait for the
event. The only valid operation on this object is to wait until it
is readable. */
extern int serial_event_fd (struct serial_event *event);
/* Set the event. This signals the file descriptor returned by
serial_event_fd as readable. */
extern void serial_event_set (struct serial_event *event);
/* Clear the event. The file descriptor returned by serial_event_fd
is not longer readable after this, until a new serial_event_set
call is made. */
extern void serial_event_clear (struct serial_event *event);
#endif