Index: runtime/bin/socket_base_win.cc |
diff --git a/runtime/bin/socket_win.cc b/runtime/bin/socket_base_win.cc |
similarity index 55% |
copy from runtime/bin/socket_win.cc |
copy to runtime/bin/socket_base_win.cc |
index 3b0efe507e10a728d82de5da4e54cf76efcb7d58..27448a3838637563d83ec396466255c6f7f2bfc3 100644 |
--- a/runtime/bin/socket_win.cc |
+++ b/runtime/bin/socket_base_win.cc |
@@ -7,14 +7,14 @@ |
#include "platform/globals.h" |
#if defined(HOST_OS_WINDOWS) |
-#include "bin/socket.h" |
-#include "bin/socket_win.h" |
+#include "bin/socket_base.h" |
#include "bin/builtin.h" |
#include "bin/eventhandler.h" |
#include "bin/file.h" |
#include "bin/lockers.h" |
#include "bin/log.h" |
+#include "bin/socket_base_win.h" |
#include "bin/thread.h" |
#include "bin/utils.h" |
#include "bin/utils_win.h" |
@@ -28,7 +28,8 @@ SocketAddress::SocketAddress(struct sockaddr* sockaddr) { |
// Clear the port before calling WSAAddressToString as WSAAddressToString |
// includes the port in the formatted string. |
- int err = Socket::FormatNumericAddress(*raw, as_string_, INET6_ADDRSTRLEN); |
+ int err = |
+ SocketBase::FormatNumericAddress(*raw, as_string_, INET6_ADDRSTRLEN); |
if (err != 0) { |
as_string_[0] = 0; |
@@ -38,34 +39,10 @@ SocketAddress::SocketAddress(struct sockaddr* sockaddr) { |
} |
-bool Socket::FormatNumericAddress(const RawAddr& addr, char* address, int len) { |
- socklen_t salen = SocketAddress::GetAddrLength(addr); |
- DWORD l = len; |
- RawAddr& raw = const_cast<RawAddr&>(addr); |
- return WSAAddressToStringA(&raw.addr, salen, NULL, address, &l) != 0; |
-} |
- |
- |
-Socket::Socket(intptr_t fd) : ReferenceCounted(), fd_(fd), port_(ILLEGAL_PORT) { |
- ASSERT(fd_ != kClosedFd); |
- Handle* handle = reinterpret_cast<Handle*>(fd_); |
- ASSERT(handle != NULL); |
-} |
- |
- |
-void Socket::SetClosedFd() { |
- ASSERT(fd_ != kClosedFd); |
- Handle* handle = reinterpret_cast<Handle*>(fd_); |
- ASSERT(handle != NULL); |
- handle->Release(); |
- fd_ = kClosedFd; |
-} |
- |
- |
static Mutex* init_mutex = new Mutex(); |
static bool socket_initialized = false; |
-bool Socket::Initialize() { |
+bool SocketBase::Initialize() { |
MutexLocker lock(init_mutex); |
if (socket_initialized) { |
return true; |
@@ -83,38 +60,50 @@ bool Socket::Initialize() { |
} |
-intptr_t Socket::Available(intptr_t fd) { |
+bool SocketBase::FormatNumericAddress(const RawAddr& addr, |
+ char* address, |
+ int len) { |
+ socklen_t salen = SocketAddress::GetAddrLength(addr); |
+ DWORD l = len; |
+ RawAddr& raw = const_cast<RawAddr&>(addr); |
+ return WSAAddressToStringA(&raw.addr, salen, NULL, address, &l) != 0; |
+} |
+ |
+ |
+intptr_t SocketBase::Available(intptr_t fd) { |
ClientSocket* client_socket = reinterpret_cast<ClientSocket*>(fd); |
return client_socket->Available(); |
} |
-intptr_t Socket::Read(intptr_t fd, void* buffer, intptr_t num_bytes) { |
+intptr_t SocketBase::Read(intptr_t fd, void* buffer, intptr_t num_bytes) { |
Handle* handle = reinterpret_cast<Handle*>(fd); |
return handle->Read(buffer, num_bytes); |
} |
-intptr_t Socket::RecvFrom(intptr_t fd, |
- void* buffer, |
- intptr_t num_bytes, |
- RawAddr* addr) { |
+intptr_t SocketBase::RecvFrom(intptr_t fd, |
+ void* buffer, |
+ intptr_t num_bytes, |
+ RawAddr* addr) { |
Handle* handle = reinterpret_cast<Handle*>(fd); |
socklen_t addr_len = sizeof(addr->ss); |
return handle->RecvFrom(buffer, num_bytes, &addr->addr, addr_len); |
} |
-intptr_t Socket::Write(intptr_t fd, const void* buffer, intptr_t num_bytes) { |
+intptr_t SocketBase::Write(intptr_t fd, |
+ const void* buffer, |
+ intptr_t num_bytes) { |
Handle* handle = reinterpret_cast<Handle*>(fd); |
return handle->Write(buffer, num_bytes); |
} |
-intptr_t Socket::SendTo(intptr_t fd, |
- const void* buffer, |
- intptr_t num_bytes, |
- const RawAddr& addr) { |
+intptr_t SocketBase::SendTo(intptr_t fd, |
+ const void* buffer, |
+ intptr_t num_bytes, |
+ const RawAddr& addr) { |
Handle* handle = reinterpret_cast<Handle*>(fd); |
RawAddr& raw = const_cast<RawAddr&>(addr); |
return handle->SendTo(buffer, num_bytes, &raw.addr, |
@@ -122,7 +111,7 @@ intptr_t Socket::SendTo(intptr_t fd, |
} |
-intptr_t Socket::GetPort(intptr_t fd) { |
+intptr_t SocketBase::GetPort(intptr_t fd) { |
ASSERT(reinterpret_cast<Handle*>(fd)->is_socket()); |
SocketHandle* socket_handle = reinterpret_cast<SocketHandle*>(fd); |
RawAddr raw; |
@@ -134,7 +123,7 @@ intptr_t Socket::GetPort(intptr_t fd) { |
} |
-SocketAddress* Socket::GetRemotePeer(intptr_t fd, intptr_t* port) { |
+SocketAddress* SocketBase::GetRemotePeer(intptr_t fd, intptr_t* port) { |
ASSERT(reinterpret_cast<Handle*>(fd)->is_socket()); |
SocketHandle* socket_handle = reinterpret_cast<SocketHandle*>(fd); |
RawAddr raw; |
@@ -150,123 +139,19 @@ SocketAddress* Socket::GetRemotePeer(intptr_t fd, intptr_t* port) { |
} |
-static intptr_t Create(const RawAddr& addr) { |
- SOCKET s = socket(addr.ss.ss_family, SOCK_STREAM, 0); |
- if (s == INVALID_SOCKET) { |
- return -1; |
- } |
- |
- linger l; |
- l.l_onoff = 1; |
- l.l_linger = 10; |
- int status = setsockopt(s, SOL_SOCKET, SO_LINGER, reinterpret_cast<char*>(&l), |
- sizeof(l)); |
- if (status != NO_ERROR) { |
- FATAL("Failed setting SO_LINGER on socket"); |
- } |
- |
- ClientSocket* client_socket = new ClientSocket(s); |
- return reinterpret_cast<intptr_t>(client_socket); |
-} |
- |
- |
-static intptr_t Connect(intptr_t fd, |
- const RawAddr& addr, |
- const RawAddr& bind_addr) { |
- ASSERT(reinterpret_cast<Handle*>(fd)->is_client_socket()); |
- ClientSocket* handle = reinterpret_cast<ClientSocket*>(fd); |
- SOCKET s = handle->socket(); |
- |
- int status = |
- bind(s, &bind_addr.addr, SocketAddress::GetAddrLength(bind_addr)); |
- if (status != NO_ERROR) { |
- int rc = WSAGetLastError(); |
- handle->mark_closed(); // Destructor asserts that socket is marked closed. |
- handle->Release(); |
- closesocket(s); |
- SetLastError(rc); |
- return -1; |
- } |
- |
- LPFN_CONNECTEX connectEx = NULL; |
- GUID guid_connect_ex = WSAID_CONNECTEX; |
- DWORD bytes; |
- status = WSAIoctl(s, SIO_GET_EXTENSION_FUNCTION_POINTER, &guid_connect_ex, |
- sizeof(guid_connect_ex), &connectEx, sizeof(connectEx), |
- &bytes, NULL, NULL); |
- DWORD rc; |
- if (status != SOCKET_ERROR) { |
- handle->EnsureInitialized(EventHandler::delegate()); |
- |
- OverlappedBuffer* overlapped = OverlappedBuffer::AllocateConnectBuffer(); |
- |
- status = connectEx(s, &addr.addr, SocketAddress::GetAddrLength(addr), NULL, |
- 0, NULL, overlapped->GetCleanOverlapped()); |
- |
- |
- if (status == TRUE) { |
- handle->ConnectComplete(overlapped); |
- return fd; |
- } else if (WSAGetLastError() == ERROR_IO_PENDING) { |
- return fd; |
- } |
- rc = WSAGetLastError(); |
- // Cleanup in case of error. |
- OverlappedBuffer::DisposeBuffer(overlapped); |
- handle->Release(); |
- } else { |
- rc = WSAGetLastError(); |
- } |
- handle->Close(); |
- handle->Release(); |
- SetLastError(rc); |
- return -1; |
-} |
- |
- |
-intptr_t Socket::CreateConnect(const RawAddr& addr) { |
- intptr_t fd = Create(addr); |
- if (fd < 0) { |
- return fd; |
- } |
- |
- RawAddr bind_addr; |
- memset(&bind_addr, 0, sizeof(bind_addr)); |
- bind_addr.ss.ss_family = addr.ss.ss_family; |
- if (addr.ss.ss_family == AF_INET) { |
- bind_addr.in.sin_addr.s_addr = INADDR_ANY; |
- } else { |
- bind_addr.in6.sin6_addr = in6addr_any; |
- } |
- |
- return Connect(fd, addr, bind_addr); |
-} |
- |
- |
-intptr_t Socket::CreateBindConnect(const RawAddr& addr, |
- const RawAddr& source_addr) { |
- intptr_t fd = Create(addr); |
- if (fd < 0) { |
- return fd; |
- } |
- |
- return Connect(fd, addr, source_addr); |
-} |
- |
- |
-bool Socket::IsBindError(intptr_t error_number) { |
+bool SocketBase::IsBindError(intptr_t error_number) { |
return error_number == WSAEADDRINUSE || error_number == WSAEADDRNOTAVAIL || |
error_number == WSAEINVAL; |
} |
-void Socket::GetError(intptr_t fd, OSError* os_error) { |
+void SocketBase::GetError(intptr_t fd, OSError* os_error) { |
Handle* handle = reinterpret_cast<Handle*>(fd); |
os_error->SetCodeAndMessage(OSError::kSystem, handle->last_error()); |
} |
-int Socket::GetType(intptr_t fd) { |
+int SocketBase::GetType(intptr_t fd) { |
Handle* handle = reinterpret_cast<Handle*>(fd); |
switch (GetFileType(handle->handle())) { |
case FILE_TYPE_CHAR: |
@@ -281,7 +166,7 @@ int Socket::GetType(intptr_t fd) { |
} |
-intptr_t Socket::GetStdioHandle(intptr_t num) { |
+intptr_t SocketBase::GetStdioHandle(intptr_t num) { |
if (num != 0) { |
return -1; |
} |
@@ -289,28 +174,16 @@ intptr_t Socket::GetStdioHandle(intptr_t num) { |
if (handle == INVALID_HANDLE_VALUE) { |
return -1; |
} |
- StdHandle* std_handle = StdHandle::Stdin(handle); |
- std_handle->Retain(); |
+ StdHandle* std_handle = new StdHandle(handle); |
std_handle->MarkDoesNotSupportOverlappedIO(); |
std_handle->EnsureInitialized(EventHandler::delegate()); |
return reinterpret_cast<intptr_t>(std_handle); |
} |
-intptr_t ServerSocket::Accept(intptr_t fd) { |
- ListenSocket* listen_socket = reinterpret_cast<ListenSocket*>(fd); |
- ClientSocket* client_socket = listen_socket->Accept(); |
- if (client_socket != NULL) { |
- return reinterpret_cast<intptr_t>(client_socket); |
- } else { |
- return -1; |
- } |
-} |
- |
- |
-AddressList<SocketAddress>* Socket::LookupAddress(const char* host, |
- int type, |
- OSError** os_error) { |
+AddressList<SocketAddress>* SocketBase::LookupAddress(const char* host, |
+ int type, |
+ OSError** os_error) { |
Initialize(); |
// Perform a name lookup for a host name. |
@@ -354,10 +227,10 @@ AddressList<SocketAddress>* Socket::LookupAddress(const char* host, |
} |
-bool Socket::ReverseLookup(const RawAddr& addr, |
- char* host, |
- intptr_t host_len, |
- OSError** os_error) { |
+bool SocketBase::ReverseLookup(const RawAddr& addr, |
+ char* host, |
+ intptr_t host_len, |
+ OSError** os_error) { |
ASSERT(host_len >= NI_MAXHOST); |
int status = getnameinfo(&addr.addr, SocketAddress::GetAddrLength(addr), host, |
host_len, NULL, 0, NI_NAMEREQD); |
@@ -372,7 +245,7 @@ bool Socket::ReverseLookup(const RawAddr& addr, |
} |
-bool Socket::ParseAddress(int type, const char* address, RawAddr* addr) { |
+bool SocketBase::ParseAddress(int type, const char* address, RawAddr* addr) { |
int result; |
Utf8ToWideScope system_address(address); |
if (type == SocketAddress::TYPE_IPV4) { |
@@ -385,45 +258,12 @@ bool Socket::ParseAddress(int type, const char* address, RawAddr* addr) { |
} |
-intptr_t Socket::CreateBindDatagram(const RawAddr& addr, bool reuseAddress) { |
- SOCKET s = socket(addr.ss.ss_family, SOCK_DGRAM, IPPROTO_UDP); |
- if (s == INVALID_SOCKET) { |
- return -1; |
- } |
- |
- int status; |
- if (reuseAddress) { |
- BOOL optval = true; |
- status = setsockopt(s, SOL_SOCKET, SO_REUSEADDR, |
- reinterpret_cast<const char*>(&optval), sizeof(optval)); |
- if (status == SOCKET_ERROR) { |
- DWORD rc = WSAGetLastError(); |
- closesocket(s); |
- SetLastError(rc); |
- return -1; |
- } |
- } |
- |
- status = bind(s, &addr.addr, SocketAddress::GetAddrLength(addr)); |
- if (status == SOCKET_ERROR) { |
- DWORD rc = WSAGetLastError(); |
- closesocket(s); |
- SetLastError(rc); |
- return -1; |
- } |
- |
- DatagramSocket* datagram_socket = new DatagramSocket(s); |
- datagram_socket->EnsureInitialized(EventHandler::delegate()); |
- return reinterpret_cast<intptr_t>(datagram_socket); |
-} |
- |
- |
-bool Socket::ListInterfacesSupported() { |
+bool SocketBase::ListInterfacesSupported() { |
return true; |
} |
-AddressList<InterfaceSocketAddress>* Socket::ListInterfaces( |
+AddressList<InterfaceSocketAddress>* SocketBase::ListInterfaces( |
int type, |
OSError** os_error) { |
Initialize(); |
@@ -473,95 +313,13 @@ AddressList<InterfaceSocketAddress>* Socket::ListInterfaces( |
} |
-intptr_t ServerSocket::CreateBindListen(const RawAddr& addr, |
- intptr_t backlog, |
- bool v6_only) { |
- SOCKET s = socket(addr.ss.ss_family, SOCK_STREAM, IPPROTO_TCP); |
- if (s == INVALID_SOCKET) { |
- return -1; |
- } |
- |
- BOOL optval = true; |
- int status = |
- setsockopt(s, SOL_SOCKET, SO_EXCLUSIVEADDRUSE, |
- reinterpret_cast<const char*>(&optval), sizeof(optval)); |
- if (status == SOCKET_ERROR) { |
- DWORD rc = WSAGetLastError(); |
- closesocket(s); |
- SetLastError(rc); |
- return -1; |
- } |
- |
- if (addr.ss.ss_family == AF_INET6) { |
- optval = v6_only; |
- setsockopt(s, IPPROTO_IPV6, IPV6_V6ONLY, |
- reinterpret_cast<const char*>(&optval), sizeof(optval)); |
- } |
- |
- status = bind(s, &addr.addr, SocketAddress::GetAddrLength(addr)); |
- if (status == SOCKET_ERROR) { |
- DWORD rc = WSAGetLastError(); |
- closesocket(s); |
- SetLastError(rc); |
- return -1; |
- } |
- |
- ListenSocket* listen_socket = new ListenSocket(s); |
- |
- // Test for invalid socket port 65535 (some browsers disallow it). |
- if ((SocketAddress::GetAddrPort(addr) == 0) && |
- (Socket::GetPort(reinterpret_cast<intptr_t>(listen_socket)) == 65535)) { |
- // Don't close fd until we have created new. By doing that we ensure another |
- // port. |
- intptr_t new_s = CreateBindListen(addr, backlog, v6_only); |
- DWORD rc = WSAGetLastError(); |
- closesocket(s); |
- listen_socket->Release(); |
- SetLastError(rc); |
- return new_s; |
- } |
- |
- status = listen(s, backlog > 0 ? backlog : SOMAXCONN); |
- if (status == SOCKET_ERROR) { |
- DWORD rc = WSAGetLastError(); |
- closesocket(s); |
- listen_socket->Release(); |
- SetLastError(rc); |
- return -1; |
- } |
- |
- return reinterpret_cast<intptr_t>(listen_socket); |
-} |
- |
- |
-bool ServerSocket::StartAccept(intptr_t fd) { |
- ListenSocket* listen_socket = reinterpret_cast<ListenSocket*>(fd); |
- listen_socket->EnsureInitialized(EventHandler::delegate()); |
- // Always keep 5 outstanding accepts going, to enhance performance. |
- for (int i = 0; i < 5; i++) { |
- if (!listen_socket->IssueAccept()) { |
- DWORD rc = WSAGetLastError(); |
- listen_socket->Close(); |
- if (!listen_socket->HasPendingAccept()) { |
- // Delete socket now, if there are no pending accepts. Otherwise, |
- // the event-handler will take care of deleting it. |
- listen_socket->Release(); |
- } |
- SetLastError(rc); |
- return false; |
- } |
- } |
- return true; |
-} |
- |
- |
-void Socket::Close(intptr_t fd) { |
+void SocketBase::Close(intptr_t fd) { |
ClientSocket* client_socket = reinterpret_cast<ClientSocket*>(fd); |
client_socket->Close(); |
} |
-bool Socket::GetNoDelay(intptr_t fd, bool* enabled) { |
+bool SocketBase::GetNoDelay(intptr_t fd, bool* enabled) { |
SocketHandle* handle = reinterpret_cast<SocketHandle*>(fd); |
int on; |
socklen_t len = sizeof(on); |
@@ -574,7 +332,7 @@ bool Socket::GetNoDelay(intptr_t fd, bool* enabled) { |
} |
-bool Socket::SetNoDelay(intptr_t fd, bool enabled) { |
+bool SocketBase::SetNoDelay(intptr_t fd, bool enabled) { |
SocketHandle* handle = reinterpret_cast<SocketHandle*>(fd); |
int on = enabled ? 1 : 0; |
return setsockopt(handle->socket(), IPPROTO_TCP, TCP_NODELAY, |
@@ -582,7 +340,9 @@ bool Socket::SetNoDelay(intptr_t fd, bool enabled) { |
} |
-bool Socket::GetMulticastLoop(intptr_t fd, intptr_t protocol, bool* enabled) { |
+bool SocketBase::GetMulticastLoop(intptr_t fd, |
+ intptr_t protocol, |
+ bool* enabled) { |
SocketHandle* handle = reinterpret_cast<SocketHandle*>(fd); |
uint8_t on; |
socklen_t len = sizeof(on); |
@@ -598,7 +358,9 @@ bool Socket::GetMulticastLoop(intptr_t fd, intptr_t protocol, bool* enabled) { |
} |
-bool Socket::SetMulticastLoop(intptr_t fd, intptr_t protocol, bool enabled) { |
+bool SocketBase::SetMulticastLoop(intptr_t fd, |
+ intptr_t protocol, |
+ bool enabled) { |
SocketHandle* handle = reinterpret_cast<SocketHandle*>(fd); |
int on = enabled ? 1 : 0; |
int level = protocol == SocketAddress::TYPE_IPV4 ? IPPROTO_IP : IPPROTO_IPV6; |
@@ -609,7 +371,7 @@ bool Socket::SetMulticastLoop(intptr_t fd, intptr_t protocol, bool enabled) { |
} |
-bool Socket::GetMulticastHops(intptr_t fd, intptr_t protocol, int* value) { |
+bool SocketBase::GetMulticastHops(intptr_t fd, intptr_t protocol, int* value) { |
SocketHandle* handle = reinterpret_cast<SocketHandle*>(fd); |
uint8_t v; |
socklen_t len = sizeof(v); |
@@ -625,7 +387,7 @@ bool Socket::GetMulticastHops(intptr_t fd, intptr_t protocol, int* value) { |
} |
-bool Socket::SetMulticastHops(intptr_t fd, intptr_t protocol, int value) { |
+bool SocketBase::SetMulticastHops(intptr_t fd, intptr_t protocol, int value) { |
SocketHandle* handle = reinterpret_cast<SocketHandle*>(fd); |
int v = value; |
int level = protocol == SocketAddress::TYPE_IPV4 ? IPPROTO_IP : IPPROTO_IPV6; |
@@ -636,7 +398,7 @@ bool Socket::SetMulticastHops(intptr_t fd, intptr_t protocol, int value) { |
} |
-bool Socket::GetBroadcast(intptr_t fd, bool* enabled) { |
+bool SocketBase::GetBroadcast(intptr_t fd, bool* enabled) { |
SocketHandle* handle = reinterpret_cast<SocketHandle*>(fd); |
int on; |
socklen_t len = sizeof(on); |
@@ -649,7 +411,7 @@ bool Socket::GetBroadcast(intptr_t fd, bool* enabled) { |
} |
-bool Socket::SetBroadcast(intptr_t fd, bool enabled) { |
+bool SocketBase::SetBroadcast(intptr_t fd, bool enabled) { |
SocketHandle* handle = reinterpret_cast<SocketHandle*>(fd); |
int on = enabled ? 1 : 0; |
return setsockopt(handle->socket(), SOL_SOCKET, SO_BROADCAST, |
@@ -657,10 +419,10 @@ bool Socket::SetBroadcast(intptr_t fd, bool enabled) { |
} |
-bool Socket::JoinMulticast(intptr_t fd, |
- const RawAddr& addr, |
- const RawAddr&, |
- int interfaceIndex) { |
+bool SocketBase::JoinMulticast(intptr_t fd, |
+ const RawAddr& addr, |
+ const RawAddr&, |
+ int interfaceIndex) { |
SocketHandle* handle = reinterpret_cast<SocketHandle*>(fd); |
int proto = addr.addr.sa_family == AF_INET ? IPPROTO_IP : IPPROTO_IPV6; |
struct group_req mreq; |
@@ -671,10 +433,10 @@ bool Socket::JoinMulticast(intptr_t fd, |
} |
-bool Socket::LeaveMulticast(intptr_t fd, |
- const RawAddr& addr, |
- const RawAddr&, |
- int interfaceIndex) { |
+bool SocketBase::LeaveMulticast(intptr_t fd, |
+ const RawAddr& addr, |
+ const RawAddr&, |
+ int interfaceIndex) { |
SocketHandle* handle = reinterpret_cast<SocketHandle*>(fd); |
int proto = addr.addr.sa_family == AF_INET ? IPPROTO_IP : IPPROTO_IPV6; |
struct group_req mreq; |