From 86aec86281212fd19e89c866c47f51e45c30cc42 Mon Sep 17 00:00:00 2001 From: Pav Lucistnik Date: Sun, 24 Sep 2006 12:31:29 +0000 Subject: - Fix 100% CPU usage looping when a vnode change event came but it was never untriggered. Patch by Rui Lopes PR: ports/103525 Submitted by: Robin Breathe (maintainer) --- .../files/patch-src_lib_ioloop-notify-kqueue.c | 14 ++++++++++++++ 1 file changed, 14 insertions(+) create mode 100644 mail/dovecot-devel/files/patch-src_lib_ioloop-notify-kqueue.c (limited to 'mail/dovecot-devel/files') diff --git a/mail/dovecot-devel/files/patch-src_lib_ioloop-notify-kqueue.c b/mail/dovecot-devel/files/patch-src_lib_ioloop-notify-kqueue.c new file mode 100644 index 000000000000..bdf3f6d75899 --- /dev/null +++ b/mail/dovecot-devel/files/patch-src_lib_ioloop-notify-kqueue.c @@ -0,0 +1,14 @@ +--- src/lib/ioloop-notify-kqueue.c 16 Aug 2006 17:58:03 -0000 1.3.2.2 ++++ src/lib/ioloop-notify-kqueue.c 26 Aug 2006 13:55:01 -0000 1.3.2.3 +@@ -111,7 +111,10 @@ + io->callback = callback; + io->context = context; + +- EV_SET(&ev, fd, EVFILT_VNODE, EV_ADD, ++ /* EV_CLEAR flag is needed because the EVFILT_VNODE filter reports ++ event state transitions and not the current state. With this flag, ++ the same event is only returned once. */ ++ EV_SET(&ev, fd, EVFILT_VNODE, EV_ADD | EV_CLEAR, + NOTE_DELETE | NOTE_WRITE | NOTE_EXTEND | NOTE_REVOKE, 0, io); + if (kevent(ctx->kq, &ev, 1, NULL, 0, NULL) < 0) { + i_error("kevent(%d, %s) for notify failed: %m", fd, path); -- cgit v1.2.3