aboutsummaryrefslogtreecommitdiffhomepage
path: root/src/core/ext/transport
diff options
context:
space:
mode:
authorGravatar Makarand Dharmapurikar <makarandd@google.com>2016-08-10 14:53:40 -0700
committerGravatar Makarand Dharmapurikar <makarandd@google.com>2016-08-10 14:53:40 -0700
commit35da822b442a60d5e9d0711cc046f9c578d63ad9 (patch)
tree27765f724cdf728d9d7770d92050a1343b624417 /src/core/ext/transport
parent198f8b01946ac107700958ac6c2ea11ed523f2a5 (diff)
WIP
Diffstat (limited to 'src/core/ext/transport')
-rw-r--r--src/core/ext/transport/cronet/transport/cronet_transport.c7
1 files changed, 4 insertions, 3 deletions
diff --git a/src/core/ext/transport/cronet/transport/cronet_transport.c b/src/core/ext/transport/cronet/transport/cronet_transport.c
index dc6a780eda..7e65def4de 100644
--- a/src/core/ext/transport/cronet/transport/cronet_transport.c
+++ b/src/core/ext/transport/cronet/transport/cronet_transport.c
@@ -280,7 +280,7 @@ static void on_succeeded(cronet_bidirectional_stream *stream) {
CRONET_LOG(GPR_DEBUG, "on_succeeded(%p)", stream);
stream_obj *s = (stream_obj *)stream->annotation;
cronet_bidirectional_stream_destroy(s->cbs);
- s->state.state_callback_received[OP_FAILED] = true;
+ s->state.state_callback_received[OP_SUCCEEDED] = true;
s->cbs = NULL;
execute_from_storage(s);
}
@@ -480,8 +480,8 @@ static bool op_can_be_run(grpc_transport_stream_op *curr_op, struct op_state *st
// we haven't received headers yet.
else if (!stream_state->state_callback_received[OP_RECV_INITIAL_METADATA]) result = false;
} else if (op_id == OP_SEND_MESSAGE) {
- // already executed
- if (stream_state->state_op_done[OP_SEND_MESSAGE]) result = false;
+ // already executed (note we're checking op specific state, not stream state)
+ if (op_state->state_op_done[OP_SEND_MESSAGE]) result = false;
// we haven't sent headers yet.
else if (!stream_state->state_callback_received[OP_SEND_INITIAL_METADATA]) result = false;
} else if (op_id == OP_RECV_MESSAGE) {
@@ -599,6 +599,7 @@ static enum OP_RESULT execute_stream_op(struct op_and_state *oas) {
result = ACTION_TAKEN_WITH_CALLBACK;
}
stream_state->state_op_done[OP_SEND_MESSAGE] = true;
+ oas->state.state_op_done[OP_SEND_MESSAGE] = true;
} else if (stream_op->recv_message && op_can_be_run(stream_op, stream_state, &oas->state, OP_RECV_MESSAGE)) {
CRONET_LOG(GPR_DEBUG, "running: %p OP_RECV_MESSAGE", oas);
if (stream_state->state_op_done[OP_CANCEL_ERROR]) {