OpenEdv-开源电子网

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

在IAP编程中,每次程序运行到FLASH_ErasePage(uint32_t Page_Address)函数时,就会死机

[复制链接]

17

主题

54

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
310
金钱
310
注册时间
2016-7-1
在线时间
94 小时
发表于 2017-6-14 10:59:25 | 显示全部楼层 |阅读模式
5金钱
在IAP编程中,每次程序运行到FLASH_ErasePage(uint32_t Page_Address)函数时,就会死机。再重新上电,但程序就不能启动了。必须再重新烧写bootloader才可以运行。只要再运行到擦除函数,程序还回死掉!!!!问题已经困扰好久了。之前怀疑过是进行擦除的时候,误擦除了bootloader那部分代码。但是在地址设置上,设置bootloader的地址是0x08000000,APP的起始地址是0x08002c00,没冲突的!!请大神们帮我分析一下,可能导致问题的原因!!!谢谢,谢谢!!!()

int Config_FlashWrite( u8 *data,u16 len)
{
    u16 temp_data; //= (u16 *)data;
    u16 i = 0;
    vu32 temp_addr;
    Config_FlashStart(); //
    DBG_print(DBG_DEBUG, "pass Config_FlashStar1");
    if(flash_program_addr>APP_END)
    {
        DBG_print(DBG_DEBUG, "ERR! flash_program_addr<%lx> = APP_END<%lx>", flash_program_addr,APP_END);
        return ERROR;
    }
    DBG_print(DBG_DEBUG, "pass Config_FlashStar2");
    FLASH_ErasePage(flash_program_addr);


    DBG_print(DBG_DEBUG, "pass FLASH_ErasePage");
    temp_addr = flash_program_addr;
    for (  ;temp_addr < (flash_program_addr + len); i+=2, temp_addr += 2)
    {
        temp_data = data|(u16)data[i+1]<<8;
        DBG_print(DBG_DEBUG, "fw %lx = %x",temp_addr,temp_data);
       FLASH_ProgramHalfWord(temp_addr, temp_data);
        DBG_print(DBG_DEBUG, "fr %lx = %x",temp_addr,*(vu16 *)temp_addr);
        if(temp_data != *(vu16 *)temp_addr)
        {
            DBG_print(DBG_DEBUG, "Flashwrite fail");
            return ERROR;
        }                                                                             
    }                                                                              
    DBG_print(DBG_DEBUG, "flash_program_addr");
    return  CORRECT;
}





360反馈意见截图16210606719174.jpg
360反馈意见截图1617111290109130.jpg
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

43

主题

481

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1352
金钱
1352
注册时间
2014-12-24
在线时间
321 小时
发表于 2017-6-14 13:43:32 | 显示全部楼层
回复

使用道具 举报

38

主题

196

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1179
金钱
1179
注册时间
2015-11-9
在线时间
249 小时
发表于 2017-6-14 14:35:49 | 显示全部楼层
擦除最小单位是以页为单位,你的Bootload代码只有10K,计算擦除起始页的时候是不是计算成了bootload所在页???建议你查一下
回复

使用道具 举报

17

主题

54

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
310
金钱
310
注册时间
2016-7-1
在线时间
94 小时
 楼主| 发表于 2017-6-14 14:43:54 | 显示全部楼层
jinggx 发表于 2017-6-14 13:43
地址必须page align

给擦除那个函数传入的地址就是第11K的起始地址
回复

使用道具 举报

17

主题

54

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
310
金钱
310
注册时间
2016-7-1
在线时间
94 小时
 楼主| 发表于 2017-6-14 14:44:41 | 显示全部楼层
shibinjie 发表于 2017-6-14 14:35
擦除最小单位是以页为单位,你的Bootload代码只有10K,计算擦除起始页的时候是不是计算成了bootload所在页 ...

擦除起始页的地址传入的是APP的起始地址
回复

使用道具 举报

38

主题

196

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1179
金钱
1179
注册时间
2015-11-9
在线时间
249 小时
发表于 2017-6-14 16:19:46 | 显示全部楼层
carey32 发表于 2017-6-14 14:44
擦除起始页的地址传入的是APP的起始地址

那不就被擦掉了嘛
回复

使用道具 举报

17

主题

54

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
310
金钱
310
注册时间
2016-7-1
在线时间
94 小时
 楼主| 发表于 2017-6-18 09:38:03 | 显示全部楼层
jinggx 发表于 2017-6-14 13:43
地址必须page align

死机的问题找到了,但是没解决的了!!!之所以运行到FLASH_ErasePage这个函数就死机,是因为在对函数里面有对“FLASH->AR= Page_Address”,但是通过打印信息看到,Page_Address的值赋不到FLASH->AR里面去,所以FLASH->AR的值一直是0,然后擦除就从0开始擦除了,烧进去的bootloader也就被擦出了,导致死机,APP代码就没法写入,。现在还没有发现导致FLASH->AR写不进去页擦除地址的原因(书上说,在BSY位为1时,不能写FLASH->AR这个寄存器,但在打印FLASH->AR的值得同时也打印了FLASH->SR的值,发现SR的BSY 位并不处于忙的状态,然后现在就没找到其它导致FLASH->AR写不进去的原因了
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165540
金钱
165540
注册时间
2010-12-1
在线时间
2117 小时
发表于 2017-6-18 18:56:56 | 显示全部楼层
我们不是有IAP例程么?
参考下我们例程,分分钟解决了。
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2025-8-18 04:05

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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