2018-06-22 23:11:28 +08:00
|
|
|
|
# amebaz on RT-Thread
|
2018-06-22 23:05:38 +08:00
|
|
|
|
|
2018-10-25 16:36:46 +08:00
|
|
|
|
## 1 简介
|
2018-06-22 23:05:38 +08:00
|
|
|
|
|
2018-10-25 16:36:46 +08:00
|
|
|
|
amebaz 是由Realtek推出的Cortex-M4内核的WiFi SOC芯片,属于rtl8710b系列。硬件特性如下:
|
2018-06-22 23:05:38 +08:00
|
|
|
|
|
|
|
|
|
| 硬件 | 描述 |
|
|
|
|
|
| -- | -- |
|
|
|
|
|
|芯片型号| amebaz |
|
|
|
|
|
|CPU| Cortex-M4 |
|
|
|
|
|
|主频| 125MHz |
|
|
|
|
|
|
2018-10-25 16:36:46 +08:00
|
|
|
|
## 2 编译说明
|
2018-06-22 23:05:38 +08:00
|
|
|
|
|
|
|
|
|
| 环境 | 说明 |
|
|
|
|
|
| ------------ | ------------------------------------------------------------ |
|
|
|
|
|
| PC操作系统 | Linux/MacOS/Windows |
|
2018-10-19 16:45:41 +08:00
|
|
|
|
| 编译器 | arm-none-eabi-gcc version 6.3.1 20170620 (release) |
|
|
|
|
|
| 构建工具 | scons |
|
2018-06-22 23:05:38 +08:00
|
|
|
|
| 依赖软件环境 | Env工具/(IAR或arm-none-eabi-gcc)/git/调试器驱动 |
|
|
|
|
|
|
2018-10-25 16:36:46 +08:00
|
|
|
|
## 3 下载源码
|
2018-06-22 23:05:38 +08:00
|
|
|
|
|
|
|
|
|
```bash
|
|
|
|
|
git clone https://github.com/RT-Thread/rt-thread.git
|
|
|
|
|
```
|
|
|
|
|
|
2018-10-25 16:36:46 +08:00
|
|
|
|
## 4 环境准备
|
2018-06-22 23:05:38 +08:00
|
|
|
|
|
2018-10-25 16:36:46 +08:00
|
|
|
|
### 4.1 Windows 环境准备
|
|
|
|
|
|
|
|
|
|
Windows环境下有两种开发环境,`GCC toolchain` 和 `IAR IDE`,根据不同的需求自行选择。
|
|
|
|
|
|
|
|
|
|
#### 4.1.1 IAR 发开环境
|
|
|
|
|
|
|
|
|
|
IAR 开发环境需要开发者自己安装软件,安装过程这里就不特别说明了。amebaz工程当前仅支持 `IAR 7.X` 的版本。
|
|
|
|
|
|
|
|
|
|
#### 4.4.2 GCC 开发环境
|
|
|
|
|
|
|
|
|
|
GCC开发使用 RT-Thread 官方提供的 env 工具,该工具集成 GCC 工具链,还具有编译构建环境、图形化系统配置及软件包管理功能。
|
|
|
|
|
|
|
|
|
|
下载地址:[点击下载env工具](https://www.rt-thread.org/page/download.html)
|
|
|
|
|
|
|
|
|
|
第一次使用env工具的开发者可以去这里查看教程:[RT-Thread env 工具用户手册](https://www.rt-thread.org/document/site/rtthread-development-guide/rtthread-tool-manual/env/env-user-manual/)。
|
|
|
|
|
|
|
|
|
|
### 4.2 Linux/Mac 环境准备
|
|
|
|
|
|
|
|
|
|
Linux/Mac 仅支持 GCC 工具链。
|
2018-06-22 23:05:38 +08:00
|
|
|
|
|
|
|
|
|
```bash
|
|
|
|
|
cd rt-thread/bsp/amebaz
|
|
|
|
|
scons --menuconfig
|
|
|
|
|
source ~/.env/env.sh
|
|
|
|
|
pkgs --upgrade
|
|
|
|
|
```
|
|
|
|
|
|
2018-10-25 16:36:46 +08:00
|
|
|
|
## 5 配置工程(可选)
|
2018-06-22 23:05:38 +08:00
|
|
|
|
|
2018-10-25 16:36:46 +08:00
|
|
|
|
### 5.1 Windows 配置工程
|
2018-06-22 23:05:38 +08:00
|
|
|
|
|
2018-10-25 16:36:46 +08:00
|
|
|
|
配置工程,需要在相应的工程目录下使用 `menuconfig` 命令打开图形界面,开发者根据自己的需求开关功能组件。
|
2018-06-22 23:05:38 +08:00
|
|
|
|
|
|
|
|
|
```bash
|
2018-10-25 16:36:46 +08:00
|
|
|
|
menuconfig
|
2018-06-22 23:05:38 +08:00
|
|
|
|
```
|
|
|
|
|
|
2018-10-25 16:36:46 +08:00
|
|
|
|
### 5.2 Linux/Mac 配置工程
|
|
|
|
|
|
|
|
|
|
(Linux/Mac)
|
2018-06-22 23:05:38 +08:00
|
|
|
|
|
|
|
|
|
```bash
|
2018-10-25 16:36:46 +08:00
|
|
|
|
scons --menuconfig
|
2018-06-22 23:05:38 +08:00
|
|
|
|
```
|
|
|
|
|
|
2018-10-25 16:36:46 +08:00
|
|
|
|
## 6 更新软件包
|
2018-06-22 23:05:38 +08:00
|
|
|
|
|
2018-10-25 16:36:46 +08:00
|
|
|
|
amebaz 配套的驱动库以 package 形式提供,故需先下载对应的 package(realtek-ameba),在工程目录下,使用下面命令下载软件包。
|
2018-06-22 23:05:38 +08:00
|
|
|
|
|
|
|
|
|
```bash
|
|
|
|
|
pkgs --update
|
|
|
|
|
```
|
|
|
|
|
|
2018-10-25 16:36:46 +08:00
|
|
|
|
## 7 编译
|
|
|
|
|
|
|
|
|
|
### 7.1 Windows 编译工程
|
|
|
|
|
|
|
|
|
|
#### 7.1.1 IAR 编译工程
|
2018-06-22 23:05:38 +08:00
|
|
|
|
|
2018-10-25 16:36:46 +08:00
|
|
|
|
先打开工程目录下的IAR工程(project.eww),然后单击 Project 选项卡,单击 Rebuild All 选项,进行编译
|
2018-06-22 23:05:38 +08:00
|
|
|
|
|
2018-10-25 16:36:46 +08:00
|
|
|
|
![ ](figures/iar_build.png)
|
2018-06-22 23:05:38 +08:00
|
|
|
|
|
2018-10-25 16:36:46 +08:00
|
|
|
|
#### 7.1.2 GCC 编译工程
|
|
|
|
|
|
|
|
|
|
可以使用env编译工程,无需设置GCC工具链路径,直接在 rt-thread/bsp/amebaz 工程目录下输入 `scons` 编译即可。编译完成后,在工程目录下生成 `image2_all_ota1.bin` 文件。
|
|
|
|
|
|
|
|
|
|
```bash
|
|
|
|
|
scons
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
### 7.2 Linux/Mac 编译工程
|
|
|
|
|
|
|
|
|
|
如果没有配置GCC路径的环境变量,则需要使用以下指令设置gcc路径。
|
2018-06-22 23:05:38 +08:00
|
|
|
|
|
|
|
|
|
```bash
|
|
|
|
|
export RTT_EXEC_PATH=[GCC路径]
|
|
|
|
|
```
|
|
|
|
|
|
2018-10-25 16:36:46 +08:00
|
|
|
|
设置 GCC 路径后,使用 `scons` 编译工程。
|
2018-06-22 23:05:38 +08:00
|
|
|
|
|
|
|
|
|
```bash
|
2018-10-25 16:36:46 +08:00
|
|
|
|
scons
|
2018-06-22 23:05:38 +08:00
|
|
|
|
```
|
|
|
|
|
|
2022-10-09 19:08:19 -04:00
|
|
|
|
或者通过 `scons --exec-path="GCC工具链路径"` 命令,在指定工具链位置的同时直接编译。
|
|
|
|
|
|
2018-06-22 23:05:38 +08:00
|
|
|
|
出现下列信息即为编译成功
|
|
|
|
|
|
|
|
|
|
```bash
|
|
|
|
|
LINK rtthread.axf
|
|
|
|
|
arm-none-eabi-objcopy -j .ram_image2.entry -j .ram_image2.data -j .ram_image2.bss -j .ram_image2.skb.bss -j .ram_heap.data -Obinary rtthread.axf ram_2.r.bin
|
|
|
|
|
arm-none-eabi-objcopy -j .xip_image2.text -Obinary rtthread.axf xip_image2.bin
|
|
|
|
|
arm-none-eabi-objcopy -j .ram_rdp.text -Obinary rtthread.axf rdp.bin
|
|
|
|
|
python gen_bin.py
|
|
|
|
|
is_law = 1
|
|
|
|
|
start = 10005000, end = 0, base = 10000000
|
|
|
|
|
Input file size: 65852
|
|
|
|
|
copy size 45372
|
|
|
|
|
start = 10005000, end = 0, base = 10000000
|
|
|
|
|
Input file size: 45372
|
|
|
|
|
copy size 24892
|
|
|
|
|
start = 0, end = 0, base = 0
|
|
|
|
|
Input file size: 336816
|
|
|
|
|
copy size 336816
|
|
|
|
|
size = 361772
|
|
|
|
|
checksum 209b36c
|
|
|
|
|
'true' is not recognized as an internal or external command,
|
|
|
|
|
operable program or batch file.
|
|
|
|
|
Done...
|
|
|
|
|
scons: done building targets.
|
|
|
|
|
```
|
|
|
|
|
|
2018-10-25 16:36:46 +08:00
|
|
|
|
如果编译正确无误,会在工程目录下生成 image2_all_ota1.bin 文件。
|
|
|
|
|
|
|
|
|
|
## 8 烧写及执行
|
2018-06-22 23:05:38 +08:00
|
|
|
|
|
2018-10-25 16:36:46 +08:00
|
|
|
|
### 8.1 IAR下载
|
2018-06-22 23:05:38 +08:00
|
|
|
|
|
2018-10-25 16:36:46 +08:00
|
|
|
|
下载程序分为两部分:
|
2018-06-22 23:05:38 +08:00
|
|
|
|
|
2018-10-25 16:36:46 +08:00
|
|
|
|
(a)先使用jlink工具正确连接A14(CLK),A15(TMS),GND,VCC引脚
|
2018-06-22 23:05:38 +08:00
|
|
|
|
|
2018-10-25 16:36:46 +08:00
|
|
|
|
(b)打开 IAR 工程并完成编译后,单击 Project 选项卡下 Download 选项,选择 Download active application 下载程序。
|
|
|
|
|
|
|
|
|
|
![IAR下载程序](figures/iar_download.png)
|
|
|
|
|
|
|
|
|
|
(c)短按复位按钮,连接串口查看调试信息
|
|
|
|
|
|
|
|
|
|
### 8.2 串口下载
|
|
|
|
|
|
|
|
|
|
串口下载分为三个步骤
|
|
|
|
|
|
|
|
|
|
(a)板子进入下载模式
|
|
|
|
|
|
|
|
|
|
板子使用 `micros usb` 上电,然后按住 `FLASH` 键不放手,短按 `RST` 键,松开 `RST` 和 `FLASH` 键进入下载模式。
|
|
|
|
|
|
|
|
|
|
(b)配置下载工具
|
|
|
|
|
|
|
|
|
|
打开 Image Tool 下载工具配置使用,选择 `micros usb` 所对应的串口端口,选择波特率,默认波特率 1.5Mbps,然后打开串口端口,如下载工具图“①”所示
|
|
|
|
|
|
|
|
|
|
![串口下载程序](figures/image-tool_v2.2.0.png)
|
|
|
|
|
|
|
|
|
|
boot选择工程提供的 `boot_all.bin`, OTA1 选择生成的 image2_all_ota1.bin 文件(通常在工程目录下),并且注意在这两个选项前面打勾确认,其他默认即可,如下载工具图“②”。
|
|
|
|
|
|
|
|
|
|
(c)下载程序
|
|
|
|
|
|
|
|
|
|
按下 Download(如下载工具图 “③”),即可开始下载程序,并且可以从日志窗口查看到下载信息。
|
|
|
|
|
|
|
|
|
|
## 9 运行
|
|
|
|
|
|
|
|
|
|
下载程序后,连接串口(默认使用板子上 `micro usb`),打开串口工具,配置串口波特率 115200,数据位 8 位,停止位 1 位,无校验,无流控;短按 `RST` 键复位,串口将输出调试信息,如下所示:
|
2018-06-22 23:05:38 +08:00
|
|
|
|
|
|
|
|
|
```bash
|
|
|
|
|
\ | /
|
|
|
|
|
- RT - Thread Operating System
|
2018-10-25 16:36:46 +08:00
|
|
|
|
/ | \ 3.1.1 build Oct 25 2018
|
2018-06-22 23:05:38 +08:00
|
|
|
|
2006 - 2018 Copyright by rt-thread team
|
2018-10-25 16:36:46 +08:00
|
|
|
|
lwIP-2.0.2 initialized!
|
|
|
|
|
|
|
|
|
|
Initializing WIFI ...
|
|
|
|
|
LDO Mode, BD_Info: 0
|
2018-06-22 23:05:38 +08:00
|
|
|
|
|
2018-10-25 16:36:46 +08:00
|
|
|
|
LDO Mode, BD_Info: 0
|
2018-06-22 23:05:38 +08:00
|
|
|
|
|
2018-10-25 16:36:46 +08:00
|
|
|
|
WIFI initialized
|
|
|
|
|
[I/WIFI] amebaz_wifi_start success
|
|
|
|
|
build time: Oct 25 2018 10:52:02
|
|
|
|
|
Hello RT-Thread!
|
|
|
|
|
[I/WLAN.dev] wlan init success
|
|
|
|
|
[I/WLAN.lwip] eth device init ok name:w0
|
|
|
|
|
msh >
|
|
|
|
|
```
|
2018-10-19 16:45:41 +08:00
|
|
|
|
|
2018-10-25 16:36:46 +08:00
|
|
|
|
## 10 WIFI简单使用
|
2018-10-19 16:45:41 +08:00
|
|
|
|
|
2018-10-25 16:36:46 +08:00
|
|
|
|
### wifi扫描命令
|
2018-10-19 16:45:41 +08:00
|
|
|
|
|
|
|
|
|
wifi 扫描命令格式如下
|
|
|
|
|
|
2018-10-25 16:36:46 +08:00
|
|
|
|
```bash
|
|
|
|
|
wifi scan
|
2018-10-19 16:45:41 +08:00
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
命令说明
|
|
|
|
|
|
|
|
|
|
| 字段 | 描述 |
|
|
|
|
|
| ---- | ------------------------ |
|
|
|
|
|
| wifi | 有关wifi命令都以wifi开头 |
|
|
|
|
|
| scan | wifi执行扫描动作 |
|
|
|
|
|
|
|
|
|
|
在调试工具中输入该命令,即可进行 wifi 命令扫描,调试信息如下
|
|
|
|
|
|
2018-10-25 16:36:46 +08:00
|
|
|
|
```bash
|
2018-10-19 16:45:41 +08:00
|
|
|
|
scan ap down
|
|
|
|
|
SSID MAC security rssi chn Mbps
|
|
|
|
|
------------------------------- ----------------- -------------- ---- --- ----
|
|
|
|
|
NEO-shanghai-ap2 58:66:ba:a1:ee:71 WPA2_TKIP_PSK -74 11 0
|
|
|
|
|
WQ1 88:25:93:94:51:54 WPA2_AES_PSK -76 13 0
|
|
|
|
|
shyc1 a0:40:a0:a3:e8:c9 WPA2_AES_PSK -77 13 0
|
|
|
|
|
KVIP 70:65:82:3b:71:43 WPA2_AES_PSK -83 11 0
|
|
|
|
|
YST2016 88:25:93:c6:67:d1 WPA2_TKIP_PSK -84 4 0
|
|
|
|
|
```
|
|
|
|
|
|
2018-10-25 16:36:46 +08:00
|
|
|
|
> 注:wifi 有关的命令,均以wifi开头。
|
2018-10-19 16:45:41 +08:00
|
|
|
|
|
2018-10-25 16:36:46 +08:00
|
|
|
|
### wifi 接入
|
2018-10-19 16:45:41 +08:00
|
|
|
|
|
|
|
|
|
接入 wifi 之前,先介绍一下其接入的命令 ,如下
|
|
|
|
|
|
2018-10-25 16:36:46 +08:00
|
|
|
|
```bash
|
|
|
|
|
wifi join ssid 123456789
|
2018-10-19 16:45:41 +08:00
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
命令说明
|
|
|
|
|
|
|
|
|
|
| 字段 | 描述 |
|
|
|
|
|
| --------- | ---------------------------------- |
|
|
|
|
|
| wifi | 有关wifi命令都以wifi开头 |
|
|
|
|
|
| join | wifi执行连接动作 |
|
|
|
|
|
| ssid | 热点的名字 |
|
|
|
|
|
| 123456789 | 热点的密码,没有密码可不输入这一项 |
|
|
|
|
|
|
|
|
|
|
了解上述命令,并且成功完成前面步骤,在串口中输入 `wifi w0 join realthread_VIP 123456789` ,如下日志表示连接成功
|
|
|
|
|
|
2018-10-25 16:36:46 +08:00
|
|
|
|
```bash
|
2018-10-19 16:45:41 +08:00
|
|
|
|
|
|
|
|
|
WIFI wlan0 Setting:
|
|
|
|
|
==============================
|
|
|
|
|
MODE => STATION
|
|
|
|
|
SSID => realthread_VIP
|
|
|
|
|
CHANNEL => 6
|
|
|
|
|
SECURITY => AES
|
|
|
|
|
PASSWORD => 123456789
|
|
|
|
|
[I/WLAN.mgnt] wifi connect success ssid:realthread_VIP
|
|
|
|
|
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
另外,提供一个简单的测试使用命令,查询设备IP地址命令:ifconfig。
|
|
|
|
|
|
2018-10-25 16:36:46 +08:00
|
|
|
|
```bash
|
2018-10-19 16:45:41 +08:00
|
|
|
|
network interface: w0 (Default)
|
|
|
|
|
MTU: 1500
|
|
|
|
|
MAC: 00 e0 4c d5 ac 46
|
|
|
|
|
FLAGS: UP LINK_UP ETHARP BROADCAST
|
|
|
|
|
ip address: 172.16.200.110
|
|
|
|
|
gw address: 172.16.200.1
|
|
|
|
|
net mask : 255.255.255.0
|
|
|
|
|
dns server #0: 172.16.200.1
|
|
|
|
|
dns server #1: 223.5.5.5
|
|
|
|
|
```
|
|
|
|
|
|
2018-10-25 16:36:46 +08:00
|
|
|
|
## 驱动支持情况及计划
|
2018-06-22 23:05:38 +08:00
|
|
|
|
|
|
|
|
|
| 驱动 | 支持情况 | 备注 |
|
|
|
|
|
| ---------- | :------: | :--------------------------: |
|
2018-10-19 16:45:41 +08:00
|
|
|
|
| UART | 支持 | UART0 |
|
|
|
|
|
| WLAN | 部分支持 | 仅支持STA模式 |
|
|
|
|
|
|
2018-10-25 16:36:46 +08:00
|
|
|
|
## 联系人信息
|
2018-06-22 23:05:38 +08:00
|
|
|
|
|
|
|
|
|
维护人:
|
|
|
|
|
[flyingcys][4] < [flyingcys@163.com][5] >
|
|
|
|
|
|
|
|
|
|
[1]: https://www.rt-thread.org/page/download.html
|
|
|
|
|
[4]: https://github.com/flyingcys
|
|
|
|
|
[5]: mailto:flyingcys@163.com
|