zhangyan 842b555358
[bsp/phytium]c++支持,gpio,qspi驱动修改 (#9059)
* GPIO驱动与QSPI驱动适配

* C++支持

* update

---------

Co-authored-by: 张衍 <zhangyan1491@phytium.com.cn>
2024-06-16 15:42:37 +08:00

185 lines
4.9 KiB
Markdown
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

# 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)