2022-03-21 10:01:11 +10:30
|
|
|
# https://www.embecosm.com/resources/tool-chain-downloads/#riscv-stable
|
|
|
|
#CROSS_COMPILE ?= riscv32-unknown-elf-
|
|
|
|
|
|
|
|
# Toolchain from https://github.com/xpack-dev-tools/riscv-none-embed-gcc-xpack
|
|
|
|
CROSS_COMPILE ?= riscv-none-embed-
|
|
|
|
|
|
|
|
# Submodules
|
|
|
|
CH32V307_SDK = hw/mcu/wch/ch32v307
|
|
|
|
DEPS_SUBMODULES += $(CH32V307_SDK)
|
|
|
|
|
|
|
|
# WCH-SDK paths
|
|
|
|
CH32V307_SDK_SRC = $(CH32V307_SDK)/EVT/EXAM/SRC
|
|
|
|
|
|
|
|
include $(TOP)/$(BOARD_PATH)/board.mk
|
|
|
|
|
|
|
|
CFLAGS += \
|
|
|
|
-flto \
|
|
|
|
-march=rv32imac \
|
|
|
|
-mabi=ilp32 \
|
|
|
|
-msmall-data-limit=8 \
|
|
|
|
-mno-save-restore -Os \
|
|
|
|
-fmessage-length=0 \
|
|
|
|
-fsigned-char \
|
|
|
|
-ffunction-sections \
|
|
|
|
-fdata-sections \
|
|
|
|
-nostdlib -nostartfiles \
|
2022-03-22 23:31:20 +10:30
|
|
|
-DCFG_TUSB_MCU=OPT_MCU_CH32V307 \
|
2022-03-21 10:01:11 +10:30
|
|
|
-Xlinker --gc-sections \
|
2023-01-12 10:25:48 +07:00
|
|
|
-DBOARD_TUD_MAX_SPEED=OPT_MODE_HIGH_SPEED
|
2023-01-08 00:02:17 +07:00
|
|
|
|
2023-11-23 12:43:13 +07:00
|
|
|
LDFLAGS_GCC += -specs=nosys.specs -specs=nano.specs
|
|
|
|
|
2022-03-21 10:01:11 +10:30
|
|
|
SRC_C += \
|
2023-10-06 13:04:54 +03:00
|
|
|
src/portable/wch/dcd_ch32_usbhs.c \
|
2023-01-12 12:08:56 +07:00
|
|
|
$(CH32V307_SDK_SRC)/Core/core_riscv.c \
|
|
|
|
$(CH32V307_SDK_SRC)/Peripheral/src/ch32v30x_gpio.c \
|
|
|
|
$(CH32V307_SDK_SRC)/Peripheral/src/ch32v30x_misc.c \
|
|
|
|
$(CH32V307_SDK_SRC)/Peripheral/src/ch32v30x_rcc.c \
|
2023-03-16 23:11:11 +07:00
|
|
|
$(CH32V307_SDK_SRC)/Peripheral/src/ch32v30x_usart.c
|
|
|
|
|
2022-03-21 10:01:11 +10:30
|
|
|
SRC_S += \
|
2023-03-16 23:11:11 +07:00
|
|
|
$(CH32V307_SDK_SRC)/Startup/startup_ch32v30x_D8C.S
|
2022-03-21 10:01:11 +10:30
|
|
|
|
|
|
|
INC += \
|
|
|
|
$(TOP)/$(BOARD_PATH) \
|
2023-01-12 12:30:18 +07:00
|
|
|
$(TOP)/$(CH32V307_SDK_SRC)/Peripheral/inc
|
2022-03-21 10:01:11 +10:30
|
|
|
|
|
|
|
# For freeRTOS port source
|
2023-03-16 23:11:11 +07:00
|
|
|
FREERTOS_PORTABLE_SRC = $(FREERTOS_PORTABLE_PATH)/RISC-V
|
2022-03-21 10:01:11 +10:30
|
|
|
|
2023-01-12 10:25:48 +07:00
|
|
|
# wch-link is not supported yet in official openOCD yet. We need to either use
|
|
|
|
# 1. download openocd as part of mounriver studio http://www.mounriver.com/download or
|
|
|
|
# 2. compiled from modified source https://github.com/kprasadvnsi/riscv-openocd-wch
|
|
|
|
#
|
2023-03-16 23:11:11 +07:00
|
|
|
# Note: For Linux, somehow openocd in mounriver studio does not seem to have wch-link enable,
|
2023-01-12 10:25:48 +07:00
|
|
|
# therefore we need to compile it from source as follows:
|
|
|
|
# git clone https://github.com/kprasadvnsi/riscv-openocd-wch
|
|
|
|
# cd riscv-openocd-wch
|
|
|
|
# ./bootstrap
|
|
|
|
# ./configure CFLAGS="-Wno-error" --enable-wlink
|
|
|
|
# make
|
|
|
|
# openocd binaries will be generated in riscv-openocd-wch/src
|
|
|
|
|
2022-03-21 10:01:11 +10:30
|
|
|
# flash target ROM bootloader
|
|
|
|
flash: $(BUILD)/$(PROJECT).elf
|
2023-01-12 13:31:36 +07:00
|
|
|
openocd -f $(TOP)/$(FAMILY_PATH)/wch-riscv.cfg -c init -c halt -c "program $<" -c wlink_reset_resume -c exit
|