V'TBt=!=] 原创:ICCCCC
?v8.3EE1\o $g? ]9}p 前言:
. 7WNd/WG ktX\{g! U ]6)^+(zU Ax &Z= 一、开箱
Y'tPD#|r 4%#Y)zo.e %Wy$m?gD NzB"u+jB eZpyDw C{ ;{mKt%# c*LB=;npI Q;A1&UA2 二、在线仿真测试
fLM5L_S}Y ._2#89V 测试环境:MDK v5.30
:l~^un|<2Y C+\c(M a 测试芯片:STM32F429BIT6
akg$vHhK4 &&Ruy(&]I 建立测试工程项目过程略过,直接进入设置,仿真设备选择CMSIS-DAP,如下所示:
aH7i$U& H+Dv-*i c^ $_epc* NN(ZH73 点击Settings进行设置,如下所示:
dqd:V$o [-}LEH1[p QN`K|,}H^ R+vago: v%gkQa ^2C)Wk$ <Uj~S 5[<"_ /SDN7M]m! @'UbTB! Pack选项,可以使能或者不使能,如果异常就切换。
fyYHwG zJC!MeN 都设置好,回到主界面,点击下载,如下所示:
tf?syk+jB7 V`*N2ztSL SMX70T!'9 J_PAWW [img]https://z3.ax1x.com/2021/10/28/5bhwDO.png[/img]
L9(mY `d>" HLMcOuj 下载成功。点击主界面Debug按钮,进入仿真状态,如下所示:
88%7 >TZ 'V, [img]https://www.z4a.net/images/2021/10/28/40.png[/img]
)S41N^j. LIzdP,^pc [img]https://z3.ax1x.com/2021/10/28/5bhDVe.png[/img]
2>%|PQ -!d'!;
] 全速运行,一切正常,点击暂停,可以正常查看各种变量数据等。
1+wmR4o 8:* [img]https://z3.ax1x.com/2021/10/28/5bh0bD.png[/img]
8%C7!l q ./SDZ:5/ 测试环境:MDK v5.30
c8uFLM j aMaICM 测试芯片:STM32H743XIH6
-*`7Q'}% KZ8Hp=s 测试组件:EventRecorder
vTE3-v[i 4yOYw*X Debug配置上差不多,需要注意的是Trace选项里的Clock要跟目标单片机时钟一致,如下所示:
UZJ^e$N ']Q4SB"q [img]https://z3.ax1x.com/2021/10/28/5bhrUH.png[/img]
n=t50/jV3= 3y#0Lb-y 配置好后进入仿真状态,全速运行,时间测试及printf正常显示,代码执行时间准确,10MHz的带宽完全满足,效果如下所示:
`6bIxb{ IXjFK [img]https://z3.ax1x.com/2021/10/28/5bhc8I.png[/img]
1Q[I $=-F O9%`G [img]https://z3.ax1x.com/2021/10/28/5bhs5d.png[/img]
B49:
R> {J#SpG 7 在线仿真完结。
z;T_%?u ..FEyf 三、UID加密操作
^,W;dM2 EI+RF{IKh UID 加密设置是创芯工坊研发的目前市面上烧录器在授权控制上较为强大的加密版本,不但提供了随机的内置离线授权方法,一键生成动态的项目代码,同时提供了在线授权服务器(目前市面上提供此功能的只有 Segger 的 Secure Flash)支持第三方基于创芯工坊提供的授权服务器模板自建授权服务器,支持在线非对称授权方案,创芯工坊技术团队提供全程技术支持,支持离线 ICWKEY ECDSA非对称授权算法。
dJvT2s.t[ FA5|` [img]https://z3.ax1x.com/2021/10/28/5bh6PA.png[/img]
rlUo# <Wd#HKIG>l 本次先使用<内置离线授权>,芯片使用STM32F429BIT6,配置如下:
rV6&: \ zG
IxmJ. [img]https://z3.ax1x.com/2021/10/28/5bhg2t.png[/img]
1Ce7\A NUSb7<s,&Y 密钥储存地址在芯片flash最后倒退12字节位置,密钥长度选择12字节,小端模式。点击UID矩阵编码按钮,打开窗口如下所示:
,"6Bw|s FM{^ND9x [img]https://z3.ax1x.com/2021/10/28/5bhWKf.png[/img]
Oy(fh%k# hJ~Na\?w [img]https://www.z4a.net/images/2021/10/28/16353823221.png[/img]
=@e3I)D#?i m5c=h [img]https://z3.ax1x.com/2021/10/28/5bh2xP.png[/img]
}%^N9AA8 =&%}p[
3g 导出源码:导出源码功能将用户设置好的信息,导出为 MDK Source Code(如果用户 IDE 为其他格式,请包含对应的源码和头文件即可使用),导出的源码 Demo 如下图所示:
4gR;,%E\TO sd5%S zx [img]https://z3.ax1x.com/2021/10/28/5bhfr8.png[/img]
e3o?=; `!BP.-Zv 主要文件就是cortex_chipid_binding.c与cortex_chipid_binding.h,本小节只讲使用,不解析程序。
.wH`9aq;5@ B/Jz$D 编译并保存:编译并保存功能将用户设置好的 Power Writer 内置授权功能同步到PowerWriter 硬件,同时导出源码供用户使用。
>:C0ZQUW H$D),s
gv 其他选项请根据自己需求配置,保存项目为f429bit6uid.pkg。
CG[2 0^lCZ,uq; 准备个正常的MDK项目,复制cortex_chipid_binding.c与cortex_chipid_binding.h到项目下,打开工程,如下所示:
asEk3 Z;v5L/; 使用的是安富莱电子的例子,板子是V6开发板。
azK7kM~ HB|R1<t;HB [img]https://z3.ax1x.com/2021/10/28/5bhhqS.png[/img]
1>~bzXY# #uRj9|E7 main.c文件加入#include "cortex_chipid_binding.h"头文件,打开工程选项,C/C++里选择C99模式,因为导出的代码编写方式是变量就近定义,默认的C89是不支持这种骚写法,如下所示:
z D "n7; !=uaB. [img]https://z3.ax1x.com/2021/10/28/5bh5Vg.png[/img]
%P8*Az&]T +aY]?] [img]https://z3.ax1x.com/2021/10/28/5bhIaQ.png[/img]
RpmOg
[I~&vLTe 全项目编译,报如下错误:
<cof `jHbA #sO .\Flash\Obj\output.axf: Error: L6220E: Load region LR_IROM1 size (2097232 bytes) exceeds limit (2097152 bytes). Region contains 2087436 bytes of padding and 0 bytes of veneers (total 2087436 bytes of linker generated content).
"O}u2B b 8]@$7hy8 意思是数据越界了,查看代码发现是cortex_chipid_binding.c里的指定了一个地址,这个地址就是存放密钥的地址,本意是告诉编译器我要占用12字节空间,可是编译器编译时还在这个位置后面放了代码,所以导致越界。
)~X.x"}8k M6nQ17\{ const static char mKey[UID_KEY_LENGTH] __attribute__((section(UID_KEYADDR_INNER)))
\\R$C QsemN7B"< 解决方法就是禁止这行代码,把cortex_chipid_binding.h的UID_KEYADDR_PLACEHOLDER_EN宏设置为0,如下所示:
5%r:hO @S ?Yf0h_> #define UID_KEYADDR_PLACEHOLDER_EN 0 //Key Store Addr In Flash Enable/Disable Placeholder
T]_]{%z =Ch^;Wyt 再次编译通过,在main.c文件里加上密钥判断,代码如下:
NIo!WOi )44c[Z [img]https://z3.ax1x.com/2021/10/28/5bh7Ps.png[/img]
cFD3 m%ec=%L9 再次编译无错误,加载编译好的程序到烧录器,如下所示:
`erKHZ]S n0a|GZyO] [img]https://z3.ax1x.com/2021/10/28/5bho5j.png[/img]
c1Rn1M,2k * :kMv;9 保存项目,在线烧录到目标单片机,如下所示:
6 2*p*t MlKSjKl" ! [img]https://z3.ax1x.com/2021/10/28/5bhHGn.png[/img]
IGnP#@`5] Be$v%4 开发板运行跑马灯,说明密钥校验通过。
;2y4^ A<szY92&5 四、创芯工坊发布固件
,K WIuCU; urbSprdF 这个应用是创芯工坊平台的一大核心功能,也是一大创新。简单来讲就是为开发者和使用者提供一个平台,开发者在平台上发布程序,使用者购买然后烧录程序。
`=Z3X(Kc <q`'[1Y4 这节我们来看批量离线模式,适用于大批量烧录。
.ZtW
y) U -I0J-~# 打开创芯工坊官网www.icworkshop.com,登陆账号,进入用户中心,如下所示:
ln1!%B; <jAn~=Uq[, [img]https://z3.ax1x.com/2021/10/28/5bhb2q.png[/img]
zG*
>g Q8H+=L: 点击我是开发者,如下所示:
:pH3M[7 ''Y'ZsQ; [img]https://z3.ax1x.com/2021/10/28/5bhqx0.png[/img]
B?nw([4m fxQ4kiI 点击程序发布,如下所示:
pw.K,?kYr {j8M78 }3 [img]https://z3.ax1x.com/2021/10/28/5bhOMV.png[/img]
8a8CY,n{ _
?o>i/ 为了方便测试,价格选择赠送,指定对象就是使用者账号。
?hmuAgOtbh +RBX2$kB [img]https://z3.ax1x.com/2021/10/28/5bhjqU.png[/img]
_LSp \{Z 14pyHMOR 型号根据自己项目单片机来选,pkg文件是使用pw软件打包好的文件,这里继续使用上节打包的文件。固件密钥是指pw打包时的密码,一定要正确,否则无法解析文件,编程模式选择离线。点击确认发布即可。
\1ncr4 ]N;\AXZ7 [img]https://z3.ax1x.com/2021/10/28/5bhXrT.png[/img]
91#rP|88; ,,c+R?D 使用者需要下载创芯工坊客户端,如下所示:
H~NK:qRzK =]fOQN` [img]https://www.z4a.net/images/2021/10/28/32.png[/img]
V(5*Dn84 }&LVD$Bz [img]https://z3.ax1x.com/2021/10/28/5bhxZF.png[/img]
_C3O^/<n4V e>T;'7HSS" 安装后登陆账号,如下所示:
LrH"d T
-p~8=I [img]https://www.z4a.net/images/2021/10/28/34.png[/img]
@P)2ZGG /(u# D[ 第一个既是我们刚才推送的程序,连接好PW200烧录器,点击下载固件,如下所示:
O))YJh"'_ C=Tq/L w [img]https://www.z4a.net/images/2021/10/28/35.png[/img]
wnU-5r&!] j Gp&P [img]https://www.z4a.net/images/2021/10/28/16353821721.png[/img]
*djVOC ]~:WGo=_ [img]http://changhee.cn/data/attachment/forum/202110/28/083538bgddg93242y3kkng.png[/img]
Ya
`$.D Sby(?yg [img]https://www.z4a.net/images/2021/10/28/16353819001.png[/img]
5X73@Aj tbXl5x0 这里测试的芯片是STM32F429BIT6,FLASH容量为2MB,SN位置我们放在0x081FFFFC地址,占用4字节。序列号初值我们设置为0x00000001,为了方便验证SN写入成功与否,选项字节的读保护设置为无保护,如下所示:
3;JF5e\?x 9RPZj>ezjA [img]http://changhee.cn/data/attachment/forum/202110/28/083538cs1b32gwtnnr85bw.png[/img]
{)n@Rq\=v -A,UqEt 点击执行里的全功能自动编程,操作如下所示:
(M 2hK[ /.WIED}> [img]https://www.z4a.net/images/2021/10/28/38.png[/img]
eg1Mdg\a >{)\GK0i7 现在我们来读取0x081FFFFC地址数据,操作如下所示:
P''>wjMH0 w
m|WER*. [img]http://changhee.cn/data/attachment/forum/202110/28/083542coout9zf5dohdoki.png[/img]
8#nAs\^ wEF"'T 成功读取到0x00000001,为什么是01 00 00 00?因为使用小端储存模式。
~p`[z~| 0j :u.x 结语:
60G(jO14 V!Pe%.> 时间有限,只测了小部分功能,不得不说power writer确实很强大,不管是烧录安全还是烧录速度方面,都表现非常不错,基本满足了工程师开发调试的所有要求。而且还支持STM32、STM8、GD32等十几个品牌芯片。还是非常值得推荐的。