home *** CD-ROM | disk | FTP | other *** search
/ InfoMagic Source Code 1993 July / THE_SOURCE_CODE_CD_ROM.iso / gnu / glibc-1.06 / sysdeps / mach / hurd / __pipe.c < prev    next >
Encoding:
C/C++ Source or Header  |  1992-03-21  |  2.2 KB  |  76 lines

  1. /* Copyright (C) 1992 Free Software Foundation, Inc.
  2. This file is part of the GNU C Library.
  3.  
  4. The GNU C Library is free software; you can redistribute it and/or
  5. modify it under the terms of the GNU Library General Public License as
  6. published by the Free Software Foundation; either version 2 of the
  7. License, or (at your option) any later version.
  8.  
  9. The GNU C Library is distributed in the hope that it will be useful,
  10. but WITHOUT ANY WARRANTY; without even the implied warranty of
  11. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
  12. Library General Public License for more details.
  13.  
  14. You should have received a copy of the GNU Library General Public
  15. License along with the GNU C Library; see the file COPYING.LIB.  If
  16. not, write to the Free Software Foundation, Inc., 675 Mass Ave,
  17. Cambridge, MA 02139, USA.  */
  18.  
  19. #include <ansidecl.h>
  20. #include <errno.h>
  21. #include <unistd.h>
  22. #include <stddef.h>
  23. #include <hurd.h>
  24.  
  25. /* Create a one-way communication channel (pipe).
  26.    If successul, two file descriptors are stored in FDS;
  27.    bytes written on FDS[1] can be read from FDS[0].
  28.    Returns 0 if successful, -1 if not.  */
  29. int
  30. DEFUN(__pipe, (fds), int fds[2])
  31. {
  32.   error_t err;
  33.   socket_t server, sock1, sock2;
  34.   int d1, d2;
  35.  
  36.   if (fds == NULL)
  37.     return __hurd_fail (EINVAL);
  38.  
  39.   server = _hurd_socket_server (AF_LOCAL);
  40.   if (server == NULL)
  41.     return -1;
  42.  
  43.   if (err = __socket_create (server, SOCK_STREAM, 0, &sock1))
  44.     return __hurd_fail (err);
  45.   if (err = __socket_create (server, SOCK_STREAM, 0, &sock2))
  46.     {
  47.       __mach_port_deallocate (__mach_task_self (), sock1);
  48.       return __hurd_fail (err);
  49.     }
  50.   if (err = __socket_connect2 (sock1, sock2))
  51.     {
  52.       __mach_port_deallocate (__mach_task_self (), sock1);
  53.       __mach_port_deallocate (__mach_task_self (), sock2);
  54.       return __hurd_fail (err);
  55.     }
  56.   __socket_shutdown (sock1, 1);
  57.   __socket_shutdown (sock2, 0);
  58.  
  59.   d1 = _hurd_dalloc (sock1, MACH_PORT_NULL, 0);
  60.   if (d1 < 0)
  61.     {
  62.       __mach_port_deallocate (__mach_task_self (), sock2);
  63.       return -1;
  64.     }
  65.   d2 = _hurd_dalloc (sock2, MACH_PORT_NULL, 0);
  66.   if (d2 < 0)
  67.     {
  68.       (void) close (d1);
  69.       return __hurd_fail (EMFILE);
  70.     }
  71.  
  72.   fds[0] = d1;
  73.   fds[2] = d2;
  74.   return 0;
  75. }
  76.