diff options
author | Yang Gao <yangg@google.com> | 2015-05-04 12:48:48 -0700 |
---|---|---|
committer | Yang Gao <yangg@google.com> | 2015-05-04 12:48:48 -0700 |
commit | 7164eea295d5620f61f013f8a32160dbb9eb0b74 (patch) | |
tree | 005abf39dc9635eb5e668c2a2568785cb2680cfb /src/core/transport/chttp2_transport.c | |
parent | c112d146a2dcc5e90d5f5cca10f55f212f9492c6 (diff) | |
parent | 434a36bf4ad4ce5a46bf2c59389b437126faa358 (diff) |
Merge pull request #1463 from ctiller/seqno
Fix a typo that resulted in truncating incoming sequence numbers to 24 bits
Diffstat (limited to 'src/core/transport/chttp2_transport.c')
-rw-r--r-- | src/core/transport/chttp2_transport.c | 15 |
1 files changed, 14 insertions, 1 deletions
diff --git a/src/core/transport/chttp2_transport.c b/src/core/transport/chttp2_transport.c index 97e6bae4bb..46bed36ac4 100644 --- a/src/core/transport/chttp2_transport.c +++ b/src/core/transport/chttp2_transport.c @@ -538,6 +538,19 @@ static void init_transport(transport *t, grpc_transport_setup_callback setup, push_setting(t, GRPC_CHTTP2_SETTINGS_MAX_CONCURRENT_STREAMS, channel_args->args[i].value.integer); } + } else if (0 == strcmp(channel_args->args[i].key, + GRPC_ARG_HTTP2_INITIAL_SEQUENCE_NUMBER)) { + if (channel_args->args[i].type != GRPC_ARG_INTEGER) { + gpr_log(GPR_ERROR, "%s: must be an integer", + GRPC_ARG_HTTP2_INITIAL_SEQUENCE_NUMBER); + } else if ((t->next_stream_id & 1) != + (channel_args->args[i].value.integer & 1)) { + gpr_log(GPR_ERROR, "%s: low bit must be %d on %s", + GRPC_ARG_HTTP2_INITIAL_SEQUENCE_NUMBER, t->next_stream_id & 1, + t->is_client ? "client" : "server"); + } else { + t->next_stream_id = channel_args->args[i].value.integer; + } } } } @@ -1783,7 +1796,7 @@ static int process_read(transport *t, gpr_slice slice) { /* fallthrough */ case DTS_FH_5: GPR_ASSERT(cur < end); - t->incoming_stream_id = (((gpr_uint32)*cur) << 24) & 0x7f; + t->incoming_stream_id = (((gpr_uint32)*cur) & 0x7f) << 24; if (++cur == end) { t->deframe_state = DTS_FH_6; return 1; |