| 
									
										
										
										
											2024-05-09 20:43:46 +07:00
										 |  |  | include_guard()
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-05-17 16:13:59 +07:00
										 |  |  | set(CH32_FAMILY ch32v30x)
 | 
					
						
							| 
									
										
										
										
											2024-05-20 17:26:04 +07:00
										 |  |  | set(SDK_DIR ${TOP}/hw/mcu/wch/ch32v307)
 | 
					
						
							|  |  |  | set(SDK_SRC_DIR ${SDK_DIR}/EVT/EXAM/SRC)
 | 
					
						
							| 
									
										
										
										
											2024-05-09 20:43:46 +07:00
										 |  |  | 
 | 
					
						
							|  |  |  | # include board specific
 | 
					
						
							|  |  |  | include(${CMAKE_CURRENT_LIST_DIR}/boards/${BOARD}/board.cmake)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | # toolchain set up
 | 
					
						
							|  |  |  | set(CMAKE_SYSTEM_PROCESSOR rv32imac-ilp32 CACHE INTERNAL "System Processor")
 | 
					
						
							|  |  |  | set(CMAKE_TOOLCHAIN_FILE ${TOP}/examples/build_system/cmake/toolchain/riscv_${TOOLCHAIN}.cmake)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | set(FAMILY_MCUS CH32V307 CACHE INTERNAL "")
 | 
					
						
							|  |  |  | set(OPENOCD_OPTION "-f ${CMAKE_CURRENT_LIST_DIR}/wch-riscv.cfg")
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-05-24 11:38:44 +07:00
										 |  |  | # default to highspeed, used to select USBFS / USBHS driver
 | 
					
						
							| 
									
										
										
										
											2024-05-20 17:26:04 +07:00
										 |  |  | if (NOT DEFINED SPEED)
 | 
					
						
							|  |  |  |   set(SPEED high)
 | 
					
						
							|  |  |  | endif()
 | 
					
						
							| 
									
										
										
										
											2024-05-17 16:13:59 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-05-09 20:43:46 +07:00
										 |  |  | #------------------------------------
 | 
					
						
							|  |  |  | # 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 ${CMAKE_CURRENT_FUNCTION_LIST_DIR}/ch32v307.ld)
 | 
					
						
							|  |  |  |   endif ()
 | 
					
						
							|  |  |  |   set(LD_FILE_Clang ${LD_FILE_GNU})
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if (NOT DEFINED STARTUP_FILE_GNU)
 | 
					
						
							| 
									
										
										
										
											2024-05-20 17:26:04 +07:00
										 |  |  |     set(STARTUP_FILE_GNU ${SDK_SRC_DIR}/Startup/startup_${CH32_FAMILY}_D8C.S)
 | 
					
						
							| 
									
										
										
										
											2024-05-09 20:43:46 +07:00
										 |  |  |   endif ()
 | 
					
						
							|  |  |  |   set(STARTUP_FILE_Clang ${STARTUP_FILE_GNU})
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   add_library(${BOARD_TARGET} STATIC | 
					
						
							| 
									
										
										
										
											2024-05-20 17:26:04 +07:00
										 |  |  |     ${SDK_SRC_DIR}/Core/core_riscv.c
 | 
					
						
							|  |  |  |     ${SDK_SRC_DIR}/Peripheral/src/${CH32_FAMILY}_gpio.c
 | 
					
						
							|  |  |  |     ${SDK_SRC_DIR}/Peripheral/src/${CH32_FAMILY}_misc.c
 | 
					
						
							|  |  |  |     ${SDK_SRC_DIR}/Peripheral/src/${CH32_FAMILY}_rcc.c
 | 
					
						
							|  |  |  |     ${SDK_SRC_DIR}/Peripheral/src/${CH32_FAMILY}_usart.c
 | 
					
						
							| 
									
										
										
										
											2024-05-17 16:13:59 +07:00
										 |  |  |     ${CMAKE_CURRENT_FUNCTION_LIST_DIR}/${CH32_FAMILY}_it.c
 | 
					
						
							|  |  |  |     ${CMAKE_CURRENT_FUNCTION_LIST_DIR}/system_${CH32_FAMILY}.c
 | 
					
						
							| 
									
										
										
										
											2024-05-09 20:43:46 +07:00
										 |  |  |     ${STARTUP_FILE_${CMAKE_C_COMPILER_ID}}
 | 
					
						
							|  |  |  |     )
 | 
					
						
							|  |  |  |   target_include_directories(${BOARD_TARGET} PUBLIC | 
					
						
							| 
									
										
										
										
											2024-06-14 12:51:28 +07:00
										 |  |  |     ${SDK_SRC_DIR}/Core
 | 
					
						
							| 
									
										
										
										
											2024-05-20 17:26:04 +07:00
										 |  |  |     ${SDK_SRC_DIR}/Peripheral/inc
 | 
					
						
							| 
									
										
										
										
											2024-05-09 20:43:46 +07:00
										 |  |  |     ${CMAKE_CURRENT_FUNCTION_LIST_DIR}
 | 
					
						
							|  |  |  |     )
 | 
					
						
							| 
									
										
										
										
											2024-05-24 11:38:44 +07:00
										 |  |  |   if (SPEED STREQUAL high)
 | 
					
						
							|  |  |  |     target_compile_definitions(${BOARD_TARGET} PUBLIC | 
					
						
							|  |  |  |       CFG_TUD_WCH_USBIP_USBHS=1
 | 
					
						
							|  |  |  | #      BOARD_TUD_MAX_SPEED=OPT_MODE_HIGH_SPEED
 | 
					
						
							|  |  |  |       )
 | 
					
						
							|  |  |  |   else ()
 | 
					
						
							|  |  |  |     target_compile_definitions(${BOARD_TARGET} PUBLIC | 
					
						
							|  |  |  |       CFG_TUD_WCH_USBIP_USBFS=1
 | 
					
						
							|  |  |  |       )
 | 
					
						
							|  |  |  |   endif ()
 | 
					
						
							| 
									
										
										
										
											2024-05-09 20:43:46 +07:00
										 |  |  | 
 | 
					
						
							|  |  |  |   update_board(${BOARD_TARGET})
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if (CMAKE_C_COMPILER_ID STREQUAL "GNU")
 | 
					
						
							|  |  |  |     target_compile_options(${BOARD_TARGET} PUBLIC | 
					
						
							|  |  |  |       -msmall-data-limit=8
 | 
					
						
							|  |  |  |       -mno-save-restore
 | 
					
						
							|  |  |  |       -fmessage-length=0
 | 
					
						
							|  |  |  |       -fsigned-char
 | 
					
						
							|  |  |  |       )
 | 
					
						
							|  |  |  |     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")
 | 
					
						
							|  |  |  |     message(FATAL_ERROR "Clang is not supported for MSP432E4")
 | 
					
						
							|  |  |  |   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}/debug_uart.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_CH32V307 ${RTOS})
 | 
					
						
							|  |  |  |   target_sources(${TARGET}-tinyusb PUBLIC | 
					
						
							| 
									
										
										
										
											2024-05-20 17:26:04 +07:00
										 |  |  |     ${TOP}/src/portable/wch/dcd_ch32_usbhs.c
 | 
					
						
							| 
									
										
										
										
											2024-05-17 16:13:59 +07:00
										 |  |  |     ${TOP}/src/portable/wch/dcd_ch32_usbfs.c
 | 
					
						
							| 
									
										
										
										
											2024-05-09 20:43:46 +07:00
										 |  |  |     )
 | 
					
						
							|  |  |  |   target_link_libraries(${TARGET}-tinyusb PUBLIC board_${BOARD})
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   # Link dependencies
 | 
					
						
							|  |  |  |   target_link_libraries(${TARGET} PUBLIC board_${BOARD} ${TARGET}-tinyusb)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   # Flashing
 | 
					
						
							|  |  |  |   family_add_bin_hex(${TARGET})
 | 
					
						
							|  |  |  |   family_flash_openocd_wch(${TARGET})
 | 
					
						
							|  |  |  | endfunction()
 |