From 11287a94c2a1cffb0e3202e7fd5eee40480520e1 Mon Sep 17 00:00:00 2001 From: Ussama Naal <606033+Samahu@users.noreply.github.com> Date: Fri, 9 Feb 2024 09:41:41 -0800 Subject: [PATCH] Use timeout when waiting for packets to be proceed in case they don't come (#293) --- CHANGELOG.rst | 1 + ouster-ros/package.xml | 2 +- ouster-ros/src/os_sensor_node.cpp | 12 ++++++------ ouster-sensor-msgs/package.xml | 2 +- 4 files changed, 9 insertions(+), 8 deletions(-) diff --git a/CHANGELOG.rst b/CHANGELOG.rst index ffac6b65..3a3a2d74 100644 --- a/CHANGELOG.rst +++ b/CHANGELOG.rst @@ -7,6 +7,7 @@ Changelog * [BUGFIX]: LaserScan is not properly aligned with generated point cloud * address an issue where LaserScan appeared different on FW prior to 2.4 * [BUGFIX]: LaserScan does not work when using dual mode +* [BUGFIX]: ROS2 crashes when standby mode is set and then set to normal ouster_ros v0.12.0 diff --git a/ouster-ros/package.xml b/ouster-ros/package.xml index 9b4f760b..cc6a0f7a 100644 --- a/ouster-ros/package.xml +++ b/ouster-ros/package.xml @@ -2,7 +2,7 @@ ouster_ros - 0.12.1 + 0.12.2 Ouster ROS2 driver ouster developers BSD diff --git a/ouster-ros/src/os_sensor_node.cpp b/ouster-ros/src/os_sensor_node.cpp index 0c9ae654..ca52a39c 100644 --- a/ouster-ros/src/os_sensor_node.cpp +++ b/ouster-ros/src/os_sensor_node.cpp @@ -799,9 +799,9 @@ void OusterSensor::start_packet_processing_threads() { imu_packets_processing_thread_active = true; imu_packets_processing_thread = std::make_unique([this]() { while (imu_packets_processing_thread_active) { - imu_packets->read([this](const uint8_t* buffer) { - on_imu_packet_msg(buffer); - }); + imu_packets->read_timeout([this](const uint8_t* buffer) { + if (buffer != nullptr) on_imu_packet_msg(buffer); + }, 1s); } RCLCPP_DEBUG(get_logger(), "imu_packets_processing_thread done."); }); @@ -809,9 +809,9 @@ void OusterSensor::start_packet_processing_threads() { lidar_packets_processing_thread_active = true; lidar_packets_processing_thread = std::make_unique([this]() { while (lidar_packets_processing_thread_active) { - lidar_packets->read([this](const uint8_t* buffer) { - on_lidar_packet_msg(buffer); - }); + lidar_packets->read_timeout([this](const uint8_t* buffer) { + if (buffer != nullptr) on_lidar_packet_msg(buffer); + }, 1s); } RCLCPP_DEBUG(get_logger(), "lidar_packets_processing_thread done."); }); diff --git a/ouster-sensor-msgs/package.xml b/ouster-sensor-msgs/package.xml index 08cbc873..d2087191 100644 --- a/ouster-sensor-msgs/package.xml +++ b/ouster-sensor-msgs/package.xml @@ -2,7 +2,7 @@ ouster_sensor_msgs - 0.12.0 + 0.12.2 ouster_ros message and service definitions ouster developers BSD