From 7609e413af380182985ce52b8946a8ec598e7f60 Mon Sep 17 00:00:00 2001 From: Chris Lalancette Date: Thu, 20 Jun 2024 21:22:44 -0400 Subject: [PATCH] Fix checking of the guard condition. (#204) * Fix checking of the guard condition. Previously, when we were checking if a guard condition was triggered, we would actually check and reset it. But that means that when we later on went to set the appropriate things in the wait_set, we wouldn't actually set the guard_condition true, since it was false by that point. Instead, add in two separate methods; the one that just returns whether it is triggered, which we call when checking, and the one that checks and resets, which we call when setting it in the wait_set. Signed-off-by: Chris Lalancette * Make has_triggered_condition args const Signed-off-by: Yadunund --------- Signed-off-by: Chris Lalancette Signed-off-by: Yadunund Co-authored-by: Yadunund --- rmw_zenoh_cpp/src/detail/guard_condition.cpp | 9 +++++++-- rmw_zenoh_cpp/src/detail/guard_condition.hpp | 2 ++ rmw_zenoh_cpp/src/rmw_zenoh.cpp | 14 ++++++-------- 3 files changed, 15 insertions(+), 10 deletions(-) diff --git a/rmw_zenoh_cpp/src/detail/guard_condition.cpp b/rmw_zenoh_cpp/src/detail/guard_condition.cpp index feb6ea48..76f1c1f8 100644 --- a/rmw_zenoh_cpp/src/detail/guard_condition.cpp +++ b/rmw_zenoh_cpp/src/detail/guard_condition.cpp @@ -53,16 +53,21 @@ void GuardCondition::detach_condition() condition_variable_ = nullptr; } +bool GuardCondition::has_triggered() const +{ + std::lock_guard lock(internal_mutex_); + return has_triggered_; +} + ///============================================================================= bool GuardCondition::get_and_reset_trigger() { std::lock_guard lock(internal_mutex_); bool ret = has_triggered_; - // There is no data associated with the guard condition, so as soon as the callers asks about the - // state, we can immediately reset and get ready for the next trigger. has_triggered_ = false; return ret; } + } // namespace rmw_zenoh_cpp diff --git a/rmw_zenoh_cpp/src/detail/guard_condition.hpp b/rmw_zenoh_cpp/src/detail/guard_condition.hpp index 07e1e6b0..9adb737e 100644 --- a/rmw_zenoh_cpp/src/detail/guard_condition.hpp +++ b/rmw_zenoh_cpp/src/detail/guard_condition.hpp @@ -35,6 +35,8 @@ class GuardCondition final void detach_condition(); + bool has_triggered() const; + bool get_and_reset_trigger(); private: diff --git a/rmw_zenoh_cpp/src/rmw_zenoh.cpp b/rmw_zenoh_cpp/src/rmw_zenoh.cpp index 87aebac8..c3deb4f8 100644 --- a/rmw_zenoh_cpp/src/rmw_zenoh.cpp +++ b/rmw_zenoh_cpp/src/rmw_zenoh.cpp @@ -3137,20 +3137,18 @@ rmw_destroy_wait_set(rmw_wait_set_t * wait_set) } static bool has_triggered_condition( - rmw_subscriptions_t * subscriptions, - rmw_guard_conditions_t * guard_conditions, - rmw_services_t * services, - rmw_clients_t * clients, - rmw_events_t * events) + const rmw_subscriptions_t * const subscriptions, + const rmw_guard_conditions_t * const guard_conditions, + const rmw_services_t * const services, + const rmw_clients_t * const clients, + const rmw_events_t * const events) { - static_cast(events); - if (guard_conditions) { for (size_t i = 0; i < guard_conditions->guard_condition_count; ++i) { rmw_zenoh_cpp::GuardCondition * gc = static_cast(guard_conditions->guard_conditions[i]); if (gc != nullptr) { - if (gc->get_and_reset_trigger()) { + if (gc->has_triggered()) { return true; } }