| 
									
										
										
										
											2023-05-23 21:45:00 +07:00
										 |  |  | include_guard()
 | 
					
						
							| 
									
										
										
										
											2023-05-06 15:14:54 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-06-02 15:26:16 +07:00
										 |  |  | set(SDK_DIR ${TOP}/hw/mcu/nxp/mcux-sdk)
 | 
					
						
							|  |  |  | set(CMSIS_DIR ${TOP}/lib/CMSIS_5)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | # include board specific
 | 
					
						
							|  |  |  | include(${CMAKE_CURRENT_LIST_DIR}/boards/${BOARD}/board.cmake)
 | 
					
						
							| 
									
										
										
										
											2023-11-16 15:38:55 +07:00
										 |  |  | set(MCU_VARIANT_WITH_CORE ${MCU_VARIANT}${MCU_CORE})
 | 
					
						
							| 
									
										
										
										
											2023-06-01 12:36:08 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-04-21 18:10:28 +07:00
										 |  |  | # toolchain set up
 | 
					
						
							| 
									
										
										
										
											2025-01-22 22:31:08 +07:00
										 |  |  | if (NOT DEFINED CMAKE_SYSTEM_CPU)
 | 
					
						
							|  |  |  |   set(CMAKE_SYSTEM_CPU cortex-m7 CACHE INTERNAL "System Processor")
 | 
					
						
							| 
									
										
										
										
											2024-11-02 15:13:08 +01:00
										 |  |  | endif ()
 | 
					
						
							| 
									
										
										
										
											2023-11-23 20:06:22 +07:00
										 |  |  | set(CMAKE_TOOLCHAIN_FILE ${TOP}/examples/build_system/cmake/toolchain/arm_${TOOLCHAIN}.cmake)
 | 
					
						
							| 
									
										
										
										
											2023-04-20 16:55:48 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-06-16 11:26:38 +07:00
										 |  |  | set(FAMILY_MCUS MIMXRT1XXX CACHE INTERNAL "")
 | 
					
						
							| 
									
										
										
										
											2023-05-08 00:24:48 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-05-06 15:14:54 +07:00
										 |  |  | #------------------------------------
 | 
					
						
							|  |  |  | # BOARD_TARGET
 | 
					
						
							|  |  |  | #------------------------------------
 | 
					
						
							|  |  |  | # only need to be built ONCE for all examples
 | 
					
						
							| 
									
										
										
										
											2023-06-02 15:26:16 +07:00
										 |  |  | function(add_board_target BOARD_TARGET)
 | 
					
						
							| 
									
										
										
										
											2023-07-25 15:07:21 +07:00
										 |  |  |   if (TARGET ${BOARD_TARGET})
 | 
					
						
							|  |  |  |     return()
 | 
					
						
							|  |  |  |   endif ()
 | 
					
						
							| 
									
										
										
										
											2023-04-20 14:09:38 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-04-22 22:00:45 +07:00
										 |  |  |   # LD_FILE and STARTUP_FILE can be defined in board.cmake
 | 
					
						
							|  |  |  |   if (NOT DEFINED LD_FILE_${CMAKE_C_COMPILER_ID})
 | 
					
						
							|  |  |  |     set(LD_FILE_GNU ${SDK_DIR}/devices/${MCU_VARIANT}/gcc/${MCU_VARIANT}xxxxx${MCU_CORE}_flexspi_nor.ld)
 | 
					
						
							| 
									
										
										
										
											2024-11-30 22:26:33 +01:00
										 |  |  |     set(LD_FILE_IAR ${SDK_DIR}/devices/${MCU_VARIANT}/iar/${MCU_VARIANT}xxxxx${MCU_CORE}_flexspi_nor.icf)
 | 
					
						
							| 
									
										
										
										
											2024-04-22 22:00:45 +07:00
										 |  |  |   endif ()
 | 
					
						
							|  |  |  |   set(LD_FILE_Clang ${LD_FILE_GNU})
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if (NOT DEFINED STARTUP_FILE_${CMAKE_C_COMPILER_ID})
 | 
					
						
							|  |  |  |     set(STARTUP_FILE_GNU ${SDK_DIR}/devices/${MCU_VARIANT}/gcc/startup_${MCU_VARIANT_WITH_CORE}.S)
 | 
					
						
							| 
									
										
										
										
											2024-11-30 22:26:33 +01:00
										 |  |  |     set(STARTUP_FILE_IAR ${SDK_DIR}/devices/${MCU_VARIANT}/iar/startup_${MCU_VARIANT_WITH_CORE}.s)
 | 
					
						
							| 
									
										
										
										
											2024-04-22 22:00:45 +07:00
										 |  |  |   endif ()
 | 
					
						
							|  |  |  |   set(STARTUP_FILE_Clang ${STARTUP_FILE_GNU})
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-07-25 15:07:21 +07:00
										 |  |  |   add_library(${BOARD_TARGET} STATIC | 
					
						
							| 
									
										
										
										
											2024-04-22 22:00:45 +07:00
										 |  |  |     ${STARTUP_FILE_${CMAKE_C_COMPILER_ID}}
 | 
					
						
							| 
									
										
										
										
											2023-07-25 15:07:21 +07:00
										 |  |  |     ${CMAKE_CURRENT_FUNCTION_LIST_DIR}/boards/${BOARD}/board/clock_config.c
 | 
					
						
							| 
									
										
										
										
											2023-11-16 15:38:55 +07:00
										 |  |  |     ${CMAKE_CURRENT_FUNCTION_LIST_DIR}/boards/${BOARD}/board/pin_mux.c
 | 
					
						
							| 
									
										
										
										
											2023-07-25 15:07:21 +07:00
										 |  |  |     ${SDK_DIR}/drivers/common/fsl_common.c
 | 
					
						
							| 
									
										
										
										
											2023-11-16 15:38:55 +07:00
										 |  |  |     ${SDK_DIR}/drivers/common/fsl_common_arm.c
 | 
					
						
							| 
									
										
										
										
											2023-07-25 15:07:21 +07:00
										 |  |  |     ${SDK_DIR}/drivers/igpio/fsl_gpio.c
 | 
					
						
							|  |  |  |     ${SDK_DIR}/drivers/lpspi/fsl_lpspi.c
 | 
					
						
							|  |  |  |     ${SDK_DIR}/drivers/lpuart/fsl_lpuart.c
 | 
					
						
							| 
									
										
										
										
											2024-07-18 09:24:29 +07:00
										 |  |  |     ${SDK_DIR}/drivers/ocotp/fsl_ocotp.c
 | 
					
						
							| 
									
										
										
										
											2023-11-16 15:38:55 +07:00
										 |  |  |     ${SDK_DIR}/devices/${MCU_VARIANT}/system_${MCU_VARIANT_WITH_CORE}.c
 | 
					
						
							| 
									
										
										
										
											2023-07-25 15:07:21 +07:00
										 |  |  |     ${SDK_DIR}/devices/${MCU_VARIANT}/xip/fsl_flexspi_nor_boot.c
 | 
					
						
							|  |  |  |     ${SDK_DIR}/devices/${MCU_VARIANT}/drivers/fsl_clock.c
 | 
					
						
							|  |  |  |     )
 | 
					
						
							| 
									
										
										
										
											2023-11-16 15:38:55 +07:00
										 |  |  | 
 | 
					
						
							|  |  |  |   # Optional drivers: only available for some mcus: rt1160, rt1170
 | 
					
						
							|  |  |  |   set(OPTIONAL_DRIVER fsl_dcdc.c fsl_pmu.c fsl_anatop_ai.c)
 | 
					
						
							|  |  |  |   foreach(FILE IN LISTS OPTIONAL_DRIVER)
 | 
					
						
							|  |  |  |     if(EXISTS ${SDK_DIR}/devices/${MCU_VARIANT}/drivers/${FILE})
 | 
					
						
							|  |  |  |       target_sources(${BOARD_TARGET} PRIVATE ${SDK_DIR}/devices/${MCU_VARIANT}/drivers/${FILE})
 | 
					
						
							|  |  |  |     endif()
 | 
					
						
							|  |  |  |   endforeach()
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-02 15:13:08 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-07-25 15:07:21 +07:00
										 |  |  |   target_compile_definitions(${BOARD_TARGET} PUBLIC | 
					
						
							| 
									
										
										
										
											2024-04-22 22:00:45 +07:00
										 |  |  |     __STARTUP_CLEAR_BSS
 | 
					
						
							| 
									
										
										
										
											2024-11-02 15:13:08 +01:00
										 |  |  |     CFG_TUSB_MEM_SECTION=__attribute__\(\(section\(\"NonCacheable\"\)\)\)
 | 
					
						
							| 
									
										
										
										
											2023-07-25 15:07:21 +07:00
										 |  |  |     )
 | 
					
						
							| 
									
										
										
										
											2024-11-02 15:13:08 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |   if (NOT M4 STREQUAL "1")
 | 
					
						
							|  |  |  |     target_compile_definitions(${BOARD_TARGET} PUBLIC | 
					
						
							|  |  |  |       __ARMVFP__=0
 | 
					
						
							|  |  |  |       __ARMFPV5__=0
 | 
					
						
							|  |  |  |       XIP_EXTERNAL_FLASH=1
 | 
					
						
							|  |  |  |       XIP_BOOT_HEADER_ENABLE=1
 | 
					
						
							|  |  |  |       )
 | 
					
						
							|  |  |  |   endif ()
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-07-25 15:07:21 +07:00
										 |  |  |   target_include_directories(${BOARD_TARGET} PUBLIC | 
					
						
							|  |  |  |     ${CMAKE_CURRENT_FUNCTION_LIST_DIR}/boards/${BOARD}
 | 
					
						
							|  |  |  |     ${CMAKE_CURRENT_FUNCTION_LIST_DIR}/boards/${BOARD}/board
 | 
					
						
							|  |  |  |     ${CMSIS_DIR}/CMSIS/Core/Include
 | 
					
						
							|  |  |  |     ${SDK_DIR}/devices/${MCU_VARIANT}
 | 
					
						
							|  |  |  |     ${SDK_DIR}/devices/${MCU_VARIANT}/drivers
 | 
					
						
							|  |  |  |     #${SDK_DIR}/drivers/adc_12b1msps_sar
 | 
					
						
							|  |  |  |     ${SDK_DIR}/drivers/common
 | 
					
						
							|  |  |  |     ${SDK_DIR}/drivers/igpio
 | 
					
						
							|  |  |  |     ${SDK_DIR}/drivers/lpspi
 | 
					
						
							|  |  |  |     ${SDK_DIR}/drivers/lpuart
 | 
					
						
							| 
									
										
										
										
											2024-07-18 09:24:29 +07:00
										 |  |  |     ${SDK_DIR}/drivers/ocotp
 | 
					
						
							| 
									
										
										
										
											2023-07-25 15:07:21 +07:00
										 |  |  |     )
 | 
					
						
							| 
									
										
										
										
											2023-06-02 15:26:16 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-07-25 15:07:21 +07:00
										 |  |  |   update_board(${BOARD_TARGET})
 | 
					
						
							| 
									
										
										
										
											2023-06-02 15:26:16 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-07-25 15:07:21 +07:00
										 |  |  |   if (CMAKE_C_COMPILER_ID STREQUAL "GNU")
 | 
					
						
							|  |  |  |     target_link_options(${BOARD_TARGET} PUBLIC | 
					
						
							|  |  |  |       "LINKER:--script=${LD_FILE_GNU}"
 | 
					
						
							| 
									
										
										
										
											2024-04-22 22:00:45 +07:00
										 |  |  |       -nostartfiles
 | 
					
						
							|  |  |  |       --specs=nosys.specs --specs=nano.specs
 | 
					
						
							| 
									
										
										
										
											2023-07-25 15:07:21 +07:00
										 |  |  |       # force linker to look for these symbols
 | 
					
						
							|  |  |  |       -Wl,-uimage_vector_table
 | 
					
						
							|  |  |  |       -Wl,-ug_boot_data
 | 
					
						
							|  |  |  |       )
 | 
					
						
							| 
									
										
										
										
											2024-04-22 22:00:45 +07:00
										 |  |  |   elseif (CMAKE_C_COMPILER_ID STREQUAL "Clang")
 | 
					
						
							|  |  |  |     target_link_options(${BOARD_TARGET} PUBLIC | 
					
						
							|  |  |  |       "LINKER:--script=${LD_FILE_GNU}"
 | 
					
						
							|  |  |  |       -Wl,-uimage_vector_table
 | 
					
						
							|  |  |  |       -Wl,-ug_boot_data
 | 
					
						
							|  |  |  |       )
 | 
					
						
							| 
									
										
										
										
											2023-07-25 15:07:21 +07:00
										 |  |  |   elseif (CMAKE_C_COMPILER_ID STREQUAL "IAR")
 | 
					
						
							|  |  |  |     target_link_options(${BOARD_TARGET} PUBLIC | 
					
						
							|  |  |  |       "LINKER:--config=${LD_FILE_IAR}"
 | 
					
						
							|  |  |  |       )
 | 
					
						
							| 
									
										
										
										
											2023-04-20 14:09:38 +07:00
										 |  |  |   endif ()
 | 
					
						
							| 
									
										
										
										
											2023-06-02 15:26:16 +07:00
										 |  |  | endfunction()
 | 
					
						
							| 
									
										
										
										
											2023-05-06 15:14:54 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-05-25 21:27:26 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-05-06 15:14:54 +07:00
										 |  |  | #------------------------------------
 | 
					
						
							|  |  |  | # Functions
 | 
					
						
							|  |  |  | #------------------------------------
 | 
					
						
							| 
									
										
										
										
											2023-06-27 15:45:38 +07:00
										 |  |  | function(family_configure_example TARGET RTOS)
 | 
					
						
							|  |  |  |   family_configure_common(${TARGET} ${RTOS})
 | 
					
						
							| 
									
										
										
										
											2023-04-20 14:09:38 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-06-02 15:26:16 +07:00
										 |  |  |   # Board target
 | 
					
						
							|  |  |  |   add_board_target(board_${BOARD})
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-05-09 10:02:44 +07:00
										 |  |  |   target_sources(${TARGET} PUBLIC | 
					
						
							| 
									
										
										
										
											2023-05-06 15:14:54 +07:00
										 |  |  |     # BSP
 | 
					
						
							|  |  |  |     ${CMAKE_CURRENT_FUNCTION_LIST_DIR}/family.c
 | 
					
						
							| 
									
										
										
										
											2023-05-08 00:24:48 +07:00
										 |  |  |     ${CMAKE_CURRENT_FUNCTION_LIST_DIR}/../board.c
 | 
					
						
							| 
									
										
										
										
											2023-05-06 15:14:54 +07:00
										 |  |  |     )
 | 
					
						
							| 
									
										
										
										
											2023-05-09 10:02:44 +07:00
										 |  |  |   target_include_directories(${TARGET} PUBLIC | 
					
						
							| 
									
										
										
										
											2023-05-10 18:15:48 +07:00
										 |  |  |     # family, hw, board
 | 
					
						
							| 
									
										
										
										
											2023-04-21 18:10:28 +07:00
										 |  |  |     ${CMAKE_CURRENT_FUNCTION_LIST_DIR}
 | 
					
						
							|  |  |  |     ${CMAKE_CURRENT_FUNCTION_LIST_DIR}/../../
 | 
					
						
							|  |  |  |     ${CMAKE_CURRENT_FUNCTION_LIST_DIR}/boards/${BOARD}
 | 
					
						
							| 
									
										
										
										
											2023-04-20 14:09:38 +07:00
										 |  |  |     )
 | 
					
						
							| 
									
										
										
										
											2023-04-21 18:10:28 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-06-16 14:17:25 +07:00
										 |  |  |   # Add TinyUSB target and port source
 | 
					
						
							| 
									
										
										
										
											2025-01-24 15:06:05 +07:00
										 |  |  |   family_add_tinyusb(${TARGET} OPT_MCU_MIMXRT1XXX)
 | 
					
						
							| 
									
										
										
										
											2025-01-25 16:08:40 +07:00
										 |  |  |   target_sources(${TARGET} PRIVATE | 
					
						
							| 
									
										
										
										
											2023-06-16 12:02:42 +07:00
										 |  |  |     ${TOP}/src/portable/chipidea/ci_hs/dcd_ci_hs.c
 | 
					
						
							|  |  |  |     ${TOP}/src/portable/chipidea/ci_hs/hcd_ci_hs.c
 | 
					
						
							|  |  |  |     ${TOP}/src/portable/ehci/ehci.c
 | 
					
						
							|  |  |  |     )
 | 
					
						
							| 
									
										
										
										
											2025-01-25 16:08:40 +07:00
										 |  |  |   target_link_libraries(${TARGET} PUBLIC board_${BOARD})
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-06-02 11:42:17 +07:00
										 |  |  |   # Flashing
 | 
					
						
							| 
									
										
										
										
											2024-11-30 21:50:50 +01:00
										 |  |  |   family_add_bin_hex(${TARGET})
 | 
					
						
							| 
									
										
										
										
											2023-05-19 16:27:07 +07:00
										 |  |  |   family_flash_jlink(${TARGET})
 | 
					
						
							| 
									
										
										
										
											2023-06-02 15:26:16 +07:00
										 |  |  |   #family_flash_nxplink(${TARGET})
 | 
					
						
							| 
									
										
										
										
											2023-11-16 20:05:27 +07:00
										 |  |  |   #family_flash_pyocd(${TARGET})
 | 
					
						
							| 
									
										
										
										
											2023-04-21 18:10:28 +07:00
										 |  |  | endfunction()
 |