From 202e6d38c43299e767f7765c7df2236849fc727b Mon Sep 17 00:00:00 2001 From: Andrew Tridgell Date: Mon, 18 Feb 2019 13:53:50 +1100 Subject: [PATCH] AP_Logger: fixed race condition with multi-thread AP_Logger --- libraries/AP_Logger/AP_Logger.h | 1 + .../AP_Logger/AP_Logger_MAVLinkLogTransfer.cpp | 13 +++++++++++++ 2 files changed, 14 insertions(+) diff --git a/libraries/AP_Logger/AP_Logger.h b/libraries/AP_Logger/AP_Logger.h index a009252e9d..5bf82e07dd 100644 --- a/libraries/AP_Logger/AP_Logger.h +++ b/libraries/AP_Logger/AP_Logger.h @@ -437,6 +437,7 @@ private: uint32_t _log_data_page; GCS_MAVLINK *_log_sending_link; + HAL_Semaphore_Recursive _log_send_sem; bool should_handle_log_message(); void handle_log_message(class GCS_MAVLINK &, mavlink_message_t *msg); diff --git a/libraries/AP_Logger/AP_Logger_MAVLinkLogTransfer.cpp b/libraries/AP_Logger/AP_Logger_MAVLinkLogTransfer.cpp index e0b35835e0..2bcbf638e9 100644 --- a/libraries/AP_Logger/AP_Logger_MAVLinkLogTransfer.cpp +++ b/libraries/AP_Logger/AP_Logger_MAVLinkLogTransfer.cpp @@ -66,6 +66,8 @@ void AP_Logger::handle_log_message(GCS_MAVLINK &link, mavlink_message_t *msg) */ void AP_Logger::handle_log_request_list(GCS_MAVLINK &link, mavlink_message_t *msg) { + WITH_SEMAPHORE(_log_send_sem); + if (_log_sending_link != nullptr) { link.send_text(MAV_SEVERITY_INFO, "Log download in progress"); return; @@ -102,6 +104,8 @@ void AP_Logger::handle_log_request_list(GCS_MAVLINK &link, mavlink_message_t *ms */ void AP_Logger::handle_log_request_data(GCS_MAVLINK &link, mavlink_message_t *msg) { + WITH_SEMAPHORE(_log_send_sem); + if (_log_sending_link != nullptr) { // some GCS (e.g. MAVProxy) attempt to stream request_data // messages when they're filling gaps in the downloaded logs. @@ -167,6 +171,7 @@ void AP_Logger::handle_log_request_erase(GCS_MAVLINK &link, mavlink_message_t *m */ void AP_Logger::handle_log_request_end(GCS_MAVLINK &link, mavlink_message_t *msg) { + WITH_SEMAPHORE(_log_send_sem); mavlink_log_request_end_t packet; mavlink_msg_log_request_end_decode(msg, &packet); @@ -179,6 +184,8 @@ void AP_Logger::handle_log_request_end(GCS_MAVLINK &link, mavlink_message_t *msg */ void AP_Logger::handle_log_send() { + WITH_SEMAPHORE(_log_send_sem); + if (_log_sending_link == nullptr) { return; } @@ -200,6 +207,8 @@ void AP_Logger::handle_log_send() void AP_Logger::handle_log_sending() { + WITH_SEMAPHORE(_log_send_sem); + #if CONFIG_HAL_BOARD == HAL_BOARD_SITL // assume USB speeds in SITL for the purposes of log download const uint8_t num_sends = 40; @@ -233,6 +242,8 @@ void AP_Logger::handle_log_sending() */ void AP_Logger::handle_log_send_listing() { + WITH_SEMAPHORE(_log_send_sem); + if (!HAVE_PAYLOAD_SPACE(_log_sending_link->get_chan(), LOG_ENTRY)) { // no space return; @@ -268,6 +279,8 @@ void AP_Logger::handle_log_send_listing() */ bool AP_Logger::handle_log_send_data() { + WITH_SEMAPHORE(_log_send_sem); + if (!HAVE_PAYLOAD_SPACE(_log_sending_link->get_chan(), LOG_DATA)) { // no space return false;