|  | @@ -61,8 +61,6 @@
 | 
											
												
													
														|  |  /* TODO (makdharma): Hook up into the wider tracing mechanism */
 |  |  /* TODO (makdharma): Hook up into the wider tracing mechanism */
 | 
											
												
													
														|  |  int grpc_cronet_trace = 0;
 |  |  int grpc_cronet_trace = 0;
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -extern bool grpc_cronet_packet_coalescing_enabled;
 |  | 
 | 
											
												
													
														|  | -
 |  | 
 | 
											
												
													
														|  |  enum e_op_result {
 |  |  enum e_op_result {
 | 
											
												
													
														|  |    ACTION_TAKEN_WITH_CALLBACK,
 |  |    ACTION_TAKEN_WITH_CALLBACK,
 | 
											
												
													
														|  |    ACTION_TAKEN_NO_CALLBACK,
 |  |    ACTION_TAKEN_NO_CALLBACK,
 | 
											
										
											
												
													
														|  | @@ -152,13 +150,12 @@ struct op_state {
 | 
											
												
													
														|  |    bool state_callback_received[OP_NUM_OPS];
 |  |    bool state_callback_received[OP_NUM_OPS];
 | 
											
												
													
														|  |    bool fail_state;
 |  |    bool fail_state;
 | 
											
												
													
														|  |    bool flush_read;
 |  |    bool flush_read;
 | 
											
												
													
														|  | 
 |  | +#ifdef GRPC_CRONET_WITH_PACKET_COALESCING
 | 
											
												
													
														|  |    bool flush_cronet_when_ready;
 |  |    bool flush_cronet_when_ready;
 | 
											
												
													
														|  |    bool pending_write_for_trailer;
 |  |    bool pending_write_for_trailer;
 | 
											
												
													
														|  | 
 |  | +#endif
 | 
											
												
													
														|  |    bool unprocessed_send_message;
 |  |    bool unprocessed_send_message;
 | 
											
												
													
														|  |    grpc_error *cancel_error;
 |  |    grpc_error *cancel_error;
 | 
											
												
													
														|  | -
 |  | 
 | 
											
												
													
														|  | -  /* Whether packet coalescing is enabled */
 |  | 
 | 
											
												
													
														|  | -  bool packet_coalescing_enabled;
 |  | 
 | 
											
												
													
														|  |    /* data structure for storing data coming from server */
 |  |    /* data structure for storing data coming from server */
 | 
											
												
													
														|  |    struct read_state rs;
 |  |    struct read_state rs;
 | 
											
												
													
														|  |    /* data structure for storing data going to the server */
 |  |    /* data structure for storing data going to the server */
 | 
											
										
											
												
													
														|  | @@ -428,10 +425,12 @@ static void on_stream_ready(bidirectional_stream *stream) {
 | 
											
												
													
														|  |    }
 |  |    }
 | 
											
												
													
														|  |  /* Send the initial metadata on wire if there is no SEND_MESSAGE or
 |  |  /* Send the initial metadata on wire if there is no SEND_MESSAGE or
 | 
											
												
													
														|  |   * SEND_TRAILING_METADATA ops pending */
 |  |   * SEND_TRAILING_METADATA ops pending */
 | 
											
												
													
														|  | -  if (s->state.packet_coalescing_enabled && s->state.flush_cronet_when_ready) {
 |  | 
 | 
											
												
													
														|  | 
 |  | +#ifdef GRPC_CRONET_WITH_PACKET_COALESCING
 | 
											
												
													
														|  | 
 |  | +  if (s->state.flush_cronet_when_ready) {
 | 
											
												
													
														|  |      CRONET_LOG(GPR_DEBUG, "cronet_bidirectional_stream_flush (%p)", s->cbs);
 |  |      CRONET_LOG(GPR_DEBUG, "cronet_bidirectional_stream_flush (%p)", s->cbs);
 | 
											
												
													
														|  |      bidirectional_stream_flush(stream);
 |  |      bidirectional_stream_flush(stream);
 | 
											
												
													
														|  |    }
 |  |    }
 | 
											
												
													
														|  | 
 |  | +#endif
 | 
											
												
													
														|  |    gpr_mu_unlock(&s->mu);
 |  |    gpr_mu_unlock(&s->mu);
 | 
											
												
													
														|  |    execute_from_storage(s);
 |  |    execute_from_storage(s);
 | 
											
												
													
														|  |  }
 |  |  }
 | 
											
										
											
												
													
														|  | @@ -569,10 +568,10 @@ static void on_response_trailers_received(
 | 
											
												
													
														|  |      CRONET_LOG(GPR_DEBUG, "bidirectional_stream_write (%p, 0)", s->cbs);
 |  |      CRONET_LOG(GPR_DEBUG, "bidirectional_stream_write (%p, 0)", s->cbs);
 | 
											
												
													
														|  |      s->state.state_callback_received[OP_SEND_MESSAGE] = false;
 |  |      s->state.state_callback_received[OP_SEND_MESSAGE] = false;
 | 
											
												
													
														|  |      bidirectional_stream_write(s->cbs, "", 0, true);
 |  |      bidirectional_stream_write(s->cbs, "", 0, true);
 | 
											
												
													
														|  | -    if (s->state.packet_coalescing_enabled) {
 |  | 
 | 
											
												
													
														|  | -      CRONET_LOG(GPR_DEBUG, "bidirectional_stream_flush (%p)", s->cbs);
 |  | 
 | 
											
												
													
														|  | -      bidirectional_stream_flush(s->cbs);
 |  | 
 | 
											
												
													
														|  | -    }
 |  | 
 | 
											
												
													
														|  | 
 |  | +#ifdef GRPC_CRONET_WITH_PACKET_COALESCING
 | 
											
												
													
														|  | 
 |  | +    CRONET_LOG(GPR_DEBUG, "bidirectional_stream_flush (%p)", s->cbs);
 | 
											
												
													
														|  | 
 |  | +    bidirectional_stream_flush(s->cbs);
 | 
											
												
													
														|  | 
 |  | +#endif
 | 
											
												
													
														|  |      s->state.state_op_done[OP_SEND_TRAILING_METADATA] = true;
 |  |      s->state.state_op_done[OP_SEND_TRAILING_METADATA] = true;
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |      gpr_mu_unlock(&s->mu);
 |  |      gpr_mu_unlock(&s->mu);
 | 
											
										
											
												
													
														|  | @@ -769,9 +768,11 @@ static bool op_can_be_run(grpc_transport_stream_op *curr_op,
 | 
											
												
													
														|  |        result = false;
 |  |        result = false;
 | 
											
												
													
														|  |      /* we haven't got on_write_completed for the send yet */
 |  |      /* we haven't got on_write_completed for the send yet */
 | 
											
												
													
														|  |      else if (stream_state->state_op_done[OP_SEND_MESSAGE] &&
 |  |      else if (stream_state->state_op_done[OP_SEND_MESSAGE] &&
 | 
											
												
													
														|  | -             !stream_state->state_callback_received[OP_SEND_MESSAGE] &&
 |  | 
 | 
											
												
													
														|  | -             !(stream_state->packet_coalescing_enabled &&
 |  | 
 | 
											
												
													
														|  | -               stream_state->pending_write_for_trailer))
 |  | 
 | 
											
												
													
														|  | 
 |  | +             !stream_state->state_callback_received[OP_SEND_MESSAGE]
 | 
											
												
													
														|  | 
 |  | +#ifdef GRPC_CRONET_WITH_PACKET_COALESCING
 | 
											
												
													
														|  | 
 |  | +             && !stream_state->pending_write_for_trailer
 | 
											
												
													
														|  | 
 |  | +#endif
 | 
											
												
													
														|  | 
 |  | +             )
 | 
											
												
													
														|  |        result = false;
 |  |        result = false;
 | 
											
												
													
														|  |    } else if (op_id == OP_CANCEL_ERROR) {
 |  |    } else if (op_id == OP_CANCEL_ERROR) {
 | 
											
												
													
														|  |      /* already executed */
 |  |      /* already executed */
 | 
											
										
											
												
													
														|  | @@ -857,10 +858,10 @@ static enum e_op_result execute_stream_op(grpc_exec_ctx *exec_ctx,
 | 
											
												
													
														|  |      s->cbs = bidirectional_stream_create(s->curr_ct.engine, s->curr_gs,
 |  |      s->cbs = bidirectional_stream_create(s->curr_ct.engine, s->curr_gs,
 | 
											
												
													
														|  |                                           &cronet_callbacks);
 |  |                                           &cronet_callbacks);
 | 
											
												
													
														|  |      CRONET_LOG(GPR_DEBUG, "%p = bidirectional_stream_create()", s->cbs);
 |  |      CRONET_LOG(GPR_DEBUG, "%p = bidirectional_stream_create()", s->cbs);
 | 
											
												
													
														|  | -    if (stream_state->packet_coalescing_enabled) {
 |  | 
 | 
											
												
													
														|  | -      bidirectional_stream_disable_auto_flush(s->cbs, true);
 |  | 
 | 
											
												
													
														|  | -      bidirectional_stream_delay_request_headers_until_flush(s->cbs, true);
 |  | 
 | 
											
												
													
														|  | -    }
 |  | 
 | 
											
												
													
														|  | 
 |  | +#ifdef GRPC_CRONET_WITH_PACKET_COALESCING
 | 
											
												
													
														|  | 
 |  | +    bidirectional_stream_disable_auto_flush(s->cbs, true);
 | 
											
												
													
														|  | 
 |  | +    bidirectional_stream_delay_request_headers_until_flush(s->cbs, true);
 | 
											
												
													
														|  | 
 |  | +#endif
 | 
											
												
													
														|  |      char *url = NULL;
 |  |      char *url = NULL;
 | 
											
												
													
														|  |      const char *method = "POST";
 |  |      const char *method = "POST";
 | 
											
												
													
														|  |      s->header_array.headers = NULL;
 |  |      s->header_array.headers = NULL;
 | 
											
										
											
												
													
														|  | @@ -871,10 +872,11 @@ static enum e_op_result execute_stream_op(grpc_exec_ctx *exec_ctx,
 | 
											
												
													
														|  |      CRONET_LOG(GPR_DEBUG, "bidirectional_stream_start(%p, %s)", s->cbs, url);
 |  |      CRONET_LOG(GPR_DEBUG, "bidirectional_stream_start(%p, %s)", s->cbs, url);
 | 
											
												
													
														|  |      bidirectional_stream_start(s->cbs, url, 0, method, &s->header_array, false);
 |  |      bidirectional_stream_start(s->cbs, url, 0, method, &s->header_array, false);
 | 
											
												
													
														|  |      stream_state->state_op_done[OP_SEND_INITIAL_METADATA] = true;
 |  |      stream_state->state_op_done[OP_SEND_INITIAL_METADATA] = true;
 | 
											
												
													
														|  | -    if (stream_state->packet_coalescing_enabled && !stream_op->send_message &&
 |  | 
 | 
											
												
													
														|  | -        !stream_op->send_trailing_metadata) {
 |  | 
 | 
											
												
													
														|  | 
 |  | +#ifdef GRPC_CRONET_WITH_PACKET_COALESCING
 | 
											
												
													
														|  | 
 |  | +    if (!stream_op->send_message && !stream_op->send_trailing_metadata) {
 | 
											
												
													
														|  |        s->state.flush_cronet_when_ready = true;
 |  |        s->state.flush_cronet_when_ready = true;
 | 
											
												
													
														|  |      }
 |  |      }
 | 
											
												
													
														|  | 
 |  | +#endif
 | 
											
												
													
														|  |      result = ACTION_TAKEN_WITH_CALLBACK;
 |  |      result = ACTION_TAKEN_WITH_CALLBACK;
 | 
											
												
													
														|  |    } else if (stream_op->send_message &&
 |  |    } else if (stream_op->send_message &&
 | 
											
												
													
														|  |               op_can_be_run(stream_op, stream_state, &oas->state,
 |  |               op_can_be_run(stream_op, stream_state, &oas->state,
 | 
											
										
											
												
													
														|  | @@ -911,18 +913,19 @@ static enum e_op_result execute_stream_op(grpc_exec_ctx *exec_ctx,
 | 
											
												
													
														|  |          stream_state->state_callback_received[OP_SEND_MESSAGE] = false;
 |  |          stream_state->state_callback_received[OP_SEND_MESSAGE] = false;
 | 
											
												
													
														|  |          bidirectional_stream_write(s->cbs, stream_state->ws.write_buffer,
 |  |          bidirectional_stream_write(s->cbs, stream_state->ws.write_buffer,
 | 
											
												
													
														|  |                                     (int)write_buffer_size, false);
 |  |                                     (int)write_buffer_size, false);
 | 
											
												
													
														|  | -        if (stream_state->packet_coalescing_enabled) {
 |  | 
 | 
											
												
													
														|  | -          if (!stream_op->send_trailing_metadata) {
 |  | 
 | 
											
												
													
														|  | -            CRONET_LOG(GPR_DEBUG, "bidirectional_stream_flush (%p)", s->cbs);
 |  | 
 | 
											
												
													
														|  | -            bidirectional_stream_flush(s->cbs);
 |  | 
 | 
											
												
													
														|  | -            result = ACTION_TAKEN_WITH_CALLBACK;
 |  | 
 | 
											
												
													
														|  | -          } else {
 |  | 
 | 
											
												
													
														|  | -            stream_state->pending_write_for_trailer = true;
 |  | 
 | 
											
												
													
														|  | -            result = ACTION_TAKEN_NO_CALLBACK;
 |  | 
 | 
											
												
													
														|  | -          }
 |  | 
 | 
											
												
													
														|  | -        } else {
 |  | 
 | 
											
												
													
														|  | 
 |  | +#ifdef GRPC_CRONET_WITH_PACKET_COALESCING
 | 
											
												
													
														|  | 
 |  | +        if (!stream_op->send_trailing_metadata) {
 | 
											
												
													
														|  | 
 |  | +          CRONET_LOG(GPR_DEBUG, "bidirectional_stream_flush (%p)",
 | 
											
												
													
														|  | 
 |  | +                     s->cbs);
 | 
											
												
													
														|  | 
 |  | +          bidirectional_stream_flush(s->cbs);
 | 
											
												
													
														|  |            result = ACTION_TAKEN_WITH_CALLBACK;
 |  |            result = ACTION_TAKEN_WITH_CALLBACK;
 | 
											
												
													
														|  | 
 |  | +        } else {
 | 
											
												
													
														|  | 
 |  | +          stream_state->pending_write_for_trailer = true;
 | 
											
												
													
														|  | 
 |  | +          result = ACTION_TAKEN_NO_CALLBACK;
 | 
											
												
													
														|  |          }
 |  |          }
 | 
											
												
													
														|  | 
 |  | +#else
 | 
											
												
													
														|  | 
 |  | +        result = ACTION_TAKEN_WITH_CALLBACK;
 | 
											
												
													
														|  | 
 |  | +#endif
 | 
											
												
													
														|  |        } else {
 |  |        } else {
 | 
											
												
													
														|  |          result = NO_ACTION_POSSIBLE;
 |  |          result = NO_ACTION_POSSIBLE;
 | 
											
												
													
														|  |        }
 |  |        }
 | 
											
										
											
												
													
														|  | @@ -941,10 +944,10 @@ static enum e_op_result execute_stream_op(grpc_exec_ctx *exec_ctx,
 | 
											
												
													
														|  |                   s->cbs);
 |  |                   s->cbs);
 | 
											
												
													
														|  |        stream_state->state_callback_received[OP_SEND_MESSAGE] = false;
 |  |        stream_state->state_callback_received[OP_SEND_MESSAGE] = false;
 | 
											
												
													
														|  |        bidirectional_stream_write(s->cbs, "", 0, true);
 |  |        bidirectional_stream_write(s->cbs, "", 0, true);
 | 
											
												
													
														|  | -      if (stream_state->packet_coalescing_enabled) {
 |  | 
 | 
											
												
													
														|  | -        CRONET_LOG(GPR_DEBUG, "bidirectional_stream_flush (%p)", s->cbs);
 |  | 
 | 
											
												
													
														|  | -        bidirectional_stream_flush(s->cbs);
 |  | 
 | 
											
												
													
														|  | -      }
 |  | 
 | 
											
												
													
														|  | 
 |  | +#ifdef GRPC_CRONET_WITH_PACKET_COALESCING
 | 
											
												
													
														|  | 
 |  | +      CRONET_LOG(GPR_DEBUG, "bidirectional_stream_flush (%p)", s->cbs);
 | 
											
												
													
														|  | 
 |  | +      bidirectional_stream_flush(s->cbs);
 | 
											
												
													
														|  | 
 |  | +#endif
 | 
											
												
													
														|  |        result = ACTION_TAKEN_WITH_CALLBACK;
 |  |        result = ACTION_TAKEN_WITH_CALLBACK;
 | 
											
												
													
														|  |      }
 |  |      }
 | 
											
												
													
														|  |      stream_state->state_op_done[OP_SEND_TRAILING_METADATA] = true;
 |  |      stream_state->state_op_done[OP_SEND_TRAILING_METADATA] = true;
 | 
											
										
											
												
													
														|  | @@ -1173,9 +1176,10 @@ static int init_stream(grpc_exec_ctx *exec_ctx, grpc_transport *gt,
 | 
											
												
													
														|  |           sizeof(s->state.state_callback_received));
 |  |           sizeof(s->state.state_callback_received));
 | 
											
												
													
														|  |    s->state.fail_state = s->state.flush_read = false;
 |  |    s->state.fail_state = s->state.flush_read = false;
 | 
											
												
													
														|  |    s->state.cancel_error = NULL;
 |  |    s->state.cancel_error = NULL;
 | 
											
												
													
														|  | 
 |  | +#ifdef GRPC_CRONET_WITH_PACKET_COALESCING
 | 
											
												
													
														|  |    s->state.flush_cronet_when_ready = s->state.pending_write_for_trailer = false;
 |  |    s->state.flush_cronet_when_ready = s->state.pending_write_for_trailer = false;
 | 
											
												
													
														|  | 
 |  | +#endif
 | 
											
												
													
														|  |    s->state.unprocessed_send_message = false;
 |  |    s->state.unprocessed_send_message = false;
 | 
											
												
													
														|  | -  s->state.packet_coalescing_enabled = grpc_cronet_packet_coalescing_enabled;
 |  | 
 | 
											
												
													
														|  |    gpr_mu_init(&s->mu);
 |  |    gpr_mu_init(&s->mu);
 | 
											
												
													
														|  |    return 0;
 |  |    return 0;
 | 
											
												
													
														|  |  }
 |  |  }
 |