Index: third_party/mojo/src/mojo/edk/system/data_pipe_impl.h |
diff --git a/third_party/mojo/src/mojo/edk/system/data_pipe_impl.h b/third_party/mojo/src/mojo/edk/system/data_pipe_impl.h |
index e1339c00cebc1425fb3ee790c77080a72ab00ca5..20ca900044e145fb2a8ec2869351d376399f07fa 100644 |
--- a/third_party/mojo/src/mojo/edk/system/data_pipe_impl.h |
+++ b/third_party/mojo/src/mojo/edk/system/data_pipe_impl.h |
@@ -7,18 +7,21 @@ |
#include <stdint.h> |
+#include "base/compiler_specific.h" |
#include "base/macros.h" |
#include "mojo/edk/embedder/platform_handle_vector.h" |
#include "mojo/edk/system/data_pipe.h" |
#include "mojo/edk/system/handle_signals_state.h" |
#include "mojo/edk/system/memory.h" |
#include "mojo/edk/system/system_impl_export.h" |
+#include "mojo/public/c/system/data_pipe.h" |
#include "mojo/public/c/system/types.h" |
namespace mojo { |
namespace system { |
class Channel; |
+class MessageInTransit; |
// Base class/interface for classes that "implement" |DataPipe| for various |
// situations (local versus remote). The methods, other than the constructor, |
@@ -81,12 +84,26 @@ class MOJO_SYSTEM_IMPL_EXPORT DataPipeImpl { |
size_t* actual_size, |
embedder::PlatformHandleVector* platform_handles) = 0; |
+ virtual bool OnReadMessage(unsigned port, MessageInTransit* message) = 0; |
+ virtual void OnDetachFromChannel(unsigned port) = 0; |
+ |
protected: |
DataPipeImpl() : owner_() {} |
+ // Helper to convert the given circular buffer into messages. The input is a |
+ // circular buffer |buffer| (with appropriate element size and capacity), with |
+ // current contents starting at |start_index| of length |current_num_bytes|. |
+ // This will convert all of the contents. |
+ void ConvertDataToMessages(const char* buffer, |
+ size_t* start_index, |
+ size_t* current_num_bytes, |
+ MessageInTransitQueue* message_queue); |
+ |
DataPipe* owner() const { return owner_; } |
- bool may_discard() const { return owner_->may_discard(); } |
+ const MojoCreateDataPipeOptions& validated_options() const { |
+ return owner_->validated_options(); |
+ } |
size_t element_num_bytes() const { return owner_->element_num_bytes(); } |
size_t capacity_num_bytes() const { return owner_->capacity_num_bytes(); } |
bool producer_open() const { return owner_->producer_open_no_lock(); } |
@@ -116,6 +133,29 @@ class MOJO_SYSTEM_IMPL_EXPORT DataPipeImpl { |
DISALLOW_COPY_AND_ASSIGN(DataPipeImpl); |
}; |
+// TODO(vtl): This is not the ideal place for the following structs; find |
+// somewhere better. |
+ |
+// Serialized form of a producer dispatcher. This will actually be followed by a |
+// serialized |ChannelEndpoint|; we want to preserve alignment guarantees. |
+struct ALIGNAS(8) SerializedDataPipeProducerDispatcher { |
+ // Only validated (and thus canonicalized) options should be serialized. |
+ // However, the deserializer must revalidate (as with everything received). |
+ MojoCreateDataPipeOptions validated_options; |
+ // Number of bytes already enqueued to the consumer. Set to |
+ // |static_cast<size_t>(-1)| if the consumer is already closed, in which case |
+ // this will *not* be followed by a serialized |ChannelEndpoint|. |
+ size_t consumer_num_bytes; |
+}; |
+ |
+// Serialized form of a consumer dispatcher. This will actually be followed by a |
+// serialized |ChannelEndpoint|; we want to preserve alignment guarantees. |
+struct ALIGNAS(8) SerializedDataPipeConsumerDispatcher { |
+ // Only validated (and thus canonicalized) options should be serialized. |
+ // However, the deserializer must revalidate (as with everything received). |
+ MojoCreateDataPipeOptions validated_options; |
+}; |
+ |
} // namespace system |
} // namespace mojo |