OLD | NEW |
---|---|
1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2011 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/curvecp/messenger.h" | 5 #include "net/curvecp/messenger.h" |
6 | 6 |
7 #include "base/logging.h" | 7 #include "base/logging.h" |
8 #include "base/message_loop.h" | 8 #include "base/message_loop.h" |
9 #include "net/base/io_buffer.h" | 9 #include "net/base/io_buffer.h" |
10 #include "net/base/net_errors.h" | 10 #include "net/base/net_errors.h" |
(...skipping 41 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
52 | 52 |
53 // Size of the send buffer. | 53 // Size of the send buffer. |
54 static const size_t kSendBufferSize = (128 * 1024); | 54 static const size_t kSendBufferSize = (128 * 1024); |
55 // Size of the receive buffer. | 55 // Size of the receive buffer. |
56 static const size_t kReceiveBufferSize = (128 * 1024); | 56 static const size_t kReceiveBufferSize = (128 * 1024); |
57 | 57 |
58 Messenger::Messenger(Packetizer* packetizer) | 58 Messenger::Messenger(Packetizer* packetizer) |
59 : packetizer_(packetizer), | 59 : packetizer_(packetizer), |
60 send_buffer_(kSendBufferSize), | 60 send_buffer_(kSendBufferSize), |
61 send_complete_callback_(NULL), | 61 send_complete_callback_(NULL), |
62 receive_complete_callback_(NULL), | 62 old_receive_complete_callback_(NULL), |
63 pending_receive_length_(0), | 63 pending_receive_length_(0), |
64 send_message_in_progress_(false), | 64 send_message_in_progress_(false), |
65 ALLOW_THIS_IN_INITIALIZER_LIST( | 65 ALLOW_THIS_IN_INITIALIZER_LIST( |
66 send_message_callback_(this, &Messenger::OnSendMessageComplete)), | 66 send_message_callback_(this, &Messenger::OnSendMessageComplete)), |
67 ALLOW_THIS_IN_INITIALIZER_LIST(factory_(this)) { | 67 ALLOW_THIS_IN_INITIALIZER_LIST(factory_(this)) { |
68 } | 68 } |
69 | 69 |
70 Messenger::~Messenger() { | 70 Messenger::~Messenger() { |
71 } | 71 } |
72 | 72 |
73 int Messenger::Read(IOBuffer* buf, int buf_len, OldCompletionCallback* callback) { | 73 int Messenger::Read(IOBuffer* buf, int buf_len, OldCompletionCallback* callback) { |
74 DCHECK(CalledOnValidThread()); | 74 DCHECK(CalledOnValidThread()); |
75 DCHECK(!receive_complete_callback_); | 75 DCHECK(!old_receive_complete_callback_); |
csilv
2011/12/07 00:03:48
change this to match line 91
James Hawkins
2011/12/07 00:19:37
Done.
| |
76 | |
77 if (!received_list_.bytes_available()) { | |
78 old_receive_complete_callback_ = callback; | |
79 pending_receive_ = buf; | |
80 pending_receive_length_ = buf_len; | |
81 return ERR_IO_PENDING; | |
82 } | |
83 | |
84 int bytes_read = InternalRead(buf, buf_len); | |
85 DCHECK_LT(0, bytes_read); | |
86 return bytes_read; | |
87 } | |
88 int Messenger::Read(IOBuffer* buf, int buf_len, | |
89 const CompletionCallback& callback) { | |
90 DCHECK(CalledOnValidThread()); | |
91 DCHECK(!old_receive_complete_callback_ && | |
92 receive_complete_callback_.is_null()); | |
76 | 93 |
77 if (!received_list_.bytes_available()) { | 94 if (!received_list_.bytes_available()) { |
78 receive_complete_callback_ = callback; | 95 receive_complete_callback_ = callback; |
79 pending_receive_ = buf; | 96 pending_receive_ = buf; |
80 pending_receive_length_ = buf_len; | 97 pending_receive_length_ = buf_len; |
81 return ERR_IO_PENDING; | 98 return ERR_IO_PENDING; |
82 } | 99 } |
83 | 100 |
84 int bytes_read = InternalRead(buf, buf_len); | 101 int bytes_read = InternalRead(buf, buf_len); |
85 DCHECK_LT(0, bytes_read); | 102 DCHECK_LT(0, bytes_read); |
(...skipping 245 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
331 // Add to our received block list | 348 // Add to our received block list |
332 uint64 position = uint64_unpack(header->position); | 349 uint64 position = uint64_unpack(header->position); |
333 scoped_refptr<IOBuffer> buffer(new IOBuffer(body_length)); | 350 scoped_refptr<IOBuffer> buffer(new IOBuffer(body_length)); |
334 memcpy(buffer->data(), message->data() + sizeof(Message), body_length); | 351 memcpy(buffer->data(), message->data() + sizeof(Message), body_length); |
335 received_list_.AddBlock(position, buffer, body_length); | 352 received_list_.AddBlock(position, buffer, body_length); |
336 | 353 |
337 SendAck(message_id); | 354 SendAck(message_id); |
338 } | 355 } |
339 | 356 |
340 // If we have data available, and a read is pending, notify the callback. | 357 // If we have data available, and a read is pending, notify the callback. |
341 if (received_list_.bytes_available() && receive_complete_callback_) { | 358 if (received_list_.bytes_available() && |
359 (old_receive_complete_callback_ || | |
360 !receive_complete_callback_.is_null())) { | |
342 // Pass the data up to the caller. | 361 // Pass the data up to the caller. |
343 int bytes_read = InternalRead(pending_receive_, pending_receive_length_); | 362 int bytes_read = InternalRead(pending_receive_, pending_receive_length_); |
344 OldCompletionCallback* callback = receive_complete_callback_; | 363 if (old_receive_complete_callback_) { |
345 receive_complete_callback_ = NULL; | 364 OldCompletionCallback* callback = old_receive_complete_callback_; |
346 callback->Run(bytes_read); | 365 old_receive_complete_callback_ = NULL; |
366 callback->Run(bytes_read); | |
367 } else { | |
368 CompletionCallback callback = receive_complete_callback_; | |
369 receive_complete_callback_.Reset(); | |
370 callback.Run(bytes_read); | |
371 } | |
347 } | 372 } |
348 } | 373 } |
349 | 374 |
350 void Messenger::SendAck(uint32 last_message_received) { | 375 void Messenger::SendAck(uint32 last_message_received) { |
351 scoped_refptr<IOBuffer> buffer(new IOBuffer(sizeof(Message))); | 376 scoped_refptr<IOBuffer> buffer(new IOBuffer(sizeof(Message))); |
352 memset(buffer->data(), 0, sizeof(Message)); | 377 memset(buffer->data(), 0, sizeof(Message)); |
353 Message* message = reinterpret_cast<Message*>(buffer->data()); | 378 Message* message = reinterpret_cast<Message*>(buffer->data()); |
354 uint32_pack(message->last_message_received, last_message_received); | 379 uint32_pack(message->last_message_received, last_message_received); |
355 uint64_pack(message->acknowledge_1, received_list_.bytes_received()); | 380 uint64_pack(message->acknowledge_1, received_list_.bytes_received()); |
356 LOG(ERROR) << "SendAck " << received_list_.bytes_received(); | 381 LOG(ERROR) << "SendAck " << received_list_.bytes_received(); |
357 // TODO(mbelshe): fill in remainder of selective acknowledgements | 382 // TODO(mbelshe): fill in remainder of selective acknowledgements |
358 | 383 |
359 // TODO(mbelshe): Fix this - it is totally possible to have a send message | 384 // TODO(mbelshe): Fix this - it is totally possible to have a send message |
360 // in progress here... | 385 // in progress here... |
361 DCHECK(!send_message_in_progress_); | 386 DCHECK(!send_message_in_progress_); |
362 | 387 |
363 int rv = packetizer_->SendMessage(key_, | 388 int rv = packetizer_->SendMessage(key_, |
364 buffer->data(), | 389 buffer->data(), |
365 sizeof(Message), | 390 sizeof(Message), |
366 &send_message_callback_); | 391 &send_message_callback_); |
367 // TODO(mbelshe): Fix me! Deal with the error cases | 392 // TODO(mbelshe): Fix me! Deal with the error cases |
368 DCHECK(rv == sizeof(Message)); | 393 DCHECK(rv == sizeof(Message)); |
369 } | 394 } |
370 | 395 |
371 } // namespace net | 396 } // namespace net |
OLD | NEW |