Chromium Code Reviews| 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 |