From 0a51dbe7f9396015ecd3b96b630a77a82ae69a69 Mon Sep 17 00:00:00 2001 From: Miguel Company Date: Fri, 4 Oct 2024 07:43:55 +0200 Subject: [PATCH 1/8] Fix issues in Dynamic Network Interfaces (#5282) * Refs #21690. Parse `--rescan` argument on communication applications. Signed-off-by: Miguel Company * Refs #21690. Implement rescan mechanism. Signed-off-by: Miguel Company * Refs #21690. Add docker infrastructure. Signed-off-by: Miguel Company * Refs #21690. Add CMake infrastructure. Signed-off-by: Miguel Company * Refs #21690. Ensure same domain and topic name are used. Signed-off-by: Miguel Company * Refs #21690. Add `--loops` argument to publisher. Signed-off-by: Miguel Company * Refs #21690. Publisher exits after publishing all samples. Signed-off-by: Miguel Company * Refs #21690. Improve subscriber script. Signed-off-by: Miguel Company * Refs #21690. Add test. Signed-off-by: Miguel Company * Refs #21690. Make publisher wait subscriber. Signed-off-by: Miguel Company * Refs #21690. Possible fix. Signed-off-by: Miguel Company * Refs #21690. Clear locators before recalculating them. Signed-off-by: Miguel Company * Refs #21690. Move local participant proxy update to PDP. Signed-off-by: Miguel Company * Refs #21690. Improve new method's logic. Signed-off-by: Miguel Company * Refs #21690. Include what you use. Signed-off-by: Miguel Company * Refs #21690. Add empty method to update endpoint locators. Signed-off-by: Miguel Company * Refs #21690. Add implementation for `update_endpoint_locators_if_default_nts`. Signed-off-by: Miguel Company * Refs #21690. Compare against old default locators. Signed-off-by: Miguel Company * Refs #21690. Update locators in attributes. Signed-off-by: Miguel Company * Refs #17283. Avoid early return on `PDP::local_participant_attributes_update_nts`. Signed-off-by: Miguel Company * Refs #17283. Apply suggestions. Signed-off-by: Miguel Company --------- Signed-off-by: Miguel Company (cherry picked from commit 91bd7c857d8760f1a523e878368f895fbc41a955) --- .../rtps/builtin/discovery/participant/PDP.h | 49 ++++++ .../builtin/discovery/participant/PDP.cpp | 161 ++++++++++++++++++ .../rtps/participant/RTPSParticipantImpl.cpp | 22 +++ test/dds/communication/CMakeLists.txt | 4 + test/dds/communication/PubSubMain.cpp | 6 +- test/dds/communication/PublisherMain.cpp | 28 ++- test/dds/communication/PublisherModule.cpp | 20 +++ test/dds/communication/PublisherModule.hpp | 20 ++- test/dds/communication/SubscriberMain.cpp | 19 ++- test/dds/communication/SubscriberModule.cpp | 23 ++- test/dds/communication/SubscriberModule.hpp | 21 ++- .../communication/dyn_network/CMakeLists.txt | 61 +++++++ test/dds/communication/dyn_network/Dockerfile | 27 +++ .../dynamic_interfaces.compose.yml | 42 +++++ .../dyn_network/launch_subscriber.bash | 33 ++++ .../communication/security/PublisherMain.cpp | 16 +- .../security/PublisherModule.cpp | 20 +++ .../security/PublisherModule.hpp | 19 ++- .../communication/security/SubscriberMain.cpp | 15 +- .../security/SubscriberModule.cpp | 25 ++- .../security/SubscriberModule.hpp | 19 ++- 21 files changed, 613 insertions(+), 37 deletions(-) create mode 100644 test/dds/communication/dyn_network/CMakeLists.txt create mode 100644 test/dds/communication/dyn_network/Dockerfile create mode 100644 test/dds/communication/dyn_network/dynamic_interfaces.compose.yml create mode 100755 test/dds/communication/dyn_network/launch_subscriber.bash diff --git a/include/fastdds/rtps/builtin/discovery/participant/PDP.h b/include/fastdds/rtps/builtin/discovery/participant/PDP.h index f9eb5f2731b..bf5d06e7142 100644 --- a/include/fastdds/rtps/builtin/discovery/participant/PDP.h +++ b/include/fastdds/rtps/builtin/discovery/participant/PDP.h @@ -22,10 +22,14 @@ #ifndef DOXYGEN_SHOULD_SKIP_THIS_PUBLIC #include +#include #include #include #include +#include +#include +<<<<<<< HEAD:include/fastdds/rtps/builtin/discovery/participant/PDP.h #include #include #include @@ -37,6 +41,35 @@ #include #include #include +======= +#include + +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include + +#include +#include +#include +#include +#include +#include +>>>>>>> 91bd7c857 (Fix issues in Dynamic Network Interfaces (#5282)):src/cpp/rtps/builtin/discovery/participant/PDP.h namespace eprosima { @@ -51,6 +84,7 @@ struct IProxyObserver; namespace rtps { +<<<<<<< HEAD:include/fastdds/rtps/builtin/discovery/participant/PDP.h class PDPServerListener; class PDPEndpoints; @@ -68,8 +102,13 @@ namespace rtps { class RTPSWriter; class RTPSReader; +======= +class BaseWriter; +class BaseReader; +>>>>>>> 91bd7c857 (Fix issues in Dynamic Network Interfaces (#5282)):src/cpp/rtps/builtin/discovery/participant/PDP.h class WriterHistory; class ReaderHistory; +struct RTPSParticipantAllocationAttributes; class RTPSParticipantImpl; class RTPSParticipantListener; class BuiltinProtocols; @@ -79,6 +118,7 @@ class ReaderProxyData; class WriterProxyData; class ParticipantProxyData; class ReaderListener; +class PDPEndpoints; class PDPListener; class PDPServerListener; class ITopicPayloadPool; @@ -493,6 +533,15 @@ class PDP : public fastdds::statistics::rtps::IProxyQueryable #endif // FASTDDS_STATISTICS + virtual void local_participant_attributes_update_nts( + const RTPSParticipantAttributes& new_atts); + + virtual void update_endpoint_locators_if_default_nts( + const std::vector& writers, + const std::vector& readers, + const RTPSParticipantAttributes& old_atts, + const RTPSParticipantAttributes& new_atts); + protected: //!Pointer to the builtin protocols object. diff --git a/src/cpp/rtps/builtin/discovery/participant/PDP.cpp b/src/cpp/rtps/builtin/discovery/participant/PDP.cpp index 6aaa543991f..025aaedc7fb 100644 --- a/src/cpp/rtps/builtin/discovery/participant/PDP.cpp +++ b/src/cpp/rtps/builtin/discovery/participant/PDP.cpp @@ -66,6 +66,52 @@ #include #include +<<<<<<< HEAD +======= +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include + +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#if HAVE_SECURITY +#include +#endif // if HAVE_SECURITY +#include +#include +#include +#include + +>>>>>>> 91bd7c857 (Fix issues in Dynamic Network Interfaces (#5282)) namespace eprosima { namespace fastrtps { namespace rtps { @@ -1662,6 +1708,121 @@ void PDP::add_builtin_security_attributes( #endif // HAVE_SECURITY +void PDP::local_participant_attributes_update_nts( + const RTPSParticipantAttributes& new_atts) +{ + // Update user data + auto participant_data = getLocalParticipantProxyData(); + participant_data->m_userData.data_vec(new_atts.userData); + + // If we are intraprocess only, we do not need to update locators + bool announce_locators = !mp_RTPSParticipant->is_intraprocess_only(); + if (announce_locators) + { + // Clear all locators + participant_data->metatraffic_locators.unicast.clear(); + participant_data->metatraffic_locators.multicast.clear(); + participant_data->default_locators.unicast.clear(); + participant_data->default_locators.multicast.clear(); + + // Update default locators + for (const Locator_t& loc : new_atts.defaultUnicastLocatorList) + { + participant_data->default_locators.add_unicast_locator(loc); + } + for (const Locator_t& loc : new_atts.defaultMulticastLocatorList) + { + participant_data->default_locators.add_multicast_locator(loc); + } + + // Update metatraffic locators + for (const auto& locator : new_atts.builtin.metatrafficUnicastLocatorList) + { + participant_data->metatraffic_locators.add_unicast_locator(locator); + } + if (!new_atts.builtin.avoid_builtin_multicast || participant_data->metatraffic_locators.unicast.empty()) + { + for (const auto& locator : new_atts.builtin.metatrafficMulticastLocatorList) + { + participant_data->metatraffic_locators.add_multicast_locator(locator); + } + } + + fastdds::rtps::network::external_locators::add_external_locators(*participant_data, + new_atts.builtin.metatraffic_external_unicast_locators, + new_atts.default_external_unicast_locators); + } +} + +void PDP::update_endpoint_locators_if_default_nts( + const std::vector& writers, + const std::vector& readers, + const RTPSParticipantAttributes& old_atts, + const RTPSParticipantAttributes& new_atts) +{ + // Check if default locators have changed + const auto& old_default_unicast = old_atts.defaultUnicastLocatorList; + const auto& old_default_multicast = old_atts.defaultMulticastLocatorList; + const auto& new_default_unicast = new_atts.defaultUnicastLocatorList; + const auto& new_default_multicast = new_atts.defaultMulticastLocatorList; + + // Early return if there is no change in default unicast locators + if ((old_default_unicast == new_default_unicast) && + (old_default_multicast == new_default_multicast)) + { + return; + } + + // Update proxies of endpoints with default configured locators + EDP* edp = get_edp(); + for (BaseWriter* writer : writers) + { + if ((old_default_multicast == writer->getAttributes().multicastLocatorList) && + (old_default_unicast == writer->getAttributes().unicastLocatorList)) + { + writer->getAttributes().multicastLocatorList = new_default_multicast; + writer->getAttributes().unicastLocatorList = new_default_unicast; + + WriterProxyData* wdata = nullptr; + GUID_t participant_guid; + wdata = addWriterProxyData(writer->getGuid(), participant_guid, + [](WriterProxyData* proxy, bool is_update, const ParticipantProxyData& participant) + { + static_cast(is_update); + assert(is_update); + + proxy->set_locators(participant.default_locators); + return true; + }); + assert(wdata != nullptr); + edp->process_writer_proxy_data(writer, wdata); + } + } + for (BaseReader* reader : readers) + { + if ((old_default_multicast == reader->getAttributes().multicastLocatorList) && + (old_default_unicast == reader->getAttributes().unicastLocatorList)) + { + reader->getAttributes().multicastLocatorList = new_default_multicast; + reader->getAttributes().unicastLocatorList = new_default_unicast; + + ReaderProxyData* rdata = nullptr; + GUID_t participant_guid; + rdata = addReaderProxyData(reader->getGuid(), participant_guid, + [](ReaderProxyData* proxy, bool is_update, const ParticipantProxyData& participant) + { + static_cast(is_update); + assert(is_update); + + proxy->set_locators(participant.default_locators); + return true; + }); + assert(rdata != nullptr); + edp->process_reader_proxy_data(reader, rdata); + } + } +} + } /* namespace rtps */ } /* namespace fastrtps */ } /* namespace eprosima */ diff --git a/src/cpp/rtps/participant/RTPSParticipantImpl.cpp b/src/cpp/rtps/participant/RTPSParticipantImpl.cpp index 921257b3926..bc017513028 100644 --- a/src/cpp/rtps/participant/RTPSParticipantImpl.cpp +++ b/src/cpp/rtps/participant/RTPSParticipantImpl.cpp @@ -1539,9 +1539,16 @@ void RTPSParticipantImpl::update_attributes( // Check if new interfaces have been added if (internal_metatraffic_locators_) { +<<<<<<< HEAD LocatorList_t metatraffic_unicast_locator_list = m_att.builtin.metatrafficUnicastLocatorList; get_default_metatraffic_locators(); if (!(metatraffic_unicast_locator_list == m_att.builtin.metatrafficUnicastLocatorList)) +======= + LocatorList_t metatraffic_unicast_locator_list = temp_atts.builtin.metatrafficUnicastLocatorList; + temp_atts.builtin.metatrafficUnicastLocatorList.clear(); + get_default_metatraffic_locators(temp_atts); + if (!(metatraffic_unicast_locator_list == temp_atts.builtin.metatrafficUnicastLocatorList)) +>>>>>>> 91bd7c857 (Fix issues in Dynamic Network Interfaces (#5282)) { local_interfaces_changed = true; EPROSIMA_LOG_INFO(RTPS_PARTICIPANT, m_att.getName() << " updated its metatraffic locators"); @@ -1549,9 +1556,16 @@ void RTPSParticipantImpl::update_attributes( } if (internal_default_locators_) { +<<<<<<< HEAD LocatorList_t default_unicast_locator_list = m_att.defaultUnicastLocatorList; get_default_unicast_locators(); if (!(default_unicast_locator_list == m_att.defaultUnicastLocatorList)) +======= + LocatorList_t default_unicast_locator_list = temp_atts.defaultUnicastLocatorList; + temp_atts.defaultUnicastLocatorList.clear(); + get_default_unicast_locators(temp_atts); + if (!(default_unicast_locator_list == temp_atts.defaultUnicastLocatorList)) +>>>>>>> 91bd7c857 (Fix issues in Dynamic Network Interfaces (#5282)) { local_interfaces_changed = true; EPROSIMA_LOG_INFO(RTPS_PARTICIPANT, @@ -1673,7 +1687,9 @@ void RTPSParticipantImpl::update_attributes( { std::lock_guard lock(*pdp->getMutex()); + pdp->local_participant_attributes_update_nts(temp_atts); +<<<<<<< HEAD // Update user data auto local_participant_proxy_data = pdp->getLocalParticipantProxyData(); local_participant_proxy_data->m_userData.data_vec(m_att.userData); @@ -1692,6 +1708,12 @@ void RTPSParticipantImpl::update_attributes( for (auto locator : m_att.defaultUnicastLocatorList) { local_participant_proxy_data->default_locators.add_unicast_locator(locator); +======= + if (local_interfaces_changed && internal_default_locators_) + { + std::lock_guard _(endpoints_list_mutex); + pdp->update_endpoint_locators_if_default_nts(m_userWriterList, m_userReaderList, m_att, temp_atts); +>>>>>>> 91bd7c857 (Fix issues in Dynamic Network Interfaces (#5282)) } if (local_interfaces_changed) diff --git a/test/dds/communication/CMakeLists.txt b/test/dds/communication/CMakeLists.txt index d2696757422..37e11ef4f00 100644 --- a/test/dds/communication/CMakeLists.txt +++ b/test/dds/communication/CMakeLists.txt @@ -314,3 +314,7 @@ if(Python3_Interpreter_FOUND) endif() endif() + +if(UNIX AND NOT(APPLE) AND NOT(QNXNTO) AND NOT(ANDROID)) + add_subdirectory(dyn_network) +endif() diff --git a/test/dds/communication/PubSubMain.cpp b/test/dds/communication/PubSubMain.cpp index 46553c9f64b..11ea78de1ee 100644 --- a/test/dds/communication/PubSubMain.cpp +++ b/test/dds/communication/PubSubMain.cpp @@ -52,7 +52,7 @@ void publisher_run( publisher->wait_discovery(wait); } - publisher->run(samples, loops, interval); + publisher->run(samples, 0, loops, interval); } int main( @@ -197,7 +197,7 @@ int main( DomainParticipantFactory::get_instance()->load_XML_profiles_file(xml_file); } - SubscriberModule subscriber(publishers, samples, fixed_type, zero_copy); + SubscriberModule subscriber(publishers, samples, fixed_type, zero_copy, false, false); PublisherModule publisher(exit_on_lost_liveliness, fixed_type, zero_copy); uint32_t result = 1; @@ -208,7 +208,7 @@ int main( if (subscriber.init(seed, magic)) { - result = subscriber.run(notexit, timeout) ? 0 : -1; + result = subscriber.run(notexit, 0, timeout) ? 0 : -1; } publisher_thread.join(); diff --git a/test/dds/communication/PublisherMain.cpp b/test/dds/communication/PublisherMain.cpp index 0d72b20ae5b..3124e1c592d 100644 --- a/test/dds/communication/PublisherMain.cpp +++ b/test/dds/communication/PublisherMain.cpp @@ -29,9 +29,11 @@ using namespace eprosima::fastdds::dds; * --seed * --wait * --samples + * --loops + * --interval * --magic * --xmlfile - * --interval + * --rescan */ int main( @@ -46,7 +48,9 @@ int main( uint32_t wait = 0; char* xml_file = nullptr; uint32_t samples = 4; + uint32_t loops = 0; uint32_t interval = 250; + uint32_t rescan_interval_seconds = 0; std::string magic; while (arg_count < argc) @@ -93,6 +97,16 @@ int main( samples = strtol(argv[arg_count], nullptr, 10); } + else if (strcmp(argv[arg_count], "--loops") == 0) + { + if (++arg_count >= argc) + { + std::cout << "--loops expects a parameter" << std::endl; + return -1; + } + + loops = strtol(argv[arg_count], nullptr, 10); + } else if (strcmp(argv[arg_count], "--interval") == 0) { if (++arg_count >= argc) @@ -123,6 +137,16 @@ int main( xml_file = argv[arg_count]; } + else if (strcmp(argv[arg_count], "--rescan") == 0) + { + if (++arg_count >= argc) + { + std::cout << "--rescan expects a parameter" << std::endl; + return -1; + } + + rescan_interval_seconds = strtol(argv[arg_count], nullptr, 10); + } else { std::cout << "Wrong argument " << argv[arg_count] << std::endl; @@ -146,7 +170,7 @@ int main( publisher.wait_discovery(wait); } - publisher.run(samples, 0, interval); + publisher.run(samples, rescan_interval_seconds, loops, interval); return 0; } diff --git a/test/dds/communication/PublisherModule.cpp b/test/dds/communication/PublisherModule.cpp index d798a5c8434..f43a4c3062d 100644 --- a/test/dds/communication/PublisherModule.cpp +++ b/test/dds/communication/PublisherModule.cpp @@ -134,6 +134,7 @@ void PublisherModule::wait_discovery( void PublisherModule::run( uint32_t samples, + const uint32_t rescan_interval, const uint32_t loops, uint32_t interval) { @@ -141,6 +142,22 @@ void PublisherModule::run( uint16_t index = 1; void* sample = nullptr; + std::thread net_rescan_thread([this, rescan_interval]() + { + if (rescan_interval > 0) + { + auto interval = std::chrono::seconds(rescan_interval); + while (run_) + { + std::this_thread::sleep_for(interval); + if (run_) + { + participant_->set_qos(participant_->get_qos()); + } + } + } + }); + while (run_ && (loops == 0 || loops > current_loop)) { if (zero_copy_) @@ -187,6 +204,9 @@ void PublisherModule::run( std::this_thread::sleep_for(std::chrono::milliseconds(interval)); } + + run_ = false; + net_rescan_thread.join(); } void PublisherModule::on_publication_matched( diff --git a/test/dds/communication/PublisherModule.hpp b/test/dds/communication/PublisherModule.hpp index fb144821a0a..0f8905c13ff 100644 --- a/test/dds/communication/PublisherModule.hpp +++ b/test/dds/communication/PublisherModule.hpp @@ -19,6 +19,15 @@ #ifndef TEST_DDS_COMMUNICATION_PUBLISHERMODULE_HPP #define TEST_DDS_COMMUNICATION_PUBLISHERMODULE_HPP +<<<<<<< HEAD +======= +#include +#include +#include +#include + +#include +>>>>>>> 91bd7c857 (Fix issues in Dynamic Network Interfaces (#5282)) #include #include #include @@ -41,8 +50,8 @@ class PublisherModule PublisherModule( bool exit_on_lost_liveliness, - bool fixed_type = false, - bool zero_copy = false) + bool fixed_type, + bool zero_copy) : exit_on_lost_liveliness_(exit_on_lost_liveliness) , fixed_type_(zero_copy || fixed_type) // If zero copy active, fixed type is required , zero_copy_(zero_copy) @@ -80,8 +89,9 @@ class PublisherModule void run( uint32_t samples, - uint32_t loops = 0, - uint32_t interval = 250); + const uint32_t rescan_interval, + uint32_t loops, + uint32_t interval); private: @@ -93,7 +103,7 @@ class PublisherModule bool exit_on_lost_liveliness_ = false; bool fixed_type_ = false; bool zero_copy_ = false; - bool run_ = true; + std::atomic_bool run_{true}; DomainParticipant* participant_ = nullptr; TypeSupport type_; Publisher* publisher_ = nullptr; diff --git a/test/dds/communication/SubscriberMain.cpp b/test/dds/communication/SubscriberMain.cpp index cb96f16ffb8..eee9b3e0e1e 100644 --- a/test/dds/communication/SubscriberMain.cpp +++ b/test/dds/communication/SubscriberMain.cpp @@ -26,13 +26,15 @@ using namespace eprosima::fastdds::dds; * --notexit * --fixed_type * --zero_copy + * --succeed_on_timeout * --seed * --samples * --magic + * --timeout * --xmlfile * --publishers - * --succeed_on_timeout - * --timeout + * --die_on_data_received + * --rescan */ int main( @@ -49,6 +51,7 @@ int main( uint32_t samples = 4; uint32_t publishers = 1; uint32_t timeout = 86400000; // 24 h in ms + uint32_t rescan_interval_seconds = 0; char* xml_file = nullptr; std::string magic; @@ -134,6 +137,16 @@ int main( { die_on_data_received = true; } + else if (strcmp(argv[arg_count], "--rescan") == 0) + { + if (++arg_count >= argc) + { + std::cout << "--rescan expects a parameter" << std::endl; + return -1; + } + + rescan_interval_seconds = strtol(argv[arg_count], nullptr, 10); + } else { std::cout << "Wrong argument " << argv[arg_count] << std::endl; @@ -152,7 +165,7 @@ int main( if (subscriber.init(seed, magic)) { - return subscriber.run(notexit, timeout) ? 0 : -1; + return subscriber.run(notexit, rescan_interval_seconds, timeout) ? 0 : -1; } return -1; diff --git a/test/dds/communication/SubscriberModule.cpp b/test/dds/communication/SubscriberModule.cpp index 77992bbd823..d0336e6dc73 100644 --- a/test/dds/communication/SubscriberModule.cpp +++ b/test/dds/communication/SubscriberModule.cpp @@ -132,17 +132,35 @@ bool SubscriberModule::init( bool SubscriberModule::run( bool notexit, + const uint32_t rescan_interval, uint32_t timeout) { - return run_for(notexit, std::chrono::milliseconds(timeout)); + return run_for(notexit, rescan_interval, std::chrono::milliseconds(timeout)); } bool SubscriberModule::run_for( bool notexit, + const uint32_t rescan_interval, const std::chrono::milliseconds& timeout) { bool returned_value = false; + std::thread net_rescan_thread([this, rescan_interval]() + { + if (rescan_interval > 0) + { + auto interval = std::chrono::seconds(rescan_interval); + while (run_) + { + std::this_thread::sleep_for(interval); + if (run_) + { + participant_->set_qos(participant_->get_qos()); + } + } + } + }); + while (notexit && run_) { std::this_thread::sleep_for(std::chrono::milliseconds(250)); @@ -192,6 +210,9 @@ bool SubscriberModule::run_for( returned_value = false; } + run_ = false; + net_rescan_thread.join(); + return returned_value; } diff --git a/test/dds/communication/SubscriberModule.hpp b/test/dds/communication/SubscriberModule.hpp index 901e3137dc7..62226538c8c 100644 --- a/test/dds/communication/SubscriberModule.hpp +++ b/test/dds/communication/SubscriberModule.hpp @@ -19,6 +19,7 @@ #ifndef TEST_COMMUNICATION_SUBSCRIBER_HPP #define TEST_COMMUNICATION_SUBSCRIBER_HPP +<<<<<<< HEAD #include #include #include @@ -28,9 +29,13 @@ #include "types/HelloWorldPubSubTypes.h" #include +======= +#include +#include +>>>>>>> 91bd7c857 (Fix issues in Dynamic Network Interfaces (#5282)) #include #include -#include +#include namespace eprosima { namespace fastdds { @@ -44,10 +49,10 @@ class SubscriberModule SubscriberModule( const uint32_t publishers, const uint32_t max_number_samples, - bool fixed_type = false, - bool zero_copy = false, - bool succeed_on_timeout = false, - bool die_on_data_received = false) + bool fixed_type, + bool zero_copy, + bool succeed_on_timeout, + bool die_on_data_received) : publishers_(publishers) , max_number_samples_(max_number_samples) , fixed_type_(zero_copy || fixed_type) // If zero copy active, fixed type is required @@ -86,10 +91,12 @@ class SubscriberModule bool run( bool notexit, - uint32_t timeout = 86400000); + const uint32_t rescan_interval, + uint32_t timeout); bool run_for( bool notexit, + const uint32_t rescan_interval, const std::chrono::milliseconds& timeout); private: @@ -103,7 +110,7 @@ class SubscriberModule std::map number_samples_; bool fixed_type_ = false; bool zero_copy_ = false; - bool run_ = true; + std::atomic_bool run_{true}; bool succeed_on_timeout_ = false; DomainParticipant* participant_ = nullptr; TypeSupport type_; diff --git a/test/dds/communication/dyn_network/CMakeLists.txt b/test/dds/communication/dyn_network/CMakeLists.txt new file mode 100644 index 00000000000..0d95ac665e0 --- /dev/null +++ b/test/dds/communication/dyn_network/CMakeLists.txt @@ -0,0 +1,61 @@ +# Copyright 2024 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. +message(STATUS "Configuring dynamic network interfaces tests") + +# Find docker +find_program(DOCKER_EXECUTABLE docker) +if(NOT DOCKER_EXECUTABLE) + message(FATAL_ERROR "Docker not found") +endif() + +set(SHELL_EXECUTABLE "") +set(TINYXML2_LIB_DIR_COMPOSE_VOLUME "") +set(TINYXML2_LIB_DIR_COMPOSE_LD_LIBRARY_PATH "") + +# Linux configurations +if(UNIX AND NOT(APPLE) AND NOT(QNXNTO) AND NOT(ANDROID)) + # Find bash + find_program(BASH_EXECUTABLE bash) + if(NOT BASH_EXECUTABLE) + message(FATAL_ERROR "bash not found") + endif() + + set(SHELL_EXECUTABLE ${BASH_EXECUTABLE}) + +# Windows configurations +elseif(WIN32) + # We don't know which docker image to use for Windows yet + message(FATAL_ERROR "Windows not supported yet") + +# Unsupported platform +else() + message(FATAL_ERROR "Unsupported platform") +endif() + +# Configure TinyXML2 library path if installed in user library path +if(NOT (TINYXML2_FROM_SOURCE OR TINYXML2_FROM_THIRDPARTY)) + get_filename_component(TINYXML2_LIB_DIR ${TINYXML2_LIBRARY} DIRECTORY) + set(TINYXML2_LIB_DIR_COMPOSE_VOLUME "- ${TINYXML2_LIB_DIR}:${CMAKE_INSTALL_PREFIX}/${DATA_INSTALL_DIR}/fastdds:ro") + set(TINYXML2_LIB_DIR_COMPOSE_LD_LIBRARY_PATH ":${CMAKE_INSTALL_PREFIX}/${DATA_INSTALL_DIR}/fastdds") +endif() + +configure_file(Dockerfile + ${CMAKE_CURRENT_BINARY_DIR}/Dockerfile @ONLY) +configure_file(dynamic_interfaces.compose.yml + ${CMAKE_CURRENT_BINARY_DIR}/dynamic_interfaces.compose.yml @ONLY) +configure_file(launch_subscriber.bash + ${CMAKE_CURRENT_BINARY_DIR}/launch_subscriber.bash @ONLY) +add_test(NAME dds.communication.dynamic_interfaces + COMMAND ${DOCKER_EXECUTABLE} compose -f ${CMAKE_CURRENT_BINARY_DIR}/dynamic_interfaces.compose.yml up + WORKING_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}) diff --git a/test/dds/communication/dyn_network/Dockerfile b/test/dds/communication/dyn_network/Dockerfile new file mode 100644 index 00000000000..ebdcae10bba --- /dev/null +++ b/test/dds/communication/dyn_network/Dockerfile @@ -0,0 +1,27 @@ +# Copyright 2024 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. + +# Tag, branch, or commit in github.com/eProsima/DDS-Suite +ARG ubuntu_version=22.04 +FROM ubuntu:$ubuntu_version AS ubuntu-net-tools + +# Needed for a dependency that forces to set timezone +ENV TZ=Europe/Madrid +RUN ln -snf /usr/share/zoneinfo/$TZ /etc/localtime && echo $TZ > /etc/timezone + +# Avoids using interactions during building +ENV DEBIAN_FRONTEND=noninteractive + +# Install apt dependencies +RUN apt-get update && apt-get install --yes net-tools && rm -rf /var/lib/apt/lists/* diff --git a/test/dds/communication/dyn_network/dynamic_interfaces.compose.yml b/test/dds/communication/dyn_network/dynamic_interfaces.compose.yml new file mode 100644 index 00000000000..9d45abbbc48 --- /dev/null +++ b/test/dds/communication/dyn_network/dynamic_interfaces.compose.yml @@ -0,0 +1,42 @@ +# Copyright 2024 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. +version: "3" + +services: + publisher: + image: ubuntu:22.04 + volumes: + - @PROJECT_BINARY_DIR@:@PROJECT_BINARY_DIR@ + - @fastcdr_LIB_DIR@:@fastcdr_LIB_DIR@ + @TINYXML2_LIB_DIR_COMPOSE_VOLUME@ + environment: + LD_LIBRARY_PATH: @PROJECT_BINARY_DIR@/src/cpp:@fastcdr_LIB_DIR@@TINYXML2_LIB_DIR_COMPOSE_LD_LIBRARY_PATH@ + EXAMPLE_DIR: @PROJECT_BINARY_DIR@/test/dds/communication + command: @SHELL_EXECUTABLE@ -c "$${EXAMPLE_DIR}/DDSCommunicationPublisher --xmlfile $${EXAMPLE_DIR}/simple_reliable_profile.xml --wait 1 --samples 10 --loops 1 --seed 0 --magic T" + + subscriber: + build: . + image: ubuntu-net-tools:22.04 + privileged: true + volumes: + - @PROJECT_BINARY_DIR@:@PROJECT_BINARY_DIR@ + - @fastcdr_LIB_DIR@:@fastcdr_LIB_DIR@ + @TINYXML2_LIB_DIR_COMPOSE_VOLUME@ + environment: + LD_LIBRARY_PATH: @PROJECT_BINARY_DIR@/src/cpp:@fastcdr_LIB_DIR@@TINYXML2_LIB_DIR_COMPOSE_LD_LIBRARY_PATH@ + EXAMPLE_DIR: @PROJECT_BINARY_DIR@/test/dds/communication + working_dir: @PROJECT_BINARY_DIR@/test/dds/communication + command: @SHELL_EXECUTABLE@ "dyn_network/launch_subscriber.bash" + depends_on: + - publisher diff --git a/test/dds/communication/dyn_network/launch_subscriber.bash b/test/dds/communication/dyn_network/launch_subscriber.bash new file mode 100755 index 00000000000..9ee62e1338b --- /dev/null +++ b/test/dds/communication/dyn_network/launch_subscriber.bash @@ -0,0 +1,33 @@ +# Copyright 2019 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. + +#!/bin/bash + +# Note: This script is intended to be used in a privileged container, since it requires to bring down and up the eth0 interface. + +echo "Putting down eth0 interface..." +ifconfig eth0 down + +echo "Launching subscriber..." +${EXAMPLE_DIR}/DDSCommunicationSubscriber --xmlfile ${EXAMPLE_DIR}/simple_reliable_profile.xml --samples 10 --seed 0 --magic T --rescan 2 & +subs_pid=$! +echo "Subscriber launched." + +echo "Waiting 2 seconds and bring up eth0 interface..." +sleep 2s +ifconfig eth0 up +echo "eth0 interface is up." + +echo "Waiting 3s for the subscriber (process id $subs_pid) to finish..." +wait $subs_pid diff --git a/test/dds/communication/security/PublisherMain.cpp b/test/dds/communication/security/PublisherMain.cpp index 2b87543a7d6..35a8e692c49 100644 --- a/test/dds/communication/security/PublisherMain.cpp +++ b/test/dds/communication/security/PublisherMain.cpp @@ -29,9 +29,10 @@ using namespace eprosima::fastdds::dds; * --seed * --wait * --samples + * --interval * --magic * --xmlfile - * --interval + * --rescan */ int main( @@ -48,6 +49,7 @@ int main( char* xml_file = nullptr; uint32_t samples = 4; uint32_t interval = 250; + uint32_t rescan_interval_seconds = 0; std::string magic; while (arg_count < argc) @@ -128,6 +130,16 @@ int main( xml_file = argv[arg_count]; } + else if (strcmp(argv[arg_count], "--rescan") == 0) + { + if (++arg_count >= argc) + { + std::cout << "--rescan expects a parameter" << std::endl; + return -1; + } + + rescan_interval_seconds = strtol(argv[arg_count], nullptr, 10); + } else { std::cout << "Wrong argument " << argv[arg_count] << std::endl; @@ -151,7 +163,7 @@ int main( publisher.wait_discovery(wait); } - publisher.run(samples, 0, interval); + publisher.run(samples, rescan_interval_seconds, 0, interval); return 0; } diff --git a/test/dds/communication/security/PublisherModule.cpp b/test/dds/communication/security/PublisherModule.cpp index ca7f60843b4..809822164f9 100644 --- a/test/dds/communication/security/PublisherModule.cpp +++ b/test/dds/communication/security/PublisherModule.cpp @@ -134,6 +134,7 @@ void PublisherModule::wait_discovery( void PublisherModule::run( uint32_t samples, + const uint32_t rescan_interval, const uint32_t loops, uint32_t interval) { @@ -141,6 +142,22 @@ void PublisherModule::run( uint16_t index = 1; void* sample = nullptr; + std::thread net_rescan_thread([this, rescan_interval]() + { + if (rescan_interval > 0) + { + auto interval = std::chrono::seconds(rescan_interval); + while (run_) + { + std::this_thread::sleep_for(interval); + if (run_) + { + participant_->set_qos(participant_->get_qos()); + } + } + } + }); + while (run_ && (loops == 0 || loops > current_loop)) { if (zero_copy_) @@ -187,6 +204,9 @@ void PublisherModule::run( std::this_thread::sleep_for(std::chrono::milliseconds(interval)); } + + run_ = false; + net_rescan_thread.join(); } void PublisherModule::on_publication_matched( diff --git a/test/dds/communication/security/PublisherModule.hpp b/test/dds/communication/security/PublisherModule.hpp index e4e99d5743c..e37d9155510 100644 --- a/test/dds/communication/security/PublisherModule.hpp +++ b/test/dds/communication/security/PublisherModule.hpp @@ -19,6 +19,14 @@ #ifndef TEST_DDS_COMMUNICATION_PUBLISHERMODULE_HPP #define TEST_DDS_COMMUNICATION_PUBLISHERMODULE_HPP +<<<<<<< HEAD +======= +#include +#include +#include + +#include +>>>>>>> 91bd7c857 (Fix issues in Dynamic Network Interfaces (#5282)) #include #include #include @@ -42,8 +50,8 @@ class PublisherModule PublisherModule( bool exit_on_lost_liveliness, bool exit_on_disposal_received, - bool fixed_type = false, - bool zero_copy = false) + bool fixed_type, + bool zero_copy) : exit_on_lost_liveliness_(exit_on_lost_liveliness) , exit_on_disposal_received_(exit_on_disposal_received) , fixed_type_(zero_copy || fixed_type) // If zero copy active, fixed type is required @@ -82,8 +90,9 @@ class PublisherModule void run( uint32_t samples, - uint32_t loops = 0, - uint32_t interval = 250); + const uint32_t rescan_interval, + uint32_t loops, + uint32_t interval); private: @@ -96,7 +105,7 @@ class PublisherModule bool exit_on_disposal_received_ = false; bool fixed_type_ = false; bool zero_copy_ = false; - bool run_ = true; + std::atomic_bool run_ {true}; DomainParticipant* participant_ = nullptr; TypeSupport type_; Publisher* publisher_ = nullptr; diff --git a/test/dds/communication/security/SubscriberMain.cpp b/test/dds/communication/security/SubscriberMain.cpp index f1f0d513ee6..3f0e01effff 100644 --- a/test/dds/communication/security/SubscriberMain.cpp +++ b/test/dds/communication/security/SubscriberMain.cpp @@ -31,6 +31,8 @@ using namespace eprosima::fastdds::dds; * --magic * --xmlfile * --publishers + * --die_on_data_received + * --rescan */ int main( @@ -45,6 +47,7 @@ int main( uint32_t seed = 7800; uint32_t samples = 4; uint32_t publishers = 1; + uint32_t rescan_interval_seconds = 0; char* xml_file = nullptr; std::string magic; @@ -116,6 +119,16 @@ int main( { die_on_data_received = true; } + else if (strcmp(argv[arg_count], "--rescan") == 0) + { + if (++arg_count >= argc) + { + std::cout << "--rescan expects a parameter" << std::endl; + return -1; + } + + rescan_interval_seconds = strtol(argv[arg_count], nullptr, 10); + } else { std::cout << "Wrong argument " << argv[arg_count] << std::endl; @@ -134,7 +147,7 @@ int main( if (subscriber.init(seed, magic)) { - return subscriber.run(notexit) ? 0 : -1; + return subscriber.run(notexit, rescan_interval_seconds) ? 0 : -1; } return -1; diff --git a/test/dds/communication/security/SubscriberModule.cpp b/test/dds/communication/security/SubscriberModule.cpp index 4160e127297..102231a5566 100644 --- a/test/dds/communication/security/SubscriberModule.cpp +++ b/test/dds/communication/security/SubscriberModule.cpp @@ -130,17 +130,35 @@ bool SubscriberModule::init( } bool SubscriberModule::run( - bool notexit) + bool notexit, + const uint32_t rescan_interval) { - return run_for(notexit, std::chrono::hours(24)); + return run_for(notexit, rescan_interval, std::chrono::hours(24)); } bool SubscriberModule::run_for( bool notexit, + const uint32_t rescan_interval, const std::chrono::milliseconds& timeout) { bool returned_value = false; + std::thread net_rescan_thread([this, rescan_interval]() + { + if (rescan_interval > 0) + { + auto interval = std::chrono::seconds(rescan_interval); + while (run_) + { + std::this_thread::sleep_for(interval); + if (run_) + { + participant_->set_qos(participant_->get_qos()); + } + } + } + }); + while (notexit && run_) { std::this_thread::sleep_for(std::chrono::milliseconds(250)); @@ -184,6 +202,9 @@ bool SubscriberModule::run_for( returned_value = false; } + run_ = false; + net_rescan_thread.join(); + return returned_value; } diff --git a/test/dds/communication/security/SubscriberModule.hpp b/test/dds/communication/security/SubscriberModule.hpp index 980c6c5acc6..c082d73fb80 100644 --- a/test/dds/communication/security/SubscriberModule.hpp +++ b/test/dds/communication/security/SubscriberModule.hpp @@ -19,6 +19,7 @@ #ifndef TEST_COMMUNICATION_SUBSCRIBER_HPP #define TEST_COMMUNICATION_SUBSCRIBER_HPP +<<<<<<< HEAD #include #include #include @@ -28,9 +29,13 @@ #include "types/HelloWorldPubSubTypes.h" #include +======= +#include +#include +>>>>>>> 91bd7c857 (Fix issues in Dynamic Network Interfaces (#5282)) #include #include -#include +#include namespace eprosima { namespace fastdds { @@ -44,9 +49,9 @@ class SubscriberModule SubscriberModule( const uint32_t publishers, const uint32_t max_number_samples, - bool fixed_type = false, - bool zero_copy = false, - bool die_on_data_received = false) + bool fixed_type, + bool zero_copy, + bool die_on_data_received) : publishers_(publishers) , max_number_samples_(max_number_samples) , fixed_type_(zero_copy || fixed_type) // If zero copy active, fixed type is required @@ -83,10 +88,12 @@ class SubscriberModule const std::string& magic); bool run( - bool notexit); + bool notexit, + const uint32_t rescan_interval); bool run_for( bool notexit, + const uint32_t rescan_interval, const std::chrono::milliseconds& timeout); private: @@ -100,7 +107,7 @@ class SubscriberModule std::map number_samples_; bool fixed_type_ = false; bool zero_copy_ = false; - bool run_ = true; + std::atomic_bool run_{true}; DomainParticipant* participant_ = nullptr; TypeSupport type_; Subscriber* subscriber_ = nullptr; From a53cdebb63f3b7f512209e480c52da35dba97b2a Mon Sep 17 00:00:00 2001 From: eProsima Date: Fri, 25 Oct 2024 11:31:44 +0200 Subject: [PATCH 2/8] Refs #17283: Fix conflicts Signed-off-by: eProsima --- .../rtps/builtin/discovery/participant/PDP.h | 44 ----- .../builtin/discovery/participant/PDP.cpp | 161 ------------------ .../rtps/participant/RTPSParticipantImpl.cpp | 66 ++++--- test/dds/communication/PublisherModule.hpp | 7 - test/dds/communication/SubscriberModule.hpp | 16 +- .../security/PublisherModule.hpp | 7 - .../security/SubscriberModule.hpp | 16 +- 7 files changed, 56 insertions(+), 261 deletions(-) diff --git a/include/fastdds/rtps/builtin/discovery/participant/PDP.h b/include/fastdds/rtps/builtin/discovery/participant/PDP.h index bf5d06e7142..9993eaf10bd 100644 --- a/include/fastdds/rtps/builtin/discovery/participant/PDP.h +++ b/include/fastdds/rtps/builtin/discovery/participant/PDP.h @@ -29,7 +29,6 @@ #include #include -<<<<<<< HEAD:include/fastdds/rtps/builtin/discovery/participant/PDP.h #include #include #include @@ -41,35 +40,6 @@ #include #include #include -======= -#include - -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include - -#include -#include -#include -#include -#include -#include ->>>>>>> 91bd7c857 (Fix issues in Dynamic Network Interfaces (#5282)):src/cpp/rtps/builtin/discovery/participant/PDP.h namespace eprosima { @@ -84,7 +54,6 @@ struct IProxyObserver; namespace rtps { -<<<<<<< HEAD:include/fastdds/rtps/builtin/discovery/participant/PDP.h class PDPServerListener; class PDPEndpoints; @@ -102,10 +71,6 @@ namespace rtps { class RTPSWriter; class RTPSReader; -======= -class BaseWriter; -class BaseReader; ->>>>>>> 91bd7c857 (Fix issues in Dynamic Network Interfaces (#5282)):src/cpp/rtps/builtin/discovery/participant/PDP.h class WriterHistory; class ReaderHistory; struct RTPSParticipantAllocationAttributes; @@ -533,15 +498,6 @@ class PDP : public fastdds::statistics::rtps::IProxyQueryable #endif // FASTDDS_STATISTICS - virtual void local_participant_attributes_update_nts( - const RTPSParticipantAttributes& new_atts); - - virtual void update_endpoint_locators_if_default_nts( - const std::vector& writers, - const std::vector& readers, - const RTPSParticipantAttributes& old_atts, - const RTPSParticipantAttributes& new_atts); - protected: //!Pointer to the builtin protocols object. diff --git a/src/cpp/rtps/builtin/discovery/participant/PDP.cpp b/src/cpp/rtps/builtin/discovery/participant/PDP.cpp index 025aaedc7fb..6aaa543991f 100644 --- a/src/cpp/rtps/builtin/discovery/participant/PDP.cpp +++ b/src/cpp/rtps/builtin/discovery/participant/PDP.cpp @@ -66,52 +66,6 @@ #include #include -<<<<<<< HEAD -======= -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include - -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#if HAVE_SECURITY -#include -#endif // if HAVE_SECURITY -#include -#include -#include -#include - ->>>>>>> 91bd7c857 (Fix issues in Dynamic Network Interfaces (#5282)) namespace eprosima { namespace fastrtps { namespace rtps { @@ -1708,121 +1662,6 @@ void PDP::add_builtin_security_attributes( #endif // HAVE_SECURITY -void PDP::local_participant_attributes_update_nts( - const RTPSParticipantAttributes& new_atts) -{ - // Update user data - auto participant_data = getLocalParticipantProxyData(); - participant_data->m_userData.data_vec(new_atts.userData); - - // If we are intraprocess only, we do not need to update locators - bool announce_locators = !mp_RTPSParticipant->is_intraprocess_only(); - if (announce_locators) - { - // Clear all locators - participant_data->metatraffic_locators.unicast.clear(); - participant_data->metatraffic_locators.multicast.clear(); - participant_data->default_locators.unicast.clear(); - participant_data->default_locators.multicast.clear(); - - // Update default locators - for (const Locator_t& loc : new_atts.defaultUnicastLocatorList) - { - participant_data->default_locators.add_unicast_locator(loc); - } - for (const Locator_t& loc : new_atts.defaultMulticastLocatorList) - { - participant_data->default_locators.add_multicast_locator(loc); - } - - // Update metatraffic locators - for (const auto& locator : new_atts.builtin.metatrafficUnicastLocatorList) - { - participant_data->metatraffic_locators.add_unicast_locator(locator); - } - if (!new_atts.builtin.avoid_builtin_multicast || participant_data->metatraffic_locators.unicast.empty()) - { - for (const auto& locator : new_atts.builtin.metatrafficMulticastLocatorList) - { - participant_data->metatraffic_locators.add_multicast_locator(locator); - } - } - - fastdds::rtps::network::external_locators::add_external_locators(*participant_data, - new_atts.builtin.metatraffic_external_unicast_locators, - new_atts.default_external_unicast_locators); - } -} - -void PDP::update_endpoint_locators_if_default_nts( - const std::vector& writers, - const std::vector& readers, - const RTPSParticipantAttributes& old_atts, - const RTPSParticipantAttributes& new_atts) -{ - // Check if default locators have changed - const auto& old_default_unicast = old_atts.defaultUnicastLocatorList; - const auto& old_default_multicast = old_atts.defaultMulticastLocatorList; - const auto& new_default_unicast = new_atts.defaultUnicastLocatorList; - const auto& new_default_multicast = new_atts.defaultMulticastLocatorList; - - // Early return if there is no change in default unicast locators - if ((old_default_unicast == new_default_unicast) && - (old_default_multicast == new_default_multicast)) - { - return; - } - - // Update proxies of endpoints with default configured locators - EDP* edp = get_edp(); - for (BaseWriter* writer : writers) - { - if ((old_default_multicast == writer->getAttributes().multicastLocatorList) && - (old_default_unicast == writer->getAttributes().unicastLocatorList)) - { - writer->getAttributes().multicastLocatorList = new_default_multicast; - writer->getAttributes().unicastLocatorList = new_default_unicast; - - WriterProxyData* wdata = nullptr; - GUID_t participant_guid; - wdata = addWriterProxyData(writer->getGuid(), participant_guid, - [](WriterProxyData* proxy, bool is_update, const ParticipantProxyData& participant) - { - static_cast(is_update); - assert(is_update); - - proxy->set_locators(participant.default_locators); - return true; - }); - assert(wdata != nullptr); - edp->process_writer_proxy_data(writer, wdata); - } - } - for (BaseReader* reader : readers) - { - if ((old_default_multicast == reader->getAttributes().multicastLocatorList) && - (old_default_unicast == reader->getAttributes().unicastLocatorList)) - { - reader->getAttributes().multicastLocatorList = new_default_multicast; - reader->getAttributes().unicastLocatorList = new_default_unicast; - - ReaderProxyData* rdata = nullptr; - GUID_t participant_guid; - rdata = addReaderProxyData(reader->getGuid(), participant_guid, - [](ReaderProxyData* proxy, bool is_update, const ParticipantProxyData& participant) - { - static_cast(is_update); - assert(is_update); - - proxy->set_locators(participant.default_locators); - return true; - }); - assert(rdata != nullptr); - edp->process_reader_proxy_data(reader, rdata); - } - } -} - } /* namespace rtps */ } /* namespace fastrtps */ } /* namespace eprosima */ diff --git a/src/cpp/rtps/participant/RTPSParticipantImpl.cpp b/src/cpp/rtps/participant/RTPSParticipantImpl.cpp index bc017513028..12582690a9e 100644 --- a/src/cpp/rtps/participant/RTPSParticipantImpl.cpp +++ b/src/cpp/rtps/participant/RTPSParticipantImpl.cpp @@ -1539,16 +1539,10 @@ void RTPSParticipantImpl::update_attributes( // Check if new interfaces have been added if (internal_metatraffic_locators_) { -<<<<<<< HEAD LocatorList_t metatraffic_unicast_locator_list = m_att.builtin.metatrafficUnicastLocatorList; + m_att.builtin.metatrafficUnicastLocatorList.clear(); get_default_metatraffic_locators(); if (!(metatraffic_unicast_locator_list == m_att.builtin.metatrafficUnicastLocatorList)) -======= - LocatorList_t metatraffic_unicast_locator_list = temp_atts.builtin.metatrafficUnicastLocatorList; - temp_atts.builtin.metatrafficUnicastLocatorList.clear(); - get_default_metatraffic_locators(temp_atts); - if (!(metatraffic_unicast_locator_list == temp_atts.builtin.metatrafficUnicastLocatorList)) ->>>>>>> 91bd7c857 (Fix issues in Dynamic Network Interfaces (#5282)) { local_interfaces_changed = true; EPROSIMA_LOG_INFO(RTPS_PARTICIPANT, m_att.getName() << " updated its metatraffic locators"); @@ -1556,16 +1550,10 @@ void RTPSParticipantImpl::update_attributes( } if (internal_default_locators_) { -<<<<<<< HEAD LocatorList_t default_unicast_locator_list = m_att.defaultUnicastLocatorList; + m_att.defaultUnicastLocatorList.clear(); get_default_unicast_locators(); if (!(default_unicast_locator_list == m_att.defaultUnicastLocatorList)) -======= - LocatorList_t default_unicast_locator_list = temp_atts.defaultUnicastLocatorList; - temp_atts.defaultUnicastLocatorList.clear(); - get_default_unicast_locators(temp_atts); - if (!(default_unicast_locator_list == temp_atts.defaultUnicastLocatorList)) ->>>>>>> 91bd7c857 (Fix issues in Dynamic Network Interfaces (#5282)) { local_interfaces_changed = true; EPROSIMA_LOG_INFO(RTPS_PARTICIPANT, @@ -1687,9 +1675,49 @@ void RTPSParticipantImpl::update_attributes( { std::lock_guard lock(*pdp->getMutex()); - pdp->local_participant_attributes_update_nts(temp_atts); -<<<<<<< HEAD + // Update user data + auto participant_data = pdp->getLocalParticipantProxyData(); + participant_data->m_userData.data_vec(m_att.userData); + + // If we are intraprocess only, we do not need to update locators + bool announce_locators = !is_intraprocess_only(); + if (announce_locators) + { + // Clear all locators + participant_data->metatraffic_locators.unicast.clear(); + participant_data->metatraffic_locators.multicast.clear(); + participant_data->default_locators.unicast.clear(); + participant_data->default_locators.multicast.clear(); + + // Update default locators + for (const Locator_t& loc : m_att.defaultUnicastLocatorList) + { + participant_data->default_locators.add_unicast_locator(loc); + } + for (const Locator_t& loc : m_att.defaultMulticastLocatorList) + { + participant_data->default_locators.add_multicast_locator(loc); + } + + // Update metatraffic locators + for (const auto& locator : m_att.builtin.metatrafficUnicastLocatorList) + { + participant_data->metatraffic_locators.add_unicast_locator(locator); + } + if (!m_att.builtin.avoid_builtin_multicast || participant_data->metatraffic_locators.unicast.empty()) + { + for (const auto& locator : m_att.builtin.metatrafficMulticastLocatorList) + { + participant_data->metatraffic_locators.add_multicast_locator(locator); + } + } + + fastdds::rtps::network::external_locators::add_external_locators(*participant_data, + m_att.builtin.metatraffic_external_unicast_locators, + m_att.default_external_unicast_locators); + } + // Update user data auto local_participant_proxy_data = pdp->getLocalParticipantProxyData(); local_participant_proxy_data->m_userData.data_vec(m_att.userData); @@ -1708,12 +1736,6 @@ void RTPSParticipantImpl::update_attributes( for (auto locator : m_att.defaultUnicastLocatorList) { local_participant_proxy_data->default_locators.add_unicast_locator(locator); -======= - if (local_interfaces_changed && internal_default_locators_) - { - std::lock_guard _(endpoints_list_mutex); - pdp->update_endpoint_locators_if_default_nts(m_userWriterList, m_userReaderList, m_att, temp_atts); ->>>>>>> 91bd7c857 (Fix issues in Dynamic Network Interfaces (#5282)) } if (local_interfaces_changed) diff --git a/test/dds/communication/PublisherModule.hpp b/test/dds/communication/PublisherModule.hpp index 0f8905c13ff..593d224c6d6 100644 --- a/test/dds/communication/PublisherModule.hpp +++ b/test/dds/communication/PublisherModule.hpp @@ -19,15 +19,11 @@ #ifndef TEST_DDS_COMMUNICATION_PUBLISHERMODULE_HPP #define TEST_DDS_COMMUNICATION_PUBLISHERMODULE_HPP -<<<<<<< HEAD -======= #include #include #include #include -#include ->>>>>>> 91bd7c857 (Fix issues in Dynamic Network Interfaces (#5282)) #include #include #include @@ -36,9 +32,6 @@ #include "types/FixedSizedPubSubTypes.h" #include "types/HelloWorldPubSubTypes.h" -#include -#include - namespace eprosima { namespace fastdds { namespace dds { diff --git a/test/dds/communication/SubscriberModule.hpp b/test/dds/communication/SubscriberModule.hpp index 62226538c8c..964d28cbbc0 100644 --- a/test/dds/communication/SubscriberModule.hpp +++ b/test/dds/communication/SubscriberModule.hpp @@ -19,7 +19,12 @@ #ifndef TEST_COMMUNICATION_SUBSCRIBER_HPP #define TEST_COMMUNICATION_SUBSCRIBER_HPP -<<<<<<< HEAD +#include +#include +#include +#include +#include + #include #include #include @@ -28,15 +33,6 @@ #include "types/FixedSizedPubSubTypes.h" #include "types/HelloWorldPubSubTypes.h" -#include -======= -#include -#include ->>>>>>> 91bd7c857 (Fix issues in Dynamic Network Interfaces (#5282)) -#include -#include -#include - namespace eprosima { namespace fastdds { namespace dds { diff --git a/test/dds/communication/security/PublisherModule.hpp b/test/dds/communication/security/PublisherModule.hpp index e37d9155510..3b91aec0087 100644 --- a/test/dds/communication/security/PublisherModule.hpp +++ b/test/dds/communication/security/PublisherModule.hpp @@ -19,14 +19,10 @@ #ifndef TEST_DDS_COMMUNICATION_PUBLISHERMODULE_HPP #define TEST_DDS_COMMUNICATION_PUBLISHERMODULE_HPP -<<<<<<< HEAD -======= #include #include #include -#include ->>>>>>> 91bd7c857 (Fix issues in Dynamic Network Interfaces (#5282)) #include #include #include @@ -35,9 +31,6 @@ #include "types/FixedSizedPubSubTypes.h" #include "types/HelloWorldPubSubTypes.h" -#include -#include - namespace eprosima { namespace fastdds { namespace dds { diff --git a/test/dds/communication/security/SubscriberModule.hpp b/test/dds/communication/security/SubscriberModule.hpp index c082d73fb80..dd73934f990 100644 --- a/test/dds/communication/security/SubscriberModule.hpp +++ b/test/dds/communication/security/SubscriberModule.hpp @@ -19,7 +19,12 @@ #ifndef TEST_COMMUNICATION_SUBSCRIBER_HPP #define TEST_COMMUNICATION_SUBSCRIBER_HPP -<<<<<<< HEAD +#include +#include +#include +#include +#include + #include #include #include @@ -28,15 +33,6 @@ #include "types/FixedSizedPubSubTypes.h" #include "types/HelloWorldPubSubTypes.h" -#include -======= -#include -#include ->>>>>>> 91bd7c857 (Fix issues in Dynamic Network Interfaces (#5282)) -#include -#include -#include - namespace eprosima { namespace fastdds { namespace dds { From 456f5ababeb39452f9742494fd1783595a7b600f Mon Sep 17 00:00:00 2001 From: eProsima Date: Tue, 29 Oct 2024 12:02:27 +0100 Subject: [PATCH 3/8] Refs #17283: Keep original PR functionality Signed-off-by: eProsima --- .../rtps/participant/RTPSParticipantImpl.cpp | 256 +++++++++--------- 1 file changed, 123 insertions(+), 133 deletions(-) diff --git a/src/cpp/rtps/participant/RTPSParticipantImpl.cpp b/src/cpp/rtps/participant/RTPSParticipantImpl.cpp index 12582690a9e..aa12e9c6bcf 100644 --- a/src/cpp/rtps/participant/RTPSParticipantImpl.cpp +++ b/src/cpp/rtps/participant/RTPSParticipantImpl.cpp @@ -1526,39 +1526,46 @@ bool RTPSParticipantImpl::registerReader( void RTPSParticipantImpl::update_attributes( const RTPSParticipantAttributes& patt) { + // Avoid ABBA with PDP mutex by using a local copy of the attributes + RTPSParticipantAttributes temp_atts; + { + std::lock_guard guard(*mp_mutex); + temp_atts = m_att; + } + bool local_interfaces_changed = false; // Update cached network interfaces if (!SystemInfo::update_interfaces()) { EPROSIMA_LOG_WARNING(RTPS_PARTICIPANT, - "Failed to update cached network interfaces during " << m_att.getName() << + "Failed to update cached network interfaces during " << temp_atts.getName() << " attributes update"); } // Check if new interfaces have been added if (internal_metatraffic_locators_) { - LocatorList_t metatraffic_unicast_locator_list = m_att.builtin.metatrafficUnicastLocatorList; - m_att.builtin.metatrafficUnicastLocatorList.clear(); + LocatorList_t metatraffic_unicast_locator_list = temp_atts.builtin.metatrafficUnicastLocatorList; + temp_atts.builtin.metatrafficUnicastLocatorList.clear(); get_default_metatraffic_locators(); - if (!(metatraffic_unicast_locator_list == m_att.builtin.metatrafficUnicastLocatorList)) + if (!(metatraffic_unicast_locator_list == temp_atts.builtin.metatrafficUnicastLocatorList)) { local_interfaces_changed = true; - EPROSIMA_LOG_INFO(RTPS_PARTICIPANT, m_att.getName() << " updated its metatraffic locators"); + EPROSIMA_LOG_INFO(RTPS_PARTICIPANT, temp_atts.getName() << " updated its metatraffic locators"); } } if (internal_default_locators_) { - LocatorList_t default_unicast_locator_list = m_att.defaultUnicastLocatorList; - m_att.defaultUnicastLocatorList.clear(); + LocatorList_t default_unicast_locator_list = temp_atts.defaultUnicastLocatorList; + temp_atts.defaultUnicastLocatorList.clear(); get_default_unicast_locators(); - if (!(default_unicast_locator_list == m_att.defaultUnicastLocatorList)) + if (!(default_unicast_locator_list == temp_atts.defaultUnicastLocatorList)) { local_interfaces_changed = true; EPROSIMA_LOG_INFO(RTPS_PARTICIPANT, - m_att.getName() << " updated default unicast locator list, current locators: " - << m_att.defaultUnicastLocatorList); + temp_atts.getName() << " updated default unicast locator list, current locators: " + << temp_atts.defaultUnicastLocatorList); } } @@ -1573,9 +1580,9 @@ void RTPSParticipantImpl::update_attributes( // Check if discovery servers need to be updated eprosima::fastdds::rtps::RemoteServerList_t converted_discovery_servers = patt.builtin.discovery_config.m_DiscoveryServers; - if (patt.builtin.discovery_config.m_DiscoveryServers != m_att.builtin.discovery_config.m_DiscoveryServers) + if (converted_discovery_servers != temp_atts.builtin.discovery_config.m_DiscoveryServers) { - for (auto& transportDescriptor : m_att.userTransports) + for (auto& transportDescriptor : temp_atts.userTransports) { TCPTransportDescriptor* pT = dynamic_cast(transportDescriptor.get()); if (pT) @@ -1600,8 +1607,8 @@ void RTPSParticipantImpl::update_attributes( } // Check if there are changes - if (converted_discovery_servers != m_att.builtin.discovery_config.m_DiscoveryServers - || patt.userData != m_att.userData + if (converted_discovery_servers != temp_atts.builtin.discovery_config.m_DiscoveryServers + || patt.userData != temp_atts.userData || local_interfaces_changed) { update_pdp = true; @@ -1609,7 +1616,7 @@ void RTPSParticipantImpl::update_attributes( LocatorList_t modified_locators; // Update RTPSParticipantAttributes members - m_att.userData = patt.userData; + temp_atts.userData = patt.userData; // If there's no PDP don't process Discovery-related attributes. if (!pdp) @@ -1622,63 +1629,23 @@ void RTPSParticipantImpl::update_attributes( using namespace fastdds::rtps::network::external_locators; if (local_interfaces_changed && internal_metatraffic_locators_) { - set_listening_locators(m_att.builtin.metatraffic_external_unicast_locators, - m_att.builtin.metatrafficUnicastLocatorList); + set_listening_locators(temp_atts.builtin.metatraffic_external_unicast_locators, + temp_atts.builtin.metatrafficUnicastLocatorList); } if (local_interfaces_changed && internal_default_locators_) { - set_listening_locators(m_att.default_external_unicast_locators, - m_att.defaultUnicastLocatorList); - } - } - - // Check that the remote servers list is consistent: all the already known remote servers must be included in - // the list and either new remote servers are added or remote server listening locator is modified. - for (auto existing_server : m_att.builtin.discovery_config.m_DiscoveryServers) - { - bool contained = false; - for (auto incoming_server : converted_discovery_servers) - { - if (existing_server.guidPrefix == incoming_server.guidPrefix) - { - for (auto incoming_locator : incoming_server.metatrafficUnicastLocatorList) - { - bool locator_contained = false; - for (auto existing_locator : existing_server.metatrafficUnicastLocatorList) - { - if (incoming_locator == existing_locator) - { - locator_contained = true; - break; - } - } - if (!locator_contained) - { - modified_servers.emplace_back(incoming_server.GetParticipant()); - modified_locators.push_back(incoming_locator); - EPROSIMA_LOG_INFO(RTPS_QOS_CHECK, - "DS Server: " << incoming_server.guidPrefix << " has modified its locators: " - << incoming_locator << " being added"); - } - } - contained = true; - break; - } - } - if (!contained) - { - EPROSIMA_LOG_ERROR(RTPS_QOS_CHECK, - "Discovery Servers cannot be removed from the list; they can only be added"); - return; + set_listening_locators(temp_atts.default_external_unicast_locators, + temp_atts.defaultUnicastLocatorList); } } { std::lock_guard lock(*pdp->getMutex()); - // Update user data + // -- The following section corresponds to the 3.x backport of the PDP method + // local_participant_attributes_update_nts auto participant_data = pdp->getLocalParticipantProxyData(); - participant_data->m_userData.data_vec(m_att.userData); + participant_data->m_userData.data_vec(temp_atts.userData); // If we are intraprocess only, we do not need to update locators bool announce_locators = !is_intraprocess_only(); @@ -1691,58 +1658,107 @@ void RTPSParticipantImpl::update_attributes( participant_data->default_locators.multicast.clear(); // Update default locators - for (const Locator_t& loc : m_att.defaultUnicastLocatorList) + for (const Locator_t& loc : temp_atts.defaultUnicastLocatorList) { participant_data->default_locators.add_unicast_locator(loc); } - for (const Locator_t& loc : m_att.defaultMulticastLocatorList) + for (const Locator_t& loc : temp_atts.defaultMulticastLocatorList) { participant_data->default_locators.add_multicast_locator(loc); } // Update metatraffic locators - for (const auto& locator : m_att.builtin.metatrafficUnicastLocatorList) + for (const auto& locator : temp_atts.builtin.metatrafficUnicastLocatorList) { participant_data->metatraffic_locators.add_unicast_locator(locator); } - if (!m_att.builtin.avoid_builtin_multicast || participant_data->metatraffic_locators.unicast.empty()) + if (!temp_atts.builtin.avoid_builtin_multicast || participant_data->metatraffic_locators.unicast.empty()) { - for (const auto& locator : m_att.builtin.metatrafficMulticastLocatorList) + for (const auto& locator : temp_atts.builtin.metatrafficMulticastLocatorList) { participant_data->metatraffic_locators.add_multicast_locator(locator); } } fastdds::rtps::network::external_locators::add_external_locators(*participant_data, - m_att.builtin.metatraffic_external_unicast_locators, - m_att.default_external_unicast_locators); + temp_atts.builtin.metatraffic_external_unicast_locators, + temp_atts.default_external_unicast_locators); } - // Update user data - auto local_participant_proxy_data = pdp->getLocalParticipantProxyData(); - local_participant_proxy_data->m_userData.data_vec(m_att.userData); + // -- The following section corresponds to the 3.x backport of the PDP method + // update_endpoint_locators_if_default_nts - // Update metatraffic locators - for (auto locator : m_att.builtin.metatrafficMulticastLocatorList) - { - local_participant_proxy_data->metatraffic_locators.add_multicast_locator(locator); - } - for (auto locator : m_att.builtin.metatrafficUnicastLocatorList) + if (local_interfaces_changed && internal_default_locators_) { - local_participant_proxy_data->metatraffic_locators.add_unicast_locator(locator); - } + std::lock_guard _(endpoints_list_mutex); + // Check if default locators have changed + const auto& old_default_unicast = m_att.defaultUnicastLocatorList; + const auto& old_default_multicast = m_att.defaultMulticastLocatorList; + const auto& new_default_unicast = temp_atts.defaultUnicastLocatorList; + const auto& new_default_multicast = temp_atts.defaultMulticastLocatorList; + + // Early return if there is no change in default unicast locators + if ((old_default_unicast == new_default_unicast) && + (old_default_multicast == new_default_multicast)) + { + return; + } - // Update default locators - for (auto locator : m_att.defaultUnicastLocatorList) - { - local_participant_proxy_data->default_locators.add_unicast_locator(locator); + // Update proxies of endpoints with default configured locators + EDP* edp = pdp->getEDP(); + for (RTPSWriter* writer : m_userWriterList) + { + if ((old_default_multicast == writer->getAttributes().multicastLocatorList) && + (old_default_unicast == writer->getAttributes().unicastLocatorList)) + { + writer->getAttributes().multicastLocatorList = new_default_multicast; + writer->getAttributes().unicastLocatorList = new_default_unicast; + + WriterProxyData* wdata = nullptr; + GUID_t participant_guid; + wdata = pdp->addWriterProxyData(writer->getGuid(), participant_guid, + [](WriterProxyData* proxy, bool is_update, const ParticipantProxyData& participant) + { + static_cast(is_update); + assert(is_update); + proxy->set_locators(participant.default_locators); + return true; + }); + assert(wdata != nullptr); + edp->processLocalWriterProxyData(writer, wdata); + } + } + for (RTPSReader* reader : m_userReaderList) + { + if ((old_default_multicast == reader->getAttributes().multicastLocatorList) && + (old_default_unicast == reader->getAttributes().unicastLocatorList)) + { + reader->getAttributes().multicastLocatorList = new_default_multicast; + reader->getAttributes().unicastLocatorList = new_default_unicast; + + ReaderProxyData* rdata = nullptr; + GUID_t participant_guid; + rdata = pdp->addReaderProxyData(reader->getGuid(), participant_guid, + [](ReaderProxyData* proxy, bool is_update, const ParticipantProxyData& participant) + { + static_cast(is_update); + assert(is_update); + + proxy->set_locators(participant.default_locators); + return true; + }); + assert(rdata != nullptr); + edp->processLocalReaderProxyData(reader, rdata); + } + } } + // -- end of 3.x backport if (local_interfaces_changed) { - createSenderResources(m_att.builtin.metatrafficMulticastLocatorList); - createSenderResources(m_att.builtin.metatrafficUnicastLocatorList); - createSenderResources(m_att.defaultUnicastLocatorList); + createSenderResources(temp_atts.builtin.metatrafficMulticastLocatorList); + createSenderResources(temp_atts.builtin.metatrafficUnicastLocatorList); + createSenderResources(temp_atts.defaultUnicastLocatorList); } if (!modified_locators.empty()) { @@ -1750,73 +1766,47 @@ void RTPSParticipantImpl::update_attributes( } // Update remote servers list - if (m_att.builtin.discovery_config.discoveryProtocol == DiscoveryProtocol::CLIENT || - m_att.builtin.discovery_config.discoveryProtocol == DiscoveryProtocol::SUPER_CLIENT || - m_att.builtin.discovery_config.discoveryProtocol == DiscoveryProtocol::SERVER || - m_att.builtin.discovery_config.discoveryProtocol == DiscoveryProtocol::BACKUP) + if (temp_atts.builtin.discovery_config.discoveryProtocol == DiscoveryProtocol::CLIENT || + temp_atts.builtin.discovery_config.discoveryProtocol == DiscoveryProtocol::SUPER_CLIENT || + temp_atts.builtin.discovery_config.discoveryProtocol == DiscoveryProtocol::SERVER || + temp_atts.builtin.discovery_config.discoveryProtocol == DiscoveryProtocol::BACKUP) { - // Add incoming servers if we don't know about them already or the listening locator has been modified - for (auto incoming_server : converted_discovery_servers) - { - eprosima::fastdds::rtps::RemoteServerList_t::iterator server_it; - for (server_it = m_att.builtin.discovery_config.m_DiscoveryServers.begin(); - server_it != m_att.builtin.discovery_config.m_DiscoveryServers.end(); server_it++) - { - if (server_it->guidPrefix == incoming_server.guidPrefix) - { - // Check if the listening locators have been modified - for (auto guid : modified_servers) - { - if (guid == incoming_server.GetParticipant()) - { - server_it->metatrafficUnicastLocatorList = - incoming_server.metatrafficUnicastLocatorList; - break; - } - } - break; - } - } - if (server_it == m_att.builtin.discovery_config.m_DiscoveryServers.end()) - { - m_att.builtin.discovery_config.m_DiscoveryServers.push_back(incoming_server); - } - } + // Update list of Discovery Servers. The participant will remain connected to the servers of the + // previous list but will cease pinging servers that are not included in the new list. + // Liveliness will be maintained until the old server is removed from the participant, ensuring + // that existing connections are unaffected by the list update. + temp_atts.builtin.discovery_config.m_DiscoveryServers = converted_discovery_servers; // Update the servers list in builtin protocols { std::unique_lock disc_lock(mp_builtinProtocols->getDiscoveryMutex()); - mp_builtinProtocols->m_DiscoveryServers = m_att.builtin.discovery_config.m_DiscoveryServers; + mp_builtinProtocols->m_DiscoveryServers = temp_atts.builtin.discovery_config.m_DiscoveryServers; } // Notify PDPServer - if (m_att.builtin.discovery_config.discoveryProtocol == DiscoveryProtocol::SERVER || - m_att.builtin.discovery_config.discoveryProtocol == DiscoveryProtocol::BACKUP) + if (temp_atts.builtin.discovery_config.discoveryProtocol == DiscoveryProtocol::SERVER || + temp_atts.builtin.discovery_config.discoveryProtocol == DiscoveryProtocol::BACKUP) { fastdds::rtps::PDPServer* pdp_server = static_cast(pdp); pdp_server->update_remote_servers_list(); - for (auto remote_server : modified_servers) - { - pdp_server->remove_remote_participant(remote_server, - ParticipantDiscoveryInfo::DISCOVERY_STATUS::DROPPED_PARTICIPANT); - } } // Notify PDPClient - else if (m_att.builtin.discovery_config.discoveryProtocol == DiscoveryProtocol::CLIENT || - m_att.builtin.discovery_config.discoveryProtocol == DiscoveryProtocol::SUPER_CLIENT) + else if (temp_atts.builtin.discovery_config.discoveryProtocol == DiscoveryProtocol::CLIENT || + temp_atts.builtin.discovery_config.discoveryProtocol == DiscoveryProtocol::SUPER_CLIENT) { fastdds::rtps::PDPClient* pdp_client = static_cast(pdp); pdp_client->update_remote_servers_list(); - for (auto remote_server : modified_servers) - { - pdp_client->remove_remote_participant(remote_server, - ParticipantDiscoveryInfo::DISCOVERY_STATUS::DROPPED_PARTICIPANT); - } } } } } + // Update the attributes data member + { + std::lock_guard guard(*mp_mutex); + m_att = temp_atts; + } + if (update_pdp) { // Send DATA(P) From 859d8eccb4f7038c8a90238eab95c703642a8557 Mon Sep 17 00:00:00 2001 From: eProsima Date: Tue, 29 Oct 2024 14:57:58 +0100 Subject: [PATCH 4/8] Refs #17283: Please uncrustify Signed-off-by: eProsima --- src/cpp/rtps/participant/RTPSParticipantImpl.cpp | 11 +++++++---- 1 file changed, 7 insertions(+), 4 deletions(-) diff --git a/src/cpp/rtps/participant/RTPSParticipantImpl.cpp b/src/cpp/rtps/participant/RTPSParticipantImpl.cpp index aa12e9c6bcf..098c52a9f99 100644 --- a/src/cpp/rtps/participant/RTPSParticipantImpl.cpp +++ b/src/cpp/rtps/participant/RTPSParticipantImpl.cpp @@ -1565,7 +1565,7 @@ void RTPSParticipantImpl::update_attributes( local_interfaces_changed = true; EPROSIMA_LOG_INFO(RTPS_PARTICIPANT, temp_atts.getName() << " updated default unicast locator list, current locators: " - << temp_atts.defaultUnicastLocatorList); + << temp_atts.defaultUnicastLocatorList); } } @@ -1672,7 +1672,8 @@ void RTPSParticipantImpl::update_attributes( { participant_data->metatraffic_locators.add_unicast_locator(locator); } - if (!temp_atts.builtin.avoid_builtin_multicast || participant_data->metatraffic_locators.unicast.empty()) + if (!temp_atts.builtin.avoid_builtin_multicast || + participant_data->metatraffic_locators.unicast.empty()) { for (const auto& locator : temp_atts.builtin.metatrafficMulticastLocatorList) { @@ -1717,7 +1718,8 @@ void RTPSParticipantImpl::update_attributes( WriterProxyData* wdata = nullptr; GUID_t participant_guid; wdata = pdp->addWriterProxyData(writer->getGuid(), participant_guid, - [](WriterProxyData* proxy, bool is_update, const ParticipantProxyData& participant) + [](WriterProxyData* proxy, bool is_update, + const ParticipantProxyData& participant) { static_cast(is_update); assert(is_update); @@ -1739,7 +1741,8 @@ void RTPSParticipantImpl::update_attributes( ReaderProxyData* rdata = nullptr; GUID_t participant_guid; rdata = pdp->addReaderProxyData(reader->getGuid(), participant_guid, - [](ReaderProxyData* proxy, bool is_update, const ParticipantProxyData& participant) + [](ReaderProxyData* proxy, bool is_update, + const ParticipantProxyData& participant) { static_cast(is_update); assert(is_update); From 5f242895b34c3991d46630cc3fd8b394b7a12fd0 Mon Sep 17 00:00:00 2001 From: Miguel Company Date: Wed, 6 Nov 2024 10:51:26 +0100 Subject: [PATCH 5/8] Restore discovery server list check code. Signed-off-by: Miguel Company --- .../rtps/participant/RTPSParticipantImpl.cpp | 83 +++++++++++++++++-- 1 file changed, 78 insertions(+), 5 deletions(-) diff --git a/src/cpp/rtps/participant/RTPSParticipantImpl.cpp b/src/cpp/rtps/participant/RTPSParticipantImpl.cpp index 098c52a9f99..5cb736fcf68 100644 --- a/src/cpp/rtps/participant/RTPSParticipantImpl.cpp +++ b/src/cpp/rtps/participant/RTPSParticipantImpl.cpp @@ -1639,6 +1639,47 @@ void RTPSParticipantImpl::update_attributes( } } + // Check that the remote servers list is consistent: all the already known remote servers must be included in + // the list and either new remote servers are added or remote server listening locator is modified. + for (auto existing_server : temp_atts.builtin.discovery_config.m_DiscoveryServers) + { + bool contained = false; + for (auto incoming_server : converted_discovery_servers) + { + if (existing_server.guidPrefix == incoming_server.guidPrefix) + { + for (auto incoming_locator : incoming_server.metatrafficUnicastLocatorList) + { + bool locator_contained = false; + for (auto existing_locator : existing_server.metatrafficUnicastLocatorList) + { + if (incoming_locator == existing_locator) + { + locator_contained = true; + break; + } + } + if (!locator_contained) + { + modified_servers.emplace_back(incoming_server.GetParticipant()); + modified_locators.push_back(incoming_locator); + EPROSIMA_LOG_INFO(RTPS_QOS_CHECK, + "DS Server: " << incoming_server.guidPrefix << " has modified its locators: " + << incoming_locator << " being added"); + } + } + contained = true; + break; + } + } + if (!contained) + { + EPROSIMA_LOG_ERROR(RTPS_QOS_CHECK, + "Discovery Servers cannot be removed from the list; they can only be added"); + return; + } + } + { std::lock_guard lock(*pdp->getMutex()); @@ -1774,11 +1815,33 @@ void RTPSParticipantImpl::update_attributes( temp_atts.builtin.discovery_config.discoveryProtocol == DiscoveryProtocol::SERVER || temp_atts.builtin.discovery_config.discoveryProtocol == DiscoveryProtocol::BACKUP) { - // Update list of Discovery Servers. The participant will remain connected to the servers of the - // previous list but will cease pinging servers that are not included in the new list. - // Liveliness will be maintained until the old server is removed from the participant, ensuring - // that existing connections are unaffected by the list update. - temp_atts.builtin.discovery_config.m_DiscoveryServers = converted_discovery_servers; + // Add incoming servers if we don't know about them already or the listening locator has been modified + for (auto incoming_server : converted_discovery_servers) + { + eprosima::fastdds::rtps::RemoteServerList_t::iterator server_it; + for (server_it = temp_atts.builtin.discovery_config.m_DiscoveryServers.begin(); + server_it != temp_atts.builtin.discovery_config.m_DiscoveryServers.end(); server_it++) + { + if (server_it->guidPrefix == incoming_server.guidPrefix) + { + // Check if the listening locators have been modified + for (auto guid : modified_servers) + { + if (guid == incoming_server.GetParticipant()) + { + server_it->metatrafficUnicastLocatorList = + incoming_server.metatrafficUnicastLocatorList; + break; + } + } + break; + } + } + if (server_it == temp_atts.builtin.discovery_config.m_DiscoveryServers.end()) + { + temp_atts.builtin.discovery_config.m_DiscoveryServers.push_back(incoming_server); + } + } // Update the servers list in builtin protocols { @@ -1792,6 +1855,11 @@ void RTPSParticipantImpl::update_attributes( { fastdds::rtps::PDPServer* pdp_server = static_cast(pdp); pdp_server->update_remote_servers_list(); + for (auto remote_server : modified_servers) + { + pdp_server->remove_remote_participant(remote_server, + ParticipantDiscoveryInfo::DISCOVERY_STATUS::DROPPED_PARTICIPANT); + } } // Notify PDPClient else if (temp_atts.builtin.discovery_config.discoveryProtocol == DiscoveryProtocol::CLIENT || @@ -1799,6 +1867,11 @@ void RTPSParticipantImpl::update_attributes( { fastdds::rtps::PDPClient* pdp_client = static_cast(pdp); pdp_client->update_remote_servers_list(); + for (auto remote_server : modified_servers) + { + pdp_client->remove_remote_participant(remote_server, + ParticipantDiscoveryInfo::DISCOVERY_STATUS::DROPPED_PARTICIPANT); + } } } } From 5bb996daa07552f39378047d475a2df93a438fa6 Mon Sep 17 00:00:00 2001 From: Miguel Company Date: Wed, 6 Nov 2024 11:21:33 +0100 Subject: [PATCH 6/8] Make backported methods static methods instead of inline code. Signed-off-by: Miguel Company --- .../rtps/participant/RTPSParticipantImpl.cpp | 233 +++++++++--------- 1 file changed, 123 insertions(+), 110 deletions(-) diff --git a/src/cpp/rtps/participant/RTPSParticipantImpl.cpp b/src/cpp/rtps/participant/RTPSParticipantImpl.cpp index 5cb736fcf68..78a84f55525 100644 --- a/src/cpp/rtps/participant/RTPSParticipantImpl.cpp +++ b/src/cpp/rtps/participant/RTPSParticipantImpl.cpp @@ -232,6 +232,127 @@ static bool get_unique_flows_parameters( return true; } +// -- The following is a backport from 3.x of a PDP method +static void local_participant_attributes_update_nts( + const RTPSParticipantAttributes& new_atts, + PDP* pdp, + RTPSParticipantImpl* participant) +{ + auto participant_data = pdp->getLocalParticipantProxyData(); + participant_data->m_userData.data_vec(new_atts.userData); + + // If we are intraprocess only, we do not need to update locators + bool announce_locators = !participant->is_intraprocess_only(); + if (announce_locators) + { + // Clear all locators + participant_data->metatraffic_locators.unicast.clear(); + participant_data->metatraffic_locators.multicast.clear(); + participant_data->default_locators.unicast.clear(); + participant_data->default_locators.multicast.clear(); + + // Update default locators + for (const Locator_t& loc : new_atts.defaultUnicastLocatorList) + { + participant_data->default_locators.add_unicast_locator(loc); + } + for (const Locator_t& loc : new_atts.defaultMulticastLocatorList) + { + participant_data->default_locators.add_multicast_locator(loc); + } + + // Update metatraffic locators + for (const auto& locator : new_atts.builtin.metatrafficUnicastLocatorList) + { + participant_data->metatraffic_locators.add_unicast_locator(locator); + } + if (!new_atts.builtin.avoid_builtin_multicast || + participant_data->metatraffic_locators.unicast.empty()) + { + for (const auto& locator : new_atts.builtin.metatrafficMulticastLocatorList) + { + participant_data->metatraffic_locators.add_multicast_locator(locator); + } + } + + fastdds::rtps::network::external_locators::add_external_locators(*participant_data, + new_atts.builtin.metatraffic_external_unicast_locators, + new_atts.default_external_unicast_locators); + } +} + +// -- The following is a backport from 3.x of a PDP method +static void update_endpoint_locators_if_default_nts( + const std::vector& writers, + const std::vector& readers, + const RTPSParticipantAttributes& old_atts, + const RTPSParticipantAttributes& new_atts, + PDP* pdp) +{ + // Check if default locators have changed + const auto& old_default_unicast = old_atts.defaultUnicastLocatorList; + const auto& old_default_multicast = old_atts.defaultMulticastLocatorList; + const auto& new_default_unicast = new_atts.defaultUnicastLocatorList; + const auto& new_default_multicast = new_atts.defaultMulticastLocatorList; + + // Early return if there is no change in default unicast locators + if ((old_default_unicast == new_default_unicast) && + (old_default_multicast == new_default_multicast)) + { + return; + } + + // Update proxies of endpoints with default configured locators + EDP* edp = pdp->getEDP(); + for (RTPSWriter* writer : writers) + { + if ((old_default_multicast == writer->getAttributes().multicastLocatorList) && + (old_default_unicast == writer->getAttributes().unicastLocatorList)) + { + writer->getAttributes().multicastLocatorList = new_default_multicast; + writer->getAttributes().unicastLocatorList = new_default_unicast; + + WriterProxyData* wdata = nullptr; + GUID_t participant_guid; + wdata = pdp->addWriterProxyData(writer->getGuid(), participant_guid, + [](WriterProxyData* proxy, bool is_update, + const ParticipantProxyData& participant) + { + static_cast(is_update); + assert(is_update); + proxy->set_locators(participant.default_locators); + return true; + }); + assert(wdata != nullptr); + edp->processLocalWriterProxyData(writer, wdata); + } + } + for (RTPSReader* reader : readers) + { + if ((old_default_multicast == reader->getAttributes().multicastLocatorList) && + (old_default_unicast == reader->getAttributes().unicastLocatorList)) + { + reader->getAttributes().multicastLocatorList = new_default_multicast; + reader->getAttributes().unicastLocatorList = new_default_unicast; + + ReaderProxyData* rdata = nullptr; + GUID_t participant_guid; + rdata = pdp->addReaderProxyData(reader->getGuid(), participant_guid, + [](ReaderProxyData* proxy, bool is_update, + const ParticipantProxyData& participant) + { + static_cast(is_update); + assert(is_update); + + proxy->set_locators(participant.default_locators); + return true; + }); + assert(rdata != nullptr); + edp->processLocalReaderProxyData(reader, rdata); + } + } +} + Locator_t& RTPSParticipantImpl::applyLocatorAdaptRule( Locator_t& loc) { @@ -1682,121 +1803,13 @@ void RTPSParticipantImpl::update_attributes( { std::lock_guard lock(*pdp->getMutex()); - - // -- The following section corresponds to the 3.x backport of the PDP method - // local_participant_attributes_update_nts - auto participant_data = pdp->getLocalParticipantProxyData(); - participant_data->m_userData.data_vec(temp_atts.userData); - - // If we are intraprocess only, we do not need to update locators - bool announce_locators = !is_intraprocess_only(); - if (announce_locators) - { - // Clear all locators - participant_data->metatraffic_locators.unicast.clear(); - participant_data->metatraffic_locators.multicast.clear(); - participant_data->default_locators.unicast.clear(); - participant_data->default_locators.multicast.clear(); - - // Update default locators - for (const Locator_t& loc : temp_atts.defaultUnicastLocatorList) - { - participant_data->default_locators.add_unicast_locator(loc); - } - for (const Locator_t& loc : temp_atts.defaultMulticastLocatorList) - { - participant_data->default_locators.add_multicast_locator(loc); - } - - // Update metatraffic locators - for (const auto& locator : temp_atts.builtin.metatrafficUnicastLocatorList) - { - participant_data->metatraffic_locators.add_unicast_locator(locator); - } - if (!temp_atts.builtin.avoid_builtin_multicast || - participant_data->metatraffic_locators.unicast.empty()) - { - for (const auto& locator : temp_atts.builtin.metatrafficMulticastLocatorList) - { - participant_data->metatraffic_locators.add_multicast_locator(locator); - } - } - - fastdds::rtps::network::external_locators::add_external_locators(*participant_data, - temp_atts.builtin.metatraffic_external_unicast_locators, - temp_atts.default_external_unicast_locators); - } - - // -- The following section corresponds to the 3.x backport of the PDP method - // update_endpoint_locators_if_default_nts + local_participant_attributes_update_nts(temp_atts, pdp, this); if (local_interfaces_changed && internal_default_locators_) { std::lock_guard _(endpoints_list_mutex); - // Check if default locators have changed - const auto& old_default_unicast = m_att.defaultUnicastLocatorList; - const auto& old_default_multicast = m_att.defaultMulticastLocatorList; - const auto& new_default_unicast = temp_atts.defaultUnicastLocatorList; - const auto& new_default_multicast = temp_atts.defaultMulticastLocatorList; - - // Early return if there is no change in default unicast locators - if ((old_default_unicast == new_default_unicast) && - (old_default_multicast == new_default_multicast)) - { - return; - } - - // Update proxies of endpoints with default configured locators - EDP* edp = pdp->getEDP(); - for (RTPSWriter* writer : m_userWriterList) - { - if ((old_default_multicast == writer->getAttributes().multicastLocatorList) && - (old_default_unicast == writer->getAttributes().unicastLocatorList)) - { - writer->getAttributes().multicastLocatorList = new_default_multicast; - writer->getAttributes().unicastLocatorList = new_default_unicast; - - WriterProxyData* wdata = nullptr; - GUID_t participant_guid; - wdata = pdp->addWriterProxyData(writer->getGuid(), participant_guid, - [](WriterProxyData* proxy, bool is_update, - const ParticipantProxyData& participant) - { - static_cast(is_update); - assert(is_update); - proxy->set_locators(participant.default_locators); - return true; - }); - assert(wdata != nullptr); - edp->processLocalWriterProxyData(writer, wdata); - } - } - for (RTPSReader* reader : m_userReaderList) - { - if ((old_default_multicast == reader->getAttributes().multicastLocatorList) && - (old_default_unicast == reader->getAttributes().unicastLocatorList)) - { - reader->getAttributes().multicastLocatorList = new_default_multicast; - reader->getAttributes().unicastLocatorList = new_default_unicast; - - ReaderProxyData* rdata = nullptr; - GUID_t participant_guid; - rdata = pdp->addReaderProxyData(reader->getGuid(), participant_guid, - [](ReaderProxyData* proxy, bool is_update, - const ParticipantProxyData& participant) - { - static_cast(is_update); - assert(is_update); - - proxy->set_locators(participant.default_locators); - return true; - }); - assert(rdata != nullptr); - edp->processLocalReaderProxyData(reader, rdata); - } - } + update_endpoint_locators_if_default_nts(m_userWriterList, m_userReaderList, m_att, temp_atts, pdp); } - // -- end of 3.x backport if (local_interfaces_changed) { From 987824dec052d84d5c3366587dbe95b47b3cd6ee Mon Sep 17 00:00:00 2001 From: Miguel Company Date: Wed, 6 Nov 2024 15:08:37 +0100 Subject: [PATCH 7/8] Methods get_default_xxx_locators with output argument. Signed-off-by: Miguel Company --- .../rtps/participant/RTPSParticipantImpl.cpp | 32 +++++++++++++------ .../rtps/participant/RTPSParticipantImpl.h | 6 ++++ 2 files changed, 28 insertions(+), 10 deletions(-) diff --git a/src/cpp/rtps/participant/RTPSParticipantImpl.cpp b/src/cpp/rtps/participant/RTPSParticipantImpl.cpp index 78a84f55525..adabd3e2299 100644 --- a/src/cpp/rtps/participant/RTPSParticipantImpl.cpp +++ b/src/cpp/rtps/participant/RTPSParticipantImpl.cpp @@ -1669,7 +1669,7 @@ void RTPSParticipantImpl::update_attributes( { LocatorList_t metatraffic_unicast_locator_list = temp_atts.builtin.metatrafficUnicastLocatorList; temp_atts.builtin.metatrafficUnicastLocatorList.clear(); - get_default_metatraffic_locators(); + get_default_metatraffic_locators(temp_atts); if (!(metatraffic_unicast_locator_list == temp_atts.builtin.metatrafficUnicastLocatorList)) { local_interfaces_changed = true; @@ -1680,7 +1680,7 @@ void RTPSParticipantImpl::update_attributes( { LocatorList_t default_unicast_locator_list = temp_atts.defaultUnicastLocatorList; temp_atts.defaultUnicastLocatorList.clear(); - get_default_unicast_locators(); + get_default_unicast_locators(temp_atts); if (!(default_unicast_locator_list == temp_atts.defaultUnicastLocatorList)) { local_interfaces_changed = true; @@ -2976,22 +2976,34 @@ void RTPSParticipantImpl::environment_file_has_changed() void RTPSParticipantImpl::get_default_metatraffic_locators() { - uint32_t metatraffic_multicast_port = m_att.port.getMulticastPort(domain_id_); + get_default_metatraffic_locators(m_att); +} + +void RTPSParticipantImpl::get_default_metatraffic_locators( + RTPSParticipantAttributes& att) +{ + uint32_t metatraffic_multicast_port = att.port.getMulticastPort(domain_id_); - m_network_Factory.getDefaultMetatrafficMulticastLocators(m_att.builtin.metatrafficMulticastLocatorList, + m_network_Factory.getDefaultMetatrafficMulticastLocators(att.builtin.metatrafficMulticastLocatorList, metatraffic_multicast_port); - m_network_Factory.NormalizeLocators(m_att.builtin.metatrafficMulticastLocatorList); + m_network_Factory.NormalizeLocators(att.builtin.metatrafficMulticastLocatorList); - m_network_Factory.getDefaultMetatrafficUnicastLocators(m_att.builtin.metatrafficUnicastLocatorList, + m_network_Factory.getDefaultMetatrafficUnicastLocators(att.builtin.metatrafficUnicastLocatorList, metatraffic_unicast_port_); - m_network_Factory.NormalizeLocators(m_att.builtin.metatrafficUnicastLocatorList); + m_network_Factory.NormalizeLocators(att.builtin.metatrafficUnicastLocatorList); } void RTPSParticipantImpl::get_default_unicast_locators() { - uint32_t unicast_port = metatraffic_unicast_port_ + m_att.port.offsetd3 - m_att.port.offsetd1; - m_network_Factory.getDefaultUnicastLocators(m_att.defaultUnicastLocatorList, unicast_port); - m_network_Factory.NormalizeLocators(m_att.defaultUnicastLocatorList); + get_default_unicast_locators(m_att); +} + +void RTPSParticipantImpl::get_default_unicast_locators( + RTPSParticipantAttributes& att) +{ + uint32_t unicast_port = metatraffic_unicast_port_ + att.port.offsetd3 - att.port.offsetd1; + m_network_Factory.getDefaultUnicastLocators(att.defaultUnicastLocatorList, unicast_port); + m_network_Factory.NormalizeLocators(att.defaultUnicastLocatorList); } bool RTPSParticipantImpl::is_participant_ignored( diff --git a/src/cpp/rtps/participant/RTPSParticipantImpl.h b/src/cpp/rtps/participant/RTPSParticipantImpl.h index 25059076623..372e48daafb 100644 --- a/src/cpp/rtps/participant/RTPSParticipantImpl.h +++ b/src/cpp/rtps/participant/RTPSParticipantImpl.h @@ -783,11 +783,17 @@ class RTPSParticipantImpl */ void get_default_metatraffic_locators(); + void get_default_metatraffic_locators( + RTPSParticipantAttributes& att); + /** * Get default unicast locators when not provided by the user. */ void get_default_unicast_locators(); + void get_default_unicast_locators( + RTPSParticipantAttributes& att); + bool match_local_endpoints_ = true; bool should_match_local_endpoints( From e010c9fe22126c715e1d8a14a9ddbb198c80b9dd Mon Sep 17 00:00:00 2001 From: Miguel Company Date: Wed, 6 Nov 2024 15:09:21 +0100 Subject: [PATCH 8/8] Only update attributes when necessary. Signed-off-by: Miguel Company --- src/cpp/rtps/participant/RTPSParticipantImpl.cpp | 11 ++++++----- 1 file changed, 6 insertions(+), 5 deletions(-) diff --git a/src/cpp/rtps/participant/RTPSParticipantImpl.cpp b/src/cpp/rtps/participant/RTPSParticipantImpl.cpp index adabd3e2299..644295d8dc5 100644 --- a/src/cpp/rtps/participant/RTPSParticipantImpl.cpp +++ b/src/cpp/rtps/participant/RTPSParticipantImpl.cpp @@ -1801,6 +1801,7 @@ void RTPSParticipantImpl::update_attributes( } } + // Update discovery information { std::lock_guard lock(*pdp->getMutex()); local_participant_attributes_update_nts(temp_atts, pdp, this); @@ -1888,12 +1889,12 @@ void RTPSParticipantImpl::update_attributes( } } } - } - // Update the attributes data member - { - std::lock_guard guard(*mp_mutex); - m_att = temp_atts; + // Update the attributes data member + { + std::lock_guard guard(*mp_mutex); + m_att = temp_atts; + } } if (update_pdp)