|
|
@ -276,10 +276,6 @@ static bool grpc_ruby_forked_after_init(void) { |
|
|
|
} |
|
|
|
} |
|
|
|
#endif |
|
|
|
#endif |
|
|
|
|
|
|
|
|
|
|
|
static void grpc_rb_shutdown(void) { |
|
|
|
|
|
|
|
if (!grpc_ruby_forked_after_init()) grpc_shutdown(); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/* Initialize the GRPC module structs */ |
|
|
|
/* Initialize the GRPC module structs */ |
|
|
|
|
|
|
|
|
|
|
|
/* grpc_rb_sNewServerRpc is the struct that holds new server rpc details. */ |
|
|
|
/* grpc_rb_sNewServerRpc is the struct that holds new server rpc details. */ |
|
|
@ -298,12 +294,6 @@ VALUE sym_metadata = Qundef; |
|
|
|
|
|
|
|
|
|
|
|
static gpr_once g_once_init = GPR_ONCE_INIT; |
|
|
|
static gpr_once g_once_init = GPR_ONCE_INIT; |
|
|
|
|
|
|
|
|
|
|
|
static void grpc_ruby_once_init_internal() { |
|
|
|
|
|
|
|
grpc_ruby_set_init_pid(); |
|
|
|
|
|
|
|
grpc_init(); |
|
|
|
|
|
|
|
atexit(grpc_rb_shutdown); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
void grpc_ruby_fork_guard() { |
|
|
|
void grpc_ruby_fork_guard() { |
|
|
|
if (grpc_ruby_forked_after_init()) { |
|
|
|
if (grpc_ruby_forked_after_init()) { |
|
|
|
rb_raise(rb_eRuntimeError, "grpc cannot be used before and after forking"); |
|
|
|
rb_raise(rb_eRuntimeError, "grpc cannot be used before and after forking"); |
|
|
@ -313,19 +303,7 @@ void grpc_ruby_fork_guard() { |
|
|
|
static VALUE bg_thread_init_rb_mu = Qundef; |
|
|
|
static VALUE bg_thread_init_rb_mu = Qundef; |
|
|
|
static int bg_thread_init_done = 0; |
|
|
|
static int bg_thread_init_done = 0; |
|
|
|
|
|
|
|
|
|
|
|
void grpc_ruby_once_init() { |
|
|
|
static void grpc_ruby_init_threads() { |
|
|
|
/* ruby_vm_at_exit doesn't seem to be working. It would crash once every
|
|
|
|
|
|
|
|
* blue moon, and some users are getting it repeatedly. See the discussions |
|
|
|
|
|
|
|
* - https://github.com/grpc/grpc/pull/5337
|
|
|
|
|
|
|
|
* - https://bugs.ruby-lang.org/issues/12095
|
|
|
|
|
|
|
|
* |
|
|
|
|
|
|
|
* In order to still be able to handle the (unlikely) situation where the |
|
|
|
|
|
|
|
* extension is loaded by a first Ruby VM that is subsequently destroyed, |
|
|
|
|
|
|
|
* then loaded again by another VM within the same process, we need to |
|
|
|
|
|
|
|
* schedule our initialization and destruction only once. |
|
|
|
|
|
|
|
*/ |
|
|
|
|
|
|
|
gpr_once_init(&g_once_init, grpc_ruby_once_init_internal); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Avoid calling calling into ruby library (when creating threads here)
|
|
|
|
// Avoid calling calling into ruby library (when creating threads here)
|
|
|
|
// in gpr_once_init. In general, it appears to be unsafe to call
|
|
|
|
// in gpr_once_init. In general, it appears to be unsafe to call
|
|
|
|
// into the ruby library while holding a non-ruby mutex, because a gil yield
|
|
|
|
// into the ruby library while holding a non-ruby mutex, because a gil yield
|
|
|
@ -339,6 +317,27 @@ void grpc_ruby_once_init() { |
|
|
|
rb_mutex_unlock(bg_thread_init_rb_mu); |
|
|
|
rb_mutex_unlock(bg_thread_init_rb_mu); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
static int64_t g_grpc_ruby_init_count; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
void grpc_ruby_init() { |
|
|
|
|
|
|
|
gpr_once_init(&g_once_init, grpc_ruby_set_init_pid); |
|
|
|
|
|
|
|
grpc_init(); |
|
|
|
|
|
|
|
grpc_ruby_init_threads(); |
|
|
|
|
|
|
|
// (only gpr_log after logging has been initialized)
|
|
|
|
|
|
|
|
gpr_log(GPR_DEBUG, |
|
|
|
|
|
|
|
"GRPC_RUBY: grpc_ruby_init - prev g_grpc_ruby_init_count:%" PRId64, |
|
|
|
|
|
|
|
g_grpc_ruby_init_count++); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
void grpc_ruby_shutdown() { |
|
|
|
|
|
|
|
GPR_ASSERT(g_grpc_ruby_init_count > 0); |
|
|
|
|
|
|
|
if (!grpc_ruby_forked_after_init()) grpc_shutdown(); |
|
|
|
|
|
|
|
gpr_log( |
|
|
|
|
|
|
|
GPR_DEBUG, |
|
|
|
|
|
|
|
"GRPC_RUBY: grpc_ruby_shutdown - prev g_grpc_ruby_init_count:%" PRId64, |
|
|
|
|
|
|
|
g_grpc_ruby_init_count--); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
void Init_grpc_c() { |
|
|
|
void Init_grpc_c() { |
|
|
|
if (!grpc_rb_load_core()) { |
|
|
|
if (!grpc_rb_load_core()) { |
|
|
|
rb_raise(rb_eLoadError, "Couldn't find or load gRPC's dynamic C core"); |
|
|
|
rb_raise(rb_eLoadError, "Couldn't find or load gRPC's dynamic C core"); |
|
|
|