|
|
@ -148,7 +148,8 @@ static void *method_parameters_create_from_json(const grpc_json *json) { |
|
|
|
if (!parse_timeout(field, &timeout)) return NULL; |
|
|
|
if (!parse_timeout(field, &timeout)) return NULL; |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
method_parameters *value = gpr_malloc(sizeof(method_parameters)); |
|
|
|
method_parameters *value = |
|
|
|
|
|
|
|
(method_parameters *)gpr_malloc(sizeof(method_parameters)); |
|
|
|
gpr_ref_init(&value->refs, 1); |
|
|
|
gpr_ref_init(&value->refs, 1); |
|
|
|
value->timeout = timeout; |
|
|
|
value->timeout = timeout; |
|
|
|
value->wait_for_ready = wait_for_ready; |
|
|
|
value->wait_for_ready = wait_for_ready; |
|
|
@ -254,7 +255,7 @@ static void set_channel_connectivity_state_locked(grpc_exec_ctx *exec_ctx, |
|
|
|
|
|
|
|
|
|
|
|
static void on_lb_policy_state_changed_locked(grpc_exec_ctx *exec_ctx, |
|
|
|
static void on_lb_policy_state_changed_locked(grpc_exec_ctx *exec_ctx, |
|
|
|
void *arg, grpc_error *error) { |
|
|
|
void *arg, grpc_error *error) { |
|
|
|
lb_policy_connectivity_watcher *w = arg; |
|
|
|
lb_policy_connectivity_watcher *w = (lb_policy_connectivity_watcher *)arg; |
|
|
|
grpc_connectivity_state publish_state = w->state; |
|
|
|
grpc_connectivity_state publish_state = w->state; |
|
|
|
/* check if the notification is for the latest policy */ |
|
|
|
/* check if the notification is for the latest policy */ |
|
|
|
if (w->lb_policy == w->chand->lb_policy) { |
|
|
|
if (w->lb_policy == w->chand->lb_policy) { |
|
|
@ -281,7 +282,8 @@ static void on_lb_policy_state_changed_locked(grpc_exec_ctx *exec_ctx, |
|
|
|
static void watch_lb_policy_locked(grpc_exec_ctx *exec_ctx, channel_data *chand, |
|
|
|
static void watch_lb_policy_locked(grpc_exec_ctx *exec_ctx, channel_data *chand, |
|
|
|
grpc_lb_policy *lb_policy, |
|
|
|
grpc_lb_policy *lb_policy, |
|
|
|
grpc_connectivity_state current_state) { |
|
|
|
grpc_connectivity_state current_state) { |
|
|
|
lb_policy_connectivity_watcher *w = gpr_malloc(sizeof(*w)); |
|
|
|
lb_policy_connectivity_watcher *w = |
|
|
|
|
|
|
|
(lb_policy_connectivity_watcher *)gpr_malloc(sizeof(*w)); |
|
|
|
GRPC_CHANNEL_STACK_REF(chand->owning_stack, "watch_lb_policy"); |
|
|
|
GRPC_CHANNEL_STACK_REF(chand->owning_stack, "watch_lb_policy"); |
|
|
|
w->chand = chand; |
|
|
|
w->chand = chand; |
|
|
|
GRPC_CLOSURE_INIT(&w->on_changed, on_lb_policy_state_changed_locked, w, |
|
|
|
GRPC_CLOSURE_INIT(&w->on_changed, on_lb_policy_state_changed_locked, w, |
|
|
@ -310,7 +312,8 @@ typedef struct { |
|
|
|
} service_config_parsing_state; |
|
|
|
} service_config_parsing_state; |
|
|
|
|
|
|
|
|
|
|
|
static void parse_retry_throttle_params(const grpc_json *field, void *arg) { |
|
|
|
static void parse_retry_throttle_params(const grpc_json *field, void *arg) { |
|
|
|
service_config_parsing_state *parsing_state = arg; |
|
|
|
service_config_parsing_state *parsing_state = |
|
|
|
|
|
|
|
(service_config_parsing_state *)arg; |
|
|
|
if (strcmp(field->key, "retryThrottling") == 0) { |
|
|
|
if (strcmp(field->key, "retryThrottling") == 0) { |
|
|
|
if (parsing_state->retry_throttle_data != NULL) return; // Duplicate.
|
|
|
|
if (parsing_state->retry_throttle_data != NULL) return; // Duplicate.
|
|
|
|
if (field->type != GRPC_JSON_OBJECT) return; |
|
|
|
if (field->type != GRPC_JSON_OBJECT) return; |
|
|
@ -365,7 +368,7 @@ static void parse_retry_throttle_params(const grpc_json *field, void *arg) { |
|
|
|
|
|
|
|
|
|
|
|
static void on_resolver_result_changed_locked(grpc_exec_ctx *exec_ctx, |
|
|
|
static void on_resolver_result_changed_locked(grpc_exec_ctx *exec_ctx, |
|
|
|
void *arg, grpc_error *error) { |
|
|
|
void *arg, grpc_error *error) { |
|
|
|
channel_data *chand = arg; |
|
|
|
channel_data *chand = (channel_data *)arg; |
|
|
|
if (GRPC_TRACER_ON(grpc_client_channel_trace)) { |
|
|
|
if (GRPC_TRACER_ON(grpc_client_channel_trace)) { |
|
|
|
gpr_log(GPR_DEBUG, "chand=%p: got resolver result: error=%s", chand, |
|
|
|
gpr_log(GPR_DEBUG, "chand=%p: got resolver result: error=%s", chand, |
|
|
|
grpc_error_string(error)); |
|
|
|
grpc_error_string(error)); |
|
|
@ -391,7 +394,8 @@ static void on_resolver_result_changed_locked(grpc_exec_ctx *exec_ctx, |
|
|
|
channel_arg = |
|
|
|
channel_arg = |
|
|
|
grpc_channel_args_find(chand->resolver_result, GRPC_ARG_LB_ADDRESSES); |
|
|
|
grpc_channel_args_find(chand->resolver_result, GRPC_ARG_LB_ADDRESSES); |
|
|
|
if (channel_arg != NULL && channel_arg->type == GRPC_ARG_POINTER) { |
|
|
|
if (channel_arg != NULL && channel_arg->type == GRPC_ARG_POINTER) { |
|
|
|
grpc_lb_addresses *addresses = channel_arg->value.pointer.p; |
|
|
|
grpc_lb_addresses *addresses = |
|
|
|
|
|
|
|
(grpc_lb_addresses *)channel_arg->value.pointer.p; |
|
|
|
bool found_balancer_address = false; |
|
|
|
bool found_balancer_address = false; |
|
|
|
for (size_t i = 0; i < addresses->num_addresses; ++i) { |
|
|
|
for (size_t i = 0; i < addresses->num_addresses; ++i) { |
|
|
|
if (addresses->addresses[i].is_balancer) { |
|
|
|
if (addresses->addresses[i].is_balancer) { |
|
|
@ -586,9 +590,10 @@ static void on_resolver_result_changed_locked(grpc_exec_ctx *exec_ctx, |
|
|
|
|
|
|
|
|
|
|
|
static void start_transport_op_locked(grpc_exec_ctx *exec_ctx, void *arg, |
|
|
|
static void start_transport_op_locked(grpc_exec_ctx *exec_ctx, void *arg, |
|
|
|
grpc_error *error_ignored) { |
|
|
|
grpc_error *error_ignored) { |
|
|
|
grpc_transport_op *op = arg; |
|
|
|
grpc_transport_op *op = (grpc_transport_op *)arg; |
|
|
|
grpc_channel_element *elem = op->handler_private.extra_arg; |
|
|
|
grpc_channel_element *elem = |
|
|
|
channel_data *chand = elem->channel_data; |
|
|
|
(grpc_channel_element *)op->handler_private.extra_arg; |
|
|
|
|
|
|
|
channel_data *chand = (channel_data *)elem->channel_data; |
|
|
|
|
|
|
|
|
|
|
|
if (op->on_connectivity_state_change != NULL) { |
|
|
|
if (op->on_connectivity_state_change != NULL) { |
|
|
|
grpc_connectivity_state_notify_on_state_change( |
|
|
|
grpc_connectivity_state_notify_on_state_change( |
|
|
@ -642,7 +647,7 @@ static void start_transport_op_locked(grpc_exec_ctx *exec_ctx, void *arg, |
|
|
|
static void cc_start_transport_op(grpc_exec_ctx *exec_ctx, |
|
|
|
static void cc_start_transport_op(grpc_exec_ctx *exec_ctx, |
|
|
|
grpc_channel_element *elem, |
|
|
|
grpc_channel_element *elem, |
|
|
|
grpc_transport_op *op) { |
|
|
|
grpc_transport_op *op) { |
|
|
|
channel_data *chand = elem->channel_data; |
|
|
|
channel_data *chand = (channel_data *)elem->channel_data; |
|
|
|
|
|
|
|
|
|
|
|
GPR_ASSERT(op->set_accept_stream == false); |
|
|
|
GPR_ASSERT(op->set_accept_stream == false); |
|
|
|
if (op->bind_pollset != NULL) { |
|
|
|
if (op->bind_pollset != NULL) { |
|
|
@ -662,7 +667,7 @@ static void cc_start_transport_op(grpc_exec_ctx *exec_ctx, |
|
|
|
static void cc_get_channel_info(grpc_exec_ctx *exec_ctx, |
|
|
|
static void cc_get_channel_info(grpc_exec_ctx *exec_ctx, |
|
|
|
grpc_channel_element *elem, |
|
|
|
grpc_channel_element *elem, |
|
|
|
const grpc_channel_info *info) { |
|
|
|
const grpc_channel_info *info) { |
|
|
|
channel_data *chand = elem->channel_data; |
|
|
|
channel_data *chand = (channel_data *)elem->channel_data; |
|
|
|
gpr_mu_lock(&chand->info_mu); |
|
|
|
gpr_mu_lock(&chand->info_mu); |
|
|
|
if (info->lb_policy_name != NULL) { |
|
|
|
if (info->lb_policy_name != NULL) { |
|
|
|
*info->lb_policy_name = chand->info_lb_policy_name == NULL |
|
|
|
*info->lb_policy_name = chand->info_lb_policy_name == NULL |
|
|
@ -682,7 +687,7 @@ static void cc_get_channel_info(grpc_exec_ctx *exec_ctx, |
|
|
|
static grpc_error *cc_init_channel_elem(grpc_exec_ctx *exec_ctx, |
|
|
|
static grpc_error *cc_init_channel_elem(grpc_exec_ctx *exec_ctx, |
|
|
|
grpc_channel_element *elem, |
|
|
|
grpc_channel_element *elem, |
|
|
|
grpc_channel_element_args *args) { |
|
|
|
grpc_channel_element_args *args) { |
|
|
|
channel_data *chand = elem->channel_data; |
|
|
|
channel_data *chand = (channel_data *)elem->channel_data; |
|
|
|
GPR_ASSERT(args->is_last); |
|
|
|
GPR_ASSERT(args->is_last); |
|
|
|
GPR_ASSERT(elem->filter == &grpc_client_channel_filter); |
|
|
|
GPR_ASSERT(elem->filter == &grpc_client_channel_filter); |
|
|
|
// Initialize data members.
|
|
|
|
// Initialize data members.
|
|
|
@ -713,7 +718,8 @@ static grpc_error *cc_init_channel_elem(grpc_exec_ctx *exec_ctx, |
|
|
|
"client channel factory arg must be a pointer"); |
|
|
|
"client channel factory arg must be a pointer"); |
|
|
|
} |
|
|
|
} |
|
|
|
grpc_client_channel_factory_ref(arg->value.pointer.p); |
|
|
|
grpc_client_channel_factory_ref(arg->value.pointer.p); |
|
|
|
chand->client_channel_factory = arg->value.pointer.p; |
|
|
|
chand->client_channel_factory = |
|
|
|
|
|
|
|
(grpc_client_channel_factory *)arg->value.pointer.p; |
|
|
|
// Get server name to resolve, using proxy mapper if needed.
|
|
|
|
// Get server name to resolve, using proxy mapper if needed.
|
|
|
|
arg = grpc_channel_args_find(args->channel_args, GRPC_ARG_SERVER_URI); |
|
|
|
arg = grpc_channel_args_find(args->channel_args, GRPC_ARG_SERVER_URI); |
|
|
|
if (arg == NULL) { |
|
|
|
if (arg == NULL) { |
|
|
@ -745,7 +751,7 @@ static grpc_error *cc_init_channel_elem(grpc_exec_ctx *exec_ctx, |
|
|
|
|
|
|
|
|
|
|
|
static void shutdown_resolver_locked(grpc_exec_ctx *exec_ctx, void *arg, |
|
|
|
static void shutdown_resolver_locked(grpc_exec_ctx *exec_ctx, void *arg, |
|
|
|
grpc_error *error) { |
|
|
|
grpc_error *error) { |
|
|
|
grpc_resolver *resolver = arg; |
|
|
|
grpc_resolver *resolver = (grpc_resolver *)arg; |
|
|
|
grpc_resolver_shutdown_locked(exec_ctx, resolver); |
|
|
|
grpc_resolver_shutdown_locked(exec_ctx, resolver); |
|
|
|
GRPC_RESOLVER_UNREF(exec_ctx, resolver, "channel"); |
|
|
|
GRPC_RESOLVER_UNREF(exec_ctx, resolver, "channel"); |
|
|
|
} |
|
|
|
} |
|
|
@ -753,7 +759,7 @@ static void shutdown_resolver_locked(grpc_exec_ctx *exec_ctx, void *arg, |
|
|
|
/* Destructor for channel_data */ |
|
|
|
/* Destructor for channel_data */ |
|
|
|
static void cc_destroy_channel_elem(grpc_exec_ctx *exec_ctx, |
|
|
|
static void cc_destroy_channel_elem(grpc_exec_ctx *exec_ctx, |
|
|
|
grpc_channel_element *elem) { |
|
|
|
grpc_channel_element *elem) { |
|
|
|
channel_data *chand = elem->channel_data; |
|
|
|
channel_data *chand = (channel_data *)elem->channel_data; |
|
|
|
if (chand->resolver != NULL) { |
|
|
|
if (chand->resolver != NULL) { |
|
|
|
GRPC_CLOSURE_SCHED( |
|
|
|
GRPC_CLOSURE_SCHED( |
|
|
|
exec_ctx, GRPC_CLOSURE_CREATE(shutdown_resolver_locked, chand->resolver, |
|
|
|
exec_ctx, GRPC_CLOSURE_CREATE(shutdown_resolver_locked, chand->resolver, |
|
|
@ -848,7 +854,7 @@ typedef struct client_channel_call_data { |
|
|
|
|
|
|
|
|
|
|
|
grpc_subchannel_call *grpc_client_channel_get_subchannel_call( |
|
|
|
grpc_subchannel_call *grpc_client_channel_get_subchannel_call( |
|
|
|
grpc_call_element *elem) { |
|
|
|
grpc_call_element *elem) { |
|
|
|
call_data *calld = elem->call_data; |
|
|
|
call_data *calld = (call_data *)elem->call_data; |
|
|
|
return calld->subchannel_call; |
|
|
|
return calld->subchannel_call; |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
@ -868,7 +874,7 @@ static void waiting_for_pick_batches_add( |
|
|
|
// This is called via the call combiner, so access to calld is synchronized.
|
|
|
|
// This is called via the call combiner, so access to calld is synchronized.
|
|
|
|
static void fail_pending_batch_in_call_combiner(grpc_exec_ctx *exec_ctx, |
|
|
|
static void fail_pending_batch_in_call_combiner(grpc_exec_ctx *exec_ctx, |
|
|
|
void *arg, grpc_error *error) { |
|
|
|
void *arg, grpc_error *error) { |
|
|
|
call_data *calld = arg; |
|
|
|
call_data *calld = (call_data *)arg; |
|
|
|
if (calld->waiting_for_pick_batches_count > 0) { |
|
|
|
if (calld->waiting_for_pick_batches_count > 0) { |
|
|
|
--calld->waiting_for_pick_batches_count; |
|
|
|
--calld->waiting_for_pick_batches_count; |
|
|
|
grpc_transport_stream_op_batch_finish_with_failure( |
|
|
|
grpc_transport_stream_op_batch_finish_with_failure( |
|
|
@ -882,7 +888,7 @@ static void fail_pending_batch_in_call_combiner(grpc_exec_ctx *exec_ctx, |
|
|
|
static void waiting_for_pick_batches_fail(grpc_exec_ctx *exec_ctx, |
|
|
|
static void waiting_for_pick_batches_fail(grpc_exec_ctx *exec_ctx, |
|
|
|
grpc_call_element *elem, |
|
|
|
grpc_call_element *elem, |
|
|
|
grpc_error *error) { |
|
|
|
grpc_error *error) { |
|
|
|
call_data *calld = elem->call_data; |
|
|
|
call_data *calld = (call_data *)elem->call_data; |
|
|
|
if (GRPC_TRACER_ON(grpc_client_channel_trace)) { |
|
|
|
if (GRPC_TRACER_ON(grpc_client_channel_trace)) { |
|
|
|
gpr_log(GPR_DEBUG, |
|
|
|
gpr_log(GPR_DEBUG, |
|
|
|
"chand=%p calld=%p: failing %" PRIdPTR " pending batches: %s", |
|
|
|
"chand=%p calld=%p: failing %" PRIdPTR " pending batches: %s", |
|
|
@ -912,7 +918,7 @@ static void waiting_for_pick_batches_fail(grpc_exec_ctx *exec_ctx, |
|
|
|
// This is called via the call combiner, so access to calld is synchronized.
|
|
|
|
// This is called via the call combiner, so access to calld is synchronized.
|
|
|
|
static void run_pending_batch_in_call_combiner(grpc_exec_ctx *exec_ctx, |
|
|
|
static void run_pending_batch_in_call_combiner(grpc_exec_ctx *exec_ctx, |
|
|
|
void *arg, grpc_error *ignored) { |
|
|
|
void *arg, grpc_error *ignored) { |
|
|
|
call_data *calld = arg; |
|
|
|
call_data *calld = (call_data *)arg; |
|
|
|
if (calld->waiting_for_pick_batches_count > 0) { |
|
|
|
if (calld->waiting_for_pick_batches_count > 0) { |
|
|
|
--calld->waiting_for_pick_batches_count; |
|
|
|
--calld->waiting_for_pick_batches_count; |
|
|
|
grpc_subchannel_call_process_op( |
|
|
|
grpc_subchannel_call_process_op( |
|
|
@ -924,8 +930,8 @@ static void run_pending_batch_in_call_combiner(grpc_exec_ctx *exec_ctx, |
|
|
|
// This is called via the call combiner, so access to calld is synchronized.
|
|
|
|
// This is called via the call combiner, so access to calld is synchronized.
|
|
|
|
static void waiting_for_pick_batches_resume(grpc_exec_ctx *exec_ctx, |
|
|
|
static void waiting_for_pick_batches_resume(grpc_exec_ctx *exec_ctx, |
|
|
|
grpc_call_element *elem) { |
|
|
|
grpc_call_element *elem) { |
|
|
|
channel_data *chand = elem->channel_data; |
|
|
|
channel_data *chand = (channel_data *)elem->channel_data; |
|
|
|
call_data *calld = elem->call_data; |
|
|
|
call_data *calld = (call_data *)elem->call_data; |
|
|
|
if (GRPC_TRACER_ON(grpc_client_channel_trace)) { |
|
|
|
if (GRPC_TRACER_ON(grpc_client_channel_trace)) { |
|
|
|
gpr_log(GPR_DEBUG, "chand=%p calld=%p: sending %" PRIdPTR |
|
|
|
gpr_log(GPR_DEBUG, "chand=%p calld=%p: sending %" PRIdPTR |
|
|
|
" pending batches to subchannel_call=%p", |
|
|
|
" pending batches to subchannel_call=%p", |
|
|
@ -950,8 +956,8 @@ static void waiting_for_pick_batches_resume(grpc_exec_ctx *exec_ctx, |
|
|
|
// that the resolver has returned results to the channel.
|
|
|
|
// that the resolver has returned results to the channel.
|
|
|
|
static void apply_service_config_to_call_locked(grpc_exec_ctx *exec_ctx, |
|
|
|
static void apply_service_config_to_call_locked(grpc_exec_ctx *exec_ctx, |
|
|
|
grpc_call_element *elem) { |
|
|
|
grpc_call_element *elem) { |
|
|
|
channel_data *chand = elem->channel_data; |
|
|
|
channel_data *chand = (channel_data *)elem->channel_data; |
|
|
|
call_data *calld = elem->call_data; |
|
|
|
call_data *calld = (call_data *)elem->call_data; |
|
|
|
if (GRPC_TRACER_ON(grpc_client_channel_trace)) { |
|
|
|
if (GRPC_TRACER_ON(grpc_client_channel_trace)) { |
|
|
|
gpr_log(GPR_DEBUG, "chand=%p calld=%p: applying service config to call", |
|
|
|
gpr_log(GPR_DEBUG, "chand=%p calld=%p: applying service config to call", |
|
|
|
chand, calld); |
|
|
|
chand, calld); |
|
|
@ -961,7 +967,7 @@ static void apply_service_config_to_call_locked(grpc_exec_ctx *exec_ctx, |
|
|
|
grpc_server_retry_throttle_data_ref(chand->retry_throttle_data); |
|
|
|
grpc_server_retry_throttle_data_ref(chand->retry_throttle_data); |
|
|
|
} |
|
|
|
} |
|
|
|
if (chand->method_params_table != NULL) { |
|
|
|
if (chand->method_params_table != NULL) { |
|
|
|
calld->method_params = grpc_method_config_table_get( |
|
|
|
calld->method_params = (method_parameters *)grpc_method_config_table_get( |
|
|
|
exec_ctx, chand->method_params_table, calld->path); |
|
|
|
exec_ctx, chand->method_params_table, calld->path); |
|
|
|
if (calld->method_params != NULL) { |
|
|
|
if (calld->method_params != NULL) { |
|
|
|
method_parameters_ref(calld->method_params); |
|
|
|
method_parameters_ref(calld->method_params); |
|
|
@ -984,8 +990,8 @@ static void apply_service_config_to_call_locked(grpc_exec_ctx *exec_ctx, |
|
|
|
static void create_subchannel_call_locked(grpc_exec_ctx *exec_ctx, |
|
|
|
static void create_subchannel_call_locked(grpc_exec_ctx *exec_ctx, |
|
|
|
grpc_call_element *elem, |
|
|
|
grpc_call_element *elem, |
|
|
|
grpc_error *error) { |
|
|
|
grpc_error *error) { |
|
|
|
channel_data *chand = elem->channel_data; |
|
|
|
channel_data *chand = (channel_data *)elem->channel_data; |
|
|
|
call_data *calld = elem->call_data; |
|
|
|
call_data *calld = (call_data *)elem->call_data; |
|
|
|
const grpc_connected_subchannel_call_args call_args = { |
|
|
|
const grpc_connected_subchannel_call_args call_args = { |
|
|
|
.pollent = calld->pollent, |
|
|
|
.pollent = calld->pollent, |
|
|
|
.path = calld->path, |
|
|
|
.path = calld->path, |
|
|
@ -1013,8 +1019,8 @@ static void create_subchannel_call_locked(grpc_exec_ctx *exec_ctx, |
|
|
|
static void subchannel_ready_locked(grpc_exec_ctx *exec_ctx, |
|
|
|
static void subchannel_ready_locked(grpc_exec_ctx *exec_ctx, |
|
|
|
grpc_call_element *elem, |
|
|
|
grpc_call_element *elem, |
|
|
|
grpc_error *error) { |
|
|
|
grpc_error *error) { |
|
|
|
call_data *calld = elem->call_data; |
|
|
|
call_data *calld = (call_data *)elem->call_data; |
|
|
|
channel_data *chand = elem->channel_data; |
|
|
|
channel_data *chand = (channel_data *)elem->channel_data; |
|
|
|
grpc_polling_entity_del_from_pollset_set(exec_ctx, calld->pollent, |
|
|
|
grpc_polling_entity_del_from_pollset_set(exec_ctx, calld->pollent, |
|
|
|
chand->interested_parties); |
|
|
|
chand->interested_parties); |
|
|
|
if (calld->connected_subchannel == NULL) { |
|
|
|
if (calld->connected_subchannel == NULL) { |
|
|
@ -1057,15 +1063,16 @@ typedef struct { |
|
|
|
static void pick_after_resolver_result_cancel_locked(grpc_exec_ctx *exec_ctx, |
|
|
|
static void pick_after_resolver_result_cancel_locked(grpc_exec_ctx *exec_ctx, |
|
|
|
void *arg, |
|
|
|
void *arg, |
|
|
|
grpc_error *error) { |
|
|
|
grpc_error *error) { |
|
|
|
pick_after_resolver_result_args *args = arg; |
|
|
|
pick_after_resolver_result_args *args = |
|
|
|
|
|
|
|
(pick_after_resolver_result_args *)arg; |
|
|
|
if (args->finished) { |
|
|
|
if (args->finished) { |
|
|
|
gpr_free(args); |
|
|
|
gpr_free(args); |
|
|
|
return; |
|
|
|
return; |
|
|
|
} |
|
|
|
} |
|
|
|
args->finished = true; |
|
|
|
args->finished = true; |
|
|
|
grpc_call_element *elem = args->elem; |
|
|
|
grpc_call_element *elem = args->elem; |
|
|
|
channel_data *chand = elem->channel_data; |
|
|
|
channel_data *chand = (channel_data *)elem->channel_data; |
|
|
|
call_data *calld = elem->call_data; |
|
|
|
call_data *calld = (call_data *)elem->call_data; |
|
|
|
// If we don't yet have a resolver result, then a closure for
|
|
|
|
// If we don't yet have a resolver result, then a closure for
|
|
|
|
// pick_after_resolver_result_done_locked() will have been added to
|
|
|
|
// pick_after_resolver_result_done_locked() will have been added to
|
|
|
|
// chand->waiting_for_resolver_result_closures, and it may not be invoked
|
|
|
|
// chand->waiting_for_resolver_result_closures, and it may not be invoked
|
|
|
@ -1091,7 +1098,8 @@ static void pick_after_resolver_result_cancel_locked(grpc_exec_ctx *exec_ctx, |
|
|
|
static void pick_after_resolver_result_done_locked(grpc_exec_ctx *exec_ctx, |
|
|
|
static void pick_after_resolver_result_done_locked(grpc_exec_ctx *exec_ctx, |
|
|
|
void *arg, |
|
|
|
void *arg, |
|
|
|
grpc_error *error) { |
|
|
|
grpc_error *error) { |
|
|
|
pick_after_resolver_result_args *args = arg; |
|
|
|
pick_after_resolver_result_args *args = |
|
|
|
|
|
|
|
(pick_after_resolver_result_args *)arg; |
|
|
|
if (args->finished) { |
|
|
|
if (args->finished) { |
|
|
|
/* cancelled, do nothing */ |
|
|
|
/* cancelled, do nothing */ |
|
|
|
if (GRPC_TRACER_ON(grpc_client_channel_trace)) { |
|
|
|
if (GRPC_TRACER_ON(grpc_client_channel_trace)) { |
|
|
@ -1102,8 +1110,8 @@ static void pick_after_resolver_result_done_locked(grpc_exec_ctx *exec_ctx, |
|
|
|
} |
|
|
|
} |
|
|
|
args->finished = true; |
|
|
|
args->finished = true; |
|
|
|
grpc_call_element *elem = args->elem; |
|
|
|
grpc_call_element *elem = args->elem; |
|
|
|
channel_data *chand = elem->channel_data; |
|
|
|
channel_data *chand = (channel_data *)elem->channel_data; |
|
|
|
call_data *calld = elem->call_data; |
|
|
|
call_data *calld = (call_data *)elem->call_data; |
|
|
|
if (error != GRPC_ERROR_NONE) { |
|
|
|
if (error != GRPC_ERROR_NONE) { |
|
|
|
if (GRPC_TRACER_ON(grpc_client_channel_trace)) { |
|
|
|
if (GRPC_TRACER_ON(grpc_client_channel_trace)) { |
|
|
|
gpr_log(GPR_DEBUG, "chand=%p calld=%p: resolver failed to return data", |
|
|
|
gpr_log(GPR_DEBUG, "chand=%p calld=%p: resolver failed to return data", |
|
|
@ -1123,8 +1131,8 @@ static void pick_after_resolver_result_done_locked(grpc_exec_ctx *exec_ctx, |
|
|
|
|
|
|
|
|
|
|
|
static void pick_after_resolver_result_start_locked(grpc_exec_ctx *exec_ctx, |
|
|
|
static void pick_after_resolver_result_start_locked(grpc_exec_ctx *exec_ctx, |
|
|
|
grpc_call_element *elem) { |
|
|
|
grpc_call_element *elem) { |
|
|
|
channel_data *chand = elem->channel_data; |
|
|
|
channel_data *chand = (channel_data *)elem->channel_data; |
|
|
|
call_data *calld = elem->call_data; |
|
|
|
call_data *calld = (call_data *)elem->call_data; |
|
|
|
if (GRPC_TRACER_ON(grpc_client_channel_trace)) { |
|
|
|
if (GRPC_TRACER_ON(grpc_client_channel_trace)) { |
|
|
|
gpr_log(GPR_DEBUG, |
|
|
|
gpr_log(GPR_DEBUG, |
|
|
|
"chand=%p calld=%p: deferring pick pending resolver result", chand, |
|
|
|
"chand=%p calld=%p: deferring pick pending resolver result", chand, |
|
|
@ -1148,9 +1156,9 @@ static void pick_after_resolver_result_start_locked(grpc_exec_ctx *exec_ctx, |
|
|
|
// holding the call combiner.
|
|
|
|
// holding the call combiner.
|
|
|
|
static void pick_callback_cancel_locked(grpc_exec_ctx *exec_ctx, void *arg, |
|
|
|
static void pick_callback_cancel_locked(grpc_exec_ctx *exec_ctx, void *arg, |
|
|
|
grpc_error *error) { |
|
|
|
grpc_error *error) { |
|
|
|
grpc_call_element *elem = arg; |
|
|
|
grpc_call_element *elem = (grpc_call_element *)arg; |
|
|
|
channel_data *chand = elem->channel_data; |
|
|
|
channel_data *chand = (channel_data *)elem->channel_data; |
|
|
|
call_data *calld = elem->call_data; |
|
|
|
call_data *calld = (call_data *)elem->call_data; |
|
|
|
if (error != GRPC_ERROR_NONE && calld->lb_policy != NULL) { |
|
|
|
if (error != GRPC_ERROR_NONE && calld->lb_policy != NULL) { |
|
|
|
if (GRPC_TRACER_ON(grpc_client_channel_trace)) { |
|
|
|
if (GRPC_TRACER_ON(grpc_client_channel_trace)) { |
|
|
|
gpr_log(GPR_DEBUG, "chand=%p calld=%p: cancelling pick from LB policy %p", |
|
|
|
gpr_log(GPR_DEBUG, "chand=%p calld=%p: cancelling pick from LB policy %p", |
|
|
@ -1167,9 +1175,9 @@ static void pick_callback_cancel_locked(grpc_exec_ctx *exec_ctx, void *arg, |
|
|
|
// Unrefs the LB policy and invokes subchannel_ready_locked().
|
|
|
|
// Unrefs the LB policy and invokes subchannel_ready_locked().
|
|
|
|
static void pick_callback_done_locked(grpc_exec_ctx *exec_ctx, void *arg, |
|
|
|
static void pick_callback_done_locked(grpc_exec_ctx *exec_ctx, void *arg, |
|
|
|
grpc_error *error) { |
|
|
|
grpc_error *error) { |
|
|
|
grpc_call_element *elem = arg; |
|
|
|
grpc_call_element *elem = (grpc_call_element *)arg; |
|
|
|
channel_data *chand = elem->channel_data; |
|
|
|
channel_data *chand = (channel_data *)elem->channel_data; |
|
|
|
call_data *calld = elem->call_data; |
|
|
|
call_data *calld = (call_data *)elem->call_data; |
|
|
|
if (GRPC_TRACER_ON(grpc_client_channel_trace)) { |
|
|
|
if (GRPC_TRACER_ON(grpc_client_channel_trace)) { |
|
|
|
gpr_log(GPR_DEBUG, "chand=%p calld=%p: pick completed asynchronously", |
|
|
|
gpr_log(GPR_DEBUG, "chand=%p calld=%p: pick completed asynchronously", |
|
|
|
chand, calld); |
|
|
|
chand, calld); |
|
|
@ -1186,8 +1194,8 @@ static void pick_callback_done_locked(grpc_exec_ctx *exec_ctx, void *arg, |
|
|
|
static bool pick_callback_start_locked(grpc_exec_ctx *exec_ctx, |
|
|
|
static bool pick_callback_start_locked(grpc_exec_ctx *exec_ctx, |
|
|
|
grpc_call_element *elem, |
|
|
|
grpc_call_element *elem, |
|
|
|
const grpc_lb_policy_pick_args *inputs) { |
|
|
|
const grpc_lb_policy_pick_args *inputs) { |
|
|
|
channel_data *chand = elem->channel_data; |
|
|
|
channel_data *chand = (channel_data *)elem->channel_data; |
|
|
|
call_data *calld = elem->call_data; |
|
|
|
call_data *calld = (call_data *)elem->call_data; |
|
|
|
if (GRPC_TRACER_ON(grpc_client_channel_trace)) { |
|
|
|
if (GRPC_TRACER_ON(grpc_client_channel_trace)) { |
|
|
|
gpr_log(GPR_DEBUG, "chand=%p calld=%p: starting pick on lb_policy=%p", |
|
|
|
gpr_log(GPR_DEBUG, "chand=%p calld=%p: starting pick on lb_policy=%p", |
|
|
|
chand, calld, chand->lb_policy); |
|
|
|
chand, calld, chand->lb_policy); |
|
|
@ -1222,8 +1230,8 @@ static bool pick_callback_start_locked(grpc_exec_ctx *exec_ctx, |
|
|
|
static bool pick_subchannel_locked(grpc_exec_ctx *exec_ctx, |
|
|
|
static bool pick_subchannel_locked(grpc_exec_ctx *exec_ctx, |
|
|
|
grpc_call_element *elem) { |
|
|
|
grpc_call_element *elem) { |
|
|
|
GPR_TIMER_BEGIN("pick_subchannel", 0); |
|
|
|
GPR_TIMER_BEGIN("pick_subchannel", 0); |
|
|
|
channel_data *chand = elem->channel_data; |
|
|
|
channel_data *chand = (channel_data *)elem->channel_data; |
|
|
|
call_data *calld = elem->call_data; |
|
|
|
call_data *calld = (call_data *)elem->call_data; |
|
|
|
bool pick_done = false; |
|
|
|
bool pick_done = false; |
|
|
|
if (chand->lb_policy != NULL) { |
|
|
|
if (chand->lb_policy != NULL) { |
|
|
|
apply_service_config_to_call_locked(exec_ctx, elem); |
|
|
|
apply_service_config_to_call_locked(exec_ctx, elem); |
|
|
@ -1295,8 +1303,8 @@ static void start_pick_locked(grpc_exec_ctx *exec_ctx, void *arg, |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
static void on_complete(grpc_exec_ctx *exec_ctx, void *arg, grpc_error *error) { |
|
|
|
static void on_complete(grpc_exec_ctx *exec_ctx, void *arg, grpc_error *error) { |
|
|
|
grpc_call_element *elem = arg; |
|
|
|
grpc_call_element *elem = (grpc_call_element *)arg; |
|
|
|
call_data *calld = elem->call_data; |
|
|
|
call_data *calld = (call_data *)elem->call_data; |
|
|
|
if (calld->retry_throttle_data != NULL) { |
|
|
|
if (calld->retry_throttle_data != NULL) { |
|
|
|
if (error == GRPC_ERROR_NONE) { |
|
|
|
if (error == GRPC_ERROR_NONE) { |
|
|
|
grpc_server_retry_throttle_data_record_success( |
|
|
|
grpc_server_retry_throttle_data_record_success( |
|
|
@ -1317,8 +1325,8 @@ static void on_complete(grpc_exec_ctx *exec_ctx, void *arg, grpc_error *error) { |
|
|
|
static void cc_start_transport_stream_op_batch( |
|
|
|
static void cc_start_transport_stream_op_batch( |
|
|
|
grpc_exec_ctx *exec_ctx, grpc_call_element *elem, |
|
|
|
grpc_exec_ctx *exec_ctx, grpc_call_element *elem, |
|
|
|
grpc_transport_stream_op_batch *batch) { |
|
|
|
grpc_transport_stream_op_batch *batch) { |
|
|
|
call_data *calld = elem->call_data; |
|
|
|
call_data *calld = (call_data *)elem->call_data; |
|
|
|
channel_data *chand = elem->channel_data; |
|
|
|
channel_data *chand = (channel_data *)elem->channel_data; |
|
|
|
if (chand->deadline_checking_enabled) { |
|
|
|
if (chand->deadline_checking_enabled) { |
|
|
|
grpc_deadline_state_client_start_transport_stream_op_batch(exec_ctx, elem, |
|
|
|
grpc_deadline_state_client_start_transport_stream_op_batch(exec_ctx, elem, |
|
|
|
batch); |
|
|
|
batch); |
|
|
@ -1411,8 +1419,8 @@ done: |
|
|
|
static grpc_error *cc_init_call_elem(grpc_exec_ctx *exec_ctx, |
|
|
|
static grpc_error *cc_init_call_elem(grpc_exec_ctx *exec_ctx, |
|
|
|
grpc_call_element *elem, |
|
|
|
grpc_call_element *elem, |
|
|
|
const grpc_call_element_args *args) { |
|
|
|
const grpc_call_element_args *args) { |
|
|
|
call_data *calld = elem->call_data; |
|
|
|
call_data *calld = (call_data *)elem->call_data; |
|
|
|
channel_data *chand = elem->channel_data; |
|
|
|
channel_data *chand = (channel_data *)elem->channel_data; |
|
|
|
// Initialize data members.
|
|
|
|
// Initialize data members.
|
|
|
|
calld->path = grpc_slice_ref_internal(args->path); |
|
|
|
calld->path = grpc_slice_ref_internal(args->path); |
|
|
|
calld->call_start_time = args->start_time; |
|
|
|
calld->call_start_time = args->start_time; |
|
|
@ -1432,8 +1440,8 @@ static void cc_destroy_call_elem(grpc_exec_ctx *exec_ctx, |
|
|
|
grpc_call_element *elem, |
|
|
|
grpc_call_element *elem, |
|
|
|
const grpc_call_final_info *final_info, |
|
|
|
const grpc_call_final_info *final_info, |
|
|
|
grpc_closure *then_schedule_closure) { |
|
|
|
grpc_closure *then_schedule_closure) { |
|
|
|
call_data *calld = elem->call_data; |
|
|
|
call_data *calld = (call_data *)elem->call_data; |
|
|
|
channel_data *chand = elem->channel_data; |
|
|
|
channel_data *chand = (channel_data *)elem->channel_data; |
|
|
|
if (chand->deadline_checking_enabled) { |
|
|
|
if (chand->deadline_checking_enabled) { |
|
|
|
grpc_deadline_state_destroy(exec_ctx, elem); |
|
|
|
grpc_deadline_state_destroy(exec_ctx, elem); |
|
|
|
} |
|
|
|
} |
|
|
@ -1467,7 +1475,7 @@ static void cc_destroy_call_elem(grpc_exec_ctx *exec_ctx, |
|
|
|
static void cc_set_pollset_or_pollset_set(grpc_exec_ctx *exec_ctx, |
|
|
|
static void cc_set_pollset_or_pollset_set(grpc_exec_ctx *exec_ctx, |
|
|
|
grpc_call_element *elem, |
|
|
|
grpc_call_element *elem, |
|
|
|
grpc_polling_entity *pollent) { |
|
|
|
grpc_polling_entity *pollent) { |
|
|
|
call_data *calld = elem->call_data; |
|
|
|
call_data *calld = (call_data *)elem->call_data; |
|
|
|
calld->pollent = pollent; |
|
|
|
calld->pollent = pollent; |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
@ -1491,7 +1499,7 @@ const grpc_channel_filter grpc_client_channel_filter = { |
|
|
|
|
|
|
|
|
|
|
|
static void try_to_connect_locked(grpc_exec_ctx *exec_ctx, void *arg, |
|
|
|
static void try_to_connect_locked(grpc_exec_ctx *exec_ctx, void *arg, |
|
|
|
grpc_error *error_ignored) { |
|
|
|
grpc_error *error_ignored) { |
|
|
|
channel_data *chand = arg; |
|
|
|
channel_data *chand = (channel_data *)arg; |
|
|
|
if (chand->lb_policy != NULL) { |
|
|
|
if (chand->lb_policy != NULL) { |
|
|
|
grpc_lb_policy_exit_idle_locked(exec_ctx, chand->lb_policy); |
|
|
|
grpc_lb_policy_exit_idle_locked(exec_ctx, chand->lb_policy); |
|
|
|
} else { |
|
|
|
} else { |
|
|
@ -1505,7 +1513,7 @@ static void try_to_connect_locked(grpc_exec_ctx *exec_ctx, void *arg, |
|
|
|
|
|
|
|
|
|
|
|
grpc_connectivity_state grpc_client_channel_check_connectivity_state( |
|
|
|
grpc_connectivity_state grpc_client_channel_check_connectivity_state( |
|
|
|
grpc_exec_ctx *exec_ctx, grpc_channel_element *elem, int try_to_connect) { |
|
|
|
grpc_exec_ctx *exec_ctx, grpc_channel_element *elem, int try_to_connect) { |
|
|
|
channel_data *chand = elem->channel_data; |
|
|
|
channel_data *chand = (channel_data *)elem->channel_data; |
|
|
|
grpc_connectivity_state out = |
|
|
|
grpc_connectivity_state out = |
|
|
|
grpc_connectivity_state_check(&chand->state_tracker); |
|
|
|
grpc_connectivity_state_check(&chand->state_tracker); |
|
|
|
if (out == GRPC_CHANNEL_IDLE && try_to_connect) { |
|
|
|
if (out == GRPC_CHANNEL_IDLE && try_to_connect) { |
|
|
@ -1576,7 +1584,7 @@ static void external_connectivity_watcher_list_remove( |
|
|
|
|
|
|
|
|
|
|
|
int grpc_client_channel_num_external_connectivity_watchers( |
|
|
|
int grpc_client_channel_num_external_connectivity_watchers( |
|
|
|
grpc_channel_element *elem) { |
|
|
|
grpc_channel_element *elem) { |
|
|
|
channel_data *chand = elem->channel_data; |
|
|
|
channel_data *chand = (channel_data *)elem->channel_data; |
|
|
|
int count = 0; |
|
|
|
int count = 0; |
|
|
|
|
|
|
|
|
|
|
|
gpr_mu_lock(&chand->external_connectivity_watcher_list_mu); |
|
|
|
gpr_mu_lock(&chand->external_connectivity_watcher_list_mu); |
|
|
@ -1593,7 +1601,7 @@ int grpc_client_channel_num_external_connectivity_watchers( |
|
|
|
|
|
|
|
|
|
|
|
static void on_external_watch_complete(grpc_exec_ctx *exec_ctx, void *arg, |
|
|
|
static void on_external_watch_complete(grpc_exec_ctx *exec_ctx, void *arg, |
|
|
|
grpc_error *error) { |
|
|
|
grpc_error *error) { |
|
|
|
external_connectivity_watcher *w = arg; |
|
|
|
external_connectivity_watcher *w = (external_connectivity_watcher *)arg; |
|
|
|
grpc_closure *follow_up = w->on_complete; |
|
|
|
grpc_closure *follow_up = w->on_complete; |
|
|
|
grpc_polling_entity_del_from_pollset_set(exec_ctx, &w->pollent, |
|
|
|
grpc_polling_entity_del_from_pollset_set(exec_ctx, &w->pollent, |
|
|
|
w->chand->interested_parties); |
|
|
|
w->chand->interested_parties); |
|
|
@ -1606,7 +1614,7 @@ static void on_external_watch_complete(grpc_exec_ctx *exec_ctx, void *arg, |
|
|
|
|
|
|
|
|
|
|
|
static void watch_connectivity_state_locked(grpc_exec_ctx *exec_ctx, void *arg, |
|
|
|
static void watch_connectivity_state_locked(grpc_exec_ctx *exec_ctx, void *arg, |
|
|
|
grpc_error *error_ignored) { |
|
|
|
grpc_error *error_ignored) { |
|
|
|
external_connectivity_watcher *w = arg; |
|
|
|
external_connectivity_watcher *w = (external_connectivity_watcher *)arg; |
|
|
|
external_connectivity_watcher *found = NULL; |
|
|
|
external_connectivity_watcher *found = NULL; |
|
|
|
if (w->state != NULL) { |
|
|
|
if (w->state != NULL) { |
|
|
|
external_connectivity_watcher_list_append(w->chand, w); |
|
|
|
external_connectivity_watcher_list_append(w->chand, w); |
|
|
@ -1635,8 +1643,9 @@ void grpc_client_channel_watch_connectivity_state( |
|
|
|
grpc_exec_ctx *exec_ctx, grpc_channel_element *elem, |
|
|
|
grpc_exec_ctx *exec_ctx, grpc_channel_element *elem, |
|
|
|
grpc_polling_entity pollent, grpc_connectivity_state *state, |
|
|
|
grpc_polling_entity pollent, grpc_connectivity_state *state, |
|
|
|
grpc_closure *closure, grpc_closure *watcher_timer_init) { |
|
|
|
grpc_closure *closure, grpc_closure *watcher_timer_init) { |
|
|
|
channel_data *chand = elem->channel_data; |
|
|
|
channel_data *chand = (channel_data *)elem->channel_data; |
|
|
|
external_connectivity_watcher *w = gpr_zalloc(sizeof(*w)); |
|
|
|
external_connectivity_watcher *w = |
|
|
|
|
|
|
|
(external_connectivity_watcher *)gpr_zalloc(sizeof(*w)); |
|
|
|
w->chand = chand; |
|
|
|
w->chand = chand; |
|
|
|
w->pollent = pollent; |
|
|
|
w->pollent = pollent; |
|
|
|
w->on_complete = closure; |
|
|
|
w->on_complete = closure; |
|
|
|