【南京中科微CSM32RV20开发板试用体验】linux 调试

描述

本文来源电子发烧友社区,作者:jf_25674040, 帖子地址:https://bbs.elecfans.com/jish u_2283042_1_1.html

一、 获取编译器
1.  在https://github.com/riscv-collab/riscv-gnu-toolchain/tags上获取最新版本,2022.05.15。
2. 通过编译源码的方式获取
2.1 git clone https://github.com/riscv/riscv-gnu-toolchain获取源代码
2.2 sudo apt-get install autoconf automake autotools-dev curl python3 libmpc-dev libmpfr-dev libgmp-dev gawk build-essential bison flex texinfo gperf libtool patchutils bc zlib1g-dev libexpat-dev安装所需工具
2.3 ./configure --prefix=/opt/riscv --enable-multilib 使能riscv32/risv64输出。
2.4 sudo make 安装,如果发现github下载慢,可以使用的方式下载
cd /home/wps/tmp/riscv-gnu-toolchain &&
flock `git rev-parse --git-dir`/config git submodule init /home/wps/tmp/riscv-gnu-toolchain/riscv-gcc/ &&
flock `git rev-parse --git-dir`/config git submodule update /home/wps/tmp/riscv-gnu-toolchain/riscv-gcc/


cd /home/wps/tmp/riscv-gnu-toolchain &&
flock `git rev-parse --git-dir`/config git submodule init /home/wps/tmp/riscv-gnu-toolchain/newlib/ &&
flock `git rev-parse --git-dir`/config git submodule update /home/wps/tmp/riscv-gnu-toolchain/newlib/


git config --global --add safe.directory /home/apps/riscv-gnu-toolchain


cd /home/apps/riscv-gnu-toolchain &&
flock `git rev-parse --git-dir`/config git submodule init /home/apps/riscv-gnu-toolchain/riscv-gdb/ &&
flock `git rev-parse --git-dir`/config git submodule update /home/apps/riscv-gnu-toolchain/riscv-gdb/

2.5 在bashrc中添加export PATH=/opt/riscv/bin:$PATH
二、获取api文件,当前我采取使用安装官方软件的方式获取基础API。
1. 下载CSMStudio_22.03.08_x64.zip,并在windows10下安装软件。
2. 找到安装目录下的CSM32RV20_coremark_32M或CSM32RV20_LED_Breath,并获取其中的drivers,ld目录,获取src下面的vectors.S和main.c。
3. 创建Makefile,至此便可以完成代码的编译工作,后续增加下载,调试功能。
附,当前使用的Makefile
```
#target
TARGET = hello_world


#building variables
#debug
DEBUG =1
OPT = -O2


BUILD_DIR = build
#BIN_DIR = $(BUILD_DIR)/bin


C_SOURCES =
src/main.c
drivers/Src/clic.c
drivers/Src/cmu.c
drivers/Src/gpio.c
drivers/Src/uart.c
drivers/Src/ee_printf.c
drivers/Src/adc.c
drivers/Src/comp.c
drivers/Src/data_always.c
drivers/Src/flash.c
drivers/Src/i2c.c
drivers/Src/iwdg.c
drivers/Src/lowpower.c
drivers/Src/lv.c
drivers/Src/random.c
drivers/Src/rtc.c
drivers/Src/spi.c
drivers/Src/timer.c
drivers/Src/usb.c
drivers/Src/wup.c




ASM_SOURCES =
src/vectors.S


# binaries
PREFIX = riscv64-unknown-elf-


ifdef GCC_PATH
CC = $(GCC_PATH)/$(PREFIX)gcc
AS = $(GCC_PATH)/$(PREFIX)g++
CP = $(GCC_PATH)/$(PREFIX)objcopy
SZ = $(GCC_PATH)/$(PREFIX)size
else
CC = $(PREFIX)gcc
AS = $(PREFIX)g++
CP = $(PREFIX)objcopy
SZ = $(PREFIX)size
endif


HEX = $(CP) -O ihex
BIN = $(CP) -O binary -S


# C_FLAGS
CPU = -march=rv32imac


# mcu
MCU = -mabi=ilp32 $(CPU)


AS_DEFS =
C_DEFS =


AS_INCLUDES =
-Idrivers/Inc


C_INCLUDES =
-Idrivers/Inc


# compile gcc flags
ASFLASGS = -Wall -g $(MCU) -fdata-sections -ffunction-sections -fomit-frame-pointer -mcmodel=medlow -mtune=rocket $(OPT)
ASFLASGS += $(C_DEFS) $(C_INCLUDES)
CFLAGS = -Wall -g $(MCU) -fdata-sections -ffunction-sections -fomit-frame-pointer -mcmodel=medlow -mtune=rocket $(OPT)
CFLAGS += $(C_DEFS) $(C_INCLUDES)


# link script
LDSCRIPT = ld/target.ld


LDFLAGS = $(MCU) -T $(LDSCRIPT) -nostartfiles
LDFLAGS += -Wl,-Map,map.txt
LDFLAGS += -Xlinker --gc-sections -Xlinker --cref
LDFLAGS += --specs=nano.specs --specs=nosys.specs  




all: $(BUILD_DIR)/$(TARGET).elf


# list of objects
OBJECTS = $(addprefix $(BUILD_DIR)/,$(notdir $(C_SOURCES:.c=.o)))
vpath %.c $(sort $(dir $(C_SOURCES)))
# list of ASM program objects
OBJECTS += $(addprefix $(BUILD_DIR)/,$(notdir $(ASM_SOURCES:.S=.o)))
vpath %.S $(sort $(dir $(ASM_SOURCES)))


$(BUILD_DIR)/%.o: %.c Makefile | $(BUILD_DIR)
        $(CC) -c $(CFLAGS) $< -o $@


$(BUILD_DIR)/%.o: %.S Makefile | $(BUILD_DIR)
        $(AS) -c $(CFLAGS) $< -o $@


$(BUILD_DIR)/$(TARGET).elf: $(OBJECTS) Makefile
        $(CC) $(OBJECTS) $(LDFLAGS) -o $@
        $(SZ) $@


$(BUILD_DIR):
        mkdir $@


clean:
        -rm -fR $(BUILD_DIR)
```
打开APP阅读更多精彩内容
声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉

全部0条评论

快来发表一下你的评论吧 !

×
20
完善资料,
赚取积分