目录
很多的工程师,在开发杰理蓝牙芯片的第一步就会有一个很深的疑惑,关于key的
简单理解,key文件就是密码文件,用来加密芯片的。仅此而已,无其他作用
首先,key文件是杰理公司给每家代理商分配的,只有杰理才有权限分配key,一旦分配之后就是固定存在的,不可修改 。
其次key文件一旦烧录到芯片里面之后,就不可修改,不可删除
最后,key文件要写入到芯片里面去,只有两个途径
要明白key的作用,就要先从杰理芯片的整体架构讲起:
==》其中“控制器”这个是杰理公司所设计,大概是才有OTP的机制,就是控制器生产出来就会烧录固定的代码,引导芯片直接去读取外挂的spiflash的内容到ram去执行
==》其中“存储器”是外购的,用来存放用户的程序
==》其实答案,呼之欲出,就是为了降成本
==》因为要在单颗芯片上面实现大容量的rom程序空间,成本是比较高昂的
==》但是如果选择把这些存储空间外扩,用成熟的工艺、低廉的价格的spiflash去代理,这样就是完美的解决了这个问题
==》这里还要引入一个技术,就是虚拟存储映射。早期杰理芯片开发的时候,会有一个切换bank的概念,就是程序执行到一个新的地方,就load对应位置的flash代码到ram里面运行,此时全局变量的定义就要特殊的处理 。但是目前杰理的芯片有了虚拟存储映射之后,就没有切换bank概念了
总结:
正因为这种特殊的机制,就需要密码了,也称之为key文件,其实就是密码。先来说说,不加key有什么隐患
==》假如别人要破解你的程序,只需要拿到你的芯片,开盖,然后把里面的spiflash的bin文件全部读出来,再进行简单的分析,就可以直接破解了 。因为你所有的程序都是在内置的spiflash里面放着的
==》引入key之后的好处:
所以,整个的机制这里就讲明白了,key存在的必要性
这里拿AC695N系列的芯片举例说明
至于key文件获取,需要联系您的供应商直接获取即可
错误:KEY不匹配!!
芯片没有被烧写过KEY,请删除“-key
ERROR: Failed to parse device info, error info:ERR KEY
已复制 个文件。
错误:fw文件中已经存在要添加的文件。
1个文件。
错误:fw文件中已经存在要添加的文件。
==》这个问题,log信息写的很详细了,就是目标芯片没有烧录key 。而你的程序里面加入了key文件,导致不能下载,仅此而已,详见2.4章节,删除加key这个操作即可解决
很多工程师质疑key存在的意义,觉得很麻烦。有这个疑惑只是自己没有深入去理解而已
所以通过这篇文章详细的讲解他的来历,以及存在的必要性,希望能帮助到大家