5.2:AT应用范例
- PWLINK2(含Lite)、PW400 不支持当前页面所描述的功能,请留意。
- 使用AT 功能需要先对设备开启AT 模式,参考: 设备首选项.
本章节将详细地介绍 PowerWriter AT GUI 相关的软件系统, 用户可以将其作为软件的使用指南, 或者是参考手册, 当遇到不理解的内容时, 可以随时查阅。
软件下载地址:
PowerWriter -> 资料下载 -> 客户端-> PowerWriter AT 应用
1. PowerWriter AT GUI主界面
PowerWriter AT GUI应用软件的启动界面如下图 1.1.1 所示。
2. PowerWriter AT GUI 功能
2.1 添加命令
弹出命令选择界面,如图1.1.1.1AT命令选择界面所示
鼠标单击指定的AT命令,便会将对应的命令添加到命令列表中来,若命令有参数需要设置,命令列表的"AT命令参数"列则会提示“鼠标双击设置或修改参数”,若需要修改AT命令,鼠标双击"AT命令"列即可,如下图1.1.1.2命令列表所示
2.2 插入AT命令
在选中行上方插入一条AT命令。
2.3 命令上移
将选中行AT命令移动至上一行。
2.4 命令下移
将选中行AT命令移动至下一行。
2.5 删除AT命令
将选中行AT命令删除。
2.6 清空AT命令
将命令列表中的AT命令清空。
2.7 导出AT脚本
将命令列表里的AT命令,导出为AT脚本,文件内容格式详见 [1.4 AT脚本文件内容格式](#1.4 AT脚本文件内容格式) 默认文件名为“patscript年-月-日时-分-秒”,文件后缀名为:".patscript",与命令行版本通用,如下图1.1.1.3 AT脚本文件导出所示
2.8 加载AT脚本
将选定的AT脚本文件导入到命令列表中来。
2.9 扫描AT端口
扫描开启了“USB端口AT功能”的PowerWriter,并将扫描到的端口显示到软件界面上,若未扫描到设备,则会提示"未扫描到PowerWriter,请检查设备连接情况",如下图1.1.1.4 AT端口所示
2.10 断开端口连接
断开所有的端口连接,如下图1.1.1.5 断开端口所示
2.11 执行AT命令
各个已连接的端口,多线程并发执行命令列表里的所有命令,每执行完一条命令会打印执行结果,命令执行出错,对应的端口将停止执行命令,并报错。如下图1.1.1.6 命令执行所示
2.12 打印获取信息
勾选“打印获取信息”将把“获取命令”获取到的信息输出到界面,否则不输出。
2.13 覆盖文件
勾选“覆盖文件”将在文件夹“A-COM(x)”中生成文件,否则将在文件夹“COM(x)-日期”中生成文件,如下图 1.1.1.7 查看文件所示。
2.14 查看文件
“获取命令”会将获取到的数据保存至文件,文件路径为Info\A-COM(x)或Info\COM(x)-年-月-日_时-分-秒,点击“查看文件”按钮查看获取命令生成的文件,具体的文件请查看 [1.3 “获取命令”生成的文件](#1.3 “获取命令”生成的文件),如下图 1.1.1.7 查看文件所示
3. 参数设置界面
鼠标双击"AT命令"列,若该命令需要设置参数,则会弹出参数设置界面,不同的命令会显示不同的参数,注:若AT命令是更新"PW配置",还会将设置好的配置保存为json文件,路径为软件根目录\writer_cfg.json。如下图1.2.1 和1.2.2 所示
4. “获取命令”生成的文件
- "查询PW信息"生成文件为:writer_info.json
- "查询PW配置"生成文件为:writer_cfg.json
- "获取目标芯片ID"生成文件为:chip_id.txt
- "读取目标芯片数据"生成文件为:memory.bin
- "读取目标芯片选项字"生成文件为:option_byte.bin
- "查询离线项目信息"生成文件为:project_info.json"
- "广播响应数据"生成文件为:broadcast_rsp.bin"
如下图1.3.1所示
5. AT脚本文件内容格式
AT命令码 命令参数1 参数值1 命令参数2 参数值2
5.1 AT命令码说明
"-info": 查询PW信息
"-cfg":查询PW配置
"-setcfg {-f *.json}":更新PW信息
"-setbaud {-b}":设置AT接口波特率
"-connect":连接目标芯片
"-status":获取目标芯片连接状态
"-cid":获取目标芯片ID
"-read {-addr -s}":读取目标芯片数据
"-erase {-t}":擦除目标芯片
"-erase {-t -addr -s}":擦除目标芯片扇区
"-write" {-addr -f *.bin}:写入目标芯片数据
"-read-ob":读取目标芯片选项字
"-write-vob {-t}":写入目标芯片默认选项字
"-write-uob {-t}":写入目标芯片用户选项字
"-reset -type" :复位目标芯片,默认为3
"-prj-info":查询离线项目信息
"-prj-ld {-f *.pkg} [-pwd]":加载离线项目
"-prj-dis":禁用离线项目
"-start":启动离线烧录
"-factory-sram-fw":运行FactoryTest SRAM 固件
"-factory-flash-fw":运行FactoryTest Flash 固件
"-bcst {-data} | {-f *.txt|*.bin} [-dir] [-kf] [-wtrsp -t]":扩展指令-广播
"-sleep {-t}":睡眠
5.2 AT命令参数说明
"-f":指定读取文件路径和文件名
"-pwd":输入工程密码
"-b":设置波特率
"-type": 设置复位方式,参考 https://docs.powerwriter.com/docs/next/powerwriter_for_arm/reference/ATCommand/#ATCmdTargetReset
"-addr":设置地址(10、16进制)
"-s":设置数据大小(10、16进制)
"-t":超时时间
"-data":设置立即数数据
"-dir":设置广播方向:"usbtouart/uarttousb"
"-kf":是否转发完整的AT 帧结构:"true/false"
"-wtrsp":是否等待广播应答:"true/false"
"-fw-num":hex文件固件的序号,0为起始序号,全部烧录参数为”all“
6. 错误码
- 0.Unknown error ...
- 1.The package crc validation failure...
- 2.The writer product oem does not match...
- 3.The writer is busy now...
- 4.The writer is in use...
- 5.The writer communication handle error...
- 6.The writer configuration error...
- 7.The target flash algorithm config error...
- 8.The target option byte config error...
- 9.The target chip is not connected...
- 10.The target erase failed...
- 11.The target write data failed...
- 12.The target read data failed...
- 13.The package timeout error...
- 14.The extends flash initial failed...
- 15.The extends flash erase failed...
- 16.The extends flash write failed...
- 17.The extends flash verify failed...
- 18.The extends flash read failed...
- 19.The package size error...
- 20.The target chip type error...
- 21.The target read unique id failed...
- 22.The writer update firmware failed...
- 23.The target chip protection is enabled...
- 24.The target write flash failed...
- 25.The target write option byte failed...
- 26.The writer SN error or don't match...
- 27.The target write matrix license failed...
- 28.The target write ICWKEY license failed...
- 29.The project matrix license version error...
- 30.The ICWKEY failed to request a signature...
- 31.The project of offline times has used up...
- 32.The project of version error...
- 33.The project of oem error...
- 34.The project of magic tag error...
- 35.The project of data corruption...
- 36 .The project disabled...
- 37.The package size error...
- 38.The communication port error...
- 39.The communication package error...
- 40.The writer needs to be disconnected from the online connection....
- 41.The communication port send package error...
- 42.The communication port waiting response time out...
- 43.The command is unsupported ...
- 44.The config is(has) null value ...
- 45.The target flash algorithm config error...
- 46.The Incorrect authentication password...
- 47.Disconnect the device and power it on again to complete the upgrade...
- 48.The extends ICWKEY device is not connect...
- 49.The voltage error (abnormal power supply)...
- 50.The debugger is connected...
- 51.The wireless is connecting...
- 52.The serial port check failed...
- 53.The I/O check failed...
- 54.The button check failed...
- 55.The wireless check failed...
- 56.The writer memory error...
- 57.The writer sn is limited ...
- 58.The target unique ID is limited...
- 59.The project file version is too low, please repackage...
- 60.Please connect PowerWriter device first...
- 61.The target FT(CP) validation fails ...
- 62.The target password error(such as KPROM)...
- 63.The target SPI flash not connected(such as NUVOTON) ...
- 64.The target abnormal access detected...
- 65.The target write KPROM failed...
- 66.The target write XOM failed...
- 67.The target write secure setting failed...
- 68.The target write MTP failed...
- 69.The FUS not running ...
- 70.The stack not running ...
- 71.The FUS upgrade error ...
- 72.The stack upgrade error ...
- 73.The FUS state image not found...
- 74.The FUS state image corrupt...
- 75.The FUS state image not authentic...
- 76.The FUS state image not enough space...
- 77.The FUS state user abort...
- 78.The FUS state erase error...
- 79.The FUS state write error...
- 80.The FUS ST authorization tag was not found...
- 81.The FUS custom authorization tag was not found...
- 82.The FUS authorization key locked...
- 83.The FUS UFB corrupt...
- 84.The FUS state other error ...
- 85.The stack type error ...
- 86.The vendor signature is too long
- 87.The vendor signature data is corrupted
- 88.The current target chip has no signature
- 89.Factory test disabled...
- 90.Factory test have no sram firmware...
- 91.Factory test have no flash firmware...
- 92.Write data to target SRAM failed...
- 93.Current baudrate not supported...
- 94.AT Command broadcast direction error ...
- 95.Need keep AT full frame to current receive port...
- 96.The super serial number configuration data is abnormal...
- 97.The super serial number has no remaining data...
- 98.Failed to write the super serial number...
- 99.The firmware loader digest no match...
- 100.Load DFU failed...
- 101.Update firmware(modem) failed...
- 102.Verify failed...
- 103.Reset target chip failed ...
- 104.This target chip has failed to handle BootLoader...
未列出的错误码均为保留。
7. CLI 命令行文档
7.1 不带参数运行命令行软件
直接运行命令行软件,会打印软件的说明和帮助文档,如图2.1和图2.1-2所示,"PowerWriter AT command"是命令软件的名字,">"后面可以输入命令。可输入命令详见[2.3 命令行软件命令](#2.3 命令行软件命令) 。注意:执行所有AT命令前,需先执行"-scan"命令,扫描开启了AT功能的PowerWriter。
7.2 带参数运行命令行软件
可带的参数为一个AT命令码,或.\AT脚本文件,程序会自动执行"-scan"命令,然后再执行输入的参数命令,命令执行完成,程序结束。如下图2.2和图2.3所示:
7.3 命令行软件命令
7.3.1 所有AT脚本命令
详见[1.4 AT脚本文件内容格式](#1.4 AT脚本文件内容格式)。
7.3.2 特有命令
"-scan":扫描开启了AT功能的PowerWriter
"-close":断开所有PowerWriter连接
"-cls":清除屏幕内容
"-q":退出程序
"-print-info {true|false}":是否打印获取命令获取到的信息
"-cover-file {true|false}":是否覆盖获取命令获取到的信息文件
"-info-file":打开"获取命令获取到的信息文件"文件夹
"-log":打开日志文件夹
".\*.patscript":执行AT脚本文件
"-h":帮助
7.3.3 特别说明
Tab键可补全命令,输入".\+文件夹"按Tab键可直接补全.patscript文件,若脚本文件在软件目录,输入".\"再按Tab键可直接补全。
输入了-f参数,Tab键可补全文件
字符串参数可以不使用引号,如-f"sample_files\test.bin"可写成-f sample_files\test.bin。不使用引号时,解析命令以空格为结束标志。
7.4 返回值
0:执行成功,没有错误
1~24:PowerWriter执行命令出错个数
1000:没有扫描到PowerWriter
1001:参数文件(-f的目标文件)不是josn文件格式
1002:参数文件(-f的目标文件)不是bin文件格式
1003:参数文件(-f的目标文件)不是pkg文件格式
1004:参数文件(-f的目标文件)不是txt文件格式
1005:波特率小于等于0
1006:time out小于等于0
1007:参数文件(-f的目标文件)不存在
1008:参数文件(-f的目标文件)为空
1009:json文件数据错误(缺少key)
1010:起始地址小于等于0
1011:数据大小小于等于0
1012:无效字符串命令参数(有效字符串参数为true, false, uarttousb, usbtouart)
2001:命令重复
2002:命令无效
2003:命令参数重复
2004:命令参数二义,2选1参数,两个参数都出现了
2005:命令参数过多
2006:文件格式错误
2007:文件不存在
8. 通过硬件 UART 读取芯片 ID
8.1 适用设备
适用设备为 PW200/PW300。
PWX1 在当前文档时间编写时,不支持 UART 读取芯片 ID,未来会开放 UART 功能。
8.2 准备工作
8.2.1 升级固件
菜单栏帮助,更新软件和固件,升级固件到1.01.31以上。
8.2.2 测试
特别说明:请将擦除方式选为不擦除、接口电平选5V、选项字模式选无操作到无操作,避免不小心按按钮,导致芯片的程序被覆盖!
在设备 PW200 / PW300 拿到手后,使用 PowerWriter 客户端进行设备连接:
- 选择需要读取的芯片型号
- 如提示固件更新,更新固件到 > 1.01.31 ,参考8.2.1
- 参考芯片连接图连接芯片
- 确认芯片接线是否正确(提示目标芯片已连接)
如下图所示:
连接成功后,可以使用PowerWriter客户端的读 ID 功能,尝试读取一下 ID ,如下所示:
8.2.3 启用 AT 功能
在菜单栏、设置、设备首选项中开启 AT 功能(UART)。
8.2.4 加载工程到设备
选择好芯片之后,加载空工程到设备中,如下所示:
由于只需要读取芯片 ID,只需要一个空工程即可,无需添加数据。
8.3 开源 AT API 接入
8.3.1 PowerWriter 开源 AT 源码
参考文档地址:4.3:AT 开源接口 | PowerWriter文档中心,下载源码包,如下图所示:
下载后解压,可以看到如下的目录,其中 source 目录有跨平台的 API 源码:
powerwriter_at_core 为跨平台实现,只需要适配串口收发,以及时间戳实现接口等,即可在几乎所有平台运行,目前提供的 demo 为 windows 版本,其他平台暂未提供 demo,可以参考 powerwriter_at_samples.c 进行实现。
8.3.2 接口集成
8.3.2.1 连接目标芯片
根据以上描述,以及文档手册,直接集成 powerwriter_at_core,参考 sample 进行 API 调用。调用 powerwriter_at_target_connect 发送请求连接目标芯片命令,然后通过 powerwriter_at_target_status 获取目标芯片的连接状态,如果返回连接目标芯片成功,则可以进行下一步参考,如果失败,则重试,如果超时后依然无法连接芯片,请检查接线,确认芯片型号是否正确,必要时联系技术支持。
请求连接的序列为(未加密时):
//50 57 41 54 18 00 00 00 64 00 00 00 04 00 00 00 00 00 00 00 4c 29 75 98
// 固定头部 | 帧长度 |0x64为请求连接|0x04命令长度|命令保留值 | crc32 |
返回值为 ATCmdStatusOK 或者是 ATCmdStatusError(未加密时):
/* OK 命令的帧结构为 */
//50 57 41 54 18 00 00 00 9b ff ff 7f 04 00 00 00 00 00 00 00 93 10 0a 7a
// 固定头部 | 帧长度 |ATCmdStatusOK| 0x04命令长度| 命令保留值 | crc32 |
/* ERROR 命令的帧结构为 */
//50 57 41 54 18 00 00 00 9c ff ff 7f 04 00 00 00 xx xx xx xx xx xx xx xx
// 固定头部 | 帧长度 |ATCmdStatusError| 0x04命令长度| 错误码 | crc32 |
由于连接芯片需要时间,不同的 PCB ,操作环境的不同,返回的事件长短不一,所以,需要有超时等待时间,一般设置5~10 秒(一般情况下,几十ms 就会返回成功),如果返回失败,则多尝试几次,重试几次之后,仍然报错,则表示连接芯片失败,需要检查,必要时请求技术支持。
C语言参考代码如下:
bool powerwriter_at_connect_target(S_ATChannel *channel)
{
bool connect = false;
powerwriter_at_log(LOGD, ">>>Target online bechmark ...\r\n");
/* Init target connnect */
if (!powerwriter_at_target_connect(channel))
{
powerwriter_at_log(LOGE, "[%08X]:powerwriter initial connect target failure ...\r\n",
powerwriter_at_last_error(channel));
return false;
}
powerwriter_at_log(LOGD, "powerwriter initial connect target successfully ...\r\n");
/* Get target status */
uint32_t ts = GetSystemTick();
uint32_t te = ts;
powerwriter_at_log(LOGD, "Target connecting >");
do
{
ATSleep(50);
if (powerwriter_at_target_status(channel))
{
powerwriter_at_log(LOGN, "powerwriter target connected...");
connect = true;
break;
}
powerwriter_at_log(LOGN, ">>");
te = GetSystemTick();
} while (te - ts < 10000);
powerwriter_at_log(LOGN, "\r\n");
return connect;
}
8.3.2.2 读取目标芯片 ID
调用 powerwriter_at_target_id 发送读取目标芯片 ID 命令,如果读取正常,将会返回 ATCmdRspTargetChipID 命令,如果失败,则会返回 ATCmdStatusError (结构见上一节)。
读取目标芯片 ID(未加密时):
//50 57 41 54 18 00 00 00 66 00 00 00 04 00 00 00 00 00 00 00 d3 b7 4e 74
// 固定头部 | 帧长度 |0x66为读取ID | 0x04命令长度 | 命令保留值 | crc32 |
返回值为 ATCmdRspTargetChipID 或者是 ATCmdStatusError(未加密时):
#define PW_TARGET_ID_MAX 16 // Target chip ID MAX size
typedef struct S_ATCmdRspTargetChipID
{
uint8_t m_CIDSize; // Target chip ID size
uint8_t m_CIDData[PW_TARGET_ID_MAX]; // Target chip ID data
} S_ATCmdRspTargetChipID;
/* ATCmdRspTargetChipID */
/*
50 57 41 54 25 00 00 00 67 00 00 00 11 00 00 00 10 32 30 53 41 13 33 32 33 33
固定头部 | 帧长度 |ATCmdRspTargetChipID | 0x11 命令长度|ID 长度|ID 值
22 6e 10 78 b1 01 56 84 6b 94 1e
| CRC32 |
*/
/* Get target id */
S_ATCmdRspTargetChipID m_target_id;
if (!powerwriter_at_target_id(channel, &m_target_id))
{
powerwriter_at_log(LOGE, "[%08X]:powerwriter get target id failure ...\r\n",
powerwriter_at_last_error(channel));
return false;
}
object_print(m_target_id.m_CIDData, m_target_id.m_CIDSize, "Target chip id");
powerwriter_at_log(LOGD, "powerwriter get target id successfully ...\r\n");
8.3.2.3 复位芯片
由于读取芯片 ID 时,会暂停芯片的运行,所以在读取 CID 之后,需要对产品进行功能复位,对设备进行断电,或者手动重启设备,才能恢复产品的功能。
复位目标芯片(未加密时):
//50 57 41 54 18 00 00 00 72 00 00 00 04 00 00 00 03 00 00 00 be ce e5 69
// 固定头部 | 帧长度 |0x72为复位芯片| 0x04命令长度 | E_resetType | crc32 |
返回值为 ATCmdStatusOK 或者是 ATCmdStatusError(未加密时),参考连接芯片时的错误码:
// 复位类型
typedef enum E_resetType
{
HWKeepLow, //硬件复位引脚保持为低
HWNoneReset, //硬件引脚为高阻态
HWReset, //执行硬件复位
HWCoreReset, //执行硬件复位和内核复位
CoreReset, //执行内核复位
VectorReset, //执行向量复位
POROnly, //执行上电重启(必须由PowerWriter 供电才可以)
PORAndRelease, //执行上电复位并释放端口(必须由PowerWriter 供电才可以)
_TARGET_RESET_ = PW_ENUM_MAX
}E_resetType;
/* Reset Target */
#ifdef AT_ONLINE_RESET_TARGET_SAMPLE
if (!powerwriter_at_target_reset(channel, HWCoreReset))
{
powerwriter_at_log(LOGE, "[%08X]:powerwriter AT reset target failure...\r\n",
powerwriter_at_last_error(channel));
return false;
}
powerwriter_at_log(LOGD, "powerwriter AT reset target passed ...\r\n");
/* connect target again */
if (!powerwriter_at_connect_target(channel)) {
return false;
}
#endif
特别说明:如果执行复位操作,将释放 PowerWriter 的资源,以便让目标芯片重启。
8.4 接线示意图
8.4.1 系统接线示意图参考
8.4.2 PowerWriter 设备接口参考
详见 PowerWriter 官方在线手册:2.1:功能参数 | PowerWriter文档中心