ViewVC Help
View File | Revision Log | Show Annotations | Download File
/cvs/IO-AIO/AIO.xs
(Generate patch)

Comparing IO-AIO/AIO.xs (file contents):
Revision 1.174 by root, Mon Nov 1 22:03:43 2010 UTC vs.
Revision 1.185 by root, Thu Jul 7 22:36:18 2011 UTC

16#include <sys/statvfs.h> 16#include <sys/statvfs.h>
17#include <limits.h> 17#include <limits.h>
18#include <fcntl.h> 18#include <fcntl.h>
19#include <sched.h> 19#include <sched.h>
20 20
21#if _POSIX_MEMLOCK || _POSIX_MAPPED_FILES 21#if _POSIX_MEMLOCK || _POSIX_MEMLOCK_RANGE || _POSIX_MAPPED_FILES
22# include <sys/mman.h> 22# include <sys/mman.h>
23#endif 23#endif
24 24
25/* perl namespace pollution */ 25/* perl namespace pollution */
26#undef VERSION 26#undef VERSION
118 STRLEN stroffset; \ 118 STRLEN stroffset; \
119 SV *self; 119 SV *self;
120 120
121#define EIO_NO_WRAPPERS 1 121#define EIO_NO_WRAPPERS 1
122 122
123#include "libeio/config.h"
123#include "libeio/eio.h" 124#include "libeio/eio.h"
125
126/* Linux/others */
127#ifndef O_ASYNC
128# define O_ASYNC 0
129#endif
130#ifndef O_DIRECT
131# define O_DIRECT 0
132#endif
133#ifndef O_NOATIME
134# define O_NOATIME 0
135#endif
136
137/* POSIX */
138#ifndef O_CLOEXEC
139# define O_CLOEXEC 0
140#endif
141#ifndef O_NOFOLLOW
142# define O_NOFOLLOW 0
143#endif
144#ifndef O_NOCTTY
145# define O_NOCTTY 0
146#endif
147#ifndef O_NONBLOCK
148# define O_NONBLOCK 0
149#endif
150#ifndef O_EXEC
151# define O_EXEC 0
152#endif
153#ifndef O_SEARCH
154# define O_SEARCH 0
155#endif
156#ifndef O_DIRECTORY
157# define O_DIRECTORY 0
158#endif
159#ifndef O_DSYNC
160# define O_DSYNC 0
161#endif
162#ifndef O_RSYNC
163# define O_RSYNC 0
164#endif
165#ifndef O_SYNC
166# define O_SYNC 0
167#endif
168#ifndef O_TTY_INIT
169# define O_TTY_INIT 0
170#endif
124 171
125#ifndef POSIX_FADV_NORMAL 172#ifndef POSIX_FADV_NORMAL
126# define POSIX_FADV_NORMAL 0 173# define POSIX_FADV_NORMAL 0
127# define NO_FADVISE 1
128#endif 174#endif
129#ifndef POSIX_FADV_SEQUENTIAL 175#ifndef POSIX_FADV_SEQUENTIAL
130# define POSIX_FADV_SEQUENTIAL 0 176# define POSIX_FADV_SEQUENTIAL 0
131#endif 177#endif
132#ifndef POSIX_FADV_RANDOM 178#ifndef POSIX_FADV_RANDOM
140#endif 186#endif
141#ifndef POSIX_FADV_DONTNEED 187#ifndef POSIX_FADV_DONTNEED
142# define POSIX_FADV_DONTNEED 0 188# define POSIX_FADV_DONTNEED 0
143#endif 189#endif
144 190
145#if _XOPEN_SOURCE < 600 || NO_FADVISE 191#if !HAVE_POSIX_FADVISE
146# define posix_fadvise(a,b,c,d) errno = ENOSYS /* also return ENOSYS */ 192# define posix_fadvise(a,b,c,d) errno = ENOSYS /* also return ENOSYS */
147#endif 193#endif
148 194
149#ifndef POSIX_MADV_NORMAL 195#ifndef POSIX_MADV_NORMAL
150# define POSIX_MADV_NORMAL 0 196# define POSIX_MADV_NORMAL 0
151# define NO_MADVISE 1
152#endif 197#endif
153#ifndef POSIX_MADV_SEQUENTIAL 198#ifndef POSIX_MADV_SEQUENTIAL
154# define POSIX_MADV_SEQUENTIAL 0 199# define POSIX_MADV_SEQUENTIAL 0
155#endif 200#endif
156#ifndef POSIX_MADV_RANDOM 201#ifndef POSIX_MADV_RANDOM
161#endif 206#endif
162#ifndef POSIX_MADV_DONTNEED 207#ifndef POSIX_MADV_DONTNEED
163# define POSIX_MADV_DONTNEED 0 208# define POSIX_MADV_DONTNEED 0
164#endif 209#endif
165 210
166#if _XOPEN_SOURCE < 600 || NO_MADVISE 211#if !HAVE_POSIX_MADVISE
167# define posix_madvise(a,b,c) errno = ENOSYS /* also return ENOSYS */ 212# define posix_madvise(a,b,c) errno = ENOSYS /* also return ENOSYS */
168#endif 213#endif
169 214
170#ifndef PROT_NONE 215#ifndef PROT_NONE
171# define PROT_NONE 0 216# define PROT_NONE 0
207#ifndef ST_NODIRATIME 252#ifndef ST_NODIRATIME
208# define ST_NODIRATIME 0 253# define ST_NODIRATIME 0
209#endif 254#endif
210#ifndef ST_RELATIME 255#ifndef ST_RELATIME
211# define ST_RELATIME 0 256# define ST_RELATIME 0
257#endif
258
259#ifndef S_IFIFO
260# define S_IFIFO 0
261#endif
262#ifndef S_IFCHR
263# define S_IFCHR 0
264#endif
265#ifndef S_IFBLK
266# define S_IFBLK 0
267#endif
268#ifndef S_IFLNK
269# define S_IFLNK 0
270#endif
271#ifndef S_IFREG
272# define S_IFREG 0
273#endif
274#ifndef S_IFDIR
275# define S_IFDIR 0
276#endif
277#ifndef S_IFWHT
278# define S_IFWHT 0
279#endif
280#ifndef S_IFSOCK
281# define S_IFSOCK 0
212#endif 282#endif
213 283
214#ifndef MAP_ANONYMOUS 284#ifndef MAP_ANONYMOUS
215# ifdef MAP_ANON 285# ifdef MAP_ANON
216# define MAP_ANONYMOUS MAP_ANON 286# define MAP_ANONYMOUS MAP_ANON
230#ifndef MAP_POPULATE 300#ifndef MAP_POPULATE
231# define MAP_POPULATE 0 301# define MAP_POPULATE 0
232#endif 302#endif
233#ifndef MAP_NONBLOCK 303#ifndef MAP_NONBLOCK
234# define MAP_NONBLOCK 0 304# define MAP_NONBLOCK 0
305#endif
306
307#ifndef makedev
308# define makedev(maj,min) (((maj) << 8) | (min))
309#endif
310#ifndef major
311# define major(dev) ((dev) >> 8)
312#endif
313#ifndef minor
314# define minor(dev) ((dev) & 0xff)
235#endif 315#endif
236 316
237#ifndef PAGESIZE 317#ifndef PAGESIZE
238# define PAGESIZE sysconf (_SC_PAGESIZE) 318# define PAGESIZE sysconf (_SC_PAGESIZE)
239#endif 319#endif
354 /* do not recreate the result IV from scratch each time */ 434 /* do not recreate the result IV from scratch each time */
355 if (expect_true (sv_result_cache)) 435 if (expect_true (sv_result_cache))
356 { 436 {
357 sv_result = sv_result_cache; sv_result_cache = 0; 437 sv_result = sv_result_cache; sv_result_cache = 0;
358 SvIV_set (sv_result, req->result); 438 SvIV_set (sv_result, req->result);
439 SvIOK_only (sv_result);
359 } 440 }
360 else 441 else
361 { 442 {
362 sv_result = newSViv (req->result); 443 sv_result = newSViv (req->result);
363 SvREADONLY_on (sv_result); 444 SvREADONLY_on (sv_result);
504 case EIO_NOP: 585 case EIO_NOP:
505 case EIO_BUSY: 586 case EIO_BUSY:
506 break; 587 break;
507 588
508 case EIO_READLINK: 589 case EIO_READLINK:
590 case EIO_REALPATH:
509 if (req->result > 0) 591 if (req->result > 0)
510 PUSHs (sv_2mortal (newSVpvn (req->ptr2, req->result))); 592 PUSHs (sv_2mortal (newSVpvn (req->ptr2, req->result)));
511 break; 593 break;
512 594
513 case EIO_STAT: 595 case EIO_STAT:
527 SvSETMAGIC (req->sv2); 609 SvSETMAGIC (req->sv2);
528 PUSHs (sv_result); 610 PUSHs (sv_result);
529 } 611 }
530 break; 612 break;
531 613
532 case EIO_DUP2: /* EIO_DUP2 actually means aio_close(), su fudge result value */ 614 case EIO_DUP2: /* EIO_DUP2 actually means aio_close(), so fudge result value */
533 if (req->result > 0) 615 if (req->result > 0)
534 SvIV_set (sv_result, 0); 616 SvIV_set (sv_result, 0);
535 /* FALLTHROUGH */ 617 /* FALLTHROUGH */
536 618
537 default: 619 default:
585 grp->sv2 = 0; 667 grp->sv2 = 0;
586 668
587 eio_grp_cancel (grp); 669 eio_grp_cancel (grp);
588} 670}
589 671
590static void
591create_respipe (void) 672static void create_respipe (void)
592{ 673{
593 if (s_epipe_renew (&respipe)) 674 if (s_epipe_renew (&respipe))
594 croak ("IO::AIO: unable to initialize result pipe"); 675 croak ("IO::AIO: unable to initialize result pipe");
595} 676}
596 677
637/*****************************************************************************/ 718/*****************************************************************************/
638 719
639#if !_POSIX_MAPPED_FILES 720#if !_POSIX_MAPPED_FILES
640# define mmap(addr,length,prot,flags,fd,offs) (errno = ENOSYS, -1) 721# define mmap(addr,length,prot,flags,fd,offs) (errno = ENOSYS, -1)
641# define munmap(addr,length) (errno = ENOSYS, -1) 722# define munmap(addr,length) (errno = ENOSYS, -1)
723#endif
724
725#if !_POSIX_MEMORY_PROTECTION
642# define mprotect(addr,len,prot) (errno = ENOSYS, -1) 726# define mprotect(addr,len,prot) (errno = ENOSYS, -1)
643# define PROT_NONE 0 727# define PROT_NONE 0
644# define PROT_WRITE 0 728# define PROT_WRITE 0
645# define MAP_PRIVATE 0 729# define MAP_PRIVATE 0
646# define MAP_SHARED 0 730# define MAP_SHARED 0
647# define MAP_FIXED 0 731# define MAP_FIXED 0
648#endif 732#endif
649 733
650#define MMAP_MAGIC PERL_MAGIC_ext 734#define MMAP_MAGIC PERL_MAGIC_ext
651 735
652static int
653mmap_free (pTHX_ SV *sv, MAGIC *mg) 736static int mmap_free (pTHX_ SV *sv, MAGIC *mg)
654{ 737{
655 int old_errno = errno; 738 int old_errno = errno;
656 munmap (mg->mg_ptr, (size_t)mg->mg_obj); 739 munmap (mg->mg_ptr, (size_t)mg->mg_obj);
657 errno = old_errno; 740 errno = old_errno;
658 741
674 0, 0, 0, 0, mmap_free 757 0, 0, 0, 0, mmap_free
675}; 758};
676 759
677/*****************************************************************************/ 760/*****************************************************************************/
678 761
679static SV *
680get_cb (SV *cb_sv) 762static SV * get_cb (SV *cb_sv)
681{ 763{
682 SvGETMAGIC (cb_sv); 764 SvGETMAGIC (cb_sv);
683 return SvOK (cb_sv) ? s_get_cv_croak (cb_sv) : 0; 765 return SvOK (cb_sv) ? s_get_cv_croak (cb_sv) : 0;
684} 766}
685 767
726 const_iv (O_RDWR) 808 const_iv (O_RDWR)
727 const_iv (O_CREAT) 809 const_iv (O_CREAT)
728 const_iv (O_TRUNC) 810 const_iv (O_TRUNC)
729 const_iv (O_EXCL) 811 const_iv (O_EXCL)
730 const_iv (O_APPEND) 812 const_iv (O_APPEND)
731#ifndef _WIN32 813
814 const_iv (O_ASYNC)
815 const_iv (O_DIRECT)
816 const_iv (O_NOATIME)
817
818 const_iv (O_CLOEXEC)
819 const_iv (O_NOCTTY)
820 const_iv (O_NOFOLLOW)
821 const_iv (O_NONBLOCK)
822 const_iv (O_EXEC)
823 const_iv (O_SEARCH)
824 const_iv (O_DIRECTORY)
825 const_iv (O_DSYNC)
826 const_iv (O_RSYNC)
827 const_iv (O_SYNC)
828 const_iv (O_TTY_INIT)
829
732 const_iv (S_IFIFO) 830 const_iv (S_IFIFO)
733#endif 831 const_iv (S_IFCHR)
832 const_iv (S_IFBLK)
833 const_iv (S_IFLNK)
834 const_iv (S_IFREG)
835 const_iv (S_IFDIR)
836 const_iv (S_IFWHT)
837 const_iv (S_IFSOCK)
838 const_iv (S_IFMT)
839
734 const_niv (FADV_NORMAL , POSIX_FADV_NORMAL) 840 const_niv (FADV_NORMAL , POSIX_FADV_NORMAL)
735 const_niv (FADV_SEQUENTIAL, POSIX_FADV_SEQUENTIAL) 841 const_niv (FADV_SEQUENTIAL, POSIX_FADV_SEQUENTIAL)
736 const_niv (FADV_RANDOM , POSIX_FADV_RANDOM) 842 const_niv (FADV_RANDOM , POSIX_FADV_RANDOM)
737 const_niv (FADV_NOREUSE , POSIX_FADV_NOREUSE) 843 const_niv (FADV_NOREUSE , POSIX_FADV_NOREUSE)
738 const_niv (FADV_WILLNEED , POSIX_FADV_WILLNEED) 844 const_niv (FADV_WILLNEED , POSIX_FADV_WILLNEED)
785 891
786 const_eio (SYNC_FILE_RANGE_WAIT_BEFORE) 892 const_eio (SYNC_FILE_RANGE_WAIT_BEFORE)
787 const_eio (SYNC_FILE_RANGE_WRITE) 893 const_eio (SYNC_FILE_RANGE_WRITE)
788 const_eio (SYNC_FILE_RANGE_WAIT_AFTER) 894 const_eio (SYNC_FILE_RANGE_WAIT_AFTER)
789 895
896 const_eio (FALLOC_FL_KEEP_SIZE)
897
790 const_eio (READDIR_DENTS) 898 const_eio (READDIR_DENTS)
791 const_eio (READDIR_DIRS_FIRST) 899 const_eio (READDIR_DIRS_FIRST)
792 const_eio (READDIR_STAT_ORDER) 900 const_eio (READDIR_STAT_ORDER)
793 const_eio (READDIR_FOUND_UNKNOWN) 901 const_eio (READDIR_FOUND_UNKNOWN)
794 902
820 /* atfork child called in fifo order, so before eio's handler */ 928 /* atfork child called in fifo order, so before eio's handler */
821 X_THREAD_ATFORK (0, 0, atfork_child); 929 X_THREAD_ATFORK (0, 0, atfork_child);
822} 930}
823 931
824void 932void
825max_poll_reqs (int nreqs) 933max_poll_reqs (unsigned int nreqs)
826 PROTOTYPE: $ 934 PROTOTYPE: $
827 CODE: 935 CODE:
828 eio_set_max_poll_reqs (nreqs); 936 eio_set_max_poll_reqs (nreqs);
829 937
830void 938void
832 PROTOTYPE: $ 940 PROTOTYPE: $
833 CODE: 941 CODE:
834 eio_set_max_poll_time (nseconds); 942 eio_set_max_poll_time (nseconds);
835 943
836void 944void
837min_parallel (int nthreads) 945min_parallel (unsigned int nthreads)
838 PROTOTYPE: $ 946 PROTOTYPE: $
839 CODE: 947 CODE:
840 eio_set_min_parallel (nthreads); 948 eio_set_min_parallel (nthreads);
841 949
842void 950void
843max_parallel (int nthreads) 951max_parallel (unsigned int nthreads)
844 PROTOTYPE: $ 952 PROTOTYPE: $
845 CODE: 953 CODE:
846 eio_set_max_parallel (nthreads); 954 eio_set_max_parallel (nthreads);
847 955
848void 956void
849max_idle (int nthreads) 957max_idle (unsigned int nthreads)
850 PROTOTYPE: $ 958 PROTOTYPE: $
851 CODE: 959 CODE:
852 eio_set_max_idle (nthreads); 960 eio_set_max_idle (nthreads);
853 961
854void 962void
963idle_timeout (unsigned int seconds)
964 PROTOTYPE: $
965 CODE:
966 eio_set_idle_timeout (seconds);
967
968void
855max_outstanding (int maxreqs) 969max_outstanding (unsigned int maxreqs)
856 PROTOTYPE: $ 970 PROTOTYPE: $
857 CODE: 971 CODE:
858 max_outstanding = maxreqs; 972 max_outstanding = maxreqs;
859 973
860void 974void
900 req->sv1 = newSVsv (fh); 1014 req->sv1 = newSVsv (fh);
901 req->int1 = fd; 1015 req->int1 = fd;
902 req->offs = offset; 1016 req->offs = offset;
903 req->size = nbytes; 1017 req->size = nbytes;
904 req->int2 = flags; 1018 req->int2 = flags;
1019
1020 REQ_SEND (req);
1021}
1022
1023void
1024aio_fallocate (SV *fh, int mode, off_t offset, size_t len, SV *callback=&PL_sv_undef)
1025 PPCODE:
1026{
1027 int fd = s_fileno_croak (fh, 0);
1028 dREQ;
1029
1030 req->type = EIO_FALLOCATE;
1031 req->sv1 = newSVsv (fh);
1032 req->int1 = fd;
1033 req->int2 = mode;
1034 req->offs = offset;
1035 req->size = len;
905 1036
906 REQ_SEND (req); 1037 REQ_SEND (req);
907} 1038}
908 1039
909void 1040void
987 } 1118 }
988} 1119}
989 1120
990void 1121void
991aio_readlink (SV8 *path, SV *callback=&PL_sv_undef) 1122aio_readlink (SV8 *path, SV *callback=&PL_sv_undef)
1123 ALIAS:
1124 aio_readlink = EIO_READLINK
1125 aio_realpath = EIO_REALPATH
992 PPCODE: 1126 PPCODE:
993{ 1127{
994 SV *data; 1128 SV *data;
995 dREQ; 1129 dREQ;
996 1130
997 req->type = EIO_READLINK; 1131 req->type = ix;
998 req->sv1 = newSVsv (path); 1132 req->sv1 = newSVsv (path);
999 req->ptr1 = SvPVbyte_nolen (req->sv1); 1133 req->ptr1 = SvPVbyte_nolen (req->sv1);
1000 1134
1001 REQ_SEND; 1135 REQ_SEND;
1002} 1136}
1059 req->int1 = PerlIO_fileno (IoIFP (sv_2io (fh_or_path))); 1193 req->int1 = PerlIO_fileno (IoIFP (sv_2io (fh_or_path)));
1060 } 1194 }
1061 1195
1062 REQ_SEND; 1196 REQ_SEND;
1063} 1197}
1198
1199UV
1200major (UV dev)
1201 ALIAS:
1202 minor = 1
1203 CODE:
1204 RETVAL = ix ? major (dev) : minor (dev);
1205 OUTPUT:
1206 RETVAL
1207
1208UV
1209makedev (UV maj, UV min)
1210 CODE:
1211 RETVAL = makedev (maj, min);
1212 OUTPUT:
1213 RETVAL
1064 1214
1065void 1215void
1066aio_utime (SV8 *fh_or_path, SV *atime, SV *mtime, SV *callback=&PL_sv_undef) 1216aio_utime (SV8 *fh_or_path, SV *atime, SV *mtime, SV *callback=&PL_sv_undef)
1067 PPCODE: 1217 PPCODE:
1068{ 1218{
1524 if (!SvOK (length) || len + offset > svlen) 1674 if (!SvOK (length) || len + offset > svlen)
1525 len = svlen - offset; 1675 len = svlen - offset;
1526 1676
1527 addr = (void *)(((intptr_t)addr) + offset); 1677 addr = (void *)(((intptr_t)addr) + offset);
1528 eio_page_align (&addr, &len); 1678 eio_page_align (&addr, &len);
1529#if _POSIX_MEMLOCK 1679#if _POSIX_MEMLOCK_RANGE
1530 RETVAL = munlock (addr, len); 1680 RETVAL = munlock (addr, len);
1531#else 1681#else
1532 RETVAL = ((errno = ENOSYS), -1); 1682 RETVAL = ((errno = ENOSYS), -1);
1533#endif 1683#endif
1534} 1684}

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines