xiaojuren

    1. losingamong 发表于 2011-6-24 01:26 在STM32微控制器上实现IAP程序之前首先要回顾一下STM32的内部闪存组织架构和其启动过程。STM32的内部闪存地址起始于0x8000000,一般情况下,程序文件就从此地址开始写入。此外STM32是基于Cortex-M3内核的微控制器,其内部通过一张“中断向量表”来响应中断,程序启动后,将首先从“中断向量表”取出复位中断向量执行复位中断程序完成启动。而这张“中断向量表”的起始地址是0x8000004,当中断来临,STM32的内部硬件机制亦会自动将PC指针定位到“中断向量表”处,并根据中断源取出对应的中断向量执行中断服务程序。最后还需要知道关键的一点,通过修改STM32工程的链接脚本可以修改程序文件写入闪存的起始地址。         在STM32微控制器上实现IAP方案,除了常规的串口接收数据以及闪存数据写入等常规操作外,还需注意STM32的启动过程和中断响应方式。图1显示了STM32常规的运行流程。                     图1 对图1解读如下: 1、        STM32复位后,会从地址为0x8000004处取出复位中断向量的地址,并跳转执行复位中断服务程序,如图1中标号○1所示。 2、        复位中断服务程序执行的最终结果是跳转至C程序的main函数,如图1中标号○2所示,而main函数应该是一个死循环,是一个永不返回的函数。 3、        在main函数执行的过程中,发生了一个中断请求,此时STM32的硬件机制会将PC指针强制指回中断向量表处,如图1中标号○3所示。 4、        根据中断源进入相应的中断服务程序,如图1中标号○5所示。 5、        中断服务程序执行完毕后,程序再度返回至main函数中执行,如图1中标号○6所示。 若在STM32中加入了IAP程序,则情况会如图2所示。                      图2 对图2的解读如下: 1、        STM32复位后,从地址为0x8000004处取出复位中断向量的地址,并跳转执行复位中断服务程序,随后跳转至IAP程序的main函数,如图2中标号○1、○2所示。这个过程和图1相应部分是一致的。 2、        执行完IAP过程后(STM32内部多出了新写入的程序,图2中以灰色底纹方格表示,地址始于0x8000004+N+M)跳转至新写入程序的复位向量表,取出新程序的复位中断向量的地址,并跳转执行新程序的复位中断服务程序,随后跳转至新程序的main函数,其过程如图2的标号○3所示。新程序的main函数应该也具有永不返回的特性。同时应该注意在STM32的内部存储空间在不同的位置上出现了2个中断向量表。 3、        在新程序main函数执行的过程中,一个中断请求来临,PC指针仍会回转至地址为0x8000004中断向量表处,而并不是新程序的中断向量表,如图2中标号○5所示。注意到这是由STM32的硬件机制决定的。 4、        根据中断源跳转至对应的中断服务,如图2中标号○6所示。注意此时是跳转至了新程序的中断服务程序中。 5、        中断服务执行完毕后,返回main函数。如图2中标号○8所示。 从上述两个过程的分析可以得知,对将使用IAP过程写入的程序要满足2个要求: 1、新程序必须从IAP程序之后的某个偏移量为x的地址开始; 2、必须将新程序的中断向量表相应的移动,移动的偏移量为x; 而设置程序起始位置的方法是(keil uvision4集成开发环境)在工程的“Option for Target….”界面中的“Target”页里将“IROM”的“Start”列改为欲使程序起始的地方,如图3中将程序起始位置设为0x8002000。                                                                                                             图3 将中断向量表移动的方法是在程序中加入函数: void NVIC_SetVectorTable(u32 NVIC_VectTab, u32 Offset); 其中参数NVIC_VectTab为中断向量表起始位置,而参数Offset则为地址偏移量,如将中断向量表移至0x8002000处,则应调用该函数如下: void NVIC_SetVectorTable(0x8000000, 0x2000); 同时有必要提醒读者注意的是,此函数只会修改STM32程序中用于存储中断向量的结构体变量,而不会实质地改变中断向量表在闪存中的物理位置,详情请研究该程序原型。 有了以上准备后就可以着手设计一个IAP方案了,如下: 1、STM32复位后,利用一个按键的状态进行同步,当按键按下时表示将要进行IAP过程; 2、IAP过程中,通过上位机软件向STM32的USART1设备发送所要更新的程序文件,STM32接收到数据后转而从0x8002000地址开始写入收到的数据; 3、STM32借助定时器来判断数据是否完全接收,完全接收后IAP过程结束; 4、再次复位后,跳转0x8002004地址开始运行新写入的程序; 最后提出几点注意事项: 1、具体实现的工程见附件; 2、利用IAP写入的程序文件最好是.bin格式的文件,但不能是.hex格式的文件; 3、向STM32发送程序文件时尽量慢一些,因为STM32对FLASH的写入速度往往跟不上通讯外设接口的速度; 4、建议在STM32和上位机之间设计一套握手机制和出错管理机制,这样可以大幅提高IAP的成功率; 5、附件中的IAP工程具体运行现象为,按着连接于GPIOA.0引脚上的按键后对STM32进行复位操作,若连接于GPIOA.4引脚上的LED被点亮则表示进入了IAP程序,等待从USART1接口传入欲更新的程序文件。程序文件更新完毕后,LED被熄灭。此时再度对STM32进行复位,就开始运行新写入的程序了。 [ 本帖最后由 losingamong 于 2011-6-24 01:31 编辑 ]
      谢了
    2. 手把手教你做XDS100v2仿真器 159/93535 微控制器 MCU 2013-06-03
      好贴,顶楼主
    3. 倒车雷达芯片(GM3101)的PDF中文资料 101/126559 汽车电子 2012-08-21
      谢谢楼主啦
    4. 谢谢好人
    5. 北京大学嵌入式开发讲义 88/40322 嵌入式系统 2012-08-21
      顶一个
    6. 非常喜欢
    7. STM32 中断与嵌套NVIC 快速入门。 52/35208 stm32/stm8 2012-08-21
      辛苦了
    8. 送给新手:STM32的时钟树解析 1394/186261 stm32/stm8 2012-08-21
      讲的很清楚啊
    9. 传感器版块官方QQ群:285537089 81/21719 传感器 2011-06-20
      加不了:Sad:
    10. 传感器版块官方QQ群:285537089 81/21719 传感器 2011-06-20
      我要加:loveliness:

最近访客

< 1/1 >

统计信息

已有62人来访过

  • 芯积分:10
  • 好友:--
  • 主题:--
  • 回复:10

留言

你需要登录后才可以留言 登录 | 注册


现在还没有留言