From d492e5cc034897a710993e5b1453d164ac5e4cc4 Mon Sep 17 00:00:00 2001 From: Artemy Kovalyov Date: Mon, 7 Jun 2021 15:44:09 +0000 Subject: [PATCH] GTEST: Synch last_wqe callback with main thread --- test/gtest/uct/ib/test_ib_event.cc | 12 ++++++++++-- 1 file changed, 10 insertions(+), 2 deletions(-) diff --git a/test/gtest/uct/ib/test_ib_event.cc b/test/gtest/uct/ib/test_ib_event.cc index 57fdc38fc0e..dbead43b8ff 100644 --- a/test/gtest/uct/ib/test_ib_event.cc +++ b/test/gtest/uct/ib/test_ib_event.cc @@ -57,13 +57,20 @@ class uct_test_event_base : public uct_p2p_test { struct event_ctx { uct_ib_async_event_wait_t super; volatile bool got; + uct_ib_device_t *dev; }; static unsigned last_wqe_check_cb(void *arg) { event_ctx *event = (event_ctx *)arg; - event->got = true; - ucs_callbackq_remove_safe(event->super.cbq, event->super.cb_id); + int cb_id; + + ucs_spin_lock(&event->dev->async_event_lock); + cb_id = event->super.cb_id; event->super.cb_id = UCS_CALLBACKQ_ID_NULL; + ucs_spin_unlock(&event->dev->async_event_lock); + + event->got = true; + ucs_callbackq_remove_safe(event->super.cbq, cb_id); return 1; } @@ -81,6 +88,7 @@ class uct_test_event_base : public uct_p2p_test { m_event.got = false; m_event.super.cb = last_wqe_check_cb; m_event.super.cbq = &e.worker()->progress_q; + m_event.dev = dev(e); if (before) { /* move QP to error state before scheduling event callback */