kf32 单片机 bootloader 代码疑问

[复制链接]
1937|0
 楼主| 阳光的zj 发表于 2021-4-13 10:32 | 显示全部楼层 |阅读模式
                if(*(volatile uint32_t*)0x8000  == 0x10018000 ) //判断APP空间的首个字内容是否为栈顶地址0x10018000,正确则说明APP程序已经写入
                {
                      SYS_VECTOFF = 0x8000 ; //设置向量表偏移值,即重映射向量表,这对中断服务函数正确执行至关重要
                      JumpAddress = *(volatile uint32_t*) (0x8000 + 4); //获取APP的startup()入口地址
                      Jump_To_Application = (pFunction) JumpAddress; //将startup()入口地址赋值给函数指针
                      Jump_To_Application(); //使用新的函数指针,转向执行APP的startup()函数,这将导致APP程序启动
                }


这段代码不明白,能否详细讲解一下,谢谢

if(*(volatile uint32_t*)0x8000  == 0x10018000 )  
如果将 0x8000   修改为0x1b000      

                    SYS_VECTOFF = 0x8000 ; //设置向量表偏移值,即重映射向量表,这对中断服务函数正确执行至关重要
                      JumpAddress = *(volatile uint32_t*) (0x8000 + 4); //获取APP的startup()入口地址
这两处0x8000  是否也需要修改为0x1b000   用官方给的代码ox8000 是可以跑通的,但现在修改之后不能跑通,不知道哪里出问题啦。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

9

主题

24

帖子

1

粉丝
快速回复 在线客服 返回列表 返回顶部