Add STM32 BSP peripheral drivers#414
Draft
nhuvaoanh123 wants to merge 3 commits into
Draft
Conversation
nhuvaoanh123
added a commit
to nhuvaoanh123/openbsw
that referenced
this pull request
Mar 30, 2026
Add CAN peripheral drivers for both STM32 CAN controller variants: - BxCanDevice: Basic Extended CAN controller (STM32F4 family) - FdCanDevice: Flexible Data-rate CAN controller (STM32G4 family) - BxCanTransceiver: OpenBSW CAN transceiver adapter for bxCAN - Unit test infrastructure (unitTest CMakeLists, mock device headers) The bspCan module uses compile-time chip selection (CAN_TYPE=BXCAN|FDCAN) to build only the relevant driver. Tests use mock register headers for host-based verification. Milestone: `cmake --preset tests-stm32-debug` configures. Tests run in CI Docker. Depends on eclipse-openbsw#414 (PR 2: BSP drivers). PR 3 of 10.
This was referenced Mar 30, 2026
d14b254 to
106da31
Compare
nhuvaoanh123
pushed a commit
to nhuvaoanh123/openbsw
that referenced
this pull request
Mar 30, 2026
Add CAN peripheral drivers for both STM32 CAN controller variants: - BxCanDevice: Basic Extended CAN controller (STM32F4 family) - FdCanDevice: Flexible Data-rate CAN controller (STM32G4 family) - BxCanTransceiver: OpenBSW CAN transceiver adapter for bxCAN - Unit test infrastructure (unitTest CMakeLists, mock device headers) The bspCan module uses compile-time chip selection (CAN_TYPE=BXCAN|FDCAN) to build only the relevant driver. Tests use mock register headers for host-based verification. Milestone: `cmake --preset tests-stm32-debug` configures. Tests run in CI Docker. Depends on eclipse-openbsw#414 (PR 2: BSP drivers). PR 3 of 10.
106da31 to
1d26fe8
Compare
nhuvaoanh123
added a commit
to nhuvaoanh123/openbsw
that referenced
this pull request
Mar 30, 2026
Add CAN peripheral drivers for both STM32 CAN controller variants: - BxCanDevice: Basic Extended CAN controller (STM32F4 family) - FdCanDevice: Flexible Data-rate CAN controller (STM32G4 family) - BxCanTransceiver: OpenBSW CAN transceiver adapter for bxCAN - Unit test infrastructure (unitTest CMakeLists, mock device headers) The bspCan module uses compile-time chip selection (CAN_TYPE=BXCAN|FDCAN) to build only the relevant driver. Tests use mock register headers for host-based verification. Milestone: `cmake --preset tests-stm32-debug` configures. Tests run in CI Docker. Depends on eclipse-openbsw#414 (PR 2: BSP drivers). PR 3 of 10.
1d26fe8 to
5bf1102
Compare
nhuvaoanh123
added a commit
to nhuvaoanh123/openbsw
that referenced
this pull request
Mar 31, 2026
Add CAN peripheral drivers for both STM32 CAN controller variants: - BxCanDevice: Basic Extended CAN controller (STM32F4 family) - FdCanDevice: Flexible Data-rate CAN controller (STM32G4 family) - BxCanTransceiver: OpenBSW CAN transceiver adapter for bxCAN - Unit test infrastructure (unitTest CMakeLists, mock device headers) The bspCan module uses compile-time chip selection (CAN_TYPE=BXCAN|FDCAN) to build only the relevant driver. Tests use mock register headers for host-based verification. Milestone: `cmake --preset tests-stm32-debug` configures. Tests run in CI Docker. Depends on eclipse-openbsw#414 (PR 2: BSP drivers). PR 3 of 10.
5bf1102 to
7e28e69
Compare
nhuvaoanh123
added a commit
to nhuvaoanh123/openbsw
that referenced
this pull request
Mar 31, 2026
Add CAN peripheral drivers for both STM32 CAN controller variants: - BxCanDevice: Basic Extended CAN controller (STM32F4 family) - FdCanDevice: Flexible Data-rate CAN controller (STM32G4 family) - BxCanTransceiver: OpenBSW CAN transceiver adapter for bxCAN - Unit test infrastructure (unitTest CMakeLists, mock device headers) The bspCan module uses compile-time chip selection (CAN_TYPE=BXCAN|FDCAN) to build only the relevant driver. Tests use mock register headers for host-based verification. Milestone: `cmake --preset tests-stm32-debug` configures. Tests run in CI Docker. Depends on eclipse-openbsw#414 (PR 2: BSP drivers). PR 3 of 10.
0413810 to
5fd8c07
Compare
Import the STM32F4 and STM32G4 CMSIS device headers from STMicroelectronics' dedicated RIM-tracked repositories. Keep only the F413 and G474 headers needed by the STM32 MCU foundation and record the unused upstream headers as RIM ignores.
Add the STM32 platform entry point, chip CMake files, bspMcu startup code, a software reset wrapper, and the STM32 unit-test presets. The platform reuses the shared CMSIS core from libs/3rdparty/cmsis instead of carrying a local copy.
Add STM32 BSP modules for clock, UART, GPIO, timer, ADC, and EEPROM, plus interrupt handling primitives and the ETL platform glue.
Contributor
|
Now that #413 is merged, you can continue with this one, resolving the current merge conflicts. Thanks for your contribution and sorry for the delay! |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Add this suggestion to a batch that can be applied as a single commit.This suggestion is invalid because no changes were made to the code.Suggestions cannot be applied while the pull request is closed.Suggestions cannot be applied while viewing a subset of changes.Only one suggestion per line can be applied in a batch.Add this suggestion to a batch that can be applied as a single commit.Applying suggestions on deleted lines is not supported.You must change the existing code in this line in order to create a valid suggestion.Outdated suggestions cannot be applied.This suggestion has been applied or marked resolved.Suggestions cannot be applied from pending reviews.Suggestions cannot be applied on multi-line comments.Suggestions cannot be applied while the pull request is queued to merge.Suggestion cannot be applied right now. Please check back later.
Purpose of this PR
Description
Second PR in the STM32 platform series. Adds the complete low-level BSP layer enabling UART console output, GPIO control, clock initialization, and peripheral support.
Modules added
bspClockbspUartbspIobspTimerbspInterruptsImplbspAdcbspEepromDriveretlImplbspConfigurationMilestone
CMake configures with all BSP modules included. First UART console output achieved when combined with PR 6 (FreeRTOS board config).
Depends on #413 (PR 1: MCU foundation). PR 2 of 10.
Related Issues
Part of the STM32 platform port series — see #413 for overview.
Breaking Changes
Test Plan
CC=arm-none-eabi-gcc CXX=arm-none-eabi-g++ cmake --preset nucleo-g474re-freertos-gccRegression Tests
Have tests been added/updated? [x] Yes — test source files included, runnable with PR 3+ [ ] No