From ef1c2abc0565d4ac8dd44983a3a274be5ce9cff6 Mon Sep 17 00:00:00 2001 From: ALTracer <11005378+ALTracer@users.noreply.github.com> Date: Sun, 10 Nov 2024 21:19:40 +0300 Subject: [PATCH] crc32: Buffer up log output to avoid prefix-chunking, fix `func` * Format the optional output pieces into a stack buffer, then do a single DEBUG_INFO() call * Restore the name of compiled function implementation in the log output * Avoid dividing by 0 milliseconds elapsed --- src/crc32.c | 20 ++++++++++++++------ 1 file changed, 14 insertions(+), 6 deletions(-) diff --git a/src/crc32.c b/src/crc32.c index 672d103abbc..4be05652158 100644 --- a/src/crc32.c +++ b/src/crc32.c @@ -193,20 +193,28 @@ bool bmd_crc32(target_s *const target, uint32_t *const result, const uint32_t ba #if !defined(STM32F0) && !defined(STM32F1) && !defined(STM32F2) && !defined(STM32F3) && !defined(STM32F4) && \ !defined(STM32F7) && !defined(STM32L0) && !defined(STM32L1) && !defined(STM32G0) && !defined(STM32G4) const bool status = generic_crc32(target, result, base, len); + const char *const func = "generic_crc32"; #else const bool status = stm32_crc32(target, result, base, len); + const char *const func = "stm32_crc32"; #endif #ifndef DEBUG_INFO_IS_NOOP - /* "generic_crc32: 08000110+75272 -> 1353ms, 54 KiB/s" */ - /* "stm32_crc32: 08000110+75272 -> 237ms, 310 KiB/s" */ + /* "generic_crc32: 0x08000110+75272 -> 1353ms, 54 KiB/s" */ + /* "stm32_crc32: 0x08000110+75272 -> 237ms, 310 KiB/s" */ const uint32_t end_time = platform_time_ms(); const uint32_t time_elapsed = end_time - start_time; - DEBUG_INFO("%s: 0x%08" PRIx32 "+%" PRIu32 " -> %" PRIu32 "ms", __func__, base, (uint32_t)len, time_elapsed); - if (len >= 512U) { + char logbuf[64] = {0}; + const size_t logcap = 64; + size_t loglen = 0; + loglen = snprintf(&logbuf[loglen], logcap, "%s: 0x%08" PRIx32 "+%" PRIu32 " -> %" PRIu32 "ms", func, base, + (uint32_t)len, time_elapsed); + if (len >= 512U && time_elapsed > 0U) { const uint32_t speed = len * 1000U / time_elapsed / 1024U; - DEBUG_INFO(", %" PRIu32 " KiB/s", speed); + loglen += snprintf(&logbuf[loglen], logcap - loglen, ", %" PRIu32 " KiB/s", speed); } - DEBUG_INFO("\n"); + DEBUG_INFO("%s\n", logbuf); +#else + (void)func; #endif return status; }