OpenEdv-开源电子网

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

单片机上电后都干了什么

[复制链接]

5

主题

36

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
208
金钱
208
注册时间
2015-3-14
在线时间
33 小时
发表于 2016-9-19 20:17:17 | 显示全部楼层 |阅读模式
2金钱
在学习原子的iap试验中遇到一些问题和自己的理解麻烦大家看看来讨论讨论。
在bootloder中有这么几个函数
1.if(((*(vu32*)(FLASH_APP1_ADDR+4))&0xFF000000)==0x08000000)//判断是否为0X08XXXXXX.
这个是用来判断串口输入的app是否设置在flash中的
2.if(((*(vu32*)(0X20001000+4))&0xFF000000)==0x20000000)//判断是否为0X20XXXXXX.
这个是用来判断串口输入的app是否设置在ram中的
3.if(((*(vu32*)appxaddr)&0x2FFE0000)==0x20000000)        //检查栈顶地址是否合法.
检查栈顶地址用于跳转到app
因为在app程序中设置IROM1和IRAM1后编译生成的文件中栈顶地址和复位地址的内容都不一样。我查看了一下设置下载到flash中的app他的栈顶和复位内容为0x200008b8,0x801577d
而下载到ram中的为0x2000d7b0和20008785,
问题:1.这是不是就说明下载到flash,复位的入口就在flash中,下载到ram中的复位入口就在ram,而他们的栈顶的内容都是指ram中某个地址。
2.我将bootloder的下载程序地址由原来的0x08000000改为一个值如0x08000200下载进去就没反应复位也没用,单片机就不工作。
这里我猜这个下载地址是不是要和中断向量表的起始位置要一致,好在main函数加入偏移SCB->VTOR = FLASH_BASE | 0x200;发现也不行,大小改小也没反应。
小插曲,(有次我发现点编译,,下进去的和当前的写的程序效果不一样,没运行起来,后来点全部编译下进去才好运行坛友有时要注意了)
3.同样的向量表大小对齐都是4字节为什么栈顶的地址相差这么大内。。。
4.还有我脑海里记得上电后把flash里面的程序搬到ram中运行计算的好像。
不大了解了,诸位仁兄!有没有什么书是讲这个运行机理的,中断向量表的建立,表中地址的内容是指向哪哪之类的解释说明性的书籍

最佳答案

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

其实在《Cortex-M3权威指南》上有介绍过CM3内核上电后的工作,首先加载MSP指针,然后加载复位向量到PC。。。
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

27

主题

711

帖子

0

精华

版主

Rank: 7Rank: 7Rank: 7

积分
12487
金钱
12487
注册时间
2015-11-5
在线时间
2142 小时
发表于 2016-9-19 20:17:18 | 显示全部楼层
其实在《Cortex-M3权威指南》上有介绍过CM3内核上电后的工作,首先加载MSP指针,然后加载复位向量到PC。。。
回复

使用道具 举报

5

主题

36

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
208
金钱
208
注册时间
2015-3-14
在线时间
33 小时
 楼主| 发表于 2016-9-20 21:10:24 | 显示全部楼层
FreeRTOS 发表于 2016-9-19 20:17
其实在《Cortex-M3权威指南》上有介绍过CM3内核上电后的工作,首先加载MSP指针,然后加载复位向量到PC。。 ...

能大概讲解下我的问题么
回复

使用道具 举报

5

主题

36

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
208
金钱
208
注册时间
2015-3-14
在线时间
33 小时
 楼主| 发表于 2016-9-21 10:46:14 | 显示全部楼层
楼主你好,介于楼上没说明白,这里我来回答下问题1和3,栈顶地址 = RW-data + ZI-data 转为16进制加上target里面RAM的起始地址,所以栈顶地址都是在ram中的,这也就说了这个地址是根据RW-data + ZI-data的大小而定的
回复

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2025-5-25 05:12

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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