 f392b4c91d
			
		
	
	f392b4c91d
	
	
	
		
			
			I will be porting tinyuf2 to MCXA156 and N947 and need this work in place. This is the 1st step before bringing in support for other MCX devices. We had previous patched https://github.com/hathach/mcux-sdk.git' for MCX support as it was not pulically available I updated get_deps to point to the mcux-sdk version 2.16.10 from NXP. I repointed the entry in the get_deps script to use NXP MCU repo. The existing current code couldn't build as the MCUXpresso SDK was old. - For now, I put a copy of fsl_spc.c in the drivers folder for the mcx family. None of the ports could build with the version in the mcux github sdk. The sdk on github has version 2.4.0. The SDK package that can be downloaded with the SDK generator uses 2.4.2. All of the clock_config routines use versions of the datastructure from 2.4.2. For now, keeping an updated copy in hw/bsp/mcx/drivers so we can build against the latest mcuxpresso sdk and enable MCXA156. I'll file an issue on the nxp github. - Cleaned up the MCX family.c a little bit. the MCXA/N these chips don't have SCT so I removed the neopixel code. - fixed a clock init issue w/ N947 that was causing it to crash when initializing the uart. - I tested the cmake and make scripts on the A153,A156 and N947 using the CDC/MSC sample. All worked OK. - Patched get_deps so it will do a fetch/check on a new folder. Some of the deps were failing on a fresh clone of tinyusb - Fixed lpc51,54 and lpc55 make/cmake files to build with mcuxpresso sdk 2.16.10 The folder structure for flexcomm/uart changed a little bit - lpc55s59 libpower_hardabi.a no longer is included in mcuxpressosdk, (fsl_power.c is replacement). remove of libpower_hardabi.a from the linker config. LPC55 still works as expected. - Using tinyuf2 get deps
		
			
				
	
	
		
			157 lines
		
	
	
		
			4.7 KiB
		
	
	
	
		
			CMake
		
	
	
	
	
	
			
		
		
	
	
			157 lines
		
	
	
		
			4.7 KiB
		
	
	
	
		
			CMake
		
	
	
	
	
	
| include_guard()
 | |
| 
 | |
| 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)
 | |
| 
 | |
| # toolchain set up
 | |
| set(CMAKE_SYSTEM_CPU cortex-m33 CACHE INTERNAL "System Processor")
 | |
| set(CMAKE_TOOLCHAIN_FILE ${TOP}/examples/build_system/cmake/toolchain/arm_${TOOLCHAIN}.cmake)
 | |
| 
 | |
| set(FAMILY_MCUS LPC55 CACHE INTERNAL "")
 | |
| 
 | |
| if (NOT DEFINED PORT)
 | |
|   set(PORT 0)
 | |
| endif()
 | |
| 
 | |
| # Host port will be the other port if available
 | |
| set(HOST_PORT $<NOT:${PORT}>)
 | |
| 
 | |
| #------------------------------------
 | |
| # BOARD_TARGET
 | |
| #------------------------------------
 | |
| # only need to be built ONCE for all examples
 | |
| function(add_board_target BOARD_TARGET)
 | |
|   if (TARGET ${BOARD_TARGET})
 | |
|     return()
 | |
|   endif()
 | |
| 
 | |
|   if (NOT DEFINED LD_FILE_GNU)
 | |
|     set(LD_FILE_GNU ${SDK_DIR}/devices/${MCU_VARIANT}/gcc/${MCU_CORE}_flash.ld)
 | |
|   endif ()
 | |
|   set(LD_FILE_Clang ${LD_FILE_GNU})
 | |
| 
 | |
|   if (NOT DEFINED STARTUP_FILE_GNU)
 | |
|     set(STARTUP_FILE_GNU ${SDK_DIR}/devices/${MCU_VARIANT}/gcc/startup_${MCU_CORE}.S)
 | |
|   endif ()
 | |
|   set(STARTUP_FILE_Clang ${STARTUP_FILE_GNU})
 | |
| 
 | |
|   add_library(${BOARD_TARGET} STATIC
 | |
|     ${STARTUP_FILE_${CMAKE_C_COMPILER_ID}}
 | |
|     # driver
 | |
|     ${SDK_DIR}/drivers/lpc_gpio/fsl_gpio.c
 | |
|     ${SDK_DIR}/drivers/common/fsl_common_arm.c
 | |
|     ${SDK_DIR}/drivers/flexcomm/fsl_flexcomm.c
 | |
|     ${SDK_DIR}/drivers/flexcomm/usart/fsl_usart.c
 | |
|     # mcu
 | |
|     ${SDK_DIR}/devices/${MCU_VARIANT}/system_${MCU_CORE}.c
 | |
|     ${SDK_DIR}/devices/${MCU_VARIANT}/drivers/fsl_clock.c
 | |
|     ${SDK_DIR}/devices/${MCU_VARIANT}/drivers/fsl_power.c
 | |
|     ${SDK_DIR}/devices/${MCU_VARIANT}/drivers/fsl_reset.c
 | |
|     )
 | |
|   target_include_directories(${BOARD_TARGET} PUBLIC
 | |
|     ${TOP}/lib/sct_neopixel
 | |
|     # driver
 | |
|     ${SDK_DIR}/drivers/common
 | |
|     ${SDK_DIR}/drivers/flexcomm
 | |
|     ${SDK_DIR}/drivers/flexcomm/usart
 | |
|     ${SDK_DIR}/drivers/lpc_iocon
 | |
|     ${SDK_DIR}/drivers/lpc_gpio
 | |
|     ${SDK_DIR}/drivers/sctimer
 | |
|     # mcu
 | |
|     ${SDK_DIR}/devices/${MCU_VARIANT}
 | |
|     ${SDK_DIR}/devices/${MCU_VARIANT}/drivers
 | |
|     ${CMSIS_DIR}/CMSIS/Core/Include
 | |
|     )
 | |
|   target_compile_definitions(${BOARD_TARGET} PUBLIC
 | |
|     CFG_TUSB_MEM_ALIGN=TU_ATTR_ALIGNED\(64\)
 | |
|     BOARD_TUD_RHPORT=${PORT}
 | |
|     BOARD_TUH_RHPORT=${HOST_PORT}
 | |
|     __STARTUP_CLEAR_BSS
 | |
|     )
 | |
| 
 | |
|   # Port 0 is Fullspeed, Port 1 is Highspeed. Port1 controller can only access USB_SRAM
 | |
|   if (PORT EQUAL 1)
 | |
|     target_compile_definitions(${BOARD_TARGET} PUBLIC
 | |
|       BOARD_TUD_MAX_SPEED=OPT_MODE_HIGH_SPEED
 | |
|       BOARD_TUH_MAX_SPEED=OPT_MODE_FULL_SPEED
 | |
|       CFG_TUD_MEM_SECTION=__attribute__\(\(section\(\"m_usb_global\"\)\)\)
 | |
|       )
 | |
|   else ()
 | |
|     target_compile_definitions(${BOARD_TARGET} PUBLIC
 | |
|       BOARD_TUD_MAX_SPEED=OPT_MODE_FULL_SPEED
 | |
|       BOARD_TUH_MAX_SPEED=OPT_MODE_HIGH_SPEED
 | |
|       CFG_TUH_MEM_SECTION=__attribute__\(\(section\(\"m_usb_global\"\)\)\)
 | |
|       )
 | |
|   endif ()
 | |
| 
 | |
|   update_board(${BOARD_TARGET})
 | |
| 
 | |
|   if (CMAKE_C_COMPILER_ID STREQUAL "GNU")
 | |
|     target_link_options(${BOARD_TARGET} PUBLIC
 | |
|       "LINKER:--script=${LD_FILE_GNU}"
 | |
|       --specs=nosys.specs --specs=nano.specs
 | |
|       -nostartfiles
 | |
|       )
 | |
|   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
 | |
|     # external driver
 | |
|     ${TOP}/lib/sct_neopixel/sct_neopixel.c
 | |
|     )
 | |
| 
 | |
|   # https://github.com/gsteiert/sct_neopixel/pull/1
 | |
|   if (CMAKE_C_COMPILER_ID STREQUAL "GNU")
 | |
|     set_source_files_properties(${TOP}/lib/sct_neopixel/sct_neopixel.c PROPERTIES
 | |
|       COMPILE_FLAGS "-Wno-unused-parameter")
 | |
|   endif ()
 | |
| 
 | |
|   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_LPC55)
 | |
|   target_sources(${TARGET} PUBLIC
 | |
|     ${TOP}/src/portable/nxp/lpc_ip3511/dcd_lpc_ip3511.c
 | |
|     )
 | |
|   target_link_libraries(${TARGET} PUBLIC board_${BOARD})
 | |
| 
 | |
| 
 | |
| 
 | |
|   # Flashing
 | |
|   family_add_bin_hex(${TARGET})
 | |
|   family_flash_jlink(${TARGET})
 | |
|   #family_flash_nxplink(${TARGET})
 | |
|   #family_flash_pyocd(${TARGET})
 | |
| endfunction()
 |