Skip to content

Commit

Permalink
Fix resource_quota_server bug
Browse files Browse the repository at this point in the history
  • Loading branch information
sreecha committed Nov 4, 2017
1 parent e5bca39 commit 7f3f30f
Show file tree
Hide file tree
Showing 2 changed files with 13 additions and 6 deletions.
11 changes: 10 additions & 1 deletion src/core/ext/transport/chttp2/transport/chttp2_transport.cc
Original file line number Diff line number Diff line change
Expand Up @@ -1121,6 +1121,7 @@ void grpc_chttp2_add_incoming_goaway(grpc_exec_ctx *exec_ctx,
// GRPC_CHTTP2_IF_TRACING(
// gpr_log(GPR_DEBUG, "got goaway [%d]: %s", goaway_error, msg));
t->seen_goaway = 1;
t->goaway_error = goaway_error;

/* When a client receives a GOAWAY with error code ENHANCE_YOUR_CALM and debug
* data equal to "too_many_pings", it should log the occurrence at a log level
Expand Down Expand Up @@ -2074,7 +2075,6 @@ void grpc_chttp2_fake_status(grpc_exec_ctx *exec_ctx, grpc_chttp2_transport *t,
grpc_status_code status;
grpc_slice slice;
grpc_error_get_status(exec_ctx, error, s->deadline, &status, &slice, NULL);

if (status != GRPC_STATUS_OK) {
s->seen_error = true;
}
Expand Down Expand Up @@ -2542,6 +2542,15 @@ static void read_action_locked(grpc_exec_ctx *exec_ctx, void *tp,
"Transport closed", &t->closed_with_error, 1);
}
if (error != GRPC_ERROR_NONE) {
/* If a goaway frame was received, this might be the reason why the read
* failed. Add this info to the error */
if (t->seen_goaway) {
error = grpc_error_add_child(
error, grpc_error_set_int(
GRPC_ERROR_CREATE_FROM_STATIC_STRING("GOAWAY received"),
GRPC_ERROR_INT_HTTP2_ERROR, (intptr_t)t->goaway_error));
}

close_transport_locked(exec_ctx, t, GRPC_ERROR_REF(error));
t->endpoint_reading = 0;
} else if (t->closed_with_error == GRPC_ERROR_NONE) {
Expand Down
8 changes: 3 additions & 5 deletions src/core/ext/transport/chttp2/transport/internal.h
Original file line number Diff line number Diff line change
Expand Up @@ -310,6 +310,9 @@ struct grpc_chttp2_transport {
bool seen_goaway;
/** have we sent a goaway */
grpc_chttp2_sent_goaway_state sent_goaway_state;
/** http2 error code received in the GOAWAY frame. Only relevant if
* seen_goaway is true */
uint32_t goaway_error;

/** are the local settings dirty and need to be sent? */
bool dirtied_local_settings;
Expand Down Expand Up @@ -376,11 +379,6 @@ struct grpc_chttp2_transport {
grpc_chttp2_transport *t, grpc_chttp2_stream *s,
grpc_slice slice, int is_last);

/* goaway data */
grpc_status_code goaway_error;
uint32_t goaway_last_stream_index;
grpc_slice goaway_text;

grpc_chttp2_write_cb *write_cb_pool;

/* bdp estimator */
Expand Down

0 comments on commit 7f3f30f

Please sign in to comment.