1 /* Serial interface for a pipe to a separate program
2 Copyright 1999, 2000, 2001 Free Software Foundation, Inc.
4 Contributed by Cygnus Solutions.
6 This file is part of GDB.
8 This program is free software; you can redistribute it and/or modify
9 it under the terms of the GNU General Public License as published by
10 the Free Software Foundation; either version 2 of the License, or
11 (at your option) any later version.
13 This program is distributed in the hope that it will be useful,
14 but WITHOUT ANY WARRANTY; without even the implied warranty of
15 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 GNU General Public License for more details.
18 You should have received a copy of the GNU General Public License
19 along with this program; if not, write to the Free Software
20 Foundation, Inc., 59 Temple Place - Suite 330,
21 Boston, MA 02111-1307, USA. */
27 #include "gdb_vfork.h"
29 #include <sys/types.h>
30 #include <sys/socket.h>
33 #include "gdb_string.h"
37 static int pipe_open (struct serial
*scb
, const char *name
);
38 static void pipe_close (struct serial
*scb
);
40 extern void _initialize_ser_pipe (void);
47 /* Open up a raw pipe */
50 pipe_open (struct serial
*scb
, const char *name
)
55 struct pipe_state
*state
;
57 /* Copyright (c) 1988, 1993
58 * The Regents of the University of California. All rights reserved.
60 * This code is derived from software written by Ken Arnold and
61 * published in UNIX Review, Vol. 6, No. 8.
65 if (socketpair (AF_UNIX
, SOCK_STREAM
, 0, pdes
) < 0)
68 /* Create the child process to run the command in. Note that the
69 apparent call to vfork() below *might* actually be a call to
70 fork() due to the fact that autoconf will ``#define vfork fork''
71 on certain platforms. */
85 /* re-wire pdes[1] to stdin/stdout */
87 if (pdes
[1] != STDOUT_FILENO
)
89 dup2 (pdes
[1], STDOUT_FILENO
);
92 dup2 (STDOUT_FILENO
, STDIN_FILENO
);
94 /* close any stray FD's - FIXME - how? */
95 /* POSIX.2 B.3.2.2 "popen() shall ensure that any streams
96 from previous popen() calls that remain open in the
97 parent process are closed in the new child process. */
98 for (old
= pidlist
; old
; old
= old
->next
)
99 close (fileno (old
->fp
)); /* don't allow a flush */
101 execl ("/bin/sh", "sh", "-c", name
, (char *) 0);
108 state
= XMALLOC (struct pipe_state
);
113 /* If we don't do this, GDB simply exits when the remote side dies. */
114 signal (SIGPIPE
, SIG_IGN
);
120 pipe_close (struct serial
*scb
)
122 struct pipe_state
*state
= scb
->state
;
125 int pid
= state
->pid
;
131 /* Might be useful to check that the child does die. */
135 static struct serial_ops pipe_ops
;
138 _initialize_ser_pipe (void)
140 struct serial_ops
*ops
= XMALLOC (struct serial_ops
);
141 memset (ops
, 0, sizeof (struct serial_ops
));
144 ops
->open
= pipe_open
;
145 ops
->close
= pipe_close
;
146 ops
->readchar
= ser_unix_readchar
;
147 ops
->write
= ser_unix_write
;
148 ops
->flush_output
= ser_unix_nop_flush_output
;
149 ops
->flush_input
= ser_unix_flush_input
;
150 ops
->send_break
= ser_unix_nop_send_break
;
151 ops
->go_raw
= ser_unix_nop_raw
;
152 ops
->get_tty_state
= ser_unix_nop_get_tty_state
;
153 ops
->set_tty_state
= ser_unix_nop_set_tty_state
;
154 ops
->print_tty_state
= ser_unix_nop_print_tty_state
;
155 ops
->noflush_set_tty_state
= ser_unix_nop_noflush_set_tty_state
;
156 ops
->setbaudrate
= ser_unix_nop_setbaudrate
;
157 ops
->setstopbits
= ser_unix_nop_setstopbits
;
158 ops
->drain_output
= ser_unix_nop_drain_output
;
159 ops
->async
= ser_unix_async
;
160 serial_add_interface (ops
);