From e8d07617333c03ae4ed014c99f5624782871ac1d Mon Sep 17 00:00:00 2001 From: elagil Date: Wed, 29 Nov 2023 10:34:57 +0100 Subject: [PATCH 1/6] misc: add missing NO_LIBOPENCM3 check --- src/include/gdb_if.h | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/include/gdb_if.h b/src/include/gdb_if.h index 29303c6b7b3..332683c212b 100644 --- a/src/include/gdb_if.h +++ b/src/include/gdb_if.h @@ -21,7 +21,7 @@ #ifndef INCLUDE_GDB_IF_H #define INCLUDE_GDB_IF_H -#if PC_HOSTED == 0 +#if PC_HOSTED == 0 && !defined(NO_LIBOPENCM3) #include void gdb_usb_out_cb(usbd_device *dev, uint8_t ep); #endif From b050966a88b60a40487bfea60afa0654bcab38b1 Mon Sep 17 00:00:00 2001 From: elagil Date: Wed, 29 Nov 2023 10:34:57 +0100 Subject: [PATCH 2/6] misc: fix missing strict prototypes --- src/include/gdb_main.h | 2 +- src/include/rtt_if.h | 4 ++-- src/target/adiv5_swd.c | 6 +++--- 3 files changed, 6 insertions(+), 6 deletions(-) diff --git a/src/include/gdb_main.h b/src/include/gdb_main.h index e52b886e6d5..5f6fba75820 100644 --- a/src/include/gdb_main.h +++ b/src/include/gdb_main.h @@ -31,6 +31,6 @@ extern target_s *cur_target; void gdb_poll_target(void); void gdb_main(char *pbuf, size_t pbuf_size, size_t size); int gdb_main_loop(target_controller_s *tc, char *pbuf, size_t pbuf_size, size_t size, bool in_syscall); -char *gdb_packet_buffer(); +char *gdb_packet_buffer(void); #endif /* INCLUDE_GDB_MAIN_H */ diff --git a/src/include/rtt_if.h b/src/include/rtt_if.h index 20560496e5c..ceba91a7451 100644 --- a/src/include/rtt_if.h +++ b/src/include/rtt_if.h @@ -68,8 +68,8 @@ int rtt_if_exit(void); /* target to host: write len bytes from the buffer starting at buf. return number bytes written */ uint32_t rtt_write(const char *buf, uint32_t len); /* host to target: read one character, non-blocking. return character, -1 if no character */ -int32_t rtt_getchar(); +int32_t rtt_getchar(void); /* host to target: true if no characters available for reading */ -bool rtt_nodata(); +bool rtt_nodata(void); #endif /* INCLUDE_RTT_IF_H */ diff --git a/src/target/adiv5_swd.c b/src/target/adiv5_swd.c index 52a0a034a70..a257c00b4bb 100644 --- a/src/target/adiv5_swd.c +++ b/src/target/adiv5_swd.c @@ -19,7 +19,7 @@ * along with this program. If not, see . */ -/* +/* * This file implements the SWD specific functions of the * ARM Debug Interface v5 Architecture Specification, ARM doc IHI0031A. */ @@ -67,7 +67,7 @@ static void swd_line_reset_sequence(const bool idle_cycles) } /* Switch out of dormant state into SWD */ -static void dormant_to_swd_sequence() +static void dormant_to_swd_sequence(void) { /* * ARM Debug Interface Architecture Specification, ADIv5.0 to ADIv5.2. ARM IHI 0031C @@ -102,7 +102,7 @@ static void dormant_to_swd_sequence() } /* Deprecated JTAG-to-SWD select sequence */ -static void jtag_to_swd_sequence() +static void jtag_to_swd_sequence(void) { /* * ARM Debug Interface Architecture Specification, ADIv5.0 to ADIv5.2. ARM IHI 0031C From 552936353e9d5b68e91d8d25aed45168d46346d7 Mon Sep 17 00:00:00 2001 From: elagil Date: Wed, 29 Nov 2023 10:34:58 +0100 Subject: [PATCH 3/6] misc: fix warnings for undefined variables --- src/gdb_main.c | 2 +- src/target/adiv5.c | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/src/gdb_main.c b/src/gdb_main.c index 62fb78784c3..7ba149fba37 100644 --- a/src/gdb_main.c +++ b/src/gdb_main.c @@ -41,7 +41,7 @@ #include "rtt.h" #endif -#if ADVERTISE_NOACKMODE == 1 +#if defined(ADVERTISE_NOACKMODE) && ADVERTISE_NOACKMODE == 1 /* * This lets GDB know that the probe supports ‘QStartNoAckMode’ * and prefers to operate in no-acknowledgment mode diff --git a/src/target/adiv5.c b/src/target/adiv5.c index 1c5c0cef9b0..72feb8f8cec 100644 --- a/src/target/adiv5.c +++ b/src/target/adiv5.c @@ -476,7 +476,7 @@ static uint32_t cortexm_initial_halt(adiv5_access_port_s *ap) */ static bool cortexm_prepare(adiv5_access_port_s *ap) { -#if PC_HOSTED == 1 || ENABLE_DEBUG == 1 +#if (defined(PC_HOSTED) && PC_HOSTED == 1) || (ENABLE_DEBUG == 1) uint32_t start_time = platform_time_ms(); #endif uint32_t dhcsr = cortexm_initial_halt(ap); From 9b6a5794e75b9baf40e6ce87759f7a1f004f8baf Mon Sep 17 00:00:00 2001 From: elagil Date: Wed, 29 Nov 2023 10:35:38 +0100 Subject: [PATCH 4/6] misc: rework definitions that enable debug mode --- src/Makefile | 8 +++++++- src/crc32.c | 2 +- src/include/general.h | 7 ++++++- src/platforms/common/aux_serial.h | 2 +- src/platforms/common/usb_serial.c | 16 ++++++++-------- src/platforms/f072/platform.h | 2 +- src/platforms/f3/platform.h | 2 +- src/platforms/hosted/Makefile.inc | 2 +- src/platforms/hosted/dap_jtag.c | 2 +- src/platforms/native/platform.h | 2 +- src/platforms/stlink/platform.h | 2 +- src/platforms/stlinkv3/platform.h | 2 +- src/platforms/swlink/platform.h | 2 +- src/remote.c | 2 +- src/target/adiv5.c | 12 ++++++------ src/target/cortexar.c | 2 +- src/target/cortexm.c | 4 ++-- src/target/efm32.c | 2 +- src/target/imxrt.c | 4 ++-- src/target/jtag_devs.c | 12 ++++++------ src/target/jtag_devs.h | 2 +- src/target/jtag_scan.c | 2 +- src/target/lpc_common.c | 4 ++-- src/target/rp.c | 2 +- src/target/sfdp.c | 2 +- src/target/stm32h7.c | 2 +- 26 files changed, 57 insertions(+), 46 deletions(-) diff --git a/src/Makefile b/src/Makefile index 82639d64b2b..fa17762946d 100644 --- a/src/Makefile +++ b/src/Makefile @@ -21,8 +21,14 @@ ifeq (filter, macosx darwin, $(SYS)) CFLAGS += -Wmaybe-uninitialized -Wstringop-overflow -Wunsafe-loop-optimizations endif +ifeq ($(PROBE_HOST),hosted) +ENABLE_DEBUG = 1 +endif + ifeq ($(ENABLE_DEBUG), 1) -CFLAGS += -DENABLE_DEBUG +CFLAGS += -DENABLE_DEBUG=1 +else +CFLAGS += -DENABLE_DEBUG=0 endif SRC = \ diff --git a/src/crc32.c b/src/crc32.c index 7b05155cc05..d001b6cde95 100644 --- a/src/crc32.c +++ b/src/crc32.c @@ -113,7 +113,7 @@ bool generic_crc32(target_s *const target, uint32_t *const result, const uint32_ uint8_t bytes[128U]; #endif -#if defined(ENABLE_DEBUG) +#if ENABLE_DEBUG == 1 const uint32_t start_time = platform_time_ms(); #endif uint32_t last_time = platform_time_ms(); diff --git a/src/include/general.h b/src/include/general.h index b9e6a9080b0..6df94b1dc87 100644 --- a/src/include/general.h +++ b/src/include/general.h @@ -81,7 +81,12 @@ #define PRINT_NOOP(...) \ do { \ } while (false) -#if defined(ENABLE_DEBUG) + +#ifndef ENABLE_DEBUG +#define ENABLE_DEBUG 0 +#endif + +#if ENABLE_DEBUG == 1 #define DEBUG_ERROR(...) PLATFORM_PRINTF(__VA_ARGS__) #define DEBUG_WARN(...) PLATFORM_PRINTF(__VA_ARGS__) #define DEBUG_INFO(...) PLATFORM_PRINTF(__VA_ARGS__) diff --git a/src/platforms/common/aux_serial.h b/src/platforms/common/aux_serial.h index b46f2e78734..141fcceb7ee 100644 --- a/src/platforms/common/aux_serial.h +++ b/src/platforms/common/aux_serial.h @@ -69,7 +69,7 @@ void aux_serial_send(size_t len); void aux_serial_update_receive_buffer_fullness(void); bool aux_serial_receive_buffer_empty(void); void aux_serial_drain_receive_buffer(void); -#ifdef ENABLE_DEBUG +#if ENABLE_DEBUG == 1 void aux_serial_stage_debug_buffer(void); #endif void aux_serial_stage_receive_buffer(void); diff --git a/src/platforms/common/usb_serial.c b/src/platforms/common/usb_serial.c index ede68dbef68..cc09dcde37e 100644 --- a/src/platforms/common/usb_serial.c +++ b/src/platforms/common/usb_serial.c @@ -40,7 +40,7 @@ * */ -#ifndef ENABLE_DEBUG +#if ENABLE_DEBUG != 1 #include #include @@ -77,7 +77,7 @@ static void debug_serial_receive_callback(usbd_device *dev, uint8_t ep); static bool debug_serial_send_complete = true; #endif -#if defined(ENABLE_DEBUG) && defined(PLATFORM_HAS_DEBUG) +#if (ENABLE_DEBUG == 1) && defined(PLATFORM_HAS_DEBUG) /* * This call initialises "SemiHosting", only we then do our own SVC interrupt things to * route all output through to the debug USB serial interface if debug_bmp is true. @@ -214,7 +214,7 @@ void usb_serial_set_config(usbd_device *dev, uint16_t value) usb_serial_set_state(dev, GDB_IF_NO, CDCACM_GDB_ENDPOINT + 1U); usb_serial_set_state(dev, UART_IF_NO, CDCACM_UART_ENDPOINT + 1U); -#if defined(ENABLE_DEBUG) && defined(PLATFORM_HAS_DEBUG) +#if (ENABLE_DEBUG == 1) && defined(PLATFORM_HAS_DEBUG) initialise_monitor_handles(); #endif } @@ -249,7 +249,7 @@ uint32_t debug_serial_fifo_send(const char *const fifo, const uint32_t fifo_begi return fifo_begin; } -#if defined(ENABLE_DEBUG) && defined(PLATFORM_HAS_DEBUG) +#if (ENABLE_DEBUG == 1) && defined(PLATFORM_HAS_DEBUG) static bool debug_serial_fifo_buffer_empty(void) { return debug_serial_debug_write_index == debug_serial_debug_read_index; @@ -270,17 +270,17 @@ static void debug_serial_send_data(void) * If fifo empty, nothing further to do. */ if (usb_get_config() != 1 || (aux_serial_receive_buffer_empty() -#if defined(ENABLE_DEBUG) && defined(PLATFORM_HAS_DEBUG) +#if (ENABLE_DEBUG == 1) && defined(PLATFORM_HAS_DEBUG) && debug_serial_fifo_buffer_empty() #endif )) { -#if defined(ENABLE_DEBUG) && defined(PLATFORM_HAS_DEBUG) +#if (ENABLE_DEBUG == 1) && defined(PLATFORM_HAS_DEBUG) debug_serial_debug_read_index = debug_serial_debug_write_index; #endif aux_serial_drain_receive_buffer(); debug_serial_send_complete = true; } else { -#if defined(ENABLE_DEBUG) && defined(PLATFORM_HAS_DEBUG) +#if (ENABLE_DEBUG == 1) && defined(PLATFORM_HAS_DEBUG) debug_serial_debug_read_index = debug_serial_fifo_send( debug_serial_debug_buffer, debug_serial_debug_read_index, debug_serial_debug_write_index); #endif @@ -339,7 +339,7 @@ static void debug_serial_receive_callback(usbd_device *dev, uint8_t ep) #endif } -#ifdef ENABLE_DEBUG +#if ENABLE_DEBUG == 1 #ifdef PLATFORM_HAS_DEBUG static void debug_serial_append_char(const char c) { diff --git a/src/platforms/f072/platform.h b/src/platforms/f072/platform.h index 1f6db077b3a..259108d0fb2 100644 --- a/src/platforms/f072/platform.h +++ b/src/platforms/f072/platform.h @@ -133,7 +133,7 @@ #define TRACE_IRQ NVIC_TIM3_IRQ #define TRACE_ISR tim3_isr -#ifdef ENABLE_DEBUG +#if ENABLE_DEBUG == 1 extern bool debug_bmp; #define DEBUG printf #else diff --git a/src/platforms/f3/platform.h b/src/platforms/f3/platform.h index 6d0f87145b9..3344f2b46f0 100644 --- a/src/platforms/f3/platform.h +++ b/src/platforms/f3/platform.h @@ -126,7 +126,7 @@ #define TRACE_IRQ NVIC_TIM3_IRQ #define TRACE_ISR tim3_isr -#ifdef ENABLE_DEBUG +#if ENABLE_DEBUG == 1 extern bool debug_bmp; #define DEBUG printf #else diff --git a/src/platforms/hosted/Makefile.inc b/src/platforms/hosted/Makefile.inc index 02e99f76edd..4247fc04732 100644 --- a/src/platforms/hosted/Makefile.inc +++ b/src/platforms/hosted/Makefile.inc @@ -2,7 +2,7 @@ ifeq ($(origin CC),default) CC := gcc endif SYS := $(shell $(CC) -dumpmachine) -CFLAGS += -DENABLE_DEBUG -DPLATFORM_HAS_DEBUG +CFLAGS += -DPLATFORM_HAS_DEBUG CFLAGS +=-I ./target ENABLE_CORTEXAR := 1 diff --git a/src/platforms/hosted/dap_jtag.c b/src/platforms/hosted/dap_jtag.c index 5a1d002bbcf..272d7656687 100644 --- a/src/platforms/hosted/dap_jtag.c +++ b/src/platforms/hosted/dap_jtag.c @@ -108,7 +108,7 @@ static void dap_jtag_tdi_seq(const bool final_tms, const uint8_t *const data_in, static bool dap_jtag_next(const bool tms, const bool tdi) { -#ifdef ENABLE_DEBUG +#if ENABLE_DEBUG == 1 const uint8_t tms_byte = tms ? 1 : 0; #endif const uint8_t tdi_byte = tdi ? 1 : 0; diff --git a/src/platforms/native/platform.h b/src/platforms/native/platform.h index 182b7b059f5..36a5bfce41f 100644 --- a/src/platforms/native/platform.h +++ b/src/platforms/native/platform.h @@ -30,7 +30,7 @@ #define PLATFORM_HAS_TRACESWO #define PLATFORM_HAS_POWER_SWITCH -#ifdef ENABLE_DEBUG +#if ENABLE_DEBUG == 1 #define PLATFORM_HAS_DEBUG extern bool debug_bmp; #endif diff --git a/src/platforms/stlink/platform.h b/src/platforms/stlink/platform.h index 856cd1d4977..fa56aa105e7 100644 --- a/src/platforms/stlink/platform.h +++ b/src/platforms/stlink/platform.h @@ -31,7 +31,7 @@ #include #include -#ifdef ENABLE_DEBUG +#if ENABLE_DEBUG == 1 #define PLATFORM_HAS_DEBUG extern bool debug_bmp; #endif diff --git a/src/platforms/stlinkv3/platform.h b/src/platforms/stlinkv3/platform.h index 1b6a6418cd5..c16db70a95b 100644 --- a/src/platforms/stlinkv3/platform.h +++ b/src/platforms/stlinkv3/platform.h @@ -32,7 +32,7 @@ #include #include -#ifdef ENABLE_DEBUG +#if ENABLE_DEBUG == 1 #define PLATFORM_HAS_DEBUG extern bool debug_bmp; #endif diff --git a/src/platforms/swlink/platform.h b/src/platforms/swlink/platform.h index adfcaf1afdf..88faa25abab 100644 --- a/src/platforms/swlink/platform.h +++ b/src/platforms/swlink/platform.h @@ -28,7 +28,7 @@ #include "timing.h" #include "timing_stm32.h" -#ifdef ENABLE_DEBUG +#if ENABLE_DEBUG == 1 #define PLATFORM_HAS_DEBUG extern bool debug_bmp; #endif diff --git a/src/remote.c b/src/remote.c index c7f5e6f0701..28be9b545f7 100644 --- a/src/remote.c +++ b/src/remote.c @@ -317,7 +317,7 @@ static void remote_packet_process_general(char *packet, const size_t packet_len) #endif break; case REMOTE_START: -#if defined(ENABLE_DEBUG) && defined(PLATFORM_HAS_DEBUG) +#if (ENABLE_DEBUG == 1) && defined(PLATFORM_HAS_DEBUG) debug_bmp = true; #endif remote_respond_string(REMOTE_RESP_OK, PLATFORM_IDENT "" FIRMWARE_VERSION); diff --git a/src/target/adiv5.c b/src/target/adiv5.c index 72feb8f8cec..5ddf008c81f 100644 --- a/src/target/adiv5.c +++ b/src/target/adiv5.c @@ -126,7 +126,7 @@ typedef enum arm_arch { aa_end } arm_arch_e; -#ifdef ENABLE_DEBUG +#if ENABLE_DEBUG == 1 #define ARM_COMPONENT_STR(...) __VA_ARGS__ #else #define ARM_COMPONENT_STR(...) @@ -177,7 +177,7 @@ static const struct { uint16_t arch_id; arm_arch_e arch; cid_class_e cidc; -#ifdef ENABLE_DEBUG +#if ENABLE_DEBUG == 1 const char *type; const char *full; #endif @@ -272,7 +272,7 @@ static const struct { {0xfff, 0x00, 0, aa_end, cidc_unknown, ARM_COMPONENT_STR("end", "end")}, }; -#ifdef ENABLE_DEBUG +#if ENABLE_DEBUG == 1 static const char *adiv5_arm_ap_type_string(const uint8_t ap_type, const uint8_t ap_class) { /* @@ -543,7 +543,7 @@ static void adiv5_component_probe( return; } -#if defined(ENABLE_DEBUG) +#if ENABLE_DEBUG == 1 char *indent = alloca(recursion + 1U); for (size_t i = 0; i < recursion; i++) @@ -608,7 +608,7 @@ static void adiv5_component_probe( } } -#if defined(ENABLE_DEBUG) && defined(PLATFORM_HAS_DEBUG) +#if (ENABLE_DEBUG == 1) && defined(PLATFORM_HAS_DEBUG) /* Check SYSMEM bit */ const uint32_t memtype = adiv5_mem_read32(ap, addr | ADIV5_ROM_MEMTYPE) & ADIV5_ROM_MEMTYPE_SYSMEM; @@ -747,7 +747,7 @@ adiv5_access_port_s *adiv5_new_ap(adiv5_debug_port_s *dp, uint8_t apsel) memcpy(ap, &tmpap, sizeof(*ap)); -#if defined(ENABLE_DEBUG) +#if ENABLE_DEBUG == 1 /* Grab the config register to get a complete set */ uint32_t cfg = adiv5_ap_read(ap, ADIV5_AP_CFG); DEBUG_INFO("AP %3u: IDR=%08" PRIx32 " CFG=%08" PRIx32 " BASE=%08" PRIx32 " CSW=%08" PRIx32, apsel, ap->idr, cfg, diff --git a/src/target/cortexar.c b/src/target/cortexar.c index c8d29c82b5c..e603ed28c2d 100644 --- a/src/target/cortexar.c +++ b/src/target/cortexar.c @@ -964,7 +964,7 @@ static void cortexr_mem_handle_fault( const cortexar_priv_s *const priv = (cortexar_priv_s *)target->priv; /* If we suffered a fault of some kind, grab the reason and restore DFSR/DFAR */ if (priv->core_status & CORTEXAR_STATUS_DATA_FAULT) { -#ifdef ENABLE_DEBUG +#if ENABLE_DEBUG == 1 const uint32_t fault_status = cortexar_coproc_read(target, CORTEXAR_DFSR); const uint32_t fault_addr = cortexar_coproc_read(target, CORTEXAR_DFAR); #else diff --git a/src/target/cortexm.c b/src/target/cortexm.c index 5f5a0078f21..aa7334b2988 100644 --- a/src/target/cortexm.c +++ b/src/target/cortexm.c @@ -117,7 +117,7 @@ typedef struct cortexm_priv { uint32_t demcr; } cortexm_priv_s; -#ifdef ENABLE_DEBUG +#if ENABLE_DEBUG == 1 const char *const semihosting_names[] = { "", "SYS_OPEN", @@ -1470,7 +1470,7 @@ static int cortexm_hostio_request(target_s *target) target_mem_read(target, params, arm_regs[1], sizeof(params)); int32_t ret = 0; -#ifdef ENABLE_DEBUG +#if ENABLE_DEBUG == 1 const char *syscall_descr = NULL; if (syscall < ARRAY_LENGTH(semihosting_names)) syscall_descr = semihosting_names[syscall]; diff --git a/src/target/efm32.c b/src/target/efm32.c index 692d0de2cde..900bb7d24ea 100644 --- a/src/target/efm32.c +++ b/src/target/efm32.c @@ -656,7 +656,7 @@ static bool efm32_flash_write(target_flash_s *f, target_addr_t dest, const void /* Run flashloader */ const bool ret = cortexm_run_stub(t, SRAM_BASE, dest, STUB_BUFFER_BASE, len, priv_storage->device->msc_addr) == 0; -#ifdef ENABLE_DEBUG +#if ENABLE_DEBUG == 1 /* Check the MSC_IF */ uint32_t msc = priv_storage->device->msc_addr; uint32_t msc_if = target_mem_read32(t, EFM32_MSC_IF(msc)); diff --git a/src/target/imxrt.c b/src/target/imxrt.c index 11135a58ac9..2ca6d4956d4 100644 --- a/src/target/imxrt.c +++ b/src/target/imxrt.c @@ -218,7 +218,7 @@ bool imxrt_probe(target_s *const target) snprintf(priv->name, IMXRT_NAME_MAX_LENGTH, "i.MXRT%u", priv->chip_id); target->driver = priv->name; -#if defined(ENABLE_DEBUG) && (PC_HOSTED == 1 || defined(ESP_LOGD)) +#if (ENABLE_DEBUG == 1) && (PC_HOSTED == 1 || defined(ESP_LOGD)) const uint8_t boot_mode = (target_mem_read32(target, IMXRT_SRC_BOOT_MODE2) >> 24U) & 3U; #endif DEBUG_TARGET("i.MXRT boot mode is %x\n", boot_mode); @@ -521,7 +521,7 @@ static void imxrt_spi_wait_complete(target_s *const target) target_mem_write32(target, IMXRT_FLEXSPI1_INT(priv), IMXRT_FLEXSPI1_INT_PRG_CMD_DONE); /* Check if any errors occured */ if (target_mem_read32(target, IMXRT_FLEXSPI1_INT(priv)) & IMXRT_FLEXSPI1_INT_CMD_ERR) { -#if defined(ENABLE_DEBUG) && PC_HOSTED == 1 +#if (ENABLE_DEBUG == 1) && PC_HOSTED == 1 /* Read out the status code and display it */ const uint32_t status = target_mem_read32(target, IMXRT_FLEXSPI1_STAT1(priv)); DEBUG_TARGET("Error executing sequence, offset %u, error code %u\n", (uint8_t)(status >> 16U) & 0xfU, diff --git a/src/target/jtag_devs.c b/src/target/jtag_devs.c index e9e9afd604d..e6e0a825f20 100644 --- a/src/target/jtag_devs.c +++ b/src/target/jtag_devs.c @@ -29,12 +29,12 @@ const jtag_dev_descr_s dev_descr[] = { { .idcode = 0x0ba00477U, .idmask = 0x0fff0fffU, -#ifdef ENABLE_DEBUG +#if ENABLE_DEBUG == 1 .descr = "ADIv5 JTAG-DP port.", #endif .handler = adiv5_jtag_dp_handler, }, -#ifdef ENABLE_DEBUG +#if ENABLE_DEBUG == 1 { .idcode = 0x00000477U, .idmask = 0x00000fffU, @@ -339,7 +339,7 @@ const jtag_dev_descr_s dev_descr[] = { { .idcode = 0x00000093U, .idmask = 0x00000fffU, -#ifdef ENABLE_DEBUG +#if ENABLE_DEBUG == 1 .descr = "Xilinx.", #endif .ir_quirks = @@ -352,13 +352,13 @@ const jtag_dev_descr_s dev_descr[] = { { .idcode = 0x0000563dU, .idmask = 0x0fffffffU, -#ifdef ENABLE_DEBUG +#if ENABLE_DEBUG == 1 .descr = "RISC-V debug v0.13.", #endif .handler = riscv_jtag_dtm_handler, }, #endif -#ifdef ENABLE_DEBUG +#if ENABLE_DEBUG == 1 { .idcode = 0x000007a3U, .idmask = 0x00000fffU, @@ -394,7 +394,7 @@ const jtag_dev_descr_s dev_descr[] = { { .idcode = 0U, .idmask = 0U, -#ifdef ENABLE_DEBUG +#if ENABLE_DEBUG == 1 .descr = "Unknown", #endif }, diff --git a/src/target/jtag_devs.h b/src/target/jtag_devs.h index 4465e4a250c..c08c6d2a26e 100644 --- a/src/target/jtag_devs.h +++ b/src/target/jtag_devs.h @@ -31,7 +31,7 @@ typedef struct jtag_ir_quirks { typedef struct jtag_dev_descr { uint32_t idcode; uint32_t idmask; -#ifdef ENABLE_DEBUG +#if ENABLE_DEBUG == 1 const char *descr; #endif void (*handler)(uint8_t jd_index); diff --git a/src/target/jtag_scan.c b/src/target/jtag_scan.c index c28b2daec8b..cca7a882bd1 100644 --- a/src/target/jtag_scan.c +++ b/src/target/jtag_scan.c @@ -191,7 +191,7 @@ static bool jtag_read_idcodes(void) static void jtag_display_idcodes(void) { -#if ENABLE_DEBUG +#if ENABLE_DEBUG == 1 for (size_t device = 0; device < jtag_dev_count; ++device) { const char *description = "Unknown"; for (size_t idx = 0; dev_descr[idx].idcode; ++idx) { diff --git a/src/target/lpc_common.c b/src/target/lpc_common.c index 97ff74de472..6c9db5d6127 100644 --- a/src/target/lpc_common.c +++ b/src/target/lpc_common.c @@ -41,7 +41,7 @@ typedef struct __attribute__((aligned(4))) iap_frame { iap_result_s result; } iap_frame_s; -#if defined(ENABLE_DEBUG) +#if ENABLE_DEBUG == 1 static const char *const iap_error[] = { "CMD_SUCCESS", "Invalid command", @@ -261,7 +261,7 @@ iap_status_e lpc_iap_call(lpc_flash_s *const flash, iap_result_s *const result, *result = results; /* This guard block deals with the fact iap_error is only defined when ENABLE_DEBUG is */ -#if defined(ENABLE_DEBUG) +#if ENABLE_DEBUG == 1 if (results.return_code < ARRAY_LENGTH(iap_error)) DEBUG_INFO("%s: result %s, ", __func__, iap_error[results.return_code]); else diff --git a/src/target/rp.c b/src/target/rp.c index 6961197f773..e12ec06063d 100644 --- a/src/target/rp.c +++ b/src/target/rp.c @@ -223,7 +223,7 @@ bool rp_probe(target_s *target) return false; } -#if defined(ENABLE_DEBUG) +#if ENABLE_DEBUG == 1 if ((boot_magic >> BOOTROM_VERSION_SHIFT) == 1) DEBUG_WARN("Old Bootrom Version 1!\n"); #endif diff --git a/src/target/sfdp.c b/src/target/sfdp.c index e73a706e73e..fef6a228184 100644 --- a/src/target/sfdp.c +++ b/src/target/sfdp.c @@ -43,7 +43,7 @@ static inline void sfdp_debug_print(const uint32_t address, const void *const buffer, const uint32_t length) { -#if ENABLE_DEBUG +#if ENABLE_DEBUG == 1 DEBUG_INFO("%" PRIu32 " byte SFDP read at 0x%" PRIx32 ":\n", length, address); const uint8_t *const data = buffer; for (size_t i = 0; i < length; i += 8U) { diff --git a/src/target/stm32h7.c b/src/target/stm32h7.c index cacbb5eee67..aaccf9f6a06 100644 --- a/src/target/stm32h7.c +++ b/src/target/stm32h7.c @@ -465,7 +465,7 @@ static bool stm32h7_crc_bank(target_s *target, uint32_t addr) target_mem_write32(target, reg_base + FLASH_CRCCR, crc_ctrl); target_mem_write32(target, reg_base + FLASH_CRCCR, crc_ctrl | FLASH_CRCCR_START_CRC); uint32_t status = FLASH_SR_CRC_BUSY; -#ifdef ENABLE_DEBUG +#if ENABLE_DEBUG == 1 const uint8_t bank = reg_base == FPEC1_BASE ? 1 : 2; #endif while (status & FLASH_SR_CRC_BUSY) { From 8f1405ba489f31c65077a771896533a8f015c774 Mon Sep 17 00:00:00 2001 From: elagil Date: Wed, 29 Nov 2023 10:35:39 +0100 Subject: [PATCH 5/6] misc: remove parantheses for operator precedence always set ADVERTISE_NOACKMODE (0 or 1) --- src/Makefile | 4 +++- src/gdb_main.c | 2 +- src/platforms/common/usb_serial.c | 12 ++++++------ src/remote.c | 2 +- src/target/adiv5.c | 4 ++-- src/target/imxrt.c | 4 ++-- 6 files changed, 15 insertions(+), 13 deletions(-) diff --git a/src/Makefile b/src/Makefile index fa17762946d..f344981aebe 100644 --- a/src/Makefile +++ b/src/Makefile @@ -22,7 +22,7 @@ CFLAGS += -Wmaybe-uninitialized -Wstringop-overflow -Wunsafe-loop-optimizations endif ifeq ($(PROBE_HOST),hosted) -ENABLE_DEBUG = 1 +ENABLE_DEBUG := 1 endif ifeq ($(ENABLE_DEBUG), 1) @@ -150,6 +150,8 @@ endif ifeq ($(ADVERTISE_NOACKMODE), 1) CFLAGS += -DADVERTISE_NOACKMODE=1 +else +CFLAGS += -DADVERTISE_NOACKMODE=0 endif OBJ = $(patsubst %.S,%.o,$(patsubst %.c,%.o,$(SRC))) diff --git a/src/gdb_main.c b/src/gdb_main.c index 7ba149fba37..62fb78784c3 100644 --- a/src/gdb_main.c +++ b/src/gdb_main.c @@ -41,7 +41,7 @@ #include "rtt.h" #endif -#if defined(ADVERTISE_NOACKMODE) && ADVERTISE_NOACKMODE == 1 +#if ADVERTISE_NOACKMODE == 1 /* * This lets GDB know that the probe supports ‘QStartNoAckMode’ * and prefers to operate in no-acknowledgment mode diff --git a/src/platforms/common/usb_serial.c b/src/platforms/common/usb_serial.c index cc09dcde37e..279f1146955 100644 --- a/src/platforms/common/usb_serial.c +++ b/src/platforms/common/usb_serial.c @@ -77,7 +77,7 @@ static void debug_serial_receive_callback(usbd_device *dev, uint8_t ep); static bool debug_serial_send_complete = true; #endif -#if (ENABLE_DEBUG == 1) && defined(PLATFORM_HAS_DEBUG) +#if ENABLE_DEBUG == 1 && defined(PLATFORM_HAS_DEBUG) /* * This call initialises "SemiHosting", only we then do our own SVC interrupt things to * route all output through to the debug USB serial interface if debug_bmp is true. @@ -214,7 +214,7 @@ void usb_serial_set_config(usbd_device *dev, uint16_t value) usb_serial_set_state(dev, GDB_IF_NO, CDCACM_GDB_ENDPOINT + 1U); usb_serial_set_state(dev, UART_IF_NO, CDCACM_UART_ENDPOINT + 1U); -#if (ENABLE_DEBUG == 1) && defined(PLATFORM_HAS_DEBUG) +#if ENABLE_DEBUG == 1 && defined(PLATFORM_HAS_DEBUG) initialise_monitor_handles(); #endif } @@ -249,7 +249,7 @@ uint32_t debug_serial_fifo_send(const char *const fifo, const uint32_t fifo_begi return fifo_begin; } -#if (ENABLE_DEBUG == 1) && defined(PLATFORM_HAS_DEBUG) +#if ENABLE_DEBUG == 1 && defined(PLATFORM_HAS_DEBUG) static bool debug_serial_fifo_buffer_empty(void) { return debug_serial_debug_write_index == debug_serial_debug_read_index; @@ -270,17 +270,17 @@ static void debug_serial_send_data(void) * If fifo empty, nothing further to do. */ if (usb_get_config() != 1 || (aux_serial_receive_buffer_empty() -#if (ENABLE_DEBUG == 1) && defined(PLATFORM_HAS_DEBUG) +#if ENABLE_DEBUG == 1 && defined(PLATFORM_HAS_DEBUG) && debug_serial_fifo_buffer_empty() #endif )) { -#if (ENABLE_DEBUG == 1) && defined(PLATFORM_HAS_DEBUG) +#if ENABLE_DEBUG == 1 && defined(PLATFORM_HAS_DEBUG) debug_serial_debug_read_index = debug_serial_debug_write_index; #endif aux_serial_drain_receive_buffer(); debug_serial_send_complete = true; } else { -#if (ENABLE_DEBUG == 1) && defined(PLATFORM_HAS_DEBUG) +#if ENABLE_DEBUG == 1 && defined(PLATFORM_HAS_DEBUG) debug_serial_debug_read_index = debug_serial_fifo_send( debug_serial_debug_buffer, debug_serial_debug_read_index, debug_serial_debug_write_index); #endif diff --git a/src/remote.c b/src/remote.c index 28be9b545f7..f78e7735c22 100644 --- a/src/remote.c +++ b/src/remote.c @@ -317,7 +317,7 @@ static void remote_packet_process_general(char *packet, const size_t packet_len) #endif break; case REMOTE_START: -#if (ENABLE_DEBUG == 1) && defined(PLATFORM_HAS_DEBUG) +#if ENABLE_DEBUG == 1 && defined(PLATFORM_HAS_DEBUG) debug_bmp = true; #endif remote_respond_string(REMOTE_RESP_OK, PLATFORM_IDENT "" FIRMWARE_VERSION); diff --git a/src/target/adiv5.c b/src/target/adiv5.c index 5ddf008c81f..bd57e0272df 100644 --- a/src/target/adiv5.c +++ b/src/target/adiv5.c @@ -476,7 +476,7 @@ static uint32_t cortexm_initial_halt(adiv5_access_port_s *ap) */ static bool cortexm_prepare(adiv5_access_port_s *ap) { -#if (defined(PC_HOSTED) && PC_HOSTED == 1) || (ENABLE_DEBUG == 1) +#if (defined(PC_HOSTED) && PC_HOSTED == 1) || ENABLE_DEBUG == 1 uint32_t start_time = platform_time_ms(); #endif uint32_t dhcsr = cortexm_initial_halt(ap); @@ -608,7 +608,7 @@ static void adiv5_component_probe( } } -#if (ENABLE_DEBUG == 1) && defined(PLATFORM_HAS_DEBUG) +#if ENABLE_DEBUG == 1 && defined(PLATFORM_HAS_DEBUG) /* Check SYSMEM bit */ const uint32_t memtype = adiv5_mem_read32(ap, addr | ADIV5_ROM_MEMTYPE) & ADIV5_ROM_MEMTYPE_SYSMEM; diff --git a/src/target/imxrt.c b/src/target/imxrt.c index 2ca6d4956d4..75601735482 100644 --- a/src/target/imxrt.c +++ b/src/target/imxrt.c @@ -218,7 +218,7 @@ bool imxrt_probe(target_s *const target) snprintf(priv->name, IMXRT_NAME_MAX_LENGTH, "i.MXRT%u", priv->chip_id); target->driver = priv->name; -#if (ENABLE_DEBUG == 1) && (PC_HOSTED == 1 || defined(ESP_LOGD)) +#if ENABLE_DEBUG == 1 && (PC_HOSTED == 1 || defined(ESP_LOGD)) const uint8_t boot_mode = (target_mem_read32(target, IMXRT_SRC_BOOT_MODE2) >> 24U) & 3U; #endif DEBUG_TARGET("i.MXRT boot mode is %x\n", boot_mode); @@ -521,7 +521,7 @@ static void imxrt_spi_wait_complete(target_s *const target) target_mem_write32(target, IMXRT_FLEXSPI1_INT(priv), IMXRT_FLEXSPI1_INT_PRG_CMD_DONE); /* Check if any errors occured */ if (target_mem_read32(target, IMXRT_FLEXSPI1_INT(priv)) & IMXRT_FLEXSPI1_INT_CMD_ERR) { -#if (ENABLE_DEBUG == 1) && PC_HOSTED == 1 +#if ENABLE_DEBUG == 1 && PC_HOSTED == 1 /* Read out the status code and display it */ const uint32_t status = target_mem_read32(target, IMXRT_FLEXSPI1_STAT1(priv)); DEBUG_TARGET("Error executing sequence, offset %u, error code %u\n", (uint8_t)(status >> 16U) & 0xfU, From 054499a3d5288a4558b6bf312c8ed6671e830d27 Mon Sep 17 00:00:00 2001 From: elagil Date: Wed, 29 Nov 2023 10:35:39 +0100 Subject: [PATCH 6/6] misc: remove unneeded check for defined(PC_HOSTED) --- src/target/adiv5.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/target/adiv5.c b/src/target/adiv5.c index bd57e0272df..1cea5aff631 100644 --- a/src/target/adiv5.c +++ b/src/target/adiv5.c @@ -476,7 +476,7 @@ static uint32_t cortexm_initial_halt(adiv5_access_port_s *ap) */ static bool cortexm_prepare(adiv5_access_port_s *ap) { -#if (defined(PC_HOSTED) && PC_HOSTED == 1) || ENABLE_DEBUG == 1 +#if PC_HOSTED == 1 || ENABLE_DEBUG == 1 uint32_t start_time = platform_time_ms(); #endif uint32_t dhcsr = cortexm_initial_halt(ap);