Problem with BSP_ALIAS

Sysprogs forums Forums VisualGDB Problem with BSP_ALIAS

Viewing 6 posts - 1 through 6 (of 6 total)
  • Author
    Posts
  • #34049
    drjonem
    Participant

    Hi,

    I’m trying to have different builds of the same BSP in the same CMake project, one for application, one for boot. It looks like the ALIAS function should do the job, but I am having the following issues:

    If I do as per documentation (simplified example):

    find_bsp(ID com.sysprogs.arm.stm32
    VERSION 2020.10
    MCU STM32F746NG
    ALIAS BOOT_BSP)

    find_bsp(ID com.sysprogs.arm.stm32
    VERSION 2020.10
    MCU STM32F746NG
    ALIAS APP_BSP)

    bsp_compile_definitions(BSP_ALIAS BOOT_BSP
    BOOT=1)
    add_bsp_based_executable(NAME boot_app
    BSP_ALIAS BOOT_BSP
    SOURCES test.cpp)

    bsp_compile_definitions(BSP_ALIAS APP_BSP
    BOOT=0)

    add_bsp_based_executable(NAME main_spp
    BSP_ALIAS APP_BSP
    SOURCES test2.cpp)

    cmake error with “Cannot specify compile definitions for target “BSP” which is not built by this project.” Implying that the BSP_ALIAS are not being processed.

    If I modify to

    find_bsp(ID com.sysprogs.arm.stm32
    VERSION 2020.10
    MCU STM32F746NG
    ALIAS BOOT_BSP)

    find_bsp(ID com.sysprogs.arm.stm32
    VERSION 2020.10
    MCU STM32F746NG
    ALIAS APP_BSP)

    bsp_compile_definitions(ALIAS BOOT_BSP
    BOOT=1)
    add_bsp_based_executable(NAME boot_app
    BSP_ALIAS BOOT_BSP
    SOURCES test.cpp)

    bsp_compile_definitions(ALIAS APP_BSP
    BOOT=0)

    add_bsp_based_executable(NAME main_app
    BSP_ALIAS APP_BSP
    SOURCES test2.cpp)

    i.e. changing the BSP_ALIAS to just ALIAS in the bsp_compile_definitions, cmake is happy (same is true for bsp_include_directories) which tends to suggest an error in the docco.

    However, if I build the project, I will get errors about Boot being redefined. Looking at the compiler definitions in the BSP properties, you can see that both bsp_compile_defintions have been applied to both BSP including the ALIAS, i.e. Additional Preprocessor Macros shows ALIAS;BOOT_BSP;BOOT=1;ALIAS;APP_BSP;BOOT=0

    So the system is clearly not working as it should. Any advice or resolutions? I can run as two separate solutions if necessary but this looked like a nice way of grouping common options and sources.

    I’m running v5.6R8 of VisualGDB (haven’t upgraded to R9 as there doesn’t seem to be a changelog for it) and CMake 3.20.3.2

    Also workth noting I have used your examples above for clarity but I’m actually using an improted MCUXpressor SDK:

    find_bsp(
    ID com.sysprogs.imported.ksdk2x.MIMXRT1176xxxxx_CM4_MIMXRT1176XXXXX
    VERSION 2.12.1
    MCU MIMXRT1176DVMAA_CM7_MIMXRT1176XXXXX
    ALIAS BOOT_BSP

    • This topic was modified 1 year, 1 month ago by drjonem.
    #34052
    support
    Keymaster

    Hi,

    The first code snippet you posted should work just fine. You can retest it by creating a simple STM32 project and copying it there.

    If it’s not working in a more complicated McuXpresso project, the issue is likely caused by some hard-to-see difference (e.g. a space in some identifier that breaks CMake argument order). The easiest way to narrow it down would be to use the CMake debugger to step through a working STM32 setup and a broken McuXpresso setup side-by-side, until the difference becomes obvious.

    #34057
    drjonem
    Participant

    Hi,

    I’m still not having any luck with this. As suggested, I tried creating a very simple STM32 project – see attached CMakeLists.txt.

    There seems to be a problem with cmake_parse_arguments in bsp_compile_definitions. The arguments are passed correctly; however, if the arguments are BSP_ALIAS BOOT_BSP, BSP_ALIAS is not found. If the arguments are ALIAS BOOT_BSP then somehow BSP_ALIAS is found and parse as BOOT_BSP.

    I think I will revert to using two solutions but if you can find a solution to the above, I would be interested to know as it seems very odd behaviour.

    Thanks,

    Jon

    Attachments:
    You must be logged in to view attached files.
    #34062
    support
    Keymaster

    Thanks, we have reproduced the issue with the bsp_compile_definitions() and other similar statements. Indeed, they expected the ALIAS keyword instead of BSP_ALIAS as per documentation.

    We have updated VisualGDB to handle both keywords in this build: VisualGDB-5.6.109.4853.msi

    That said, we could not reproduce the issue with the flags applied to both BSPs. If it still persists with the new build, please try reproducing it on a sample STM32-based project and share the updated repro file.

    #34063
    drjonem
    Participant

    Hi,

    Thank you for the prompt fix!

    Apologies for not updating re the flags – they were set in the BSP depending on memory destiation used and I hadn’t realised that, so that was my problem.

    Thanks again,

    Jon.

    #34064
    support
    Keymaster

    No worries. Complex problems almost always have multiple causes, and simplifying the repro scenario always helps separate them.

    If you encounter further issues, feel free to create another thread and we will be happy to help you.

Viewing 6 posts - 1 through 6 (of 6 total)
  • You must be logged in to reply to this topic.