From d271fa80f959398afb4efe56e0179b7bf63cd484 Mon Sep 17 00:00:00 2001 From: Andrew Tridgell Date: Sat, 21 Sep 2024 18:07:36 +1000 Subject: [PATCH] AP_CANManager: fixed de-registering CAN forwarding this prevented MissionPlanner MAVCAN UI from working reliably as the CANManager could think we are registered when we are not --- libraries/AP_CANManager/AP_CANManager.cpp | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/libraries/AP_CANManager/AP_CANManager.cpp b/libraries/AP_CANManager/AP_CANManager.cpp index a8e7c7e9a3892b..dfb9dbc863d4b2 100644 --- a/libraries/AP_CANManager/AP_CANManager.cpp +++ b/libraries/AP_CANManager/AP_CANManager.cpp @@ -427,9 +427,13 @@ bool AP_CANManager::handle_can_forward(mavlink_channel_t chan, const mavlink_com WITH_SEMAPHORE(can_forward.sem); const int8_t bus = int8_t(packet.param1)-1; if (bus == -1) { + /* + a request to stop forwarding + */ for (auto can_iface : hal.can) { if (can_iface && can_forward.callback_id != 0) { can_iface->unregister_frame_callback(can_forward.callback_id); + can_forward.callback_id = 0; } } return true; @@ -451,6 +455,7 @@ bool AP_CANManager::handle_can_forward(mavlink_channel_t chan, const mavlink_com for (uint8_t i=0; iunregister_frame_callback(can_forward.callback_id); + can_forward.callback_id = 0; } } @@ -647,6 +652,7 @@ void AP_CANManager::can_frame_callback(uint8_t bus, const AP_HAL::CANFrame &fram if (can_forward.callback_id != 0 && AP_HAL::millis() - can_forward.last_callback_enable_ms > 5000) { hal.can[bus]->unregister_frame_callback(can_forward.callback_id); + can_forward.callback_id = 0; return; } can_forward.frame_counter = 0;