diff options
-rw-r--r-- | net/flip/flip_framer.cc | 16 | ||||
-rw-r--r-- | net/flip/flip_protocol.h | 65 |
2 files changed, 49 insertions, 32 deletions
diff --git a/net/flip/flip_framer.cc b/net/flip/flip_framer.cc index e1760a4..dba9574 100644 --- a/net/flip/flip_framer.cc +++ b/net/flip/flip_framer.cc @@ -14,7 +14,7 @@ namespace flip { // The initial size of the control frame buffer; this is used internally -// as we we parse though control frames. +// as we parse through control frames. static const size_t kControlFrameBufferInitialSize = 32 * 1024; // The maximum size of the control frame buffer that we support. // TODO(mbelshe): We should make this stream-based so there are no limits. @@ -240,9 +240,9 @@ size_t FlipFramer::ProcessCommonHeader(const char* data, size_t len) { } void FlipFramer::ProcessControlFrameHeader() { - FlipControlFrame current_control_frame(current_frame_buffer_, false); DCHECK_EQ(FLIP_NO_ERROR, error_code_); DCHECK_LE(FlipFrame::size(), current_frame_len_); + FlipControlFrame current_control_frame(current_frame_buffer_, false); // Do some sanity checking on the control frame sizes. switch (current_control_frame.type()) { case SYN_STREAM: @@ -261,7 +261,7 @@ void FlipFramer::ProcessControlFrameHeader() { set_error(FLIP_INVALID_CONTROL_FRAME); break; case NOOP: - // NOP. Swallow it. + // NOOP. Swallow it. CHANGE_STATE(FLIP_AUTO_RESET); return; default: @@ -340,7 +340,7 @@ size_t FlipFramer::ProcessDataFramePayload(const char* data, size_t len) { int rv = inflate(decompressor_.get(), Z_SYNC_FLUSH); if (rv != Z_OK) { set_error(FLIP_DECOMPRESS_FAILURE); - goto bottom; + return 0; } size_t decompressed_size = decompressed_max_size - decompressor_->avail_out; @@ -371,8 +371,6 @@ size_t FlipFramer::ProcessDataFramePayload(const char* data, size_t len) { } else { CHANGE_STATE(FLIP_AUTO_RESET); } - - bottom: return original_len - len; } @@ -458,9 +456,10 @@ FlipSynStreamControlFrame* FlipFramer::CreateSynStream( frame.WriteBytesToOffset(4, &flags_length, sizeof(flags_length)); scoped_ptr<FlipFrame> syn_frame(frame.take()); - if (compressed) + if (compressed) { return reinterpret_cast<FlipSynStreamControlFrame*>( CompressFrame(syn_frame.get())); + } return reinterpret_cast<FlipSynStreamControlFrame*>(syn_frame.release()); } @@ -504,9 +503,10 @@ FlipSynReplyControlFrame* FlipFramer::CreateSynReply(FlipStreamId stream_id, frame.WriteBytesToOffset(4, &flags_length, sizeof(flags_length)); scoped_ptr<FlipFrame> reply_frame(frame.take()); - if (compressed) + if (compressed) { return reinterpret_cast<FlipSynReplyControlFrame*>( CompressFrame(reply_frame.get())); + } return reinterpret_cast<FlipSynReplyControlFrame*>(reply_frame.release()); } diff --git a/net/flip/flip_protocol.h b/net/flip/flip_protocol.h index 7c0c659..fb82ba6 100644 --- a/net/flip/flip_protocol.h +++ b/net/flip/flip_protocol.h @@ -130,7 +130,7 @@ union FlagsAndLength { uint32 length_; // 24 bits }; -// The basic FLIP Frame. +// The basic FLIP Frame structure. struct FlipFrameBlock { union { struct { @@ -144,23 +144,23 @@ struct FlipFrameBlock { FlagsAndLength flags_length_; }; -// A Control Frame. +// A Control Frame structure. struct FlipControlFrameBlock : FlipFrameBlock { FlipStreamId stream_id_; }; -// A SYN_STREAM Control Frame. +// A SYN_STREAM Control Frame structure. struct FlipSynStreamControlFrameBlock : FlipControlFrameBlock { uint8 priority_; uint8 unused_; }; -// A SYN_REPLY Control Frame. +// A SYN_REPLY Control Frame structure. struct FlipSynReplyControlFrameBlock : FlipControlFrameBlock { uint16 unused_; }; -// A FNI_STREAM Control Frame. +// A FNI_STREAM Control Frame structure. struct FlipFinStreamControlFrameBlock : FlipControlFrameBlock { uint32 status_; }; @@ -174,7 +174,7 @@ struct FlipFinStreamControlFrameBlock : FlipControlFrameBlock { class FlipFrame { public: // Create a FlipFrame for a given sized buffer. - explicit FlipFrame(size_t size) : frame_(NULL), needs_delete_(true) { + explicit FlipFrame(size_t size) : frame_(NULL), owns_buffer_(true) { DCHECK_GE(size, sizeof(struct FlipFrameBlock)); char* buffer = new char[size]; memset(buffer, 0, size); @@ -182,27 +182,28 @@ class FlipFrame { } // Create a FlipFrame using a pre-created buffer. - // If |needs_delete| is true, this class takes ownership of the buffer + // If |owns_buffer| is true, this class takes ownership of the buffer // and will delete it on cleanup. The buffer must have been created using // new char[]. - // If |needs_delete| is false, the caller retains ownership - // of the buffer and will keep the buffer alive longer than |this|. In other + // If |owns_buffer| is false, the caller retains ownership of the buffer and + // is responsible for making sure the buffer outlives this frame. In other // words, this class does NOT create a copy of the buffer. - FlipFrame(char* data, bool needs_delete) + FlipFrame(char* data, bool owns_buffer) : frame_(reinterpret_cast<struct FlipFrameBlock*>(data)), - needs_delete_(needs_delete) { + owns_buffer_(owns_buffer) { DCHECK(frame_); } virtual ~FlipFrame() { - if (needs_delete_) { + if (owns_buffer_) { char* buffer = reinterpret_cast<char*>(frame_); delete [] buffer; } frame_ = NULL; } - // Provide access to the frame bytes + // Provides access to the frame bytes, which is a buffer containing + // the frame packed as expected for sending over the wire. char* data() const { return reinterpret_cast<char*>(frame_); } uint8 flags() const { return frame_->flags_length_.flags_[0]; } @@ -223,13 +224,18 @@ class FlipFrame { kControlFlagMask; } + // Returns the size of the FlipFrameBlock structure. + // Note: this is not the size of the FlipFrame class. + // Every FlipFrame* class has a static size() method for accessing + // the size of the data structure which will be sent over the wire. + // Note: this is not the same as sizeof(FlipFrame). static size_t size() { return sizeof(struct FlipFrameBlock); } protected: FlipFrameBlock* frame_; private: - bool needs_delete_; + bool owns_buffer_; DISALLOW_COPY_AND_ASSIGN(FlipFrame); }; @@ -237,8 +243,8 @@ class FlipFrame { class FlipDataFrame : public FlipFrame { public: FlipDataFrame() : FlipFrame(size()) {} - FlipDataFrame(char* data, bool needs_delete) - : FlipFrame(data, needs_delete) {} + FlipDataFrame(char* data, bool owns_buffer) + : FlipFrame(data, owns_buffer) {} virtual ~FlipDataFrame() {} FlipStreamId stream_id() const { @@ -253,7 +259,10 @@ class FlipDataFrame : public FlipFrame { frame_->data_.stream_id_ = htonl(id & kStreamIdMask); } + // Returns the size of the FlipFrameBlock structure. + // Note: this is not the size of the FlipDataFrame class. static size_t size() { return FlipFrame::size(); } + private: DISALLOW_COPY_AND_ASSIGN(FlipDataFrame); }; @@ -262,8 +271,8 @@ class FlipDataFrame : public FlipFrame { class FlipControlFrame : public FlipFrame { public: explicit FlipControlFrame(size_t size) : FlipFrame(size) {} - FlipControlFrame(char* data, bool needs_delete) - : FlipFrame(data, needs_delete) {} + FlipControlFrame(char* data, bool owns_buffer) + : FlipFrame(data, owns_buffer) {} virtual ~FlipControlFrame() {} uint16 version() const { @@ -283,6 +292,8 @@ class FlipControlFrame : public FlipFrame { block()->stream_id_ = htonl(id & kStreamIdMask); } + // Returns the size of the FlipControlFrameBlock structure. + // Note: this is not the size of the FlipControlFrame class. static size_t size() { return sizeof(FlipControlFrameBlock); } private: @@ -296,8 +307,8 @@ class FlipControlFrame : public FlipFrame { class FlipSynStreamControlFrame : public FlipControlFrame { public: FlipSynStreamControlFrame() : FlipControlFrame(size()) {} - FlipSynStreamControlFrame(char* data, bool needs_delete) - : FlipControlFrame(data, needs_delete) {} + FlipSynStreamControlFrame(char* data, bool owns_buffer) + : FlipControlFrame(data, owns_buffer) {} virtual ~FlipSynStreamControlFrame() {} uint8 priority() const { return (block()->priority_ & kPriorityMask) >> 6; } @@ -311,6 +322,8 @@ class FlipSynStreamControlFrame : public FlipControlFrame { return reinterpret_cast<const char*>(block()) + size(); } + // Returns the size of the FlipSynStreamControlFrameBlock structure. + // Note: this is not the size of the FlipSynStreamControlFrame class. static size_t size() { return sizeof(FlipSynStreamControlFrameBlock); } private: @@ -324,8 +337,8 @@ class FlipSynStreamControlFrame : public FlipControlFrame { class FlipSynReplyControlFrame : public FlipControlFrame { public: FlipSynReplyControlFrame() : FlipControlFrame(size()) {} - FlipSynReplyControlFrame(char* data, bool needs_delete) - : FlipControlFrame(data, needs_delete) {} + FlipSynReplyControlFrame(char* data, bool owns_buffer) + : FlipControlFrame(data, owns_buffer) {} virtual ~FlipSynReplyControlFrame() {} int header_block_len() const { @@ -336,6 +349,8 @@ class FlipSynReplyControlFrame : public FlipControlFrame { return reinterpret_cast<const char*>(block()) + size(); } + // Returns the size of the FlipSynReplyControlFrameBlock structure. + // Note: this is not the size of the FlipSynReplyControlFrame class. static size_t size() { return sizeof(FlipSynReplyControlFrameBlock); } private: @@ -349,13 +364,15 @@ class FlipSynReplyControlFrame : public FlipControlFrame { class FlipFinStreamControlFrame : public FlipControlFrame { public: FlipFinStreamControlFrame() : FlipControlFrame(size()) {} - FlipFinStreamControlFrame(char* data, bool needs_delete) - : FlipControlFrame(data, needs_delete) {} + FlipFinStreamControlFrame(char* data, bool owns_buffer) + : FlipControlFrame(data, owns_buffer) {} virtual ~FlipFinStreamControlFrame() {} uint32 status() const { return ntohl(block()->status_); } void set_status(uint32 status) { block()->status_ = htonl(status); } + // Returns the size of the FlipFinStreamControlFrameBlock structure. + // Note: this is not the size of the FlipFinStreamControlFrame class. static size_t size() { return sizeof(FlipFinStreamControlFrameBlock); } private: |