Sfoglia il codice sorgente

Hold a ref to the call stack for the read_service_config callback.

Mark D. Roth 9 anni fa
parent
commit
31292f211f
1 ha cambiato i file con 3 aggiunte e 0 eliminazioni
  1. 3 0
      src/core/ext/client_config/client_channel.c

+ 3 - 0
src/core/ext/client_config/client_channel.c

@@ -869,6 +869,7 @@ static void read_service_config(grpc_exec_ctx *exec_ctx, void *arg,
     }
     grpc_method_config_table_unref(method_config_table);
   }
+  GRPC_CALL_STACK_UNREF(exec_ctx, calld->owning_call, "read_service_config");
 }
 
 /* Constructor for call_data */
@@ -933,6 +934,8 @@ static grpc_error *cc_init_call_elem(grpc_exec_ctx *exec_ctx,
   } else {
     // We don't yet have a resolver result, so register a callback to
     // get the service config data once the resolver returns.
+    // Take a reference to the call stack to be owned by the callback.
+    GRPC_CALL_STACK_REF(calld->owning_call, "read_service_config");
     grpc_closure_init(&calld->read_service_config, read_service_config, elem);
     grpc_closure_list_append(&chand->waiting_for_config_closures,
                              &calld->read_service_config, GRPC_ERROR_NONE);