]>
Commit | Line | Data |
---|---|---|
b52373a2 | 1 | /* Remote serial support interface definitions for GDB, the GNU Debugger. |
ae0ea72e SC |
2 | Copyright 1992 Free Software Foundation, Inc. |
3 | ||
4 | This file is part of GDB. | |
5 | ||
6 | This program is free software; you can redistribute it and/or modify | |
7 | it under the terms of the GNU General Public License as published by | |
8 | the Free Software Foundation; either version 2 of the License, or | |
9 | (at your option) any later version. | |
10 | ||
11 | This program is distributed in the hope that it will be useful, | |
12 | but WITHOUT ANY WARRANTY; without even the implied warranty of | |
13 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
14 | GNU General Public License for more details. | |
15 | ||
16 | You should have received a copy of the GNU General Public License | |
17 | along with this program; if not, write to the Free Software | |
18 | Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. */ | |
19 | ||
ed3f6049 SG |
20 | #ifdef HAVE_TERMIO |
21 | ||
22 | #include <termios.h> | |
23 | #include <unistd.h> | |
24 | ||
25 | struct ttystate | |
26 | { | |
27 | int flags; /* Flags from fcntl F_GETFL */ | |
28 | struct termios termios; /* old tty driver settings */ | |
29 | }; | |
30 | ||
31 | #else /* not HAVE_TERMIO */ | |
32 | ||
33 | #include <sgtty.h> | |
34 | ||
35 | struct ttystate { | |
36 | int flags; /* Flags from fcntl F_GETFL */ | |
37 | struct sgttyb sgttyb; /* old tty driver settings */ | |
38 | }; | |
39 | ||
40 | #endif /* not HAVE_TERMIO */ | |
ae0ea72e | 41 | /* Return a sensible default name for a serial device, something which |
b52373a2 | 42 | can be used as an argument to serial_open. */ |
ae0ea72e | 43 | |
b52373a2 | 44 | const char *serial_default_name PARAMS ((void)); |
ae0ea72e | 45 | |
b52373a2 | 46 | /* Try to open the serial device "name", return 1 if ok, 0 if not. */ |
ae0ea72e | 47 | |
b52373a2 | 48 | int serial_open PARAMS ((const char *name)); |
ae0ea72e | 49 | |
b52373a2 | 50 | /* Turn the port into raw mode. */ |
ae0ea72e | 51 | |
ed3f6049 | 52 | void serial_raw PARAMS ((int fd, struct ttystate *oldstate)); |
ae0ea72e | 53 | |
b52373a2 | 54 | /* Turn the port into normal mode. */ |
ae0ea72e | 55 | |
b52373a2 | 56 | void serial_normal PARAMS ((void)); |
ae0ea72e | 57 | |
b52373a2 | 58 | /* Read one char from the serial device with <TO>-second timeout. |
5a6242dd | 59 | Returns char if ok, else EOF, -2 for timeout, -3 for anything else */ |
ae0ea72e | 60 | |
5a6242dd | 61 | int serial_readchar PARAMS ((int to)); |
ae0ea72e | 62 | |
b52373a2 JG |
63 | /* Set the baudrate to the decimal value supplied, and return 1, or fail and |
64 | return 0. */ | |
ae0ea72e | 65 | |
a0f9783e | 66 | int serial_setbaudrate PARAMS ((int rate)); |
ae0ea72e | 67 | |
b52373a2 | 68 | /* Return the next rate in the sequence, or return 0 for failure. */ |
ae0ea72e | 69 | |
a0f9783e SG |
70 | /* Write some chars to the device, returns 0 for failure. See errno for |
71 | details. */ | |
ae0ea72e | 72 | |
ed3f6049 | 73 | int serial_write PARAMS ((const char *str, int len)); |
ae0ea72e | 74 | |
a0f9783e | 75 | /* Close the serial port */ |
ae0ea72e | 76 | |
a0f9783e | 77 | void serial_close PARAMS ((void)); |
740b7efa SG |
78 | |
79 | /* Restore the serial port to the state saved in oldstate */ | |
80 | ||
402dca80 | 81 | void serial_restore PARAMS ((int desc, struct ttystate *oldstate)); |