请问下,是否有大神研究过C2PROG下载hex文件的过程呢? 我用bushound 抓了下整个的通讯过程,再和hex文件比较,没有看出个所以然来,所以请教下大家,C2PROG 下载hex过程中,这个流程是怎样的呢?分别发送的什么东西呢?是怎么把hex下到芯片的? 小白一只,谢谢了!
PS:知道了这些后,我是想自己做一块板,下面和芯片的SCI-A通讯,上面和PC机以太网通讯,上位机软件再自己做一个界面,这样就可以实现以太网升级下位机的程序了。
This thread has been locked.
If you have a related question, please click the "Ask a related question" button in the top right corner. The newly created question will be automatically linked to this question.
请问下,是否有大神研究过C2PROG下载hex文件的过程呢? 我用bushound 抓了下整个的通讯过程,再和hex文件比较,没有看出个所以然来,所以请教下大家,C2PROG 下载hex过程中,这个流程是怎样的呢?分别发送的什么东西呢?是怎么把hex下到芯片的? 小白一只,谢谢了!
PS:知道了这些后,我是想自己做一块板,下面和芯片的SCI-A通讯,上面和PC机以太网通讯,上位机软件再自己做一个界面,这样就可以实现以太网升级下位机的程序了。
这个没有仔细研究过 我觉得首先要搞清楚hex文件的格式
然后看看烧写的顺序和流程
Hex文件是可以烧录到MCU中,被MCU执行的一种文件格式。如果用记事本打开可发现,整个文件以行为单位,每行以冒号开头,内容全部为16进制码(以ASCII码形式显示)。Hex文件可以按照如下的方式进行拆分来分析其中的内容:
例如 “:1000080080318B1E0828092820280B1D0C280D2854”可以被看作“0x10 0x00 0x08 0x00 0x80 0x31 0x8B 0x1E 0x08 0x28 0x09 0x28 0x20 0x28 0x0B 0x1D 0x0C 0x28 0x0D 0x28 0x54”
第一个字节 0x10表示本行数据的长度;
第二、三字节 0x00 0x08表示本行数据的起始地址;
第四字节 0x00表示数据类型,数据类型有:0x00、0x01、0x02、0x03、0x04、0x05。
'00' Data Rrecord:用来记录数据,HEX文件的大部分记录都是数据记录
'01' End of File Record: 用来标识文件结束,放在文件的最后,标识HEX文件的结尾
'02' Extended Segment Address Record: 用来标识扩展段地址的记录
'03' Start Segment Address Record:开始段地址记录
'04' Extended Linear Address Record: 用来标识扩展线性地址的记录
'05' Start Linear Address Record:开始线性地址记录
然后是数据,最后一个字节 0x54为校验和。
校验和的算法为:计算0x54前所有16进制码的累加和(不计进位),检验和 = 0x100 - 累加和
在上面的后2种记录,都是用来提供地址信息的。每次碰到这2个记录的时候,都可以根据记录计算出一个“基”地址。对于后面的数据记录,计算地址的时候,都是以这些“基”地址为基础的。
这个文件格式有去研究过, 就是不知道 C2PROG 把这个文件下载到芯片之前是否有 下载其他的文件下去。