rt-thread/bsp/phytium/aarch64/README.md

185 lines
4.9 KiB
Markdown
Raw Normal View History

# AARCH64 工作模式使用
- 当开发者需要基于 Phytium 系列芯片进行开发时,可以从以下几个步骤出发配置芯片
## 1. 准备编译环境
- 在aarch64目录下创建tools文件夹用于存放编译链目前支持在以下两种环境进行开发
```shell
mkdir tools
```
使用RT-Smart编译链也可编译RT-Thread但当前不支持C++
### Ubuntu 环境
#### RT-Thread
- 点击[下载编译链工具](https://armkeil.blob.core.windows.net/developer/Files/downloads/gnu-a/10.3-2021.07/binrel/gcc-arm-10.3-2021.07-x86_64-aarch64-none-elf.tar.xz)压缩包放置在tools目录下
- 在tools目录下使用tar命令解压缩
```shell
tar xvf gcc-arm-10.3-2021.07-x86_64-aarch64-none-elf.tar.xz
```
![tar_toolschain_ubuntu](./figures/tar_toolschain_ubuntu.png)
- 返回`aarch64`目录,运行`thread-env.sh脚本`,生效环境变量
```shell
source ./thread-env.sh
```
- 如下所示是`aarch64`编译相关的环境变量,运行`scons`前要确保环境变量设置正确
![aarch64_thread](./figures/aarch64_thread.png)
#### RT-Smart
- 点击[下载编译链工具](https://github.com/RT-Thread/toolchains-ci/releases/tag/v1.7)压缩包放置在tools目录下
![aarch64_tools](./figures/aarch64_tools.png)
- 在tools目录下使用tar命令解压缩
```shell
tar jxvf aarch64-linux-musleabi_for_x86_64-pc-linux-gnu_stable.tar.bz2
```
![tar_toolschain](./figures/tar_toolschain.png)
- 返回`aarch64`目录,运行`smart-env.sh`脚本,生效环境变量
```shell
source ./smart-env.sh
```
- 如下所示是`aarch64`编译相关的环境变量,运行`scons`前要确保环境变量设置正确
![aarch64_env](./figures/aarch64_env.png)
- 输入以下指令进行编译,初次编译会拉取`phytium_standalone_sdk工具包`,请确保当前环境下网络畅通
```shell
scons -j8
```
![aarch64_ubuntu_scons](./figures/aarch64_ubuntu_scons.png)
- 完成编译之后目录下将会生成以下几个文件
```
rtthread_a64.bin
rtthread_a64.elf
rtthread_a64.map
```
### RT-Thread env 环境
#### RT-Thread
- 点击[下载编译链工具](https://developer.arm.com/-/media/Files/downloads/gnu/11.2-2022.02/binrel/gcc-arm-11.2-2022.02-mingw-w64-i686-aarch64-none-elf.zip)压缩包放置在tools目录下
- 在tools目录下将下载好的编译链工具压缩包解压
- 返回`aarch32`目录,运行`thread-env.bat`脚本,生效环境变量
```shell
./thread-env.bat
```
- 如下所示是`aarch32`编译相关的环境变量,运行`scons`前要确保环境变量设置正确
![aarch64_env_thread_tools](./figures/aarch64_env_thread_tools.png)
#### RT-Smart
- 点击[下载编译链工具](https://download.rt-thread.org/download/rt-smart/toolchains/aarch64-linux-musleabi_for_i686-w64-mingw32_latest.zip
)压缩包
- 在tools目录下将下载好的编译链工具压缩包解压
![aarch64_env_tools](./figures/aarch64_env_tools.png)
- 运行脚本smart-env.bat脚本脚本生效环境变量
```shell
.\smart-env.bat
```
- 输入以下指令进行编译,初次编译会拉取`phytium_standalone_sdk工具包`,请确保当前环境下网络畅通
```shell
scons -j8
```
![aarch64_env_scons](./figures/aarch64_env_scons.png)
- 完成编译之后目录下将会生成以下几个文件
```
rtthread_a64.bin
rtthread_a64.elf
rtthread_a64.map
```
## 2. 如何选择开发板
>注:在 RT-Thread env 环境下使用`menuconfig`指令即可打开配置菜单在Ubuntu下需要使用`scons --menuconfig`
- 以 E2000Q RT-Thread为例Linux 环境下,运行`make load_e2000d_demo_rtthread`加载默认的 rtconfig, 然后输入下列命令,进入 menuconfig 进一步配置
```shell
scons --menuconfig
```
开发者通过以下选择进行配置
```
Standalone Setting > Board Configuration
```
![board_select](./figures/board_select.png)
## 3. 如何选择驱动
```shell
scons --menuconfig
```
开发者通过以下选项进行驱动的使能
```
Hardware Drivers Config > On-chip Peripheral Drivers
```
![](./figures/select_driver.png)
## 4. 开启SDK中内部调试信息
```shell
scons --menuconfig
```
开发者通过以下选项开启调试信息
![](./figures/debug_info.png)
## 5. 如何切换至 RT-Thread Smart 工作模式
### Ubuntu环境下可使用以下指令加载RT-Smart默认配置
- 以E2000D_DEMO开发板为例
```shell
make load_e2000d_demo_rtsmart
```
### RT-Thread env环境不方便安装make工具可按照以下步骤加载RT-Smart默认配置
1. 查看`makefile`文件,找到`make load_e2000d_demo_rtsmart`
![load_e2000d_rtsmart](./figures/load_e2000d_rtsmart.png)
2. 输入以下指令
```shell
cp ./configs/e2000d_demo_rtsmart ./.config -f
cp ./configs/e2000d_demo_rtsmart.h ./rtconfig.h -f
scons -c
```
## 6. 启动镜像程序
1. 完成配置后使用以下指令进行clean和重新编译
```shell
scons -c
scons -j8
```
2. 按照指导[启动镜像程序](../doc/how_to_flashed_binary.md)