aboutsummaryrefslogtreecommitdiffhomepage
path: root/test
diff options
context:
space:
mode:
authorGravatar Guantao Liu <guantaol@google.com>2019-01-07 18:22:50 -0800
committerGravatar Guantao Liu <guantaol@google.com>2019-01-07 18:22:50 -0800
commit11eff929e24cae59ed21c2f3a0bde22a6dbe0d91 (patch)
tree7f540f95825292ef732f7e35a3e646c9dbf56c6c /test
parent8dcda4dc36aa4e4d3a4c46023f6470b4c1ec7bca (diff)
Avoid the thread jump in server callback APIs.
Add a utility function in iomgr to check whether the caller thread is a worker for any background poller, and keep grpc combiner from offloading closures to the default executor if the current thread is a worker for any background poller.
Diffstat (limited to 'test')
-rw-r--r--test/cpp/microbenchmarks/bm_cq_multiple_threads.cc1
1 files changed, 1 insertions, 0 deletions
diff --git a/test/cpp/microbenchmarks/bm_cq_multiple_threads.cc b/test/cpp/microbenchmarks/bm_cq_multiple_threads.cc
index dca97c85b1..7aa197b597 100644
--- a/test/cpp/microbenchmarks/bm_cq_multiple_threads.cc
+++ b/test/cpp/microbenchmarks/bm_cq_multiple_threads.cc
@@ -94,6 +94,7 @@ static const grpc_event_engine_vtable* init_engine_vtable(bool) {
g_vtable.pollset_destroy = pollset_destroy;
g_vtable.pollset_work = pollset_work;
g_vtable.pollset_kick = pollset_kick;
+ g_vtable.is_any_background_poller_thread = [] { return false; };
g_vtable.shutdown_background_closure = [] {};
g_vtable.shutdown_engine = [] {};