123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165 |
- // Copyright 2016 Proyectos y Sistemas de Mantenimiento SL (eProsima).
- //
- // Licensed under the Apache License, Version 2.0 (the "License");
- // you may not use this file except in compliance with the License.
- // You may obtain a copy of the License at
- //
- // http://www.apache.org/licenses/LICENSE-2.0
- //
- // Unless required by applicable law or agreed to in writing, software
- // distributed under the License is distributed on an "AS IS" BASIS,
- // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- // See the License for the specific language governing permissions and
- // limitations under the License.
- /**
- * @file ResourceEvent.h
- *
- */
- #ifndef _FASTDDS_RTPS_RESOURCES_RESOURCEEVENT_H_
- #define _FASTDDS_RTPS_RESOURCES_RESOURCEEVENT_H_
- #ifndef DOXYGEN_SHOULD_SKIP_THIS_PUBLIC
- #include <fastrtps/utils/TimedMutex.hpp>
- #include <fastrtps/utils/TimedConditionVariable.hpp>
- #include <thread>
- #include <atomic>
- #include <vector>
- namespace eprosima {
- namespace fastrtps {
- namespace rtps {
- class TimedEventImpl;
- /**
- * This class centralizes all operations over timed events in the same thread.
- * @ingroup MANAGEMENT_MODULE
- */
- class ResourceEvent
- {
- public:
- ResourceEvent() = default;
- ~ResourceEvent();
- /*!
- * @brief Method to initialize the internal thread.
- */
- void init_thread();
- /*!
- * @brief This method informs that a TimedEventImpl has been created.
- *
- * This method has to be called when creating a TimedEventImpl object.
- * @param event TimedEventImpl object that has been created.
- */
- void register_timer(
- TimedEventImpl* event);
- /*!
- * @brief This method removes a TimedEventImpl object in case it is waiting to be processed by ResourceEvent's
- * internal thread.
- *
- * This method has to be called before deleting the TimedEventImpl object.
- * This method cancels any operation of the timer.
- * Then it avoids the situation of the execution thread calling the event handler when it was previously removed.
- * @param event TimedEventImpl object that will be deleted and we have to be sure all its operations are cancelled.
- */
- void unregister_timer(
- TimedEventImpl* event);
- /*!
- * @brief This method notifies to ResourceEvent that the TimedEventImpl object has operations to be scheduled.
- *
- * These operations can be the cancellation of the timer or starting another async_wait.
- * @param event TimedEventImpl object that has operations to be scheduled.
- */
- void notify(
- TimedEventImpl* event);
- /*!
- * @brief This method notifies to ResourceEvent that the TimedEventImpl object has operations to be scheduled.
- *
- * These operations can be the cancellation of the timer or starting another async_wait.
- * @note Non-blocking call version of the method.
- * @param event TimedEventImpl object that has operations to be scheduled.
- * @param timeout Maximum blocking time of the method.
- */
- void notify(
- TimedEventImpl* event,
- const std::chrono::steady_clock::time_point& timeout);
- private:
- //! Warns the internal thread can stop.
- std::atomic<bool> stop_{ false };
- //! Protects internal data.
- TimedMutex mutex_;
- //! Used to warn about changes on allow_vector_manipulation_.
- TimedConditionVariable cv_manipulation_;
- //! Flag used to allow a thread to manipulate the timer collections when the execution thread is not using them.
- bool allow_vector_manipulation_ = true;
- //! Used to warn there are new TimedEventImpl objects to be processed.
- TimedConditionVariable cv_;
- //! The total number of created timers.
- size_t timers_count_ = 0;
- //! Collection of events pending update action.
- std::vector<TimedEventImpl*> pending_timers_;
- //! Collection of registered events waiting completion.
- std::vector<TimedEventImpl*> active_timers_;
- //! Current time as seen by the execution thread.
- std::chrono::steady_clock::time_point current_time_;
- //! Execution thread.
- std::thread thread_;
- /*!
- * @brief Registers a new TimedEventImpl object in the internal queue to be processed.
- * Non thread safe.
- * @param event Event to be added in the queue.
- * @return True value if the insertion was successful. In other case, it return False.
- */
- bool register_timer_nts(
- TimedEventImpl* event);
- //! Method called by the internal thread.
- void event_service();
- //! Sorts waiting timers in ascending order of trigger time.
- void sort_timers();
- //! Updates internal register of current time.
- void update_current_time();
- //! Method called by the internal thread to process due actions.
- void do_timer_actions();
- //! Ensures internal collections can accommodate current total number of timers.
- void resize_collections()
- {
- pending_timers_.reserve(timers_count_);
- active_timers_.reserve(timers_count_);
- }
- };
- } /* namespace rtps */
- } /* namespace fastrtps */
- } /* namespace eprosima */
- #endif //DOXYGEN_SHOULD_SKIP_THIS_PUBLIC
- #endif //_FASTDDS_RTPS_RESOURCES_RESOURCEEVENT_H_
|