OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 4638|回复: 11

STM32 IAP加密文件与解密

[复制链接]

6

主题

21

帖子

0

精华

初级会员

Rank: 2

积分
92
金钱
92
注册时间
2014-6-19
在线时间
16 小时
发表于 2017-3-26 17:58:57 | 显示全部楼层 |阅读模式
5金钱
我查看了不少资料,终于学会将二进制文件加密与解密了。但在进行USB升级时犯难了。由于对USB ISP的DFU文件生成和下载不是很了解,如果要摸清楚又要花费一堆时间,我偷了一下懒。我用IAR生成二进制文件,然后加密。之后直接用STM的DFU文件生成器生成DFU文件。在USB升级的bootloader程序中我仅找到 FLASH_ProgramWord(**)位置,在该程序前面将其需要烧写的缓冲进行解密。结果我进行升级的时候,DFU擦除缓冲后连直接停在0%位置了。请问谁能指导一下我,是不是我加密和解密的地方搞错了?网上只能找到USART的加密解密例程,作用不大

最佳答案

查看完整内容[请看2#楼]

写入数据前就应该解密,接收到数据就验证 ,完毕后就解密,然后调用FLASH_ProgramWord()函数写入flash
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

120

主题

7878

帖子

13

精华

资深版主

Rank: 8Rank: 8

积分
12012
金钱
12012
注册时间
2013-9-10
在线时间
427 小时
发表于 2017-3-26 17:58:58 | 显示全部楼层
写入数据前就应该解密,接收到数据就验证 ,完毕后就解密,然后调用FLASH_ProgramWord()函数写入flash
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165538
金钱
165538
注册时间
2010-12-1
在线时间
2117 小时
发表于 2017-3-27 00:50:21 | 显示全部楼层
帮顶
回复

使用道具 举报

6

主题

21

帖子

0

精华

初级会员

Rank: 2

积分
92
金钱
92
注册时间
2014-6-19
在线时间
16 小时
 楼主| 发表于 2017-3-27 17:01:23 | 显示全部楼层
八度空间 发表于 2017-3-27 12:36
写入数据前就应该解密,接收到数据就验证 ,完毕后就解密,然后调用FLASH_ProgramWord()函数写入flash

谢谢。我想详细了解下,我先加密然后生成DFU文件的过程应该没错吧。DFU文件里面肯定包括一些说明信息不需要解密的,所以需要程序去“验证”或者说是“辨别”了。但这部分东西好像很难理清,我现在用的是USB OTG的IAP程序,程序看的我头晕。所以我才想着需要FLASH_ProgramWord()的信息才是需要解密的,我直接在这个程序前解密。估计这样做应该有问题,不知您熟不熟悉这部分东西,我应该在哪里辨别哪部分数据需要解密呢?
回复

使用道具 举报

120

主题

7878

帖子

13

精华

资深版主

Rank: 8Rank: 8

积分
12012
金钱
12012
注册时间
2013-9-10
在线时间
427 小时
发表于 2017-3-27 20:32:39 | 显示全部楼层
ccd007 发表于 2017-3-27 17:01
谢谢。我想详细了解下,我先加密然后生成DFU文件的过程应该没错吧。DFU文件里面肯定包括一些说明信息不需 ...

直接写入flash,不解密呢
现在,程序把烂铜烂铁变得智能化了,人呢,一旦离开了这烂铜烂铁就不知道干啥了
回复

使用道具 举报

120

主题

7878

帖子

13

精华

资深版主

Rank: 8Rank: 8

积分
12012
金钱
12012
注册时间
2013-9-10
在线时间
427 小时
发表于 2017-3-28 08:58:03 | 显示全部楼层
ccd007 发表于 2017-3-27 17:01
谢谢。我想详细了解下,我先加密然后生成DFU文件的过程应该没错吧。DFU文件里面肯定包括一些说明信息不需 ...

我记得,使用官方的那个DFU的话,调用写入flash前就解密了的,你只管写入数据到flash就可以了,你也可以查查相关的资料,或者研究一下官方的源码什么的
现在,程序把烂铜烂铁变得智能化了,人呢,一旦离开了这烂铜烂铁就不知道干啥了
回复

使用道具 举报

6

主题

21

帖子

0

精华

初级会员

Rank: 2

积分
92
金钱
92
注册时间
2014-6-19
在线时间
16 小时
 楼主| 发表于 2017-3-28 11:22:33 | 显示全部楼层
我几经测试修改,发现在读入时解密时无效。最终还是在写入flash前进行解密,最后成功了。早期的程序可能中间什么地方存在BUG,所以导致升级失败。后来重新编写时又成功了,想检讨以前的程序,没有保存,所以无法验证了。
回复

使用道具 举报

0

主题

6

帖子

0

精华

新手入门

积分
18
金钱
18
注册时间
2017-4-11
在线时间
3 小时
发表于 2017-4-11 17:26:53 | 显示全部楼层
楼主怎么实现的呢,分享下呗,谢谢
回复

使用道具 举报

2

主题

9

帖子

0

精华

初级会员

Rank: 2

积分
61
金钱
61
注册时间
2016-10-9
在线时间
8 小时
发表于 2017-4-11 23:23:58 | 显示全部楼层
好高深 不懂
回复

使用道具 举报

2

主题

14

帖子

0

精华

初级会员

Rank: 2

积分
98
金钱
98
注册时间
2017-8-11
在线时间
21 小时
发表于 2017-12-7 18:19:14 | 显示全部楼层
ccd007 发表于 2017-3-28 11:22
我几经测试修改,发现在读入时解密时无效。最终还是在写入flash前进行解密,最后成功了。早期的程序可能中 ...

楼主的意思是 将 .hex文件加密处理。让后直接有加密的 .hex文件生成 .Dfu文件 然后解密烧录到flash中?最后正常?
回复

使用道具 举报

1

主题

63

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1820
金钱
1820
注册时间
2015-11-30
在线时间
255 小时
发表于 2017-12-21 10:15:45 | 显示全部楼层
正好也在了解这部分 ,先学习了。
回复

使用道具 举报

69

主题

495

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
2197
金钱
2197
注册时间
2015-11-14
在线时间
542 小时
发表于 2017-12-21 10:19:26 | 显示全部楼层
楼主的学习资料可以分享一下不
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2025-6-15 14:43

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表