robin林 发表于 2014-9-25 17:37:18

KE02 bootloader 如何跳转到用户程序?跳转的代码看得(已解决)

本帖最后由 FSL_TICS_ZP 于 2014-10-8 15:59 编辑

asm(“LDR   r1,”)
asm(“MOV   r13,r1”)
asm(“ADDS   r0,r0,#0x04”)
asm(“LDR   r0,”)
asm(“BXr0”)网上看了下 说是跳转PC指针 比如我KE02 bootloader跳转向量中断重定位是到0x1000,那是不是跳转的时候PC指针会跳转到0X1000处开始运行程序,主要是我对r0,1这些存储是什么东西不了解!!!
希望有人能够帮助下,非常感谢!!!!

捷恩斯威科技 发表于 2014-9-25 18:03:52

本帖最后由 捷恩斯威科技 于 2014-9-25 18:06 编辑

没有源代码,不知道前面还有什么内容,就你贴出来这几句。 首先是初始化 SP(R13),R0指向地址存储值。 再跳转到R0+0x04开始执行。这是因为KE02的首4个字节是栈初始化值。4个字节后才真实的程序执行内容。如果R0是0x1000的话,则0x1000存值的栈初始化值,0x1004才是程序执行。好比没有BOOTLOAD的工程,则0x0000存储的栈初始化值,0x0004才是复位向量。

robin林 发表于 2014-9-25 18:42:17

捷恩斯威科技 发表于 2014-9-25 18:03
没有源代码,不知道前面还有什么内容,就你贴出来这几句。 首先是初始化 SP(R13),R0指向地址存储值。 再跳 ...

你好

SCB_VTOR=0X1000;
jumpTouser(0x1000)
{
        asm(“LDR   r1,”)
        asm(“MOV   r13,r1”)
        asm(“ADDS   r0,r0,#0x04”)
        asm(“LDR   r0,”)
        asm(“BXr0”)
}
这个是他的跳转到用户程序的代码 ,按你说的是 前面的4个字节 存储的INIT_SP,RESET_BL这两个,然后从便宜0x04地址程序从中断向量开始的吗?
因为我对程序从何处开始执行还不了解,还有 R1 R0 R13是存储着什么?是不是不同单片机是不同的,这个我得去看什么资料呢?

security 发表于 2014-9-25 19:31:00

R0存储参数0x1000,这些属于AAPCS的范畴,去百度下相应的过程调用约定。然后R13等同于sp,这些去看cortex-m3权威指南,,这里就是跳到用户的中断向量表,设置初始栈,然后跳到用户程序入口点。。中断向量表,这些都可以看权威指南

fengyunyu 发表于 2014-9-25 20:08:16

jumpTouser,调用这个函数时,传递过来的0x1000存储到r0中。

eleqian 发表于 2014-9-25 20:19:45

R13是堆栈指针,R0是调用这个函数的参数,R1只是作为普通寄存器使用。
下面的C代码是用在STM32中的,原理应该一样。

typedef void (*pAppFunc_t)(void);

pAppFunc_t pAppFunc;

// 设置用户程序的堆栈指针
__set_MSP(*(__IO uint32_t *)FLASH_APP_ADDR);
// 跳转到用户程序
pAppFunc = (pAppFunc_t)*(__IO uint32_t *)(FLASH_APP_ADDR + 4);;
pAppFunc();

FSL_TICS_ZP 发表于 2014-9-26 08:51:07

相信前面网友的回复可以回答你的问题啊!

zndz410 发表于 2014-9-26 11:12:34

r0、r1、r13等这些是属于汇编的内容,楼主学习下汇编知识就会知道。

robin林 发表于 2014-9-26 14:15:25

FSL_TICS_ZP 发表于 2014-9-26 08:51
相信前面网友的回复可以回答你的问题啊!

嗯,已经明白了,版主有KE02Flash 读写的文档吗?看英文手册没看明白

robin林 发表于 2014-9-26 14:15:52

zndz410 发表于 2014-9-26 11:12
r0、r1、r13等这些是属于汇编的内容,楼主学习下汇编知识就会知道。

谢谢!已经看懂了
页: [1]
查看完整版本: KE02 bootloader 如何跳转到用户程序?跳转的代码看得(已解决)