现在尝试多级设备一键升级,遇到其中的一个问题:上位机或中转设备如何区分BIN文件?目前的想法是:在BIN文件中添加标识。
例如:#define FLASG_ADDR 0x08010000+1024
const uint32_t binFlag@FLASG_ADDR = 0x00000001;
然后编译,生成BIN文件。
现在的疑问是:
1、我自己尝试过,读取地址FLASG_ADDR中的值,读出来的值不正确。是不是FLASG_ADDR存放着中断服务指针?
2、栈顶地址至用户主程序首地址之间的空间一般有多大?
3、如果我将FLASG_ADDR地址放到后面扇区,例如扇区11。编译时,是从扇区1编译到扇区11吗?
各位老师指点一下,谢谢?
搞定了,可以和大家共享一下。
友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
#define DeviceTypes_Addr 0x08000400 //型号定义地址
#define DeviceTypes {'B','L','C','_','M','2','E'}
unsigned char DeviceType[] __attribute__((at(DeviceTypes_Addr))) = DeviceTypes;
这样就可以在指定地址存放设备型号,
读型号的时候注意地址是0x400,而不是0x08000400
是的。老师您理解我的意思了。
只是读取时,地址为什么变成0x400?为什么读取的不是绝对地址而是偏移地址?
因为你现在是要做判断识别型号啊。上位机或者中间设备接收到的bin文件,只是单纯的二进制数据,假设把接收的数据存在一个大数组里,那型号就正好是0x400的位置,至于你要讲固件写入到flash的具体哪个位置,那是你自己控制的。
一周热门 更多>