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

Side by Side Diff: net/udp/udp_socket_libevent.h

Issue 690903002: Remove timing limitation of SetOption invocation for PPAPI sockets. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 6 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 unified diff | Download patch
OLDNEW
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 #ifndef NET_UDP_UDP_SOCKET_LIBEVENT_H_ 5 #ifndef NET_UDP_UDP_SOCKET_LIBEVENT_H_
6 #define NET_UDP_UDP_SOCKET_LIBEVENT_H_ 6 #define NET_UDP_UDP_SOCKET_LIBEVENT_H_
7 7
8 #include "base/memory/ref_counted.h" 8 #include "base/memory/ref_counted.h"
9 #include "base/memory/scoped_ptr.h" 9 #include "base/memory/scoped_ptr.h"
10 #include "base/message_loop/message_loop.h" 10 #include "base/message_loop/message_loop.h"
(...skipping 76 matching lines...) Expand 10 before | Expand all | Expand 10 after
87 // |callback| is the user callback function to call on complete. 87 // |callback| is the user callback function to call on complete.
88 // Returns a net error code, or ERR_IO_PENDING if the IO is in progress. 88 // Returns a net error code, or ERR_IO_PENDING if the IO is in progress.
89 // If ERR_IO_PENDING is returned, the caller must keep |buf| and |address| 89 // If ERR_IO_PENDING is returned, the caller must keep |buf| and |address|
90 // alive until the callback is called. 90 // alive until the callback is called.
91 int SendTo(IOBuffer* buf, 91 int SendTo(IOBuffer* buf,
92 int buf_len, 92 int buf_len,
93 const IPEndPoint& address, 93 const IPEndPoint& address,
94 const CompletionCallback& callback); 94 const CompletionCallback& callback);
95 95
96 // Set the receive buffer size (in bytes) for the socket. 96 // Set the receive buffer size (in bytes) for the socket.
97 // Returns a net error code.
97 int SetReceiveBufferSize(int32 size); 98 int SetReceiveBufferSize(int32 size);
98 99
99 // Set the send buffer size (in bytes) for the socket. 100 // Set the send buffer size (in bytes) for the socket.
101 // Returns a net error code.
100 int SetSendBufferSize(int32 size); 102 int SetSendBufferSize(int32 size);
101 103
102 // Returns true if the socket is already connected or bound. 104 // Returns true if the socket is already connected or bound.
103 bool is_connected() const { return socket_ != kInvalidSocket; } 105 bool is_connected() const { return socket_ != kInvalidSocket; }
104 106
105 const BoundNetLog& NetLog() const { return net_log_; } 107 const BoundNetLog& NetLog() const { return net_log_; }
106 108
107 // Sets corresponding flags in |socket_options_| to allow the socket 109 // Allows the socket to share the local address to which the socket will be
108 // to share the local address to which the socket will be bound with 110 // bound with other processes.
109 // other processes. Should be called before Bind(). 111 // Returns a net error code.
110 void AllowAddressReuse(); 112 int AllowAddressReuse();
111 113
112 // Sets corresponding flags in |socket_options_| to allow sending 114 // Disallows the socket to share the local address to which the socket will
113 // and receiving packets to and from broadcast addresses. Should be 115 // be bound with other processes.
114 // called before Bind(). 116 // Returns a net error code.
115 void AllowBroadcast(); 117 int DisallowAddressReuse();
118
119 // Allows sending and receiving packets to and from broadcast addresses.
120 // Returns a net error code.
121 int AllowBroadcast();
122
123 // Disallows sending and receiving packets to and from broadcast addresses.
124 // Returns a net error code.
125 int DisallowBroadcast();
116 126
117 // Join the multicast group. 127 // Join the multicast group.
118 // |group_address| is the group address to join, could be either 128 // |group_address| is the group address to join, could be either
119 // an IPv4 or IPv6 address. 129 // an IPv4 or IPv6 address.
120 // Return a network error code. 130 // Return a network error code.
121 int JoinGroup(const IPAddressNumber& group_address) const; 131 int JoinGroup(const IPAddressNumber& group_address) const;
122 132
123 // Leave the multicast group. 133 // Leave the multicast group.
124 // |group_address| is the group address to leave, could be either 134 // |group_address| is the group address to leave, could be either
125 // an IPv4 or IPv6 address. If the socket hasn't joined the group, 135 // an IPv4 or IPv6 address. If the socket hasn't joined the group,
(...skipping 37 matching lines...) Expand 10 before | Expand all | Expand 10 after
163 // Return a network error code. 173 // Return a network error code.
164 int SetDiffServCodePoint(DiffServCodePoint dscp); 174 int SetDiffServCodePoint(DiffServCodePoint dscp);
165 175
166 // Resets the thread to be used for thread-safety checks. 176 // Resets the thread to be used for thread-safety checks.
167 void DetachFromThread(); 177 void DetachFromThread();
168 178
169 private: 179 private:
170 enum SocketOptions { 180 enum SocketOptions {
171 SOCKET_OPTION_REUSE_ADDRESS = 1 << 0, 181 SOCKET_OPTION_REUSE_ADDRESS = 1 << 0,
172 SOCKET_OPTION_BROADCAST = 1 << 1, 182 SOCKET_OPTION_BROADCAST = 1 << 1,
173 SOCKET_OPTION_MULTICAST_LOOP = 1 << 2 183 SOCKET_OPTION_MULTICAST_LOOP = 1 << 2,
184 SOCKET_OPTION_RCVBUF_SIZE = 1 << 3,
185 SOCKET_OPTION_SNDBUF_SIZE = 1 << 4
174 }; 186 };
175 187
176 class ReadWatcher : public base::MessageLoopForIO::Watcher { 188 class ReadWatcher : public base::MessageLoopForIO::Watcher {
177 public: 189 public:
178 explicit ReadWatcher(UDPSocketLibevent* socket) : socket_(socket) {} 190 explicit ReadWatcher(UDPSocketLibevent* socket) : socket_(socket) {}
179 191
180 // MessageLoopForIO::Watcher methods 192 // MessageLoopForIO::Watcher methods
181 193
182 void OnFileCanReadWithoutBlocking(int /* fd */) override; 194 void OnFileCanReadWithoutBlocking(int /* fd */) override;
183 195
(...skipping 45 matching lines...) Expand 10 before | Expand all | Expand 10 after
229 const IPEndPoint* address, 241 const IPEndPoint* address,
230 const CompletionCallback& callback); 242 const CompletionCallback& callback);
231 243
232 int InternalConnect(const IPEndPoint& address); 244 int InternalConnect(const IPEndPoint& address);
233 int InternalRecvFrom(IOBuffer* buf, int buf_len, IPEndPoint* address); 245 int InternalRecvFrom(IOBuffer* buf, int buf_len, IPEndPoint* address);
234 int InternalSendTo(IOBuffer* buf, int buf_len, const IPEndPoint* address); 246 int InternalSendTo(IOBuffer* buf, int buf_len, const IPEndPoint* address);
235 247
236 // Applies |socket_options_| to |socket_|. Should be called before 248 // Applies |socket_options_| to |socket_|. Should be called before
237 // Bind(). 249 // Bind().
238 int SetSocketOptions(); 250 int SetSocketOptions();
251 int SetAddressReuseInternal(bool value);
jar (doing other things) 2014/11/04 22:51:09 nit: use better variable name than |value|. Perha
hidehiko 2014/11/05 12:48:30 Done.
252 int SetBroadcastInternal(bool value);
253 int SetReceiveBufferSizeInternal(int32 size);
254 int SetSendBufferSizeInternal(int32 size);
255
239 int DoBind(const IPEndPoint& address); 256 int DoBind(const IPEndPoint& address);
240 // Binds to a random port on |address|. 257 // Binds to a random port on |address|.
241 int RandomBind(const IPAddressNumber& address); 258 int RandomBind(const IPAddressNumber& address);
242 259
243 int socket_; 260 int socket_;
244 int addr_family_; 261 int addr_family_;
245 262
246 // Bitwise-or'd combination of SocketOptions. Specifies the set of 263 // Bitwise-or'd combination of SocketOptions. Specifies the set of
247 // options that should be applied to |socket_| before Bind(). 264 // options that should be applied to |socket_| before Bind().
248 int socket_options_; 265 int socket_options_;
249 266
267 // Buffer size set before Bind(). This should be applied
268 // in SetSocketOptions().
269 int32 rcvbuf_size_;
270 int32 sndbuf_size_;
271
250 // Multicast interface. 272 // Multicast interface.
251 uint32 multicast_interface_; 273 uint32 multicast_interface_;
252 274
253 // Multicast socket options cached for SetSocketOption. 275 // Multicast socket options cached for SetSocketOption.
254 // Cannot be used after Bind(). 276 // Cannot be used after Bind().
255 int multicast_time_to_live_; 277 int multicast_time_to_live_;
256 278
257 // How to do source port binding, used only when UDPSocket is part of 279 // How to do source port binding, used only when UDPSocket is part of
258 // UDPClientSocket, since UDPServerSocket provides Bind. 280 // UDPClientSocket, since UDPServerSocket provides Bind.
259 DatagramSocket::BindType bind_type_; 281 DatagramSocket::BindType bind_type_;
(...skipping 31 matching lines...) Expand 10 before | Expand all | Expand 10 after
291 CompletionCallback write_callback_; 313 CompletionCallback write_callback_;
292 314
293 BoundNetLog net_log_; 315 BoundNetLog net_log_;
294 316
295 DISALLOW_COPY_AND_ASSIGN(UDPSocketLibevent); 317 DISALLOW_COPY_AND_ASSIGN(UDPSocketLibevent);
296 }; 318 };
297 319
298 } // namespace net 320 } // namespace net
299 321
300 #endif // NET_UDP_UDP_SOCKET_LIBEVENT_H_ 322 #endif // NET_UDP_UDP_SOCKET_LIBEVENT_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698