summaryrefslogtreecommitdiffstats
path: root/winsup/cygwin/pipe.cc
diff options
context:
space:
mode:
authorChristopher Faylor <me@cgf.cx>2011-12-12 01:22:29 +0000
committerChristopher Faylor <me@cgf.cx>2011-12-12 01:22:29 +0000
commitb11797ad173cad16f65d469860ce056e7bff2b52 (patch)
treecf60b8e69eff9f9317b63f131a22c25c51b84e7c /winsup/cygwin/pipe.cc
parentfc25f200f473a79294ee9ab195e431b211aadf73 (diff)
downloadcygnal-b11797ad173cad16f65d469860ce056e7bff2b52.tar.gz
cygnal-b11797ad173cad16f65d469860ce056e7bff2b52.tar.bz2
cygnal-b11797ad173cad16f65d469860ce056e7bff2b52.zip
* pipe.cc (fhandler_pipe::create): Use debug_printf to print debugging info
since this isn't a "syscall". (pipe_worker): New function created from _pipe(). (_pipe): Use pipe_worker to create a pipe. Use standard syscall strace reporting on exit. (pipe): Ditto. (pipe2): Ditto.
Diffstat (limited to 'winsup/cygwin/pipe.cc')
-rw-r--r--winsup/cygwin/pipe.cc47
1 files changed, 41 insertions, 6 deletions
diff --git a/winsup/cygwin/pipe.cc b/winsup/cygwin/pipe.cc
index 6cbba6ad0..e7da0e9c8 100644
--- a/winsup/cygwin/pipe.cc
+++ b/winsup/cygwin/pipe.cc
@@ -348,7 +348,7 @@ fhandler_pipe::create (fhandler_pipe *fhs[2], unsigned psize, int mode)
res = 0;
}
- syscall_printf ("%R = pipe([%p, %p], %d, %p)", res, fhs[0], fhs[1], psize, mode);
+ debug_printf ("%R = pipe([%p, %p], %d, %p)", res, fhs[0], fhs[1], psize, mode);
return res;
}
@@ -386,8 +386,8 @@ fhandler_pipe::fstatvfs (struct statvfs *sfs)
return -1;
}
-extern "C" int
-_pipe (int filedes[2], unsigned int psize, int mode)
+static int __attribute__ ((regparm (3)))
+pipe_worker (int filedes[2], unsigned int psize, int mode)
{
fhandler_pipe *fhs[2];
int res = fhandler_pipe::create (fhs, psize, mode);
@@ -404,19 +404,54 @@ _pipe (int filedes[2], unsigned int psize, int mode)
fdout = fhs[1];
filedes[0] = fdin;
filedes[1] = fdout;
- debug_printf ("%d, %d", (int) fdin, (int) fdout);
+ }
+ return res;
+}
+
+extern "C" int
+_pipe (int filedes[2], unsigned int psize, int mode)
+{
+ int res = pipe_worker (filedes, psize, mode);
+ int read, write;
+ if (res != 0)
+ read = write = -1;
+ else
+ {
+ read = filedes[0];
+ write = filedes[1];
}
+ syscall_printf ("%R = _pipe([%d, %d], %u, %p)", res, read, write, psize, mode);
return res;
}
extern "C" int
pipe (int filedes[2])
{
- return _pipe (filedes, DEFAULT_PIPEBUFSIZE, O_BINARY);
+ int res = pipe_worker (filedes, DEFAULT_PIPEBUFSIZE, O_BINARY);
+ int read, write;
+ if (res != 0)
+ read = write = -1;
+ else
+ {
+ read = filedes[0];
+ write = filedes[1];
+ }
+ syscall_printf ("%R = pipe([%d, %d])", res, read, write);
+ return res;
}
extern "C" int
pipe2 (int filedes[2], int mode)
{
- return _pipe (filedes, DEFAULT_PIPEBUFSIZE, mode);
+ int res = pipe_worker (filedes, DEFAULT_PIPEBUFSIZE, mode);
+ int read, write;
+ if (res != 0)
+ read = write = -1;
+ else
+ {
+ read = filedes[0];
+ write = filedes[1];
+ }
+ syscall_printf ("%R = pipe2([%d, %d], %p)", res, read, write, mode);
+ return res;
}