summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorrch@chromium.org <rch@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2012-04-16 18:06:11 +0000
committerrch@chromium.org <rch@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2012-04-16 18:06:11 +0000
commit6909932454f38eb563d8fee30bcc41994eeb8166 (patch)
tree3cff4c99cd14c0bc94e87bc8b9cb08e596ee7436
parent640565b41d381acd2b026823c2fde132b97dd80a (diff)
downloadchromium_src-6909932454f38eb563d8fee30bcc41994eeb8166.zip
chromium_src-6909932454f38eb563d8fee30bcc41994eeb8166.tar.gz
chromium_src-6909932454f38eb563d8fee30bcc41994eeb8166.tar.bz2
Factor out the code to write control and frame headers into a new constructors of SpdyFrameBuilder.
Remove unused empty SpdyFrameBuilder constructor. Review URL: http://codereview.chromium.org/10053029 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@132428 0039d316-1c4b-4281-b951-d872f2087c98
-rw-r--r--net/spdy/spdy_frame_builder.cc41
-rw-r--r--net/spdy/spdy_frame_builder.h14
-rw-r--r--net/spdy/spdy_framer.cc133
-rw-r--r--net/spdy/spdy_framer_test.cc31
4 files changed, 98 insertions, 121 deletions
diff --git a/net/spdy/spdy_frame_builder.cc b/net/spdy/spdy_frame_builder.cc
index a7a291e..1ff94f2 100644
--- a/net/spdy/spdy_frame_builder.cc
+++ b/net/spdy/spdy_frame_builder.cc
@@ -9,10 +9,49 @@
namespace net {
-SpdyFrameBuilder::SpdyFrameBuilder(size_t size)
+namespace {
+
+// Creates a FlagsAndLength.
+FlagsAndLength CreateFlagsAndLength(SpdyControlFlags flags, size_t length) {
+ DCHECK_EQ(0u, length & ~static_cast<size_t>(kLengthMask));
+ FlagsAndLength flags_length;
+ flags_length.length_ = htonl(static_cast<uint32>(length));
+ DCHECK_EQ(0, flags & ~kControlFlagsMask);
+ flags_length.flags_[0] = flags;
+ return flags_length;
+}
+
+} // namespace
+
+SpdyFrameBuilder::SpdyFrameBuilder(SpdyControlType type,
+ SpdyControlFlags flags,
+ int spdy_version,
+ size_t size)
+ : buffer_(new char[size]),
+ capacity_(size),
+ length_(0) {
+ FlagsAndLength flags_length = CreateFlagsAndLength(
+ flags, size - SpdyFrame::kHeaderSize);
+ WriteUInt16(kControlFlagMask | spdy_version);
+ WriteUInt16(type);
+ WriteBytes(&flags_length, sizeof(flags_length));
+}
+
+SpdyFrameBuilder::SpdyFrameBuilder(SpdyStreamId stream_id,
+ SpdyDataFlags flags,
+ size_t size)
: buffer_(new char[size]),
capacity_(size),
length_(0) {
+ DCHECK_EQ(0u, stream_id & ~kStreamIdMask);
+ WriteUInt32(stream_id);
+ size_t length = size - SpdyFrame::kHeaderSize;
+ DCHECK_EQ(0u, length & ~static_cast<size_t>(kLengthMask));
+ FlagsAndLength flags_length;
+ flags_length.length_ = htonl(length);
+ DCHECK_EQ(0, flags & ~kDataFlagsMask);
+ flags_length.flags_[0] = flags;
+ WriteBytes(&flags_length, sizeof(flags_length));
}
SpdyFrameBuilder::~SpdyFrameBuilder() {
diff --git a/net/spdy/spdy_frame_builder.h b/net/spdy/spdy_frame_builder.h
index 31d0211..ed7c78c 100644
--- a/net/spdy/spdy_frame_builder.h
+++ b/net/spdy/spdy_frame_builder.h
@@ -27,10 +27,16 @@ class NET_EXPORT_PRIVATE SpdyFrameBuilder {
public:
~SpdyFrameBuilder();
- SpdyFrameBuilder();
-
- // Initiailizes a SpdyFrameBuilder with a buffer of given size.
- explicit SpdyFrameBuilder(size_t size);
+ // Initializes a SpdyFrameBuilder with a buffer of given size,
+ // populate with a SPDY control frame header based
+ // on |type|, |flags|, and |spdy_version|.
+ SpdyFrameBuilder(SpdyControlType type, SpdyControlFlags flags,
+ int spdy_version, size_t size);
+
+ // Initiailizes a SpdyFrameBuilder with a buffer of given size,
+ // populated with a SPDY data frame header based on
+ // |stream_id| and |flags|.
+ SpdyFrameBuilder(SpdyStreamId stream_id, SpdyDataFlags flags, size_t size);
// Returns the size of the SpdyFrameBuilder's data.
int length() const { return length_; }
diff --git a/net/spdy/spdy_framer.cc b/net/spdy/spdy_framer.cc
index f9e6e69..a9edcf6 100644
--- a/net/spdy/spdy_framer.cc
+++ b/net/spdy/spdy_framer.cc
@@ -51,16 +51,6 @@ struct DictionaryIds {
// initialized lazily to avoid static initializers.
base::LazyInstance<DictionaryIds>::Leaky g_dictionary_ids;
-// Creates a FlagsAndLength.
-FlagsAndLength CreateFlagsAndLength(SpdyControlFlags flags, size_t length) {
- DCHECK_EQ(0u, length & ~static_cast<size_t>(kLengthMask));
- FlagsAndLength flags_length;
- flags_length.length_ = htonl(static_cast<uint32>(length));
- DCHECK_EQ(0, flags & ~kControlFlagsMask);
- flags_length.flags_[0] = flags;
- return flags_length;
-}
-
// By default is compression on or off.
bool g_enable_compression_default = true;
@@ -1072,18 +1062,10 @@ SpdySynStreamControlFrame* SpdyFramer::CreateSynStream(
DCHECK_EQ(0u, associated_stream_id & ~kStreamIdMask);
// Find our length.
- size_t expected_frame_size = SpdySynStreamControlFrame::size() +
- GetSerializedLength(headers);
-
- // Create our FlagsAndLength.
- FlagsAndLength flags_length = CreateFlagsAndLength(
- flags,
- expected_frame_size - SpdyFrame::kHeaderSize);
-
- SpdyFrameBuilder frame(expected_frame_size);
- frame.WriteUInt16(kControlFlagMask | spdy_version_);
- frame.WriteUInt16(SYN_STREAM);
- frame.WriteBytes(&flags_length, sizeof(flags_length));
+ size_t frame_size = SpdySynStreamControlFrame::size() +
+ GetSerializedLength(headers);
+
+ SpdyFrameBuilder frame(SYN_STREAM, flags, spdy_version_, frame_size);
frame.WriteUInt32(stream_id);
frame.WriteUInt32(associated_stream_id);
// Cap as appropriate.
@@ -1095,6 +1077,7 @@ SpdySynStreamControlFrame* SpdyFramer::CreateSynStream(
frame.WriteUInt8(priority << ((spdy_version_ < 3) ? 6 : 5));
frame.WriteUInt8((spdy_version_ < 3) ? 0 : credential_slot);
WriteHeaderBlock(&frame, headers);
+ DCHECK_EQ(static_cast<size_t>(frame.length()), frame_size);
scoped_ptr<SpdySynStreamControlFrame> syn_frame(
reinterpret_cast<SpdySynStreamControlFrame*>(frame.take()));
@@ -1114,27 +1097,20 @@ SpdySynReplyControlFrame* SpdyFramer::CreateSynReply(
DCHECK_EQ(0u, stream_id & ~kStreamIdMask);
// Find our length.
- size_t expected_frame_size = SpdySynReplyControlFrame::size() +
- GetSerializedLength(headers);
+ size_t frame_size = SpdySynReplyControlFrame::size() +
+ GetSerializedLength(headers);
// In SPDY 2, there were 2 unused bytes before payload.
if (spdy_version_ < 3) {
- expected_frame_size += 2;
+ frame_size += 2;
}
- // Create our FlagsAndLength.
- FlagsAndLength flags_length = CreateFlagsAndLength(
- flags,
- expected_frame_size - SpdyFrame::kHeaderSize);
-
- SpdyFrameBuilder frame(expected_frame_size);
- frame.WriteUInt16(kControlFlagMask | spdy_version_);
- frame.WriteUInt16(SYN_REPLY);
- frame.WriteBytes(&flags_length, sizeof(flags_length));
+ SpdyFrameBuilder frame(SYN_REPLY, flags, spdy_version_, frame_size);
frame.WriteUInt32(stream_id);
if (spdy_version_ < 3) {
frame.WriteUInt16(0); // Unused
}
WriteHeaderBlock(&frame, headers);
+ DCHECK_EQ(static_cast<size_t>(frame.length()), frame_size);
scoped_ptr<SpdySynReplyControlFrame> reply_frame(
reinterpret_cast<SpdySynReplyControlFrame*>(frame.take()));
@@ -1153,24 +1129,20 @@ SpdyRstStreamControlFrame* SpdyFramer::CreateRstStream(
DCHECK_NE(status, INVALID);
DCHECK_LT(status, NUM_STATUS_CODES);
- SpdyFrameBuilder frame(SpdyRstStreamControlFrame::size());
- frame.WriteUInt16(kControlFlagMask | spdy_version_);
- frame.WriteUInt16(RST_STREAM);
- frame.WriteUInt32(8);
+ size_t frame_size = SpdyRstStreamControlFrame::size();
+ SpdyFrameBuilder frame(RST_STREAM, CONTROL_FLAG_NONE, spdy_version_,
+ frame_size);
frame.WriteUInt32(stream_id);
frame.WriteUInt32(status);
+ DCHECK_EQ(static_cast<size_t>(frame.length()), frame_size);
return reinterpret_cast<SpdyRstStreamControlFrame*>(frame.take());
}
SpdySettingsControlFrame* SpdyFramer::CreateSettings(
const SpdySettings& values) const {
- SpdyFrameBuilder frame(SpdySettingsControlFrame::size() + 8 * values.size());
- frame.WriteUInt16(kControlFlagMask | spdy_version_);
- frame.WriteUInt16(SETTINGS);
- size_t settings_size =
- SpdySettingsControlFrame::size() - SpdyFrame::kHeaderSize +
- 8 * values.size();
- frame.WriteUInt32(settings_size);
+ size_t frame_size = SpdySettingsControlFrame::size() + 8 * values.size();
+ SpdyFrameBuilder frame(SETTINGS, CONTROL_FLAG_NONE, spdy_version_,
+ frame_size);
frame.WriteUInt32(values.size());
SpdySettings::const_iterator it = values.begin();
while (it != values.end()) {
@@ -1179,16 +1151,15 @@ SpdySettingsControlFrame* SpdyFramer::CreateSettings(
frame.WriteUInt32(it->second);
++it;
}
+ DCHECK_EQ(static_cast<size_t>(frame.length()), frame_size);
return reinterpret_cast<SpdySettingsControlFrame*>(frame.take());
}
SpdyPingControlFrame* SpdyFramer::CreatePingFrame(uint32 unique_id) const {
- SpdyFrameBuilder frame(SpdyPingControlFrame::size());
- frame.WriteUInt16(kControlFlagMask | spdy_version_);
- frame.WriteUInt16(PING);
- size_t ping_size = SpdyPingControlFrame::size() - SpdyFrame::kHeaderSize;
- frame.WriteUInt32(ping_size);
+ size_t frame_size = SpdyPingControlFrame::size();
+ SpdyFrameBuilder frame(PING, CONTROL_FLAG_NONE, spdy_version_, frame_size);
frame.WriteUInt32(unique_id);
+ DCHECK_EQ(static_cast<size_t>(frame.length()), frame_size);
return reinterpret_cast<SpdyPingControlFrame*>(frame.take());
}
@@ -1201,16 +1172,13 @@ SpdyGoAwayControlFrame* SpdyFramer::CreateGoAway(
// this difference via a separate offset variable, since
// SpdyGoAwayControlFrame::size() returns the SPDY 3 size.
const size_t goaway_offset = (protocol_version() < 3) ? 4 : 0;
- SpdyFrameBuilder frame(SpdyGoAwayControlFrame::size() - goaway_offset);
- frame.WriteUInt16(kControlFlagMask | spdy_version_);
- frame.WriteUInt16(GOAWAY);
- size_t go_away_size =
- SpdyGoAwayControlFrame::size() - SpdyFrame::kHeaderSize - goaway_offset;
- frame.WriteUInt32(go_away_size);
+ size_t frame_size = SpdyGoAwayControlFrame::size() - goaway_offset;
+ SpdyFrameBuilder frame(GOAWAY, CONTROL_FLAG_NONE, spdy_version_, frame_size);
frame.WriteUInt32(last_accepted_stream_id);
if (protocol_version() >= 3) {
frame.WriteUInt32(status);
}
+ DCHECK_EQ(static_cast<size_t>(frame.length()), frame_size);
return reinterpret_cast<SpdyGoAwayControlFrame*>(frame.take());
}
@@ -1224,28 +1192,20 @@ SpdyHeadersControlFrame* SpdyFramer::CreateHeaders(
DCHECK_EQ(0u, stream_id & ~kStreamIdMask);
// Find our length.
- size_t expected_frame_size = SpdyHeadersControlFrame::size() +
- GetSerializedLength(headers);
+ size_t frame_size = SpdyHeadersControlFrame::size() +
+ GetSerializedLength(headers);
// In SPDY 2, there were 2 unused bytes before payload.
if (spdy_version_ < 3) {
- expected_frame_size += 2;
+ frame_size += 2;
}
- // Create our FlagsAndLength.
- FlagsAndLength flags_length = CreateFlagsAndLength(
- flags,
- expected_frame_size - SpdyFrame::kHeaderSize);
-
- SpdyFrameBuilder frame(expected_frame_size);
- frame.WriteUInt16(kControlFlagMask | spdy_version_);
- frame.WriteUInt16(HEADERS);
- frame.WriteBytes(&flags_length, sizeof(flags_length));
+ SpdyFrameBuilder frame(HEADERS, flags, spdy_version_, frame_size);
frame.WriteUInt32(stream_id);
if (spdy_version_ < 3) {
frame.WriteUInt16(0); // Unused
}
WriteHeaderBlock(&frame, headers);
- DCHECK_EQ(static_cast<size_t>(frame.length()), expected_frame_size);
+ DCHECK_EQ(static_cast<size_t>(frame.length()), frame_size);
scoped_ptr<SpdyHeadersControlFrame> headers_frame(
reinterpret_cast<SpdyHeadersControlFrame*>(frame.take()));
@@ -1265,14 +1225,12 @@ SpdyWindowUpdateControlFrame* SpdyFramer::CreateWindowUpdate(
DCHECK_LE(delta_window_size,
static_cast<uint32>(kSpdyStreamMaximumWindowSize));
- SpdyFrameBuilder frame(SpdyWindowUpdateControlFrame::size());
- frame.WriteUInt16(kControlFlagMask | spdy_version_);
- frame.WriteUInt16(WINDOW_UPDATE);
- size_t window_update_size = SpdyWindowUpdateControlFrame::size() -
- SpdyFrame::kHeaderSize;
- frame.WriteUInt32(window_update_size);
+ size_t frame_size = SpdyWindowUpdateControlFrame::size();
+ SpdyFrameBuilder frame(WINDOW_UPDATE, CONTROL_FLAG_NONE, spdy_version_,
+ frame_size);
frame.WriteUInt32(stream_id);
frame.WriteUInt32(delta_window_size);
+ DCHECK_EQ(static_cast<size_t>(frame.length()), frame_size);
return reinterpret_cast<SpdyWindowUpdateControlFrame*>(frame.take());
}
@@ -1289,16 +1247,9 @@ SpdyCredentialControlFrame* SpdyFramer::CreateCredentialFrame(
frame_size += sizeof(uint32); // size of the cert_length field
frame_size += cert->length(); // size of the cert_data field
}
- size_t payload_size = frame_size - SpdyFrame::kHeaderSize;
- SpdyFrameBuilder frame(frame_size);
- // Create our FlagsAndLength.
- SpdyControlFlags flags = CONTROL_FLAG_NONE;
- FlagsAndLength flags_length = CreateFlagsAndLength(flags, payload_size);
-
- frame.WriteUInt16(kControlFlagMask | spdy_version_);
- frame.WriteUInt16(CREDENTIAL);
- frame.WriteBytes(&flags_length, sizeof(flags_length));
+ SpdyFrameBuilder frame(CREDENTIAL, CONTROL_FLAG_NONE, spdy_version_,
+ frame_size);
frame.WriteUInt16(credential.slot);
frame.WriteUInt32(credential.proof.size());
frame.WriteBytes(credential.proof.c_str(), credential.proof.size());
@@ -1308,6 +1259,7 @@ SpdyCredentialControlFrame* SpdyFramer::CreateCredentialFrame(
frame.WriteUInt32(cert->length());
frame.WriteBytes(cert->c_str(), cert->length());
}
+ DCHECK_EQ(static_cast<size_t>(frame.length()), frame_size);
return reinterpret_cast<SpdyCredentialControlFrame*>(frame.take());
}
@@ -1316,17 +1268,10 @@ SpdyDataFrame* SpdyFramer::CreateDataFrame(SpdyStreamId stream_id,
uint32 len, SpdyDataFlags flags) {
DCHECK_EQ(0u, stream_id & ~kStreamIdMask);
- SpdyFrameBuilder frame(SpdyDataFrame::size() + len);
- frame.WriteUInt32(stream_id);
-
- DCHECK_EQ(0u, len & ~static_cast<size_t>(kLengthMask));
- FlagsAndLength flags_length;
- flags_length.length_ = htonl(len);
- DCHECK_EQ(0, flags & ~kDataFlagsMask);
- flags_length.flags_[0] = flags;
- frame.WriteBytes(&flags_length, sizeof(flags_length));
-
+ size_t frame_size = SpdyDataFrame::size() + len;
+ SpdyFrameBuilder frame(stream_id, flags, frame_size);
frame.WriteBytes(data, len);
+ DCHECK_EQ(static_cast<size_t>(frame.length()), frame_size);
scoped_ptr<SpdyFrame> data_frame(frame.take());
SpdyDataFrame* rv;
if (flags & DATA_FLAG_COMPRESSED) {
diff --git a/net/spdy/spdy_framer_test.cc b/net/spdy/spdy_framer_test.cc
index 1cfa101..0040c0b 100644
--- a/net/spdy/spdy_framer_test.cc
+++ b/net/spdy/spdy_framer_test.cc
@@ -438,18 +438,14 @@ using test::SpdyFramerTestUtil;
using test::TestSpdyVisitor;
TEST(SpdyFrameBuilderTest, WriteLimits) {
- SpdyFrameBuilder builder(kLengthMask + 4);
- // length field should fail.
- EXPECT_FALSE(builder.WriteBytes(reinterpret_cast<const void*>(0x1),
- kLengthMask + 1));
- EXPECT_EQ(0, builder.length());
-
- // Writing a block of the maximum allowed size should succeed.
+ SpdyFrameBuilder builder(1, DATA_FLAG_NONE, kLengthMask + 8);
+ // Data frame header is 8 bytes
+ EXPECT_EQ(8, builder.length());
const std::string kLargeData(kLengthMask, 'A');
builder.WriteUInt32(kLengthMask);
- EXPECT_EQ(4, builder.length());
- EXPECT_TRUE(builder.WriteBytes(kLargeData.data(), kLengthMask));
- EXPECT_EQ(4 + kLengthMask, static_cast<unsigned>(builder.length()));
+ EXPECT_EQ(12, builder.length());
+ EXPECT_TRUE(builder.WriteBytes(kLargeData.data(), kLengthMask - 4));
+ EXPECT_EQ(kLengthMask + 8, static_cast<unsigned>(builder.length()));
}
enum SpdyFramerTestTypes {
@@ -581,11 +577,8 @@ TEST_P(SpdyFramerTest, UndersizedHeaderBlockInBuffer) {
TEST_P(SpdyFramerTest, OutOfOrderHeaders) {
// Frame builder with plentiful buffer size.
- SpdyFrameBuilder frame(1024);
+ SpdyFrameBuilder frame(SYN_STREAM, CONTROL_FLAG_NONE, 1, 1024);
- frame.WriteUInt16(kControlFlagMask | 1);
- frame.WriteUInt16(SYN_STREAM);
- frame.WriteUInt32(0); // Placeholder for the length.
frame.WriteUInt32(3); // stream_id
frame.WriteUInt32(0); // Associated stream id
frame.WriteUInt16(0); // Priority.
@@ -691,11 +684,8 @@ TEST_P(SpdyFramerTest, ParseCredentialFrameData) {
TEST_P(SpdyFramerTest, DuplicateHeader) {
// Frame builder with plentiful buffer size.
- SpdyFrameBuilder frame(1024);
+ SpdyFrameBuilder frame(SYN_STREAM, CONTROL_FLAG_NONE, 1, 1024);
- frame.WriteUInt16(kControlFlagMask | 1);
- frame.WriteUInt16(SYN_STREAM);
- frame.WriteUInt32(0); // Placeholder for the length.
frame.WriteUInt32(3); // stream_id
frame.WriteUInt32(0); // associated stream id
frame.WriteUInt16(0); // Priority.
@@ -731,11 +721,8 @@ TEST_P(SpdyFramerTest, DuplicateHeader) {
TEST_P(SpdyFramerTest, MultiValueHeader) {
// Frame builder with plentiful buffer size.
- SpdyFrameBuilder frame(1024);
+ SpdyFrameBuilder frame(SYN_STREAM, CONTROL_FLAG_NONE, 1, 1024);
- frame.WriteUInt16(kControlFlagMask | 1);
- frame.WriteUInt16(SYN_STREAM);
- frame.WriteUInt32(0); // Placeholder for the length.
frame.WriteUInt32(3); // stream_id
frame.WriteUInt32(0); // associated stream id
frame.WriteUInt16(0); // Priority.