splice.h 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990
  1. /*
  2. * Function declerations and data structures related to the splice
  3. * implementation.
  4. *
  5. * Copyright (C) 2007 Jens Axboe <jens.axboe@oracle.com>
  6. *
  7. */
  8. #ifndef SPLICE_H
  9. #define SPLICE_H
  10. #include <linux/pipe_fs_i.h>
  11. /*
  12. * Flags passed in from splice/tee/vmsplice
  13. */
  14. #define SPLICE_F_MOVE (0x01) /* move pages instead of copying */
  15. #define SPLICE_F_NONBLOCK (0x02) /* don't block on the pipe splicing (but */
  16. /* we may still block on the fd we splice */
  17. /* from/to, of course */
  18. #define SPLICE_F_MORE (0x04) /* expect more data */
  19. #define SPLICE_F_GIFT (0x08) /* pages passed in are a gift */
  20. /*
  21. * Passed to the actors
  22. */
  23. struct splice_desc {
  24. size_t total_len; /* remaining length */
  25. unsigned int len; /* current length */
  26. unsigned int flags; /* splice flags */
  27. /*
  28. * actor() private data
  29. */
  30. union {
  31. void __user *userptr; /* memory to write to */
  32. struct file *file; /* file to read/write */
  33. void *data; /* cookie */
  34. } u;
  35. loff_t pos; /* file position */
  36. loff_t *opos; /* sendfile: output position */
  37. size_t num_spliced; /* number of bytes already spliced */
  38. bool need_wakeup; /* need to wake up writer */
  39. };
  40. struct partial_page {
  41. unsigned int offset;
  42. unsigned int len;
  43. unsigned long private;
  44. };
  45. /*
  46. * Passed to splice_to_pipe
  47. */
  48. struct splice_pipe_desc {
  49. struct page **pages; /* page map */
  50. struct partial_page *partial; /* pages[] may not be contig */
  51. int nr_pages; /* number of populated pages in map */
  52. unsigned int nr_pages_max; /* pages[] & partial[] arrays size */
  53. unsigned int flags; /* splice flags */
  54. const struct pipe_buf_operations *ops;/* ops associated with output pipe */
  55. void (*spd_release)(struct splice_pipe_desc *, unsigned int);
  56. };
  57. typedef int (splice_actor)(struct pipe_inode_info *, struct pipe_buffer *,
  58. struct splice_desc *);
  59. typedef int (splice_direct_actor)(struct pipe_inode_info *,
  60. struct splice_desc *);
  61. extern ssize_t splice_from_pipe(struct pipe_inode_info *, struct file *,
  62. loff_t *, size_t, unsigned int,
  63. splice_actor *);
  64. extern ssize_t __splice_from_pipe(struct pipe_inode_info *,
  65. struct splice_desc *, splice_actor *);
  66. extern ssize_t splice_to_pipe(struct pipe_inode_info *,
  67. struct splice_pipe_desc *);
  68. extern ssize_t add_to_pipe(struct pipe_inode_info *,
  69. struct pipe_buffer *);
  70. extern ssize_t splice_direct_to_actor(struct file *, struct splice_desc *,
  71. splice_direct_actor *);
  72. /*
  73. * for dynamic pipe sizing
  74. */
  75. extern int splice_grow_spd(const struct pipe_inode_info *, struct splice_pipe_desc *);
  76. extern void splice_shrink_spd(struct splice_pipe_desc *);
  77. extern void spd_release_page(struct splice_pipe_desc *, unsigned int);
  78. extern const struct pipe_buf_operations page_cache_pipe_buf_ops;
  79. extern const struct pipe_buf_operations default_pipe_buf_ops;
  80. #endif