microblaze: 64b atomic operations are not supported.
[glibc.git] / sunrpc / openchild.c
blob29f274a8ad1717a850dcc5d1ca0e4a29f8802008
1 /*
2 * Copyright (c) 2010, Oracle America, Inc.
4 * Redistribution and use in source and binary forms, with or without
5 * modification, are permitted provided that the following conditions are
6 * met:
8 * * Redistributions of source code must retain the above copyright
9 * notice, this list of conditions and the following disclaimer.
10 * * Redistributions in binary form must reproduce the above
11 * copyright notice, this list of conditions and the following
12 * disclaimer in the documentation and/or other materials
13 * provided with the distribution.
14 * * Neither the name of the "Oracle America, Inc." nor the names of its
15 * contributors may be used to endorse or promote products derived
16 * from this software without specific prior written permission.
18 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
19 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
20 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
21 * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
22 * COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT,
23 * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
24 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE
25 * GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
26 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
27 * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
28 * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
29 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
33 * Open two pipes to a child process, one for reading, one for writing.
34 * The pipes are accessed by FILE pointers. This is NOT a public
35 * interface, but for internal use only!
37 #include <stdio.h>
38 #include <stdlib.h>
39 #include <unistd.h>
40 #include <string.h>
41 #include <rpc/rpc.h>
42 #include <rpc/clnt.h>
44 #include <libio/iolibio.h>
45 #define fflush(s) _IO_fflush (s)
46 #define __fdopen(fd,m) _IO_fdopen (fd,m)
49 * returns pid, or -1 for failure
51 int
52 _openchild (const char *command, FILE ** fto, FILE ** ffrom)
54 int i;
55 int pid;
56 int pdto[2];
57 int pdfrom[2];
59 if (__pipe (pdto) < 0)
60 goto error1;
61 if (__pipe (pdfrom) < 0)
62 goto error2;
63 switch (pid = __fork ())
65 case -1:
66 goto error3;
68 case 0:
70 * child: read from pdto[0], write into pdfrom[1]
72 __close (0);
73 __dup (pdto[0]);
74 __close (1);
75 __dup (pdfrom[1]);
76 fflush (stderr);
77 for (i = _rpc_dtablesize () - 1; i >= 3; i--)
78 __close (i);
79 fflush (stderr);
80 execlp (command, command, NULL);
81 perror ("exec");
82 _exit (~0);
84 default:
86 * parent: write into pdto[1], read from pdfrom[0]
88 *fto = __fdopen (pdto[1], "w");
89 __close (pdto[0]);
90 *ffrom = __fdopen (pdfrom[0], "r");
91 __close (pdfrom[1]);
92 break;
94 return pid;
97 * error cleanup and return
99 error3:
100 __close (pdfrom[0]);
101 __close (pdfrom[1]);
102 error2:
103 __close (pdto[0]);
104 __close (pdto[1]);
105 error1:
106 return -1;