ViewVC Help
View File | Revision Log | Show Annotations | Download File
/cvs/libev/ev_iouring.c
(Generate patch)

Comparing libev/ev_iouring.c (file contents):
Revision 1.2 by root, Tue Jul 9 00:04:35 2019 UTC vs.
Revision 1.5 by root, Tue Nov 19 13:09:00 2019 UTC

361/*****************************************************************************/ 361/*****************************************************************************/
362 362
363static void 363static void
364iouring_modify (EV_P_ int fd, int oev, int nev) 364iouring_modify (EV_P_ int fd, int oev, int nev)
365{ 365{
366 fprintf (stderr,"modify %d (%d, %d) %d\n", fd, oev,nev, anfds[fd].eflags);//D
367 if (ecb_expect_false (anfds [fd].eflags)) 366 if (ecb_expect_false (anfds [fd].eflags))
368 { 367 {
369 /* we handed this fd over to epoll, so undo this first */ 368 /* we handed this fd over to epoll, so undo this first */
370 /* we do it manually because the optimisations on epoll_modify won't do us any good */ 369 /* we do it manually because the optimisations on epoll_modify won't do us any good */
371 epoll_ctl (iouring_fd, EPOLL_CTL_DEL, fd, 0); 370 epoll_ctl (iouring_fd, EPOLL_CTL_DEL, fd, 0);
471 } 470 }
472 471
473 return; 472 return;
474 } 473 }
475 474
476 fprintf (stderr, "fd %d event, rearm\n", fd);//D
477
478 /* feed events, we do not expect or handle POLLNVAL */ 475 /* feed events, we do not expect or handle POLLNVAL */
479 fd_event ( 476 fd_event (
480 EV_A_ 477 EV_A_
481 fd, 478 fd,
482 (res & (POLLOUT | POLLERR | POLLHUP) ? EV_WRITE : 0) 479 (res & (POLLOUT | POLLERR | POLLHUP) ? EV_WRITE : 0)
574static void 571static void
575iouring_poll (EV_P_ ev_tstamp timeout) 572iouring_poll (EV_P_ ev_tstamp timeout)
576{ 573{
577 /* if we have events, no need for extra syscalls, but we might have to queue events */ 574 /* if we have events, no need for extra syscalls, but we might have to queue events */
578 if (iouring_handle_cq (EV_A)) 575 if (iouring_handle_cq (EV_A))
579 timeout = 0.; 576 timeout = EV_TS_CONST (0.);
580 else 577 else
581 /* no events, so maybe wait for some */ 578 /* no events, so maybe wait for some */
582 iouring_tfd_update (EV_A_ timeout); 579 iouring_tfd_update (EV_A_ timeout);
583 580
584 /* only enter the kernel if we have somethign to submit, or we need to wait */ 581 /* only enter the kernel if we have somethign to submit, or we need to wait */
587 int res; 584 int res;
588 585
589 EV_RELEASE_CB; 586 EV_RELEASE_CB;
590 587
591 res = evsys_io_uring_enter (iouring_fd, iouring_to_submit, 1, 588 res = evsys_io_uring_enter (iouring_fd, iouring_to_submit, 1,
592 timeout ? IORING_ENTER_GETEVENTS : 0, 0, 0); 589 timeout > EV_TS_CONST (0.) ? IORING_ENTER_GETEVENTS : 0, 0, 0);
593 iouring_to_submit = 0; 590 iouring_to_submit = 0;
594 591
595 EV_ACQUIRE_CB; 592 EV_ACQUIRE_CB;
596 593
597 if (ecb_expect_false (res < 0)) 594 if (ecb_expect_false (res < 0))
609iouring_init (EV_P_ int flags) 606iouring_init (EV_P_ int flags)
610{ 607{
611 if (!epoll_init (EV_A_ 0)) 608 if (!epoll_init (EV_A_ 0))
612 return 0; 609 return 0;
613 610
614 ev_io_init (EV_A_ &iouring_epoll_w, iouring_epoll_cb, backend_fd, EV_READ); 611 ev_io_init (&iouring_epoll_w, iouring_epoll_cb, backend_fd, EV_READ);
615 ev_set_priority (&iouring_epoll_w, EV_MAXPRI); 612 ev_set_priority (&iouring_epoll_w, EV_MAXPRI);
616 613
617 ev_io_init (&iouring_tfd_w, iouring_tfd_cb, iouring_tfd, EV_READ); 614 ev_io_init (&iouring_tfd_w, iouring_tfd_cb, iouring_tfd, EV_READ);
618 ev_set_priority (&iouring_tfd_w, EV_MAXPRI); 615 ev_set_priority (&iouring_tfd_w, EV_MAXPRI);
619 616

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines