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

Unified Diff: runtime/bin/eventhandler_macos.cc

Issue 77983002: Only read from interrupt_fd when data is available. (Closed) Base URL: https://dart.googlecode.com/svn/branches/bleeding_edge/dart
Patch Set: Created 7 years, 1 month 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
« runtime/bin/eventhandler_android.cc ('K') | « 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 8964e3b28e1833051cda2a9af37961d3a7a8ab01..4fb47a8258a4aaa22527df93999aadcfbb3a1501 100644
--- a/runtime/bin/eventhandler_macos.cc
+++ b/runtime/bin/eventhandler_macos.cc
@@ -198,29 +198,15 @@ void EventHandlerImplementation::WakeupHandler(intptr_t id,
}
-bool EventHandlerImplementation::GetInterruptMessage(InterruptMessage* msg) {
- char* dst = reinterpret_cast<char*>(msg);
- int total_read = 0;
- int bytes_read =
- TEMP_FAILURE_RETRY(read(interrupt_fds_[0], dst, kInterruptMessageSize));
- if (bytes_read < 0) {
- return false;
- }
- total_read = bytes_read;
- while (total_read < kInterruptMessageSize) {
- bytes_read = TEMP_FAILURE_RETRY(read(interrupt_fds_[0],
- dst + total_read,
- kInterruptMessageSize - total_read));
- if (bytes_read > 0) {
- total_read = total_read + bytes_read;
- }
- }
- return (total_read == kInterruptMessageSize) ? true : false;
-}
-
void EventHandlerImplementation::HandleInterruptFd() {
InterruptMessage msg;
- while (GetInterruptMessage(&msg)) {
+ intptr_t available = FDUtils::AvailableBytes(interrupt_fds_[0]);
+ for (int i = 0;
+ i + kInterruptMessageSize <= available;
+ i += kInterruptMessageSize) {
+ VOID_TEMP_FAILURE_RETRY(read(interrupt_fds_[0],
+ reinterpret_cast<char*>(&msg),
+ kInterruptMessageSize));
if (msg.id == kTimerId) {
timeout_queue_.UpdateTimeout(msg.dart_port, msg.data);
} else if (msg.id == kShutdownId) {
@@ -343,6 +329,7 @@ intptr_t EventHandlerImplementation::GetEvents(struct kevent* event,
void EventHandlerImplementation::HandleEvents(struct kevent* events,
int size) {
+ bool interrupt_seen = false;
for (int i = 0; i < size; i++) {
// If flag EV_ERROR is set it indicates an error in kevent processing.
if ((events[i].flags & EV_ERROR) != 0) {
@@ -351,7 +338,9 @@ void EventHandlerImplementation::HandleEvents(struct kevent* events,
strerror_r(events[i].data, error_message, kBufferSize);
FATAL1("kevent failed %s\n", error_message);
}
- if (events[i].udata != NULL) {
+ if (events[i].udata == NULL) {
+ interrupt_seen = true;
+ } else {
SocketData* sd = reinterpret_cast<SocketData*>(events[i].udata);
intptr_t event_mask = GetEvents(events + i, sd);
if (event_mask != 0) {
@@ -365,7 +354,11 @@ void EventHandlerImplementation::HandleEvents(struct kevent* events,
}
}
}
- HandleInterruptFd();
+ if (interrupt_seen) {
+ // Handle after socket events, so we avoid closing a socket before we handle
+ // the current events.
+ HandleInterruptFd();
+ }
}
« runtime/bin/eventhandler_android.cc ('K') | « runtime/bin/eventhandler_macos.h ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698