Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(301)

Unified Diff: runtime/bin/eventhandler_macos.cc

Issue 2635253002: VM eventhandler: Read "old" event mask before it can be modified. (Closed)
Patch Set: Created 3 years, 11 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « runtime/bin/eventhandler_macos.h ('k') | no next file » | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: runtime/bin/eventhandler_macos.cc
diff --git a/runtime/bin/eventhandler_macos.cc b/runtime/bin/eventhandler_macos.cc
index 640f05a5408521b9287fbcff029b918417fe5bff..1094e5cad441b96323d4772b58cf280a4da7d728 100644
--- a/runtime/bin/eventhandler_macos.cc
+++ b/runtime/bin/eventhandler_macos.cc
@@ -43,23 +43,18 @@ bool DescriptorInfo::HasWriteEvent() {
// Unregister the file descriptor for a SocketData structure with kqueue.
static void RemoveFromKqueue(intptr_t kqueue_fd_, DescriptorInfo* di) {
- if (!di->tracked_by_kqueue()) {
- return;
- }
static const intptr_t kMaxChanges = 2;
struct kevent events[kMaxChanges];
kustermann 2017/01/20 12:22:49 Unrelated side note: Seems like legacy code: We o
zra 2017/01/20 17:16:32 Maybe in another CL. We should try the bug fix in
EV_SET(events, di->fd(), EVFILT_READ, EV_DELETE, 0, 0, NULL);
VOID_NO_RETRY_EXPECTED(kevent(kqueue_fd_, events, 1, NULL, 0, NULL));
kustermann 2017/01/20 12:22:49 Unrelated side note: We should probably check th
zra 2017/01/20 17:16:32 ditto
EV_SET(events, di->fd(), EVFILT_WRITE, EV_DELETE, 0, 0, NULL);
VOID_NO_RETRY_EXPECTED(kevent(kqueue_fd_, events, 1, NULL, 0, NULL));
kustermann 2017/01/20 12:22:49 Unrelated side note: As opposed to the adding co
zra 2017/01/20 17:16:32 ditto
- di->set_tracked_by_kqueue(false);
}
// Update the kqueue registration for SocketData structure to reflect
// the events currently of interest.
static void AddToKqueue(intptr_t kqueue_fd_, DescriptorInfo* di) {
- ASSERT(!di->tracked_by_kqueue());
kustermann 2017/01/20 12:22:49 I cannot think of a case where this ASSERT should
static const intptr_t kMaxChanges = 2;
intptr_t changes = 0;
struct kevent events[kMaxChanges];
@@ -92,8 +87,6 @@ static void AddToKqueue(intptr_t kqueue_fd_, DescriptorInfo* di) {
// as /dev/null. In such case, mark the file descriptor as closed,
// so dart will handle it accordingly.
di->NotifyAllDartPorts(1 << kCloseEvent);
- } else {
- di->set_tracked_by_kqueue(true);
}
}
@@ -160,7 +153,8 @@ void EventHandlerImplementation::UpdateKQueueInstance(intptr_t old_mask,
AddToKqueue(kqueue_fd_, di);
} else if ((old_mask != 0) && (new_mask != 0) && (old_mask != new_mask)) {
ASSERT(!di->IsListeningSocket());
- RemoveFromKqueue(kqueue_fd_, di);
+ // kevent() will automatically replace the old filter for an existing fd.
+ // There is no need to remove it first.
AddToKqueue(kqueue_fd_, di);
kustermann 2017/01/20 12:22:49 This is an incorrect change if I understand it pro
zra 2017/01/20 17:16:32 Acknowledged.
}
}
« no previous file with comments | « runtime/bin/eventhandler_macos.h ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698