ViewVC Help
View File | Revision Log | Show Annotations | Download File
/cvs/libeio/eio.h
(Generate patch)

Comparing libeio/eio.h (file contents):
Revision 1.15 by root, Tue Jun 17 23:58:48 2008 UTC vs.
Revision 1.16 by root, Sun Sep 21 00:23:45 2008 UTC

58#ifndef EIO_STRUCT_STAT 58#ifndef EIO_STRUCT_STAT
59# define EIO_STRUCT_STAT struct stat 59# define EIO_STRUCT_STAT struct stat
60#endif 60#endif
61 61
62enum { 62enum {
63 EIO_CUSTOM,
63 EIO_OPEN, EIO_CLOSE, EIO_DUP2, 64 EIO_OPEN, EIO_CLOSE, EIO_DUP2,
64 EIO_READ, EIO_WRITE, 65 EIO_READ, EIO_WRITE,
65 EIO_READAHEAD, EIO_SENDFILE, 66 EIO_READAHEAD, EIO_SENDFILE,
66 EIO_STAT, EIO_LSTAT, EIO_FSTAT, 67 EIO_STAT, EIO_LSTAT, EIO_FSTAT,
67 EIO_TRUNCATE, EIO_FTRUNCATE, 68 EIO_TRUNCATE, EIO_FTRUNCATE,
68 EIO_UTIME, EIO_FUTIME, 69 EIO_UTIME, EIO_FUTIME,
69 EIO_CHMOD, EIO_FCHMOD, 70 EIO_CHMOD, EIO_FCHMOD,
70 EIO_CHOWN, EIO_FCHOWN, 71 EIO_CHOWN, EIO_FCHOWN,
71 EIO_SYNC, EIO_FSYNC, EIO_FDATASYNC, 72 EIO_SYNC, EIO_FSYNC, EIO_FDATASYNC, EIO_MSYNC, EIO_MTOUCH,
72 EIO_UNLINK, EIO_RMDIR, EIO_MKDIR, EIO_RENAME, 73 EIO_UNLINK, EIO_RMDIR, EIO_MKDIR, EIO_RENAME,
73 EIO_MKNOD, EIO_READDIR, 74 EIO_MKNOD, EIO_READDIR,
74 EIO_LINK, EIO_SYMLINK, EIO_READLINK, 75 EIO_LINK, EIO_SYMLINK, EIO_READLINK,
75 EIO_GROUP, EIO_NOP, 76 EIO_GROUP, EIO_NOP,
76 EIO_BUSY, EIO_CUSTOM 77 EIO_BUSY,
77}; 78};
78 79
79typedef double eio_tstamp; /* feel free to use double in your code directly */ 80typedef double eio_tstamp; /* feel free to use double in your code directly */
80 81
81/* eio request structure */ 82/* eio request structure */
84{ 85{
85 eio_req volatile *next; /* private ETP */ 86 eio_req volatile *next; /* private ETP */
86 87
87 ssize_t result; /* result of syscall, e.g. result = read (... */ 88 ssize_t result; /* result of syscall, e.g. result = read (... */
88 off_t offs; /* read, write, truncate, readahead: file offset */ 89 off_t offs; /* read, write, truncate, readahead: file offset */
89 size_t size; /* read, write, readahead, sendfile: length */ 90 size_t size; /* read, write, readahead, sendfile, msync: length */
90 void *ptr1; /* all applicable requests: pathname, old name */ 91 void *ptr1; /* all applicable requests: pathname, old name */
91 void *ptr2; /* all applicable requests: new name or memory buffer */ 92 void *ptr2; /* all applicable requests: new name or memory buffer */
92 eio_tstamp nv1; /* utime, futime: atime; busy: sleep time */ 93 eio_tstamp nv1; /* utime, futime: atime; busy: sleep time */
93 eio_tstamp nv2; /* utime, futime: mtime */ 94 eio_tstamp nv2; /* utime, futime: mtime */
94 95
95 int type; /* EIO_xxx constant ETP */ 96 int type; /* EIO_xxx constant ETP */
96 int int1; /* all applicable requests: file descriptor; sendfile: output fd; open: flags */ 97 int int1; /* all applicable requests: file descriptor; sendfile: output fd; open, msync: flags */
97 long int2; /* chown, fchown: uid; sendfile: input fd; open, chmod, mkdir, mknod: file mode */ 98 long int2; /* chown, fchown: uid; sendfile: input fd; open, chmod, mkdir, mknod: file mode */
98 long int3; /* chown, fchown: gid; mknod: dev_t */ 99 long int3; /* chown, fchown: gid; mknod: dev_t */
99 int errorno; /* errno value on syscall return */ 100 int errorno; /* errno value on syscall return */
100 101
101 unsigned char flags; /* private */ 102 unsigned char flags; /* private */
158eio_req *eio_nop (int pri, eio_cb cb, void *data); /* does nothing except go through the whole process */ 159eio_req *eio_nop (int pri, eio_cb cb, void *data); /* does nothing except go through the whole process */
159eio_req *eio_busy (eio_tstamp delay, int pri, eio_cb cb, void *data); /* ties a thread for this long, simulating busyness */ 160eio_req *eio_busy (eio_tstamp delay, int pri, eio_cb cb, void *data); /* ties a thread for this long, simulating busyness */
160eio_req *eio_sync (int pri, eio_cb cb, void *data); 161eio_req *eio_sync (int pri, eio_cb cb, void *data);
161eio_req *eio_fsync (int fd, int pri, eio_cb cb, void *data); 162eio_req *eio_fsync (int fd, int pri, eio_cb cb, void *data);
162eio_req *eio_fdatasync (int fd, int pri, eio_cb cb, void *data); 163eio_req *eio_fdatasync (int fd, int pri, eio_cb cb, void *data);
164eio_req *eio_msync (void *addr, size_t length, int flags, int pri, eio_cb cb, void *data);
165eio_req *eio_mtouch (void *addr, size_t length, int flags, int pri, eio_cb cb, void *data);
163eio_req *eio_close (int fd, int pri, eio_cb cb, void *data); 166eio_req *eio_close (int fd, int pri, eio_cb cb, void *data);
164eio_req *eio_readahead (int fd, off_t offset, size_t length, int pri, eio_cb cb, void *data); 167eio_req *eio_readahead (int fd, off_t offset, size_t length, int pri, eio_cb cb, void *data);
165eio_req *eio_read (int fd, void *buf, size_t length, off_t offset, int pri, eio_cb cb, void *data); 168eio_req *eio_read (int fd, void *buf, size_t length, off_t offset, int pri, eio_cb cb, void *data);
166eio_req *eio_write (int fd, void *buf, size_t length, off_t offset, int pri, eio_cb cb, void *data); 169eio_req *eio_write (int fd, void *buf, size_t length, off_t offset, int pri, eio_cb cb, void *data);
167eio_req *eio_fstat (int fd, int pri, eio_cb cb, void *data); /* stat buffer=ptr2 allocated dynamically */ 170eio_req *eio_fstat (int fd, int pri, eio_cb cb, void *data); /* stat buffer=ptr2 allocated dynamically */

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines