| OLD | NEW |
| 1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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 <stdint.h> | 5 #include <stdint.h> |
| 6 #include <stdio.h> | 6 #include <stdio.h> |
| 7 #include <string.h> | 7 #include <string.h> |
| 8 | 8 |
| 9 #include <string> | 9 #include <string> |
| 10 #include <vector> | 10 #include <vector> |
| (...skipping 29 matching lines...) Expand all Loading... |
| 40 void SetUpMeasurement(int message_count, size_t message_size) { | 40 void SetUpMeasurement(int message_count, size_t message_size) { |
| 41 message_count_ = message_count; | 41 message_count_ = message_count; |
| 42 message_size_ = message_size; | 42 message_size_ = message_size; |
| 43 payload_ = Pickle(); | 43 payload_ = Pickle(); |
| 44 payload_.WriteString(std::string(message_size, '*')); | 44 payload_.WriteString(std::string(message_size, '*')); |
| 45 read_buffer_.resize(message_size * 2); | 45 read_buffer_.resize(message_size * 2); |
| 46 } | 46 } |
| 47 | 47 |
| 48 protected: | 48 protected: |
| 49 void WriteWaitThenRead(scoped_refptr<MessagePipe> mp) { | 49 void WriteWaitThenRead(scoped_refptr<MessagePipe> mp) { |
| 50 CHECK_EQ(mp->WriteMessage(0, | 50 CHECK_EQ(mp->WriteMessage(0, UserPointer<const void>(payload_.data()), |
| 51 UserPointer<const void>(payload_.data()), | 51 static_cast<uint32_t>(payload_.size()), nullptr, |
| 52 static_cast<uint32_t>(payload_.size()), | |
| 53 nullptr, | |
| 54 MOJO_WRITE_MESSAGE_FLAG_NONE), | 52 MOJO_WRITE_MESSAGE_FLAG_NONE), |
| 55 MOJO_RESULT_OK); | 53 MOJO_RESULT_OK); |
| 56 HandleSignalsState hss; | 54 HandleSignalsState hss; |
| 57 CHECK_EQ(test::WaitIfNecessary(mp, MOJO_HANDLE_SIGNAL_READABLE, &hss), | 55 CHECK_EQ(test::WaitIfNecessary(mp, MOJO_HANDLE_SIGNAL_READABLE, &hss), |
| 58 MOJO_RESULT_OK); | 56 MOJO_RESULT_OK); |
| 59 uint32_t read_buffer_size = static_cast<uint32_t>(read_buffer_.size()); | 57 uint32_t read_buffer_size = static_cast<uint32_t>(read_buffer_.size()); |
| 60 CHECK_EQ(mp->ReadMessage(0, | 58 CHECK_EQ(mp->ReadMessage(0, UserPointer<void>(&read_buffer_[0]), |
| 61 UserPointer<void>(&read_buffer_[0]), | 59 MakeUserPointer(&read_buffer_size), nullptr, |
| 62 MakeUserPointer(&read_buffer_size), | 60 nullptr, MOJO_READ_MESSAGE_FLAG_NONE), |
| 63 nullptr, | |
| 64 nullptr, | |
| 65 MOJO_READ_MESSAGE_FLAG_NONE), | |
| 66 MOJO_RESULT_OK); | 61 MOJO_RESULT_OK); |
| 67 CHECK_EQ(read_buffer_size, static_cast<uint32_t>(payload_.size())); | 62 CHECK_EQ(read_buffer_size, static_cast<uint32_t>(payload_.size())); |
| 68 } | 63 } |
| 69 | 64 |
| 70 void SendQuitMessage(scoped_refptr<MessagePipe> mp) { | 65 void SendQuitMessage(scoped_refptr<MessagePipe> mp) { |
| 71 CHECK_EQ(mp->WriteMessage(0, | 66 CHECK_EQ(mp->WriteMessage(0, UserPointer<const void>(""), 0, nullptr, |
| 72 UserPointer<const void>(""), | |
| 73 0, | |
| 74 nullptr, | |
| 75 MOJO_WRITE_MESSAGE_FLAG_NONE), | 67 MOJO_WRITE_MESSAGE_FLAG_NONE), |
| 76 MOJO_RESULT_OK); | 68 MOJO_RESULT_OK); |
| 77 } | 69 } |
| 78 | 70 |
| 79 void Measure(scoped_refptr<MessagePipe> mp) { | 71 void Measure(scoped_refptr<MessagePipe> mp) { |
| 80 // Have one ping-pong to ensure channel being established. | 72 // Have one ping-pong to ensure channel being established. |
| 81 WriteWaitThenRead(mp); | 73 WriteWaitThenRead(mp); |
| 82 | 74 |
| 83 std::string test_name = | 75 std::string test_name = |
| 84 base::StringPrintf("IPC_Perf_%dx_%u", | 76 base::StringPrintf("IPC_Perf_%dx_%u", message_count_, |
| 85 message_count_, | |
| 86 static_cast<unsigned>(message_size_)); | 77 static_cast<unsigned>(message_size_)); |
| 87 base::PerfTimeLogger logger(test_name.c_str()); | 78 base::PerfTimeLogger logger(test_name.c_str()); |
| 88 | 79 |
| 89 for (int i = 0; i < message_count_; ++i) | 80 for (int i = 0; i < message_count_; ++i) |
| 90 WriteWaitThenRead(mp); | 81 WriteWaitThenRead(mp); |
| 91 | 82 |
| 92 logger.Done(); | 83 logger.Done(); |
| 93 } | 84 } |
| 94 | 85 |
| 95 private: | 86 private: |
| (...skipping 24 matching lines...) Expand all Loading... |
| 120 // Wait for our end of the message pipe to be readable. | 111 // Wait for our end of the message pipe to be readable. |
| 121 HandleSignalsState hss; | 112 HandleSignalsState hss; |
| 122 MojoResult result = | 113 MojoResult result = |
| 123 test::WaitIfNecessary(mp, MOJO_HANDLE_SIGNAL_READABLE, &hss); | 114 test::WaitIfNecessary(mp, MOJO_HANDLE_SIGNAL_READABLE, &hss); |
| 124 if (result != MOJO_RESULT_OK) { | 115 if (result != MOJO_RESULT_OK) { |
| 125 rv = result; | 116 rv = result; |
| 126 break; | 117 break; |
| 127 } | 118 } |
| 128 | 119 |
| 129 uint32_t read_size = static_cast<uint32_t>(buffer.size()); | 120 uint32_t read_size = static_cast<uint32_t>(buffer.size()); |
| 130 CHECK_EQ(mp->ReadMessage(0, | 121 CHECK_EQ(mp->ReadMessage(0, UserPointer<void>(&buffer[0]), |
| 131 UserPointer<void>(&buffer[0]), | 122 MakeUserPointer(&read_size), nullptr, nullptr, |
| 132 MakeUserPointer(&read_size), | |
| 133 nullptr, | |
| 134 nullptr, | |
| 135 MOJO_READ_MESSAGE_FLAG_NONE), | 123 MOJO_READ_MESSAGE_FLAG_NONE), |
| 136 MOJO_RESULT_OK); | 124 MOJO_RESULT_OK); |
| 137 | 125 |
| 138 // Empty message indicates quitting | 126 // Empty message indicates quitting |
| 139 if (0 == read_size) | 127 if (0 == read_size) |
| 140 break; | 128 break; |
| 141 | 129 |
| 142 CHECK_EQ(mp->WriteMessage(0, | 130 CHECK_EQ(mp->WriteMessage(0, UserPointer<const void>(&buffer[0]), |
| 143 UserPointer<const void>(&buffer[0]), | 131 static_cast<uint32_t>(read_size), nullptr, |
| 144 static_cast<uint32_t>(read_size), | |
| 145 nullptr, | |
| 146 MOJO_WRITE_MESSAGE_FLAG_NONE), | 132 MOJO_WRITE_MESSAGE_FLAG_NONE), |
| 147 MOJO_RESULT_OK); | 133 MOJO_RESULT_OK); |
| 148 } | 134 } |
| 149 | 135 |
| 150 mp->Close(0); | 136 mp->Close(0); |
| 151 return rv; | 137 return rv; |
| 152 } | 138 } |
| 153 | 139 |
| 154 // Repeatedly sends messages as previous one got replied by the child. | 140 // Repeatedly sends messages as previous one got replied by the child. |
| 155 // Waits for the child to close its end before quitting once specified | 141 // Waits for the child to close its end before quitting once specified |
| (...skipping 15 matching lines...) Expand all Loading... |
| 171 } | 157 } |
| 172 | 158 |
| 173 SendQuitMessage(mp); | 159 SendQuitMessage(mp); |
| 174 mp->Close(0); | 160 mp->Close(0); |
| 175 EXPECT_EQ(0, helper()->WaitForChildShutdown()); | 161 EXPECT_EQ(0, helper()->WaitForChildShutdown()); |
| 176 } | 162 } |
| 177 | 163 |
| 178 } // namespace | 164 } // namespace |
| 179 } // namespace system | 165 } // namespace system |
| 180 } // namespace mojo | 166 } // namespace mojo |
| OLD | NEW |