CMakeLists.txt 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778
  1. cmake_minimum_required(VERSION 3.13)
  2. set(CMAKE_TOOLCHAIN_FILE ${CMAKE_CURRENT_SOURCE_DIR}/../../cmake/stm32_gcc.cmake)
  3. if(NOT TEST_FAMILIES)
  4. set(TEST_FAMILIES F0 F1 F2 F3 F4 F7 G0 G4 H7 L0 L1 L4 L5 WB WL)
  5. endif()
  6. # Nucleo boards can have different devices on it
  7. set(DEVICE_STM32F0xx_Nucleo_32 F031K6)
  8. set(DEVICE_STM32F0xx_Nucleo F030R8)
  9. set(DEVICE_STM32F1xx_Nucleo F103RB)
  10. set(DEVICE_STM32F2xx_Nucleo_144 F207ZG)
  11. set(DEVICE_STM32F3xx_Nucleo_32 F303K8)
  12. set(DEVICE_STM32F3xx_Nucleo F334R8)
  13. set(DEVICE_STM32F3xx_Nucleo_144 F303ZE)
  14. set(DEVICE_STM32F4xx_Nucleo_144 F429ZI)
  15. set(DEVICE_STM32F4xx_Nucleo F446RE)
  16. set(DEVICE_STM32F7xx_Nucleo_144 F746ZG)
  17. set(DEVICE_STM32G0xx_Nucleo G070RB)
  18. set(DEVICE_STM32G0xx_Nucleo_32 G031K8)
  19. set(DEVICE_STM32G4xx_Nucleo G474RE)
  20. set(DEVICE_STM32L0xx_Nucleo L053R8)
  21. set(DEVICE_STM32L0xx_Nucleo_32 L011K4)
  22. set(DEVICE_STM32L1xx_Nucleo L152RE)
  23. set(DEVICE_STM32L4xx_Nucleo L412RB)
  24. set(DEVICE_STM32L4xx_Nucleo_32 L412KB)
  25. set(DEVICE_STM32L4xx_Nucleo_144 L496ZG)
  26. set(DEFINES_STM32469I_EVAL USE_IOEXPANDER)
  27. set(DEFINES_STM32F769I_EVAL USE_IOEXPANDER)
  28. set(DEFINES_STM32L476G_EVAL USE_IOEXPANDER)
  29. set(DEFINES_STM32L4R9I_EVAL USE_ROCKTECH_480x272)
  30. # Ban some boards because their BSP need non-free components
  31. set(BANNED_BOARDS STM32756G_EVAL)
  32. project(bsp-test C ASM)
  33. set(CMAKE_INCLUDE_CURRENT_DIR TRUE)
  34. if(FETCH_ST_SOURCES)
  35. stm32_fetch_cube(${TEST_FAMILIES})
  36. endif()
  37. find_package(CMSIS REQUIRED)
  38. find_package(HAL REQUIRED)
  39. find_package(BSP REQUIRED)
  40. set(SOURCES main.c)
  41. foreach(FAMILY ${TEST_FAMILIES})
  42. foreach(BOARD ${BSP_${FAMILY}_BOARDS})
  43. string(REPLACE "-" "_" BOARD ${BOARD})
  44. if(BOARD IN_LIST BANNED_BOARDS)
  45. continue()
  46. endif()
  47. add_executable(bsp-test-${BOARD} ${SOURCES})
  48. target_link_libraries(bsp-test-${BOARD}
  49. BSP::STM32::${BOARD}
  50. HAL::STM32::${FAMILY}
  51. STM32::NoSys
  52. )
  53. if(DEVICE_${BOARD})
  54. target_link_libraries(bsp-test-${BOARD} CMSIS::STM32::${DEVICE_${BOARD}})
  55. endif()
  56. if(DEFINES_${BOARD})
  57. target_compile_definitions(bsp-test-${BOARD} PRIVATE ${DEFINES_${BOARD}})
  58. endif()
  59. foreach(COMP ${BSP_${FAMILY}_COMPONENTS})
  60. string(TOUPPER ${COMP} COMP)
  61. # Workaround - F3 has both CS43L22 and CS43L52 that conflicts
  62. if((FAMILY STREQUAL F3) AND (COMP STREQUAL CS43L22))
  63. continue()
  64. endif()
  65. target_link_libraries(bsp-test-${BOARD} BSP::STM32::${FAMILY}::${COMP})
  66. endforeach()
  67. endforeach()
  68. endforeach()