OpenEdv-开源电子网

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

IAP程序移植问题

[复制链接]

6

主题

33

帖子

0

精华

初级会员

Rank: 2

积分
109
金钱
109
注册时间
2016-12-13
在线时间
42 小时
发表于 2017-5-5 09:07:58 | 显示全部楼层 |阅读模式
10金钱
将IAP程序移植到RB上。程序跳转不了APP程序。卡在if(((*(vu32*)(FLASH_APP1_ADDR+4))&0xFF000000)==0x08000000)/
iap程序设置已经改了以下几个点

app程序也已经设置了以下几个点,并将APP程序修改到只有6K。
求大神解答

QQ截图20170505090114.jpg
QQ截图20170505090254.jpg
QQ截图20170505090306.jpg
QQ截图20170505090320.jpg
QQ截图20170505090445.jpg
QQ截图20170505090501.jpg
QQ截图20170505090515.jpg

最佳答案

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

解决了,是这个帖子里的。http://www.openedv.com/forum.php?mod=viewthread&tid=82345&highlight=iap IAP写flash的程序在一页没写完的情况下应该是出现了这个bug。
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

6

主题

33

帖子

0

精华

初级会员

Rank: 2

积分
109
金钱
109
注册时间
2016-12-13
在线时间
42 小时
 楼主| 发表于 2017-5-5 09:07:59 | 显示全部楼层
正点原子 发表于 2017-5-5 18:39
不能丢数据哦,丢数据肯定不行了

解决了,是这个帖子里的。http://www.openedv.com/forum.php ... 5&highlight=iap    IAP写flash的程序在一页没写完的情况下应该是出现了这个bug。
回复

使用道具 举报

6

主题

33

帖子

0

精华

初级会员

Rank: 2

积分
109
金钱
109
注册时间
2016-12-13
在线时间
42 小时
 楼主| 发表于 2017-5-5 10:01:27 | 显示全部楼层
我继续查看了生成的bin文件。在从第5字节开始是080109B9,偏移4字节为什么就通不过if(((*(vu32*)(FLASH_APP1_ADDR+4))&0xFF000000)==0x08000000)。写flash的程序部分我没有改动啊。也是从0x08010000开始写的
QQ截图20170505095104.jpg
回复

使用道具 举报

11

主题

1044

帖子

0

精华

论坛元老

Rank: 8Rank: 8

积分
3725
金钱
3725
注册时间
2011-5-23
在线时间
2013 小时
发表于 2017-5-5 10:32:56 | 显示全部楼层
进入汇编级单步,光看HEX不能证明FLASH里面也是这样的数据,需要直接在仿真里面看memory。
然后看LDR指令读取的地址和读回的数据。
RT-Thread RTOS 音频,WIFI,蓝牙
回复

使用道具 举报

70

主题

6769

帖子

0

精华

论坛大神

Rank: 7Rank: 7Rank: 7

积分
13197
金钱
13197
注册时间
2012-11-26
在线时间
3820 小时
发表于 2017-5-5 11:46:41 | 显示全部楼层
没看到你在代码里修改 向量偏移量啊
学无止境
回复

使用道具 举报

6

主题

33

帖子

0

精华

初级会员

Rank: 2

积分
109
金钱
109
注册时间
2016-12-13
在线时间
42 小时
 楼主| 发表于 2017-5-5 13:59:54 | 显示全部楼层
jermy_z 发表于 2017-5-5 11:46
没看到你在代码里修改 向量偏移量啊

向量偏移已经设置了。我把APP程序单独烧录到0x8010000后面。然后运行iap程序。是可以正确跳转APP程序的。说明是接收或者是写flash时出了问题。
回复

使用道具 举报

6

主题

33

帖子

0

精华

初级会员

Rank: 2

积分
109
金钱
109
注册时间
2016-12-13
在线时间
42 小时
 楼主| 发表于 2017-5-5 16:48:53 | 显示全部楼层
本帖最后由 笙歌余生 于 2017-5-5 17:11 编辑

串口发送完后 我在写flash之前把RAM中的USART_RX_BUF数组的数据在打印出来看了一下。发现没几个字节。似乎是丢失了。但是我的APP程序只有6K。应该是完全装的下。始终弄不明白是哪弄丢的@正点原子 大哥,能帮忙看下吗
QQ截图20170505164227.jpg
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165540
金钱
165540
注册时间
2010-12-1
在线时间
2117 小时
发表于 2017-5-5 18:39:43 | 显示全部楼层
笙歌余生 发表于 2017-5-5 16:48
串口发送完后 我在写flash之前把RAM中的USART_RX_BUF数组的数据在打印出来看了一下。发现没几个字节。似乎 ...

不能丢数据哦,丢数据肯定不行了
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复

使用道具 举报

6

主题

33

帖子

0

精华

初级会员

Rank: 2

积分
109
金钱
109
注册时间
2016-12-13
在线时间
42 小时
 楼主| 发表于 2017-5-9 16:20:35 | 显示全部楼层
正点原子 发表于 2017-5-5 18:39
不能丢数据哦,丢数据肯定不行了

我在写好SRAM之后读取(*(vu32*)(0X20001000+4))的值是正确的0X080109a5,但是经过了写flash之后,再读取(*(vu32*)(FLASH_APP1_ADDR+4))的值,就是0Xf0014770。说明写flash的时候出错了。我的芯片是103RB,例程中写flash部分应该是支持103RB的吧?
回复

使用道具 举报

6

主题

33

帖子

0

精华

初级会员

Rank: 2

积分
109
金钱
109
注册时间
2016-12-13
在线时间
42 小时
 楼主| 发表于 2017-5-9 16:40:23 | 显示全部楼层
正点原子 发表于 2017-5-5 18:39
不能丢数据哦,丢数据肯定不行了

发现问题所在了,我在之前烧录的程序中的0x08010000+4处的值是0Xf0014770,说明IAP程序中写flash未正确执行。相当于没写。但一直没看懂写flash部分错在哪了
回复

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2025-8-21 10:53

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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