| OLD | NEW |
| 1 // Copyright (c) 2013, the Dart project authors. Please see the AUTHORS file | 1 // Copyright (c) 2013, the Dart project authors. Please see the AUTHORS file |
| 2 // for details. All rights reserved. Use of this source code is governed by a | 2 // for details. All rights reserved. Use of this source code is governed by a |
| 3 // BSD-style license that can be found in the LICENSE file. | 3 // BSD-style license that can be found in the LICENSE file. |
| 4 | 4 |
| 5 #include "platform/globals.h" | 5 #include "platform/globals.h" |
| 6 #if defined(TARGET_OS_LINUX) | 6 #if defined(TARGET_OS_LINUX) |
| 7 | 7 |
| 8 #include <errno.h> // NOLINT | 8 #include <errno.h> // NOLINT |
| 9 #include <stdio.h> // NOLINT | 9 #include <stdio.h> // NOLINT |
| 10 #include <stdlib.h> // NOLINT | 10 #include <stdlib.h> // NOLINT |
| (...skipping 76 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 87 } | 87 } |
| 88 return Socket::Connect(fd, addr, port); | 88 return Socket::Connect(fd, addr, port); |
| 89 } | 89 } |
| 90 | 90 |
| 91 | 91 |
| 92 intptr_t Socket::Available(intptr_t fd) { | 92 intptr_t Socket::Available(intptr_t fd) { |
| 93 return FDUtils::AvailableBytes(fd); | 93 return FDUtils::AvailableBytes(fd); |
| 94 } | 94 } |
| 95 | 95 |
| 96 | 96 |
| 97 int Socket::Read(intptr_t fd, void* buffer, intptr_t num_bytes) { | 97 intptr_t Socket::Read(intptr_t fd, void* buffer, intptr_t num_bytes) { |
| 98 ASSERT(fd >= 0); | 98 ASSERT(fd >= 0); |
| 99 ssize_t read_bytes = TEMP_FAILURE_RETRY(read(fd, buffer, num_bytes)); | 99 ssize_t read_bytes = TEMP_FAILURE_RETRY(read(fd, buffer, num_bytes)); |
| 100 ASSERT(EAGAIN == EWOULDBLOCK); | 100 ASSERT(EAGAIN == EWOULDBLOCK); |
| 101 if (read_bytes == -1 && errno == EWOULDBLOCK) { | 101 if (read_bytes == -1 && errno == EWOULDBLOCK) { |
| 102 // If the read would block we need to retry and therefore return 0 | 102 // If the read would block we need to retry and therefore return 0 |
| 103 // as the number of bytes written. | 103 // as the number of bytes written. |
| 104 read_bytes = 0; | 104 read_bytes = 0; |
| 105 } | 105 } |
| 106 return read_bytes; | 106 return read_bytes; |
| 107 } | 107 } |
| 108 | 108 |
| 109 | 109 |
| 110 int Socket::RecvFrom(intptr_t fd, void* buffer, intptr_t num_bytes, | 110 intptr_t Socket::RecvFrom(intptr_t fd, void* buffer, intptr_t num_bytes, |
| 111 RawAddr* addr) { | 111 RawAddr* addr) { |
| 112 ASSERT(fd >= 0); | 112 ASSERT(fd >= 0); |
| 113 socklen_t addr_len = sizeof(addr->ss); | 113 socklen_t addr_len = sizeof(addr->ss); |
| 114 ssize_t read_bytes = TEMP_FAILURE_RETRY( | 114 ssize_t read_bytes = TEMP_FAILURE_RETRY( |
| 115 recvfrom(fd, buffer, num_bytes, 0, &addr->addr, &addr_len)); | 115 recvfrom(fd, buffer, num_bytes, 0, &addr->addr, &addr_len)); |
| 116 if (read_bytes == -1 && errno == EWOULDBLOCK) { | 116 if (read_bytes == -1 && errno == EWOULDBLOCK) { |
| 117 // If the read would block we need to retry and therefore return 0 | 117 // If the read would block we need to retry and therefore return 0 |
| 118 // as the number of bytes written. | 118 // as the number of bytes written. |
| 119 read_bytes = 0; | 119 read_bytes = 0; |
| 120 } | 120 } |
| 121 return read_bytes; | 121 return read_bytes; |
| 122 } | 122 } |
| 123 | 123 |
| 124 | 124 |
| 125 int Socket::Write(intptr_t fd, const void* buffer, intptr_t num_bytes) { | 125 intptr_t Socket::Write(intptr_t fd, const void* buffer, intptr_t num_bytes) { |
| 126 ASSERT(fd >= 0); | 126 ASSERT(fd >= 0); |
| 127 ssize_t written_bytes = TEMP_FAILURE_RETRY(write(fd, buffer, num_bytes)); | 127 ssize_t written_bytes = TEMP_FAILURE_RETRY(write(fd, buffer, num_bytes)); |
| 128 ASSERT(EAGAIN == EWOULDBLOCK); | 128 ASSERT(EAGAIN == EWOULDBLOCK); |
| 129 if (written_bytes == -1 && errno == EWOULDBLOCK) { | 129 if (written_bytes == -1 && errno == EWOULDBLOCK) { |
| 130 // If the would block we need to retry and therefore return 0 as | 130 // If the would block we need to retry and therefore return 0 as |
| 131 // the number of bytes written. | 131 // the number of bytes written. |
| 132 written_bytes = 0; | 132 written_bytes = 0; |
| 133 } | 133 } |
| 134 return written_bytes; | 134 return written_bytes; |
| 135 } | 135 } |
| 136 | 136 |
| 137 | 137 |
| 138 int Socket::SendTo(intptr_t fd, const void* buffer, intptr_t num_bytes, | 138 intptr_t Socket::SendTo(intptr_t fd, const void* buffer, intptr_t num_bytes, |
| 139 RawAddr addr) { | 139 RawAddr addr) { |
| 140 ASSERT(fd >= 0); | 140 ASSERT(fd >= 0); |
| 141 ssize_t written_bytes = TEMP_FAILURE_RETRY( | 141 ssize_t written_bytes = TEMP_FAILURE_RETRY( |
| 142 sendto(fd, buffer, num_bytes, 0, | 142 sendto(fd, buffer, num_bytes, 0, |
| 143 &addr.addr, SocketAddress::GetAddrLength(&addr))); | 143 &addr.addr, SocketAddress::GetAddrLength(&addr))); |
| 144 ASSERT(EAGAIN == EWOULDBLOCK); | 144 ASSERT(EAGAIN == EWOULDBLOCK); |
| 145 if (written_bytes == -1 && errno == EWOULDBLOCK) { | 145 if (written_bytes == -1 && errno == EWOULDBLOCK) { |
| 146 // If the would block we need to retry and therefore return 0 as | 146 // If the would block we need to retry and therefore return 0 as |
| 147 // the number of bytes written. | 147 // the number of bytes written. |
| 148 written_bytes = 0; | 148 written_bytes = 0; |
| (...skipping 411 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 560 mreq.gr_interface = interfaceIndex; | 560 mreq.gr_interface = interfaceIndex; |
| 561 memmove(&mreq.gr_group, &addr->ss, SocketAddress::GetAddrLength(addr)); | 561 memmove(&mreq.gr_group, &addr->ss, SocketAddress::GetAddrLength(addr)); |
| 562 return NO_RETRY_EXPECTED( | 562 return NO_RETRY_EXPECTED( |
| 563 setsockopt(fd, proto, MCAST_LEAVE_GROUP, &mreq, sizeof(mreq))) == 0; | 563 setsockopt(fd, proto, MCAST_LEAVE_GROUP, &mreq, sizeof(mreq))) == 0; |
| 564 } | 564 } |
| 565 | 565 |
| 566 } // namespace bin | 566 } // namespace bin |
| 567 } // namespace dart | 567 } // namespace dart |
| 568 | 568 |
| 569 #endif // defined(TARGET_OS_LINUX) | 569 #endif // defined(TARGET_OS_LINUX) |
| OLD | NEW |