uio.h 2.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465
  1. /* Copyright (C) 1991, 1992 Free Software Foundation, Inc.
  2. This file is part of the GNU C Library.
  3. The GNU C Library is free software; you can redistribute it and/or
  4. modify it under the terms of the GNU Library General Public License as
  5. published by the Free Software Foundation; either version 2 of the
  6. License, or (at your option) any later version.
  7. The GNU C Library is distributed in the hope that it will be useful,
  8. but WITHOUT ANY WARRANTY; without even the implied warranty of
  9. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  10. Library General Public License for more details.
  11. You should have received a copy of the GNU Library General Public
  12. License along with the GNU C Library; see the file COPYING.LIB. If
  13. not, write to the, 1992 Free Software Foundation, Inc., 675 Mass Ave,
  14. Cambridge, MA 02139, USA. */
  15. #ifndef _SYS_UIO_H
  16. #define _SYS_UIO_H 1
  17. #include <features.h>
  18. __BEGIN_DECLS
  19. #define __need_size_t
  20. #include <stddef.h>
  21. /* That is a klude for Linux. */
  22. #ifdef __linux__
  23. #include <linux/socket.h>
  24. #endif
  25. #ifndef __LINUX_UIO_H
  26. /* Structure describing a section of memory. */
  27. struct iovec
  28. {
  29. /* Starting address. */
  30. __ptr_t iov_base;
  31. /* Length in bytes. */
  32. size_t iov_len;
  33. };
  34. #endif
  35. /* Read data from file descriptor FD, and put the result in the
  36. buffers described by VECTOR, which is a vector of COUNT `struct iovec's.
  37. The buffers are filled in the order specified.
  38. Operates just like `read' (see <unistd.h>) except that data are
  39. put in VECTOR instead of a contiguous buffer. */
  40. int readv __P ((int __fd, __const struct iovec * __vector, size_t __count));
  41. /* Write data pointed by the buffers described by VECTOR, which
  42. is a vector of COUNT `struct iovec's, to file descriptor FD.
  43. The data is written in the order specified.
  44. Operates just like `write' (see <unistd.h>) except that the data
  45. are taken from VECTOR instead of a contiguous buffer. */
  46. int writev __P ((int __fd, __const struct iovec * __vector, size_t __count));
  47. __END_DECLS
  48. #endif /* sys/uio.h */