diff options
author | Vijay Pai <vpai@google.com> | 2015-02-06 13:35:33 -0800 |
---|---|---|
committer | Vijay Pai <vpai@google.com> | 2015-02-06 13:35:33 -0800 |
commit | 8a7424ad90c4ad07a909de73d2575083d44274ca (patch) | |
tree | b3391ecba34997a286c7a0932b3fe57007c15a1e | |
parent | f2d5e409d3b75fbe2a79440c8f7283420b4b9157 (diff) | |
parent | 62d424a1a4ce55a66a7565795db17ff898bc05f5 (diff) |
Merge pull request #384 from ctiller/buffer
Autohinting for write buffering
-rw-r--r-- | src/core/surface/call.c | 37 |
1 files changed, 28 insertions, 9 deletions
diff --git a/src/core/surface/call.c b/src/core/surface/call.c index c68ce5a6a8..0af524cead 100644 --- a/src/core/surface/call.c +++ b/src/core/surface/call.c @@ -54,7 +54,9 @@ typedef enum { REQ_INITIAL = 0, REQ_READY, REQ_DONE } req_state; typedef enum { SEND_NOTHING, SEND_INITIAL_METADATA, + SEND_BUFFERED_INITIAL_METADATA, SEND_MESSAGE, + SEND_BUFFERED_MESSAGE, SEND_TRAILING_METADATA_AND_FINISH, SEND_FINISH } send_action; @@ -500,19 +502,29 @@ static send_action choose_send_action(grpc_call *call) { case WRITE_STATE_INITIAL: if (is_op_live(call, GRPC_IOREQ_SEND_INITIAL_METADATA)) { call->write_state = WRITE_STATE_STARTED; - return SEND_INITIAL_METADATA; + if (is_op_live(call, GRPC_IOREQ_SEND_MESSAGE) || is_op_live(call, GRPC_IOREQ_SEND_CLOSE)) { + return SEND_BUFFERED_INITIAL_METADATA; + } else { + return SEND_INITIAL_METADATA; + } } return SEND_NOTHING; case WRITE_STATE_STARTED: if (is_op_live(call, GRPC_IOREQ_SEND_MESSAGE)) { - return SEND_MESSAGE; - } - if (is_op_live(call, GRPC_IOREQ_SEND_CLOSE)) { + if (is_op_live(call, GRPC_IOREQ_SEND_CLOSE)) { + return SEND_BUFFERED_MESSAGE; + } else { + return SEND_MESSAGE; + } + } else if (is_op_live(call, GRPC_IOREQ_SEND_CLOSE)) { call->write_state = WRITE_STATE_WRITE_CLOSED; finish_ioreq_op(call, GRPC_IOREQ_SEND_TRAILING_METADATA, GRPC_OP_OK); finish_ioreq_op(call, GRPC_IOREQ_SEND_STATUS, GRPC_OP_OK); - return call->is_client ? SEND_FINISH - : SEND_TRAILING_METADATA_AND_FINISH; + if (call->is_client) { + return SEND_FINISH; + } else { + return SEND_TRAILING_METADATA_AND_FINISH; + } } return SEND_NOTHING; case WRITE_STATE_WRITE_CLOSED: @@ -527,7 +539,7 @@ static void send_metadata(grpc_call *call, grpc_mdelem *elem) { grpc_call_op op; op.type = GRPC_SEND_METADATA; op.dir = GRPC_CALL_DOWN; - op.flags = 0; + op.flags = GRPC_WRITE_BUFFER_HINT; op.data.metadata = elem; op.done_cb = do_nothing; op.user_data = NULL; @@ -538,12 +550,16 @@ static void enact_send_action(grpc_call *call, send_action sa) { grpc_ioreq_data data; grpc_call_op op; size_t i; + gpr_uint32 flags = 0; char status_str[GPR_LTOA_MIN_BUFSIZE]; switch (sa) { case SEND_NOTHING: abort(); break; + case SEND_BUFFERED_INITIAL_METADATA: + flags |= GRPC_WRITE_BUFFER_HINT; + /* fallthrough */ case SEND_INITIAL_METADATA: data = call->request_data[GRPC_IOREQ_SEND_INITIAL_METADATA]; for (i = 0; i < data.send_metadata.count; i++) { @@ -555,17 +571,20 @@ static void enact_send_action(grpc_call *call, send_action sa) { } op.type = GRPC_SEND_START; op.dir = GRPC_CALL_DOWN; - op.flags = 0; + op.flags = flags; op.data.start.pollset = grpc_cq_pollset(call->cq); op.done_cb = finish_start_step; op.user_data = call; grpc_call_execute_op(call, &op); break; + case SEND_BUFFERED_MESSAGE: + flags |= GRPC_WRITE_BUFFER_HINT; + /* fallthrough */ case SEND_MESSAGE: data = call->request_data[GRPC_IOREQ_SEND_MESSAGE]; op.type = GRPC_SEND_MESSAGE; op.dir = GRPC_CALL_DOWN; - op.flags = 0; + op.flags = flags; op.data.message = data.send_message; op.done_cb = finish_write_step; op.user_data = call; |