From fee27ee6ed497082fe796f9e8dfa315b4031c42c Mon Sep 17 00:00:00 2001 From: Mike Date: Wed, 10 Apr 2019 14:07:59 +0100 Subject: [PATCH] Minor gdb fixes (#1662) * Add missing return value from `HardwareSerial::updateUartCallback()` * Fix debug statement in `GdbFileStream::open()` * Make sure debug output appears before exception message * Missing nullptr check in `uart_get_status()` --- Sming/SmingCore/Data/Stream/GdbFileStream.cpp | 2 +- Sming/SmingCore/HardwareSerial.cpp | 2 ++ Sming/appspecific/gdb/gdb_hooks.cpp | 3 +++ Sming/system/uart.cpp | 8 +++++--- 4 files changed, 11 insertions(+), 4 deletions(-) diff --git a/Sming/SmingCore/Data/Stream/GdbFileStream.cpp b/Sming/SmingCore/Data/Stream/GdbFileStream.cpp index f4424c909d..b3946f733c 100644 --- a/Sming/SmingCore/Data/Stream/GdbFileStream.cpp +++ b/Sming/SmingCore/Data/Stream/GdbFileStream.cpp @@ -47,7 +47,7 @@ bool GdbFileStream::open(const String& fileName, FileOpenFlags openFlags) this->size = size; gdb_syscall_lseek(fd, 0, SEEK_SET); pos = 0; - debug_d("opened file: '%s' (%u bytes) #0x%08X", fileName().c_str(), size, this); + debug_d("opened file: '%s' (%u bytes) #0x%08X", fileName.c_str(), size, this); } return true; } diff --git a/Sming/SmingCore/HardwareSerial.cpp b/Sming/SmingCore/HardwareSerial.cpp index cd37401b67..e8f7788f60 100644 --- a/Sming/SmingCore/HardwareSerial.cpp +++ b/Sming/SmingCore/HardwareSerial.cpp @@ -178,6 +178,8 @@ bool HardwareSerial::updateUartCallback() statusMask = mask; setUartCallback(mask == 0 ? nullptr : staticCallbackHandler, this); + + return mask != 0; } void HardwareSerial::commandProcessing(bool reqEnable) diff --git a/Sming/appspecific/gdb/gdb_hooks.cpp b/Sming/appspecific/gdb/gdb_hooks.cpp index ff87cab2c4..626ac3109a 100644 --- a/Sming/appspecific/gdb/gdb_hooks.cpp +++ b/Sming/appspecific/gdb/gdb_hooks.cpp @@ -72,6 +72,7 @@ void debug_print_stack(uint32_t start, uint32_t end) void debug_crash_callback(const rst_info* rst_info, uint32_t stack, uint32_t stack_end) { #ifdef ENABLE_GDB + gdbFlushUserData(); if(gdb_state.attached) { m_setPuts(gdbWriteConsole); } @@ -159,6 +160,8 @@ static void __attribute__((noinline)) gdbstub_exception_handler_flash(UserFrame* gdbstub_savedRegs.a[1] = uint32_t(frame) + EXCEPTION_GDB_SP_OFFSET; #if defined(ENABLE_GDB) && GDBSTUB_BREAK_ON_EXCEPTION + gdbFlushUserData(); + // If GDB is attached, temporarily redirect m_printf calls to the console nputs_callback_t oldPuts = nullptr; if(gdb_state.attached) { diff --git a/Sming/system/uart.cpp b/Sming/system/uart.cpp index f68f0e96ae..3583479f2d 100644 --- a/Sming/system/uart.cpp +++ b/Sming/system/uart.cpp @@ -567,9 +567,11 @@ uint8_t uart_get_status(uart_t* uart) uart->status = 0; // Read raw status register directly from real uart, masking out non-error bits uart = get_physical(uart); - status |= USIR(uart->uart_nr) & (_BV(UIBD) | _BV(UIOF) | _BV(UIFR) | _BV(UIPE)); - // Clear errors - USIC(uart->uart_nr) = status; + if(uart != nullptr) { + status |= USIR(uart->uart_nr) & (_BV(UIBD) | _BV(UIOF) | _BV(UIFR) | _BV(UIPE)); + // Clear errors + USIC(uart->uart_nr) = status; + } uart_restore_interrupts(); } return status;