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.135 by root, Sun Apr 19 13:06:15 2009 UTC vs.
Revision 1.140 by root, Wed Jun 3 12:24:49 2009 UTC

312 PL_statcache = *(EIO_STRUCT_STAT *)(req->ptr2); 312 PL_statcache = *(EIO_STRUCT_STAT *)(req->ptr2);
313 PUSHs (sv_2mortal (newSViv (req->result))); 313 PUSHs (sv_2mortal (newSViv (req->result)));
314 break; 314 break;
315 315
316 case EIO_READ: 316 case EIO_READ:
317 {
317 SvCUR_set (req->sv2, req->stroffset + (req->result > 0 ? req->result : 0)); 318 SvCUR_set (req->sv2, req->stroffset + (req->result > 0 ? req->result : 0));
318 *SvEND (req->sv2) = 0; 319 *SvEND (req->sv2) = 0;
320 SvPOK_only (req->sv2);
321 SvSETMAGIC (req->sv2);
319 PUSHs (sv_2mortal (newSViv (req->result))); 322 PUSHs (sv_2mortal (newSViv (req->result)));
323 }
320 break; 324 break;
321 325
322 case EIO_DUP2: 326 case EIO_DUP2:
323 if (req->result > 0) 327 if (req->result > 0)
324 req->result = 0; 328 req->result = 0;
499 req_submit (req); \ 503 req_submit (req); \
500 SPAGAIN; \ 504 SPAGAIN; \
501 \ 505 \
502 if (GIMME_V != G_VOID) \ 506 if (GIMME_V != G_VOID) \
503 XPUSHs (req_sv (req, AIO_REQ_KLASS)); 507 XPUSHs (req_sv (req, AIO_REQ_KLASS));
504 508
509static int
510extract_fd (SV *fh, int wr)
511{
512 int fd = PerlIO_fileno (wr ? IoOFP (sv_2io (fh)) : IoIFP (sv_2io (fh)));
513
514 if (fd < 0)
515 croak ("illegal fh argument, either not an OS file or read/write mode mismatch");
516
517 return fd;
518}
519
505MODULE = IO::AIO PACKAGE = IO::AIO 520MODULE = IO::AIO PACKAGE = IO::AIO
506 521
507PROTOTYPES: ENABLE 522PROTOTYPES: ENABLE
508 523
509BOOT: 524BOOT:
510{ 525{
511 stash = gv_stashpv ("IO::AIO", 1); 526 stash = gv_stashpv ("IO::AIO", 1);
512 527
513 newCONSTSUB (stash, "EXDEV", newSViv (EXDEV)); 528 newCONSTSUB (stash, "EXDEV", newSViv (EXDEV));
529 newCONSTSUB (stash, "ENOSYS", newSViv (ENOSYS));
514 newCONSTSUB (stash, "O_RDONLY", newSViv (O_RDONLY)); 530 newCONSTSUB (stash, "O_RDONLY", newSViv (O_RDONLY));
515 newCONSTSUB (stash, "O_WRONLY", newSViv (O_WRONLY)); 531 newCONSTSUB (stash, "O_WRONLY", newSViv (O_WRONLY));
516 newCONSTSUB (stash, "O_CREAT", newSViv (O_CREAT)); 532 newCONSTSUB (stash, "O_CREAT", newSViv (O_CREAT));
517 newCONSTSUB (stash, "O_TRUNC", newSViv (O_TRUNC)); 533 newCONSTSUB (stash, "O_TRUNC", newSViv (O_TRUNC));
518#ifndef _WIN32 534#ifndef _WIN32
590 ALIAS: 606 ALIAS:
591 aio_fsync = EIO_FSYNC 607 aio_fsync = EIO_FSYNC
592 aio_fdatasync = EIO_FDATASYNC 608 aio_fdatasync = EIO_FDATASYNC
593 PPCODE: 609 PPCODE:
594{ 610{
611 int fd = extract_fd (fh, 0);
595 dREQ; 612 dREQ;
596 613
597 req->type = ix; 614 req->type = ix;
598 req->sv1 = newSVsv (fh); 615 req->sv1 = newSVsv (fh);
599 req->int1 = PerlIO_fileno (IoIFP (sv_2io (fh))); 616 req->int1 = fd;
600 617
601 REQ_SEND (req); 618 REQ_SEND (req);
602} 619}
603 620
604void 621void
605aio_sync_file_range (SV *fh, SV *offset, SV *nbytes, IV flags, SV *callback=&PL_sv_undef) 622aio_sync_file_range (SV *fh, SV *offset, SV *nbytes, IV flags, SV *callback=&PL_sv_undef)
606 PROTOTYPE: $$$$;$ 623 PROTOTYPE: $$$$;$
607 PPCODE: 624 PPCODE:
608{ 625{
626 int fd = extract_fd (fh, 0);
609 dREQ; 627 dREQ;
610 628
611 req->type = EIO_SYNC_FILE_RANGE; 629 req->type = EIO_SYNC_FILE_RANGE;
612 req->sv1 = newSVsv (fh); 630 req->sv1 = newSVsv (fh);
613 req->int1 = PerlIO_fileno (IoIFP (sv_2io (fh))); 631 req->int1 = fd;
614 req->offs = SvVAL64 (offset); 632 req->offs = SvVAL64 (offset);
615 req->size = SvVAL64 (nbytes); 633 req->size = SvVAL64 (nbytes);
616 req->int2 = flags; 634 req->int2 = flags;
617 635
618 REQ_SEND (req); 636 REQ_SEND (req);
622aio_close (SV *fh, SV *callback=&PL_sv_undef) 640aio_close (SV *fh, SV *callback=&PL_sv_undef)
623 PROTOTYPE: $;$ 641 PROTOTYPE: $;$
624 PPCODE: 642 PPCODE:
625{ 643{
626 static int close_pipe = -1; /* dummy fd to close fds via dup2 */ 644 static int close_pipe = -1; /* dummy fd to close fds via dup2 */
645 int fd = extract_fd (fh, 0);
627 dREQ; 646 dREQ;
628 647
629 if (close_pipe < 0) 648 if (close_pipe < 0)
630 { 649 {
631 int pipefd [2]; 650 int pipefd [2];
639 } 658 }
640 659
641 req->type = EIO_DUP2; 660 req->type = EIO_DUP2;
642 req->int1 = close_pipe; 661 req->int1 = close_pipe;
643 req->sv2 = newSVsv (fh); 662 req->sv2 = newSVsv (fh);
644 req->int2 = PerlIO_fileno (IoIFP (sv_2io (fh))); 663 req->int2 = fd;
645 664
646 REQ_SEND (req); 665 REQ_SEND (req);
647} 666}
648 667
649void 668void
653 aio_write = EIO_WRITE 672 aio_write = EIO_WRITE
654 PROTOTYPE: $$$$$;$ 673 PROTOTYPE: $$$$$;$
655 PPCODE: 674 PPCODE:
656{ 675{
657 STRLEN svlen; 676 STRLEN svlen;
677 int fd = extract_fd (fh, ix == EIO_WRITE);
658 char *svptr = SvPVbyte (data, svlen); 678 char *svptr = SvPVbyte (data, svlen);
659 UV len = SvUV (length); 679 UV len = SvUV (length);
660 int fd;
661
662 if (SvTYPE (data) > SVt_PVMG)
663 croak ("illegal data argument '%s', must be plain scalar string", SvPV_nolen (data));
664
665 SvUPGRADE (data, SVt_PV);
666 SvPOK_only (data);
667 680
668 if (dataoffset < 0) 681 if (dataoffset < 0)
669 dataoffset += svlen; 682 dataoffset += svlen;
670 683
671 if (dataoffset < 0 || dataoffset > svlen) 684 if (dataoffset < 0 || dataoffset > svlen)
677 if (!SvOK (length) || len + dataoffset > svlen) 690 if (!SvOK (length) || len + dataoffset > svlen)
678 len = svlen - dataoffset; 691 len = svlen - dataoffset;
679 } 692 }
680 else 693 else
681 { 694 {
682 /* read: grow scalar as necessary */ 695 /* read: check type and grow scalar as necessary */
696 SvUPGRADE (data, SVt_PV);
683 svptr = SvGROW (data, len + dataoffset + 1); 697 svptr = SvGROW (data, len + dataoffset + 1);
684 } 698 }
685
686 if (len < 0)
687 croak ("length must not be negative");
688
689 fd = PerlIO_fileno (ix == EIO_READ ? IoIFP (sv_2io (fh))
690 : IoOFP (sv_2io (fh)));
691
692 if (fd < 0)
693 croak ("illegal fh argument, either not an OS file or read/write mode mismatch");
694 699
695 { 700 {
696 dREQ; 701 dREQ;
697 702
698 req->type = ix; 703 req->type = ix;
732void 737void
733aio_sendfile (SV *out_fh, SV *in_fh, SV *in_offset, UV length, SV *callback=&PL_sv_undef) 738aio_sendfile (SV *out_fh, SV *in_fh, SV *in_offset, UV length, SV *callback=&PL_sv_undef)
734 PROTOTYPE: $$$$;$ 739 PROTOTYPE: $$$$;$
735 PPCODE: 740 PPCODE:
736{ 741{
742 int ifd = extract_fd (in_fh , 0);
743 int ofd = extract_fd (out_fh, 0);
737 dREQ; 744 dREQ;
738 745
739 req->type = EIO_SENDFILE; 746 req->type = EIO_SENDFILE;
740 req->sv1 = newSVsv (out_fh); 747 req->sv1 = newSVsv (out_fh);
741 req->int1 = PerlIO_fileno (IoIFP (sv_2io (out_fh))); 748 req->int1 = ofd;
742 req->sv2 = newSVsv (in_fh); 749 req->sv2 = newSVsv (in_fh);
743 req->int2 = PerlIO_fileno (IoIFP (sv_2io (in_fh))); 750 req->int2 = ifd;
744 req->offs = SvVAL64 (in_offset); 751 req->offs = SvVAL64 (in_offset);
745 req->size = length; 752 req->size = length;
746 753
747 REQ_SEND; 754 REQ_SEND;
748} 755}
750void 757void
751aio_readahead (SV *fh, SV *offset, IV length, SV *callback=&PL_sv_undef) 758aio_readahead (SV *fh, SV *offset, IV length, SV *callback=&PL_sv_undef)
752 PROTOTYPE: $$$;$ 759 PROTOTYPE: $$$;$
753 PPCODE: 760 PPCODE:
754{ 761{
762 int fd = extract_fd (fh, 0);
755 dREQ; 763 dREQ;
756 764
757 req->type = EIO_READAHEAD; 765 req->type = EIO_READAHEAD;
758 req->sv1 = newSVsv (fh); 766 req->sv1 = newSVsv (fh);
759 req->int1 = PerlIO_fileno (IoIFP (sv_2io (fh))); 767 req->int1 = fd;
760 req->offs = SvVAL64 (offset); 768 req->offs = SvVAL64 (offset);
761 req->size = length; 769 req->size = length;
762 770
763 REQ_SEND; 771 REQ_SEND;
764} 772}

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines