| Index: net/spdy/spdy_protocol.h
|
| diff --git a/net/spdy/spdy_protocol.h b/net/spdy/spdy_protocol.h
|
| index 9696bf120890a04a4d62da8e126615b3797361ca..cc73977a686fe02675fa09fec3bde6c96125bdc3 100644
|
| --- a/net/spdy/spdy_protocol.h
|
| +++ b/net/spdy/spdy_protocol.h
|
| @@ -28,14 +28,15 @@ namespace net {
|
|
|
| // The major versions of SPDY. Major version differences indicate
|
| // framer-layer incompatibility, as opposed to minor version numbers
|
| -// which indicate application-layer incompatibility. It is guaranteed
|
| -// that the enum value SPDYn maps to the integer n.
|
| +// which indicate application-layer incompatibility. Do not rely on
|
| +// the mapping from enum value SPDYn to the integer n.
|
| enum SpdyMajorVersion {
|
| SPDY2 = 2,
|
| SPDY_MIN_VERSION = SPDY2,
|
| SPDY3 = 3,
|
| SPDY4 = 4,
|
| - SPDY_MAX_VERSION = SPDY4
|
| + SPDY5 = 5,
|
| + SPDY_MAX_VERSION = SPDY5
|
| };
|
|
|
| // A SPDY stream id is a 31 bit entity.
|
| @@ -360,6 +361,7 @@ enum SpdyRstStreamStatus {
|
| RST_STREAM_INVALID = 0,
|
| RST_STREAM_PROTOCOL_ERROR = 1,
|
| RST_STREAM_INVALID_STREAM = 2,
|
| + RST_STREAM_STREAM_CLOSED = 2, // Equivalent to INVALID_STREAM
|
| RST_STREAM_REFUSED_STREAM = 3,
|
| RST_STREAM_UNSUPPORTED_VERSION = 4,
|
| RST_STREAM_CANCEL = 5,
|
| @@ -368,17 +370,33 @@ enum SpdyRstStreamStatus {
|
| RST_STREAM_STREAM_IN_USE = 8,
|
| RST_STREAM_STREAM_ALREADY_CLOSED = 9,
|
| RST_STREAM_INVALID_CREDENTIALS = 10,
|
| + // FRAME_TOO_LARGE (defined by SPDY versions 3.1 and below), and
|
| + // FRAME_SIZE_ERROR (defined by HTTP/2) are mapped to the same internal
|
| + // reset status.
|
| RST_STREAM_FRAME_TOO_LARGE = 11,
|
| - RST_STREAM_NUM_STATUS_CODES = 12
|
| + RST_STREAM_FRAME_SIZE_ERROR = 11,
|
| + RST_STREAM_SETTINGS_TIMEOUT = 12,
|
| + RST_STREAM_CONNECT_ERROR = 13,
|
| + RST_STREAM_ENHANCE_YOUR_CALM = 14,
|
| + RST_STREAM_NUM_STATUS_CODES = 15
|
| };
|
|
|
| // Status codes for GOAWAY frames.
|
| enum SpdyGoAwayStatus {
|
| - GOAWAY_INVALID = -1,
|
| GOAWAY_OK = 0,
|
| + GOAWAY_NO_ERROR = GOAWAY_OK,
|
| GOAWAY_PROTOCOL_ERROR = 1,
|
| GOAWAY_INTERNAL_ERROR = 2,
|
| - GOAWAY_NUM_STATUS_CODES = 3 // Must be last.
|
| + GOAWAY_FLOW_CONTROL_ERROR = 3,
|
| + GOAWAY_SETTINGS_TIMEOUT = 4,
|
| + GOAWAY_STREAM_CLOSED = 5,
|
| + GOAWAY_FRAME_SIZE_ERROR = 6,
|
| + GOAWAY_REFUSED_STREAM = 7,
|
| + GOAWAY_CANCEL = 8,
|
| + GOAWAY_COMPRESSION_ERROR = 9,
|
| + GOAWAY_CONNECT_ERROR = 10,
|
| + GOAWAY_ENHANCE_YOUR_CALM = 11,
|
| + GOAWAY_INADEQUATE_SECURITY = 12
|
| };
|
|
|
| // A SPDY priority is a number between 0 and 7 (inclusive).
|
| @@ -426,6 +444,62 @@ class NET_EXPORT_PRIVATE SpdyConstants {
|
| // given protocol version.
|
| // Returns -1 on failure (I.E. Invalid setting id for the given version).
|
| static int SerializeSettingId(SpdyMajorVersion version, SpdySettingsIds id);
|
| +
|
| + // Returns true if a given on-the-wire enumeration of a RST_STREAM status code
|
| + // is valid for a given protocol version, false otherwise.
|
| + static bool IsValidRstStreamStatus(SpdyMajorVersion version,
|
| + int rst_stream_status_field);
|
| +
|
| + // Parses a RST_STREAM status code from an on-the-wire enumeration of a given
|
| + // protocol version.
|
| + // Behavior is undefined for invalid RST_STREAM status code fields; consumers
|
| + // should first use IsValidRstStreamStatus() to verify validity of RST_STREAM
|
| + // status code fields..
|
| + static SpdyRstStreamStatus ParseRstStreamStatus(SpdyMajorVersion version,
|
| + int rst_stream_status_field);
|
| +
|
| + // Serializes a given RST_STREAM status code to the on-the-wire enumeration
|
| + // value for the given protocol version.
|
| + // Returns -1 on failure (I.E. Invalid RST_STREAM status code for the given
|
| + // version).
|
| + static int SerializeRstStreamStatus(SpdyMajorVersion version,
|
| + SpdyRstStreamStatus rst_stream_status);
|
| +
|
| + // Returns true if a given on-the-wire enumeration of a GOAWAY status code is
|
| + // valid for the given protocol version, false otherwise.
|
| + static bool IsValidGoAwayStatus(SpdyMajorVersion version,
|
| + int goaway_status_field);
|
| +
|
| + // Parses a GOAWAY status from an on-the-wire enumeration of a given protocol
|
| + // version.
|
| + // Behavior is undefined for invalid GOAWAY status fields; consumers should
|
| + // first use IsValidGoAwayStatus() to verify validity of GOAWAY status fields.
|
| + static SpdyGoAwayStatus ParseGoAwayStatus(SpdyMajorVersion version,
|
| + int goaway_status_field);
|
| +
|
| + // Serializes a given GOAWAY status to the on-the-wire enumeration value for
|
| + // the given protocol version.
|
| + // Returns -1 on failure (I.E. Invalid GOAWAY status for the given version).
|
| + static int SerializeGoAwayStatus(SpdyMajorVersion version,
|
| + SpdyGoAwayStatus status);
|
| +
|
| + // Size, in bytes, of the data frame header. Future versions of SPDY
|
| + // will likely vary this, so we allow for the flexibility of a function call
|
| + // for this value as opposed to a constant.
|
| + static size_t GetDataFrameMinimumSize();
|
| +
|
| + // Size, in bytes, of the control frame header.
|
| + static size_t GetControlFrameHeaderSize(SpdyMajorVersion version);
|
| +
|
| + static size_t GetPrefixLength(SpdyFrameType type, SpdyMajorVersion version);
|
| +
|
| + static size_t GetFrameMaximumSize(SpdyMajorVersion version);
|
| +
|
| + static SpdyMajorVersion ParseMajorVersion(int version_number);
|
| +
|
| + static int SerializeMajorVersion(SpdyMajorVersion version);
|
| +
|
| + static std::string GetVersionString(SpdyMajorVersion version);
|
| };
|
|
|
| class SpdyFrame;
|
| @@ -636,8 +710,6 @@ class NET_EXPORT_PRIVATE SpdyRstStreamIR : public SpdyFrameWithStreamIdIR {
|
| return status_;
|
| }
|
| void set_status(SpdyRstStreamStatus status) {
|
| - DCHECK_NE(status, RST_STREAM_INVALID);
|
| - DCHECK_LT(status, RST_STREAM_NUM_STATUS_CODES);
|
| status_ = status;
|
| }
|
|
|
|
|