From ebffc8fc65e9f4e54f5f4826e5012648e2bfc078 Mon Sep 17 00:00:00 2001 From: Andrew Tridgell Date: Thu, 14 Sep 2023 08:18:57 +1000 Subject: [PATCH] HAL_ChibiOS: fixed CAN statistics on F4/L4/F3/F7 --- libraries/AP_HAL_ChibiOS/CANIface.h | 3 +++ libraries/AP_HAL_ChibiOS/CanIface.cpp | 3 ++- 2 files changed, 5 insertions(+), 1 deletion(-) diff --git a/libraries/AP_HAL_ChibiOS/CANIface.h b/libraries/AP_HAL_ChibiOS/CANIface.h index ebda8635ec..47809fa79b 100644 --- a/libraries/AP_HAL_ChibiOS/CANIface.h +++ b/libraries/AP_HAL_ChibiOS/CANIface.h @@ -218,7 +218,9 @@ public: // fetch stats text and return the size of the same, // results available via @SYS/can0_stats.txt or @SYS/can1_stats.txt void get_stats(ExpandingString &str) override; +#endif +#if !defined(HAL_BOOTLOADER_BUILD) /* return statistics structure */ @@ -226,6 +228,7 @@ public: return &stats; } #endif + /************************************ * Methods used inside interrupt * ************************************/ diff --git a/libraries/AP_HAL_ChibiOS/CanIface.cpp b/libraries/AP_HAL_ChibiOS/CanIface.cpp index f7edd22198..677f484804 100644 --- a/libraries/AP_HAL_ChibiOS/CanIface.cpp +++ b/libraries/AP_HAL_ChibiOS/CanIface.cpp @@ -292,6 +292,7 @@ int16_t CANIface::send(const AP_HAL::CANFrame& frame, uint64_t tx_deadline, if (frame.isErrorFrame() || frame.dlc > 8) { return -1; } + PERF_STATS(stats.tx_requests); /* * Normally we should perform the same check as in @ref canAcceptNewTxFrame(), because @@ -323,7 +324,7 @@ int16_t CANIface::send(const AP_HAL::CANFrame& frame, uint64_t tx_deadline, } else if ((can_->TSR & bxcan::TSR_TME2) == bxcan::TSR_TME2) { txmailbox = 2; } else { - PERF_STATS(stats.tx_rejected); + PERF_STATS(stats.tx_overflow); return 0; // No transmission for you. }