151 lines
		
	
	
		
			4.7 KiB
		
	
	
	
		
			CMake
		
	
	
	
	
	
			
		
		
	
	
			151 lines
		
	
	
		
			4.7 KiB
		
	
	
	
		
			CMake
		
	
	
	
	
	
include_guard()
 | 
						|
 | 
						|
set(ST_FAMILY h7rs)
 | 
						|
set(ST_PREFIX stm32${ST_FAMILY}xx)
 | 
						|
 | 
						|
set(ST_HAL_DRIVER ${TOP}/hw/mcu/st/stm32${ST_FAMILY}xx_hal_driver)
 | 
						|
set(ST_CMSIS ${TOP}/hw/mcu/st/cmsis_device_${ST_FAMILY})
 | 
						|
set(ST_TCPP0203 ${TOP}/hw/mcu/st/stm32-tcpp0203)
 | 
						|
set(CMSIS_5 ${TOP}/lib/CMSIS_5)
 | 
						|
 | 
						|
# include board specific
 | 
						|
include(${CMAKE_CURRENT_LIST_DIR}/boards/${BOARD}/board.cmake)
 | 
						|
 | 
						|
# toolchain set up
 | 
						|
set(CMAKE_SYSTEM_CPU cortex-m7 CACHE INTERNAL "System Processor")
 | 
						|
set(CMAKE_TOOLCHAIN_FILE ${TOP}/examples/build_system/cmake/toolchain/arm_${TOOLCHAIN}.cmake)
 | 
						|
 | 
						|
set(FAMILY_MCUS STM32H7RS CACHE INTERNAL "")
 | 
						|
 | 
						|
# ----------------------
 | 
						|
# Port & Speed Selection
 | 
						|
# ----------------------
 | 
						|
if (NOT DEFINED RHPORT_DEVICE)
 | 
						|
  set(RHPORT_DEVICE 1)
 | 
						|
endif ()
 | 
						|
if (NOT DEFINED RHPORT_HOST)
 | 
						|
  set(RHPORT_HOST 1)
 | 
						|
endif ()
 | 
						|
 | 
						|
if (NOT DEFINED RHPORT_SPEED)
 | 
						|
  set(RHPORT_SPEED OPT_MODE_FULL_SPEED OPT_MODE_HIGH_SPEED)
 | 
						|
endif ()
 | 
						|
if (NOT DEFINED RHPORT_DEVICE_SPEED)
 | 
						|
  list(GET RHPORT_SPEED ${RHPORT_DEVICE} RHPORT_DEVICE_SPEED)
 | 
						|
endif ()
 | 
						|
if (NOT DEFINED RHPORT_HOST_SPEED)
 | 
						|
  list(GET RHPORT_SPEED ${RHPORT_HOST} RHPORT_HOST_SPEED)
 | 
						|
endif ()
 | 
						|
 | 
						|
cmake_print_variables(RHPORT_DEVICE RHPORT_DEVICE_SPEED RHPORT_HOST RHPORT_HOST_SPEED)
 | 
						|
 | 
						|
#------------------------------------
 | 
						|
# BOARD_TARGET
 | 
						|
#------------------------------------
 | 
						|
# only need to be built ONCE for all examples
 | 
						|
function(add_board_target BOARD_TARGET)
 | 
						|
  if (TARGET ${BOARD_TARGET})
 | 
						|
    return()
 | 
						|
  endif()
 | 
						|
 | 
						|
  # Startup & Linker script
 | 
						|
  set(STARTUP_FILE_GNU ${ST_CMSIS}/Source/Templates/gcc/startup_${MCU_VARIANT}.s)
 | 
						|
  set(STARTUP_FILE_Clang ${STARTUP_FILE_GNU})
 | 
						|
  set(STARTUP_FILE_IAR ${ST_CMSIS}/Source/Templates/iar/startup_${MCU_VARIANT}.s)
 | 
						|
 | 
						|
  if(NOT DEFINED LD_FILE_GNU)
 | 
						|
    set(LD_FILE_GNU ${CMAKE_CURRENT_FUNCTION_LIST_DIR}/linker/${MCU_VARIANT}_flash.ld)
 | 
						|
  endif()
 | 
						|
  set(LD_FILE_Clang ${LD_FILE_GNU})
 | 
						|
  if(NOT DEFINED LD_FILE_IAR)
 | 
						|
    set(LD_FILE_IAR ${ST_CMSIS}/Source/Templates/iar/linker/${MCU_VARIANT}_flash.icf)
 | 
						|
  endif()
 | 
						|
 | 
						|
  add_library(${BOARD_TARGET} STATIC
 | 
						|
    ${ST_CMSIS}/Source/Templates/system_${ST_PREFIX}.c
 | 
						|
    ${ST_HAL_DRIVER}/Src/${ST_PREFIX}_hal.c
 | 
						|
    ${ST_HAL_DRIVER}/Src/${ST_PREFIX}_hal_cortex.c
 | 
						|
    ${ST_HAL_DRIVER}/Src/${ST_PREFIX}_hal_dma.c
 | 
						|
    ${ST_HAL_DRIVER}/Src/${ST_PREFIX}_hal_gpio.c
 | 
						|
    ${ST_HAL_DRIVER}/Src/${ST_PREFIX}_hal_pwr.c
 | 
						|
    ${ST_HAL_DRIVER}/Src/${ST_PREFIX}_hal_i2c.c
 | 
						|
    ${ST_HAL_DRIVER}/Src/${ST_PREFIX}_hal_pwr_ex.c
 | 
						|
    ${ST_HAL_DRIVER}/Src/${ST_PREFIX}_hal_rcc.c
 | 
						|
    ${ST_HAL_DRIVER}/Src/${ST_PREFIX}_hal_rcc_ex.c
 | 
						|
    ${ST_HAL_DRIVER}/Src/${ST_PREFIX}_hal_uart.c
 | 
						|
    ${ST_HAL_DRIVER}/Src/${ST_PREFIX}_hal_uart_ex.c
 | 
						|
    ${STARTUP_FILE_${CMAKE_C_COMPILER_ID}}
 | 
						|
    )
 | 
						|
  target_include_directories(${BOARD_TARGET} PUBLIC
 | 
						|
    ${CMAKE_CURRENT_FUNCTION_LIST_DIR}
 | 
						|
    ${CMSIS_5}/CMSIS/Core/Include
 | 
						|
    ${ST_CMSIS}/Include
 | 
						|
    ${ST_HAL_DRIVER}/Inc
 | 
						|
    )
 | 
						|
  target_compile_definitions(${BOARD_TARGET} PUBLIC
 | 
						|
    BOARD_TUD_RHPORT=${RHPORT_DEVICE}
 | 
						|
    BOARD_TUD_MAX_SPEED=${RHPORT_DEVICE_SPEED}
 | 
						|
    BOARD_TUH_RHPORT=${RHPORT_HOST}
 | 
						|
    BOARD_TUH_MAX_SPEED=${RHPORT_HOST_SPEED}
 | 
						|
    SEGGER_RTT_SECTION=\"noncacheable_buffer\"
 | 
						|
    BUFFER_SIZE_UP=0x300
 | 
						|
    )
 | 
						|
 | 
						|
  update_board(${BOARD_TARGET})
 | 
						|
 | 
						|
  if (CMAKE_C_COMPILER_ID STREQUAL "GNU")
 | 
						|
    target_link_options(${BOARD_TARGET} PUBLIC
 | 
						|
      "LINKER:--script=${LD_FILE_GNU}"
 | 
						|
      -nostartfiles
 | 
						|
      --specs=nosys.specs --specs=nano.specs
 | 
						|
      )
 | 
						|
  elseif (CMAKE_C_COMPILER_ID STREQUAL "Clang")
 | 
						|
    target_link_options(${BOARD_TARGET} PUBLIC
 | 
						|
      "LINKER:--script=${LD_FILE_Clang}"
 | 
						|
      )
 | 
						|
  elseif (CMAKE_C_COMPILER_ID STREQUAL "IAR")
 | 
						|
    target_link_options(${BOARD_TARGET} PUBLIC
 | 
						|
      "LINKER:--config=${LD_FILE_IAR}"
 | 
						|
      )
 | 
						|
  endif ()
 | 
						|
endfunction()
 | 
						|
 | 
						|
 | 
						|
#------------------------------------
 | 
						|
# Functions
 | 
						|
#------------------------------------
 | 
						|
function(family_configure_example TARGET RTOS)
 | 
						|
  family_configure_common(${TARGET} ${RTOS})
 | 
						|
 | 
						|
  # Board target
 | 
						|
  add_board_target(board_${BOARD})
 | 
						|
 | 
						|
  #---------- Port Specific ----------
 | 
						|
  # These files are built for each example since it depends on example's tusb_config.h
 | 
						|
  target_sources(${TARGET} PUBLIC
 | 
						|
    # BSP
 | 
						|
    ${CMAKE_CURRENT_FUNCTION_LIST_DIR}/family.c
 | 
						|
    ${CMAKE_CURRENT_FUNCTION_LIST_DIR}/../board.c
 | 
						|
    )
 | 
						|
  target_include_directories(${TARGET} PUBLIC
 | 
						|
    # family, hw, board
 | 
						|
    ${CMAKE_CURRENT_FUNCTION_LIST_DIR}
 | 
						|
    ${CMAKE_CURRENT_FUNCTION_LIST_DIR}/../../
 | 
						|
    ${CMAKE_CURRENT_FUNCTION_LIST_DIR}/boards/${BOARD}
 | 
						|
    )
 | 
						|
 | 
						|
  # Add TinyUSB target and port source
 | 
						|
  family_add_tinyusb(${TARGET} OPT_MCU_STM32H7RS ${RTOS})
 | 
						|
  target_sources(${TARGET} PUBLIC
 | 
						|
    ${TOP}/src/portable/synopsys/dwc2/dcd_dwc2.c
 | 
						|
    ${TOP}/src/portable/synopsys/dwc2/hcd_dwc2.c
 | 
						|
    ${TOP}/src/portable/synopsys/dwc2/dwc2_common.c
 | 
						|
    )
 | 
						|
  target_link_libraries(${TARGET} PUBLIC board_${BOARD})
 | 
						|
 | 
						|
  # Flashing
 | 
						|
  family_add_bin_hex(${TARGET})
 | 
						|
  family_flash_stlink(${TARGET})
 | 
						|
  family_flash_jlink(${TARGET})
 | 
						|
endfunction()
 |