| 
									
										
										
										
											2025-06-04 11:21:27 +10:00
										 |  |  | include_guard()
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | set(ST_FAMILY n6)
 | 
					
						
							|  |  |  | 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(CMSIS_5 ${TOP}/lib/CMSIS_5)
 | 
					
						
							| 
									
										
										
										
											2025-06-12 15:08:46 +07:00
										 |  |  | set(ST_TCPP0203 ${TOP}/hw/mcu/st/stm32-tcpp0203)
 | 
					
						
							| 
									
										
										
										
											2025-06-04 11:21:27 +10:00
										 |  |  | 
 | 
					
						
							|  |  |  | # include board specific
 | 
					
						
							|  |  |  | include(${CMAKE_CURRENT_LIST_DIR}/boards/${BOARD}/board.cmake)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | # toolchain set up
 | 
					
						
							|  |  |  | set(CMAKE_SYSTEM_CPU cortex-m55 CACHE INTERNAL "System Processor")
 | 
					
						
							|  |  |  | set(CMAKE_TOOLCHAIN_FILE ${TOP}/examples/build_system/cmake/toolchain/arm_${TOOLCHAIN}.cmake)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | set(FAMILY_MCUS STM32N6 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 ()
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-06-12 14:07:51 +07:00
										 |  |  | # N6 are all high speed
 | 
					
						
							| 
									
										
										
										
											2025-06-04 11:21:27 +10:00
										 |  |  | if (NOT DEFINED RHPORT_DEVICE_SPEED)
 | 
					
						
							| 
									
										
										
										
											2025-06-12 14:07:51 +07:00
										 |  |  |   set(RHPORT_DEVICE_SPEED OPT_MODE_HIGH_SPEED)
 | 
					
						
							| 
									
										
										
										
											2025-06-04 11:21:27 +10:00
										 |  |  | endif ()
 | 
					
						
							|  |  |  | if (NOT DEFINED RHPORT_HOST_SPEED)
 | 
					
						
							| 
									
										
										
										
											2025-06-12 14:07:51 +07:00
										 |  |  |   set(RHPORT_HOST_SPEED OPT_MODE_HIGH_SPEED)
 | 
					
						
							| 
									
										
										
										
											2025-06-04 11:21:27 +10:00
										 |  |  | 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 ${ST_CMSIS}/Source/Templates/gcc/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 | 
					
						
							| 
									
										
										
										
											2025-06-12 14:07:51 +07:00
										 |  |  |     ${ST_CMSIS}/Source/Templates/system_${ST_PREFIX}_fsbl.c
 | 
					
						
							| 
									
										
										
										
											2025-06-04 11:21:27 +10:00
										 |  |  |     ${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}
 | 
					
						
							| 
									
										
										
										
											2025-06-12 14:07:51 +07:00
										 |  |  |     SEGGER_RTT_SECTION="noncacheable_buffer"
 | 
					
						
							|  |  |  |     BUFFER_SIZE_UP=0x3000
 | 
					
						
							| 
									
										
										
										
											2025-06-04 11:21:27 +10:00
										 |  |  |     )
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   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_STM32N6 ${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()
 |