From 11974299eb8c7ca70a00612e928e87d69782d268 Mon Sep 17 00:00:00 2001 From: Jordan Yates Date: Sat, 6 Sep 2025 20:49:20 +1000 Subject: [PATCH 1/5] kconfig: defaults.core: remove `DEBUG_INFO` Remove `DEBUG_INFO` in line with upstream changes, it only ever applied to `x86`. Signed-off-by: Jordan Yates --- kconfig/Kconfig.defaults.core | 2 -- 1 file changed, 2 deletions(-) diff --git a/kconfig/Kconfig.defaults.core b/kconfig/Kconfig.defaults.core index 54f054407..455bc308c 100644 --- a/kconfig/Kconfig.defaults.core +++ b/kconfig/Kconfig.defaults.core @@ -224,8 +224,6 @@ configdefault UART_USE_RUNTIME_CONFIGURE default n # Debug options -configdefault DEBUG_INFO - default y configdefault DEBUG_THREAD_INFO default y configdefault OUTPUT_DISASSEMBLY From 3f72b5745726d63d05acd59f1be488c44035fdce Mon Sep 17 00:00:00 2001 From: Jordan Yates Date: Sat, 6 Sep 2025 20:28:52 +1000 Subject: [PATCH 2/5] scripts: vscode: support TF-M in QEMU Add TF-M files to QEMU `launch.json`. Signed-off-by: Jordan Yates --- scripts/west_commands/vscode.py | 27 ++++++++++++++++----------- 1 file changed, 16 insertions(+), 11 deletions(-) diff --git a/scripts/west_commands/vscode.py b/scripts/west_commands/vscode.py index 3a470861a..913b0c17c 100644 --- a/scripts/west_commands/vscode.py +++ b/scripts/west_commands/vscode.py @@ -255,6 +255,19 @@ def _tfm_build(self, build_dir, cache): launch["configurations"][0]["gdbPath"] = parent_cache.get("CMAKE_GDB") launch["configurations"][1]["gdbPath"] = parent_cache.get("CMAKE_GDB") + def _tfm_sub_image(self, build_dir): + tfm_elfs = [ + "bl2.elf", + "tfm_s.elf", + ] + tfm_paths = [build_dir / "tfm" / "bin" / elf for elf in tfm_elfs] + tfm_exists = [p for p in tfm_paths if p.exists()] + + # Add TF-M .elf files + launch["configurations"][0]["preAttachCommands"] = [ + f"add-symbol-file {str(path)}" for path in tfm_exists + ] + def _zephyr_build(self, build_dir, cache): self.cpp_properties(build_dir, cache) @@ -272,17 +285,7 @@ def _zephyr_build(self, build_dir, cache): ) if cache.get("BOARD")[-3:] == "/ns": - tfm_elfs = [ - "bl2.elf", - "tfm_s.elf", - ] - tfm_paths = [build_dir / "tfm" / "bin" / elf for elf in tfm_elfs] - tfm_exists = [p for p in tfm_paths if p.exists()] - - # Add TF-M .elf files - launch["configurations"][0]["preAttachCommands"] = [ - f"add-symbol-file {str(path)}" for path in tfm_exists - ] + self._tfm_sub_image(build_dir) if cache.get("SYSBUILD", False): # Check if a `mcuboot` folder exists at the same level mcuboot_elf = build_dir / ".." / "mcuboot" / "zephyr" / "zephyr.elf" @@ -297,6 +300,8 @@ def _qemu(self, build_dir, cache): self.cpp_properties(build_dir, cache) + if cache.get("BOARD")[-3:] == "/ns": + self._tfm_sub_image(build_dir) launch["configurations"][0]["name"] = "QEMU Attach" launch["configurations"][0]["servertype"] = "external" launch["configurations"][0]["gdbTarget"] = "localhost:1234" From 93b0ac28e8f1a9d4b0e1be760f357b50fdf749da Mon Sep 17 00:00:00 2001 From: Jordan Yates Date: Sun, 7 Sep 2025 16:23:55 +1000 Subject: [PATCH 3/5] ci: codecov: cleanup previous merge Remove any `merged.json` files from previous runs before running the merge step again. Signed-off-by: Jordan Yates --- .github/workflows/codecov.yml | 1 + 1 file changed, 1 insertion(+) diff --git a/.github/workflows/codecov.yml b/.github/workflows/codecov.yml index 6a964202c..9038126e4 100644 --- a/.github/workflows/codecov.yml +++ b/.github/workflows/codecov.yml @@ -283,6 +283,7 @@ jobs: - name: Move coverage files run: | mv ./coverage/reports/*/*.json ./coverage/reports + rm -f ./coverage/reports/merged.json ls -la ./coverage/reports - name: Generate list of coverage files From e990765af96ad68f3daf6fa1a68b4b033ccd49eb Mon Sep 17 00:00:00 2001 From: Jordan Yates Date: Sat, 6 Sep 2025 21:57:45 +1000 Subject: [PATCH 4/5] mgmr: mcumgr: fix `zephyr_library` `zephyr_library` takes no arguments. Signed-off-by: Jordan Yates --- subsys/mgmt/mcumgr/os_mgmt_infuse/CMakeLists.txt | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/subsys/mgmt/mcumgr/os_mgmt_infuse/CMakeLists.txt b/subsys/mgmt/mcumgr/os_mgmt_infuse/CMakeLists.txt index 87be541a1..d943365b1 100644 --- a/subsys/mgmt/mcumgr/os_mgmt_infuse/CMakeLists.txt +++ b/subsys/mgmt/mcumgr/os_mgmt_infuse/CMakeLists.txt @@ -1,6 +1,6 @@ # SPDX-License-Identifier: Apache-2.0 -zephyr_library(mgmt_mcumgr_grp_os) +zephyr_library() zephyr_library_sources(os_mgmt_infuse.c) if (CONFIG_BOOTLOADER_MCUBOOT) From 40ab78fb69ebda6f4f926019307aa15639b3bccb Mon Sep 17 00:00:00 2001 From: Jordan Yates Date: Sun, 7 Sep 2025 12:02:39 +1000 Subject: [PATCH 5/5] gnss: ubx: decouple headers from Zephyr Decouple our UBX headers from the Zephyr headers, to prevent breakage when the upstream implementation changes. Signed-off-by: Jordan Yates --- drivers/gnss/gnss_ubx_modem.c | 1 - include/infuse/gnss/ubx/modem.h | 3 ++- include/infuse/gnss/ubx/protocol.h | 20 ++++++++++++++++++-- 3 files changed, 20 insertions(+), 4 deletions(-) diff --git a/drivers/gnss/gnss_ubx_modem.c b/drivers/gnss/gnss_ubx_modem.c index 325403584..cd267b35c 100644 --- a/drivers/gnss/gnss_ubx_modem.c +++ b/drivers/gnss/gnss_ubx_modem.c @@ -6,7 +6,6 @@ * SPDX-License-Identifier: FSL-1.1-ALv2 */ -#include #include #include diff --git a/include/infuse/gnss/ubx/modem.h b/include/infuse/gnss/ubx/modem.h index f936e7df5..bb14fc4bb 100644 --- a/include/infuse/gnss/ubx/modem.h +++ b/include/infuse/gnss/ubx/modem.h @@ -14,9 +14,10 @@ #include #include #include -#include #include +#include + #ifdef __cplusplus extern "C" { #endif diff --git a/include/infuse/gnss/ubx/protocol.h b/include/infuse/gnss/ubx/protocol.h index 4bea6e97b..c9135c9ff 100644 --- a/include/infuse/gnss/ubx/protocol.h +++ b/include/infuse/gnss/ubx/protocol.h @@ -11,7 +11,6 @@ #ifndef INFUSE_GNSS_UBX_PROTOCOL_H_ #define INFUSE_GNSS_UBX_PROTOCOL_H_ -#include #include #include @@ -24,6 +23,22 @@ extern "C" { * @{ */ +#define UBX_PREAMBLE_SYNC_CHAR_1 0xB5 +#define UBX_PREAMBLE_SYNC_CHAR_2 0x62 + +/** + * @brief UBX Message Frame + */ +struct ubx_frame { + uint8_t preamble_sync_char_1; + uint8_t preamble_sync_char_2; + uint8_t message_class; + uint8_t message_id; + uint8_t payload_size_low; + uint8_t payload_size_high; + uint8_t payload_and_checksum[]; +}; + /** * @brief UBX Message Classes */ @@ -830,6 +845,7 @@ static inline void ubx_msg_prepare(struct net_buf_simple *buf, uint8_t msg_class */ static inline void ubx_msg_finalise(struct net_buf_simple *buf) { + const unsigned int crc_start_idx = offsetof(struct ubx_frame, message_class); struct ubx_frame *frame; uint16_t payload_size; uint8_t ckA = 0; @@ -843,7 +859,7 @@ static inline void ubx_msg_finalise(struct net_buf_simple *buf) frame->payload_size_low = payload_size; frame->payload_size_high = payload_size >> 8; /* Calculate frame CRC */ - for (unsigned int i = UBX_FRM_CHECKSUM_START_IDX; i < buf->len; i++) { + for (unsigned int i = crc_start_idx; i < buf->len; i++) { ckA += buf->data[i]; ckB += ckA; }