Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "net/tools/quic/quic_server.h" | 5 #include "net/tools/quic/quic_server.h" |
| 6 | 6 |
| 7 #include <errno.h> | 7 #include <errno.h> |
| 8 #include <features.h> | 8 #include <features.h> |
| 9 #include <netinet/in.h> | 9 #include <netinet/in.h> |
| 10 #include <string.h> | 10 #include <string.h> |
| (...skipping 10 matching lines...) Expand all Loading... | |
| 21 #include "net/quic/quic_protocol.h" | 21 #include "net/quic/quic_protocol.h" |
| 22 #include "net/tools/quic/quic_in_memory_cache.h" | 22 #include "net/tools/quic/quic_in_memory_cache.h" |
| 23 #include "net/tools/quic/quic_socket_utils.h" | 23 #include "net/tools/quic/quic_socket_utils.h" |
| 24 | 24 |
| 25 #define MMSG_MORE 0 | 25 #define MMSG_MORE 0 |
| 26 | 26 |
| 27 #ifndef SO_RXQ_OVFL | 27 #ifndef SO_RXQ_OVFL |
| 28 #define SO_RXQ_OVFL 40 | 28 #define SO_RXQ_OVFL 40 |
| 29 #endif | 29 #endif |
| 30 | 30 |
| 31 const int kEpollFlags = EPOLLIN | EPOLLOUT | EPOLLET; | |
| 32 static const char kSourceAddressTokenSecret[] = "secret"; | |
| 33 const uint32 kServerInitialFlowControlWindow = 100 * net::kMaxPacketSize; | |
| 34 | |
| 35 namespace net { | 31 namespace net { |
| 36 namespace tools { | 32 namespace tools { |
| 37 | 33 |
| 34 namespace { | |
| 35 | |
| 36 const int kEpollFlags = EPOLLIN | EPOLLOUT | EPOLLET; | |
| 37 const char kSourceAddressTokenSecret[] = "secret"; | |
| 38 const uint32 kServerInitialFlowControlWindow = 100 * net::kMaxPacketSize; | |
| 39 | |
| 40 } // namespace | |
| 41 | |
| 38 QuicServer::QuicServer() | 42 QuicServer::QuicServer() |
| 39 : port_(0), | 43 : port_(0), |
| 40 fd_(-1), | 44 fd_(-1), |
| 41 packets_dropped_(0), | 45 packets_dropped_(0), |
| 42 overflow_supported_(false), | 46 overflow_supported_(false), |
| 43 use_recvmmsg_(false), | 47 use_recvmmsg_(false), |
| 44 crypto_config_(kSourceAddressTokenSecret, QuicRandom::GetInstance()), | 48 crypto_config_(kSourceAddressTokenSecret, QuicRandom::GetInstance()), |
| 45 supported_versions_(QuicSupportedVersions()) { | 49 supported_versions_(QuicSupportedVersions()) { |
| 46 // Use hardcoded crypto parameters for now. | 50 // Use hardcoded crypto parameters for now. |
| 47 config_.SetDefaults(); | 51 config_.SetDefaults(); |
| (...skipping 37 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 85 | 89 |
| 86 bool QuicServer::Listen(const IPEndPoint& address) { | 90 bool QuicServer::Listen(const IPEndPoint& address) { |
| 87 port_ = address.port(); | 91 port_ = address.port(); |
| 88 int address_family = address.GetSockAddrFamily(); | 92 int address_family = address.GetSockAddrFamily(); |
| 89 fd_ = socket(address_family, SOCK_DGRAM | SOCK_NONBLOCK, IPPROTO_UDP); | 93 fd_ = socket(address_family, SOCK_DGRAM | SOCK_NONBLOCK, IPPROTO_UDP); |
| 90 if (fd_ < 0) { | 94 if (fd_ < 0) { |
| 91 LOG(ERROR) << "CreateSocket() failed: " << strerror(errno); | 95 LOG(ERROR) << "CreateSocket() failed: " << strerror(errno); |
| 92 return false; | 96 return false; |
| 93 } | 97 } |
| 94 | 98 |
| 99 // Enable the socket option that allows the local address to be | |
| 100 // returned if the socket is bound to more than one address. | |
| 95 int rc = QuicSocketUtils::SetGetAddressInfo(fd_, address_family); | 101 int rc = QuicSocketUtils::SetGetAddressInfo(fd_, address_family); |
|
ramant (doing other things)
2014/07/15 23:02:39
nit: do we need to call SetReceiveBufferSize and S
wtc
2014/07/16 01:09:22
I don't think these socket options depend on each
| |
| 96 | 102 |
| 97 if (rc < 0) { | 103 if (rc < 0) { |
| 98 LOG(ERROR) << "IP detection not supported" << strerror(errno); | 104 LOG(ERROR) << "IP detection not supported" << strerror(errno); |
| 99 return false; | 105 return false; |
| 100 } | 106 } |
| 101 | 107 |
| 102 int get_overflow = 1; | 108 int get_overflow = 1; |
| 103 rc = setsockopt( | 109 rc = setsockopt( |
| 104 fd_, SOL_SOCKET, SO_RXQ_OVFL, &get_overflow, sizeof(get_overflow)); | 110 fd_, SOL_SOCKET, SO_RXQ_OVFL, &get_overflow, sizeof(get_overflow)); |
| 105 | 111 |
| 106 if (rc < 0) { | 112 if (rc < 0) { |
| 107 DLOG(WARNING) << "Socket overflow detection not supported"; | 113 DLOG(WARNING) << "Socket overflow detection not supported"; |
| 108 } else { | 114 } else { |
| 109 overflow_supported_ = true; | 115 overflow_supported_ = true; |
| 110 } | 116 } |
| 111 | 117 |
| 112 // These send and receive buffer sizes are sized for a single connection, | 118 // These send and receive buffer sizes are sized for a single connection, |
| 113 // because the default usage of QuicServer is as a test server with one or | 119 // because the default usage of QuicServer is as a test server with one or |
| 114 // two clients. Adjust higher for use with many clients. | 120 // two clients. Adjust higher for use with many clients. |
| 115 if (!QuicSocketUtils::SetReceiveBufferSize(fd_, | 121 if (!QuicSocketUtils::SetReceiveBufferSize(fd_, |
| 116 TcpReceiver::kReceiveWindowTCP)) { | 122 TcpReceiver::kReceiveWindowTCP)) { |
| 117 return false; | 123 return false; |
| 118 } | 124 } |
| 119 | 125 |
| 120 if (!QuicSocketUtils::SetSendBufferSize(fd_, | 126 if (!QuicSocketUtils::SetSendBufferSize(fd_, |
| 121 TcpReceiver::kReceiveWindowTCP)) { | 127 TcpReceiver::kReceiveWindowTCP)) { |
| 122 return false; | 128 return false; |
| 123 } | 129 } |
| 124 | 130 |
| 125 // Enable the socket option that allows the local address to be | |
| 126 // returned if the socket is bound to more than on address. | |
| 127 int get_local_ip = 1; | |
| 128 rc = setsockopt(fd_, IPPROTO_IP, IP_PKTINFO, | |
| 129 &get_local_ip, sizeof(get_local_ip)); | |
| 130 if (rc == 0 && address_family == AF_INET6) { | |
| 131 rc = setsockopt(fd_, IPPROTO_IPV6, IPV6_RECVPKTINFO, | |
| 132 &get_local_ip, sizeof(get_local_ip)); | |
| 133 } | |
| 134 if (rc != 0) { | |
| 135 LOG(ERROR) << "Failed to set required socket options"; | |
| 136 return false; | |
| 137 } | |
| 138 | |
| 139 sockaddr_storage raw_addr; | 131 sockaddr_storage raw_addr; |
| 140 socklen_t raw_addr_len = sizeof(raw_addr); | 132 socklen_t raw_addr_len = sizeof(raw_addr); |
| 141 CHECK(address.ToSockAddr(reinterpret_cast<sockaddr*>(&raw_addr), | 133 CHECK(address.ToSockAddr(reinterpret_cast<sockaddr*>(&raw_addr), |
| 142 &raw_addr_len)); | 134 &raw_addr_len)); |
| 143 rc = bind(fd_, | 135 rc = bind(fd_, |
| 144 reinterpret_cast<const sockaddr*>(&raw_addr), | 136 reinterpret_cast<const sockaddr*>(&raw_addr), |
| 145 sizeof(raw_addr)); | 137 sizeof(raw_addr)); |
| 146 if (rc < 0) { | 138 if (rc < 0) { |
| 147 LOG(ERROR) << "Bind failed: " << strerror(errno); | 139 LOG(ERROR) << "Bind failed: " << strerror(errno); |
| 148 return false; | 140 return false; |
| (...skipping 86 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 235 QuicEncryptedPacket packet(buf, bytes_read, false); | 227 QuicEncryptedPacket packet(buf, bytes_read, false); |
| 236 | 228 |
| 237 IPEndPoint server_address(server_ip, port); | 229 IPEndPoint server_address(server_ip, port); |
| 238 processor->ProcessPacket(server_address, client_address, packet); | 230 processor->ProcessPacket(server_address, client_address, packet); |
| 239 | 231 |
| 240 return true; | 232 return true; |
| 241 } | 233 } |
| 242 | 234 |
| 243 } // namespace tools | 235 } // namespace tools |
| 244 } // namespace net | 236 } // namespace net |
| OLD | NEW |