mirror of
https://github.com/RT-Thread/rt-thread.git
synced 2025-02-24 23:47:17 +08:00
#### 为什么提交这份PR (why to submit this PR) - 修复ch32v307v-r1 board.h 中变量_stack_size未声明BUG - 提供ch32v307v-r1动态堆内存分配(宏开关)代码 - ch32v307v-r1 MD文档新增烧录方式,作为烧录后无运行结果的替代方案 #### 你的解决方案是什么 (what is your solution) - 去掉_stack_size未声明变量 - 动态分配内存堆,将堆起始地址放在.bss段结尾,堆结束地址放在.stack段开头[详情](https://club.rt-thread.org/ask/article/001065082e9ae611.html) - 将烧录工具替换为WCH-LinkUtility #### 在什么测试环境下测试通过 (what is the test environment) - 开发工具: RT-Thread Studio - 测试板卡:ch32v307v-r1评估板 - 烧录工具:WCH-LinkUtility
117 lines
3.6 KiB
Markdown
117 lines
3.6 KiB
Markdown
# ch32v307v-r1 BSP 说明
|
||
|
||
[English](README.md) | **中文**
|
||
|
||
## 1 开发板简介
|
||
|
||
CH32V307V-R1 是 WCH 推出的一款基于 RISC-V 内核的开发板,最高主频为 144Mhz。比较适合入门学习 RISC-V 架构。
|
||
|
||
data:image/s3,"s3://crabby-images/33d9d/33d9dc96d916b6b2dfb67853d67f7f17142b8d82" alt="board"
|
||
|
||
**基本特性:**
|
||
|
||
- MCU:CH32V307VCT6,主频 144MHz,FLASH 和 RAM 可配置
|
||
- LED:2 个,用户 LEDs,LED1(blue),LED2(blue)。
|
||
- 按键:2 个,Reset,User 。
|
||
- USB:2 个,Tpye-C。
|
||
- 网口:1 个,内置 10M PHY。
|
||
- 板载 WCH-Link 下载调试工具。
|
||
|
||
更多信息和资源请访问[互联型 RISC-V 单片机 CH32V307](https://www.wch.cn/products/CH32V307.html) 以及 [官网文档资料](https://github.com/openwch/ch32v307)
|
||
|
||
## 2 编译说明
|
||
|
||
板级包支持 RISC-V GCC 开发环境,以下是具体版本信息:
|
||
|
||
| IDE/编译器 | 已测试版本 |
|
||
| ---------- | -------------------- |
|
||
| GCC | WCH RISC-V GCC 8.2.0 |
|
||
|
||
## 3 使用说明
|
||
|
||
> 本章节是为刚接触 RT-Thread 的新手准备的使用说明,遵循简单的步骤即可将 RT-Thread 操作系统运行在该开发板上,看到实验效果 。
|
||
|
||
### 3.1 使用 Env 编译 BSP
|
||
|
||
本节讲解如何使用 Env 工具来编译 BSP 工程。
|
||
|
||
#### 3.1.1 编译 BSP
|
||
|
||
1. [下载 WCH 编译工具链](https://github.com/NanjingQinheng/sdk-toolchain-RISC-V-GCC-WCH/archive/refs/tags/V1.0.0.zip)
|
||
2. 下载 Env 工具[最新版本](https://github.com/RT-Thread/env-windows/releases)
|
||
3. 下载 RT-Thread[最新源码](https://github.com/RT-Thread/rt-thread/archive/refs/heads/master.zip)
|
||
4. 并在当前 BSP 根目录下打开 Env 工具并执行 `scons --exec-path=D:\sdk-toolchain-RISC-V-GCC-WCH-1.0.0\bin` 命令,在指定工具链位置的同时直接编译。
|
||
5. 编译完成之后会生成 **rtthread.bin** 文件。
|
||
|
||
data:image/s3,"s3://crabby-images/b93e0/b93e00f850764d8e29efe949d5b13173a1b82045" alt="sconscompile"
|
||
|
||
#### 3.1.2 硬件连接
|
||
|
||
使用数据线连接板载 wch-link 到 PC,打开电源开关。
|
||
|
||
#### 3.1.3 下载
|
||
|
||
打开 WCH RISC-V MCU ProgrammerTool 下载软件,选择刚刚生成的 **rtthread.bin** 文件,进行下载。
|
||
|
||
data:image/s3,"s3://crabby-images/8d320/8d320697e7dc69f1fe25b5e48d971d6a3e619c27" alt="tool"
|
||
|
||
> 注意:这里 Chip Mem 设置为 224K ROM + 96K RAM。不要以参考手册为准。
|
||
|
||
#### 3.1.4 运行结果
|
||
|
||
在终端工具里打开板载 wch-link 串口(WCHDapLink SERIAL,默认 115200-8-1-N),复位设备后,在串口上可以看到 RT-Thread 的输出信息:
|
||
|
||
data:image/s3,"s3://crabby-images/38c84/38c841d8665eacb6ea4df1f35b4a8a44563bd300" alt="end"
|
||
|
||
#### 3.1.5 无运行结果解决方案
|
||
|
||
将 WCH RISC-V MCU ProgrammerTool 下载软件替换为 WCH-LinkUtility.[详情](https://club.rt-thread.org/ask/article/44e5b4bc129ff373.html)
|
||
|
||
### 3.2 使用 VSCode 编译工程
|
||
|
||
在 Env 终端中敲入命令 `scons --target=vsc` 来生成 VSCode 工程. 接着敲入命令 `code .` 来打开 VSCode.
|
||
|
||
使用 **VSCode 终端** 敲入命令 `scons -j12 --exec-path=D:\sdk-toolchain-RISC-V-GCC-WCH-1.0.0\bin` 来编译工程。
|
||
|
||
data:image/s3,"s3://crabby-images/aa10e/aa10e9f7ddb1bcd076684f6113346b4e571d424a" alt="vscode-terminal"
|
||
|
||
### 3.3 导入 RT-Thread Studio 工程
|
||
|
||
#### 3.3.1 导入
|
||
|
||
打开 RT-Thread Studio 后点击:文件->导入:
|
||
|
||
data:image/s3,"s3://crabby-images/0ae12/0ae1242cb92080238841ca2826a0cb6e455eea5f" alt="import"
|
||
|
||
选择“RT-Thread Bsp 到工作空间中”:
|
||
|
||
data:image/s3,"s3://crabby-images/32b6a/32b6ab70b409b7cdac3dc713e38f9a0f38b35640" alt="windows"
|
||
|
||
填写项目信息,Bsp 根目录为 `\rt-thread\bsp\wch\risc-v\ch32v307v-r1` 目录:
|
||
|
||
data:image/s3,"s3://crabby-images/e0e7e/e0e7ebba3330837e5f3ef2f452cf02dec3e99d65" alt="config"
|
||
|
||
#### 3.3.2 配置环境
|
||
|
||
工程导入后进行编译环境的设置,首先点击“打开构建设置”进入设置界面:
|
||
|
||
data:image/s3,"s3://crabby-images/74b56/74b56294c6fbed0e1c35fbbb920a224f9c30bb54" alt="set"
|
||
|
||
将编译链路径复制到 Toolchain path 中:
|
||
|
||
data:image/s3,"s3://crabby-images/f07bf/f07bf33745bf68ccd567bc281a6adac63484bd27" alt="toolchain"
|
||
|
||
如图更改 Prefix :
|
||
|
||
data:image/s3,"s3://crabby-images/77904/779041a21a7242867eb86b04e9fe446f26337e95" alt="prefix"
|
||
|
||
进行工具设置:
|
||
|
||
data:image/s3,"s3://crabby-images/a6884/a6884e4068d898fbc0ef6cef95255e2d16da0399" alt="toolset"
|
||
|
||
#### 3.3.3 编译
|
||
|
||
编译结果如下:
|
||
|
||
data:image/s3,"s3://crabby-images/2c8ae/2c8ae32e1c58256d57d789a53511a069c7a4866f" alt="success"
|