打印

实际上有16位

[复制链接]
582|11
手机看帖
扫描二维码
随时随地手机跟帖
跳转到指定楼层
楼主
pengf|  楼主 | 2020-8-16 13:06 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
做bootloader时候,看了MPLAB X IDE生成的hex文件,hex文件里面的地址和真实地址是两倍的关系,编译器认为一个FLASH ROM单元的位数是8位,但实际上有16位

使用特权

评论回复
沙发
zhanglli| | 2020-8-16 13:10 | 只看该作者
这个是要在编译器那里配置么

使用特权

评论回复
板凳
bqyj| | 2020-8-16 13:13 | 只看该作者
先烧录进去看看对不对。

使用特权

评论回复
地板
tian111| | 2020-8-16 13:17 | 只看该作者
你只需知道每条指令是14位宽,即每个地址的有效位数为14位

使用特权

评论回复
5
chuxh| | 2020-8-16 13:32 | 只看该作者
"hex文件里面的地址和真实地址是两倍的关系" 这我不太理解,没见到过。
HEX 文件中,第一个字节(8位)是长度,第二,第三字节是长度,第四字节是数据类型,后边的字节都是数据,最后一个是校验和。
做 bootloader, 你读取HEX 文件后,按照地址把对应的数据写到FLASH就可以了,记得校验。

使用特权

评论回复
6
stly| | 2020-8-16 13:36 | 只看该作者
因为PIC16F1的单字指令长度是14bit, 所以, 是由2个8bit 字节的拼起来的.

使用特权

评论回复
7
renyaq| | 2020-8-16 13:40 | 只看该作者
所以, hex中地址是实际地址的两倍..

使用特权

评论回复
8
houcs| | 2020-8-16 13:43 | 只看该作者
这个没法修改配置,

使用特权

评论回复
9
yinxiangh| | 2020-8-16 13:46 | 只看该作者
做bootloader解析hex的时候, 需要自己清楚为啥是这样的, 然后按这个原理解析就行了...

使用特权

评论回复
10
morrisk| | 2020-8-16 13:50 | 只看该作者
自己按照规则解析hex内容即可

使用特权

评论回复
11
pengf|  楼主 | 2020-8-16 13:58 | 只看该作者

好的,我明天去单位试一下,多谢各位大侠了哈        

使用特权

评论回复
12
CoolSilicon| | 2020-8-17 20:41 | 只看该作者
你可以看一下你用的芯片的那个存储器章节, 看一下指令架构,或者字长就明白了..

使用特权

评论回复
发新帖 我要提问
您需要登录后才可以回帖 登录 | 注册

本版积分规则

718

主题

10129

帖子

3

粉丝