C2000在线升级主程序下载kernel完成后跳转到kernel运行的过程记录

本文详细阐述了从应用程序向kernel程序跳转的过程,包括设置堆栈指针、获取kernel入口地址、清理及退出函数。在汇编代码中,通过LCR指令调用函数get_entryaddr获取kernel的入口地址,然后通过无条件跳转BF指令,最终使得CPU执行kernel的入口地址,从而完成跳转。这一过程涉及到CPU寄存器的使用和程序控制流程的转换。
摘要由CSDN通过智能技术生成

在主程序下载kernel后,并且校验和对比无误,就跳入函数 boot_ram_loader();

该函数运行结束后,程序就完成了从应用程序向kernel程序的跳转。

跳转的机理是什么呢,此时要让PC装载kernel程序的入口地址,但是有不能直接装载。

结束主程序之前需要做一些准备工作,具体准备什么,我也不知道,进入kernel之前也要做一些准备工作,具体准备什么我也不知道。完了才能去触发kernel程序的入口地址装载到kernel。

具体过程:

boot_ram_loader();函数定义在如下的汇编文件中

Init_RAM_Loader.asm源文件

_boot_ram_loader:

; Initalize the stack pointer.
__stack:    .usect ".stack",0
    MOV SP, #__stack ; Initalize the stack pointer

; Fetch ram loder entry address
;函数get_entryaddr的地址被加载到PC,因此程序就运行这个函数,CKFA程序的入口地址
    LCR  _get_entryaddr

; Cleanup and exit.  At this point the EntryAddr is located in the ACC register
; 无条件跳转
    BF  _ExitBoot,UNC

上面的汇编文件只是调用了函数get_entryaddr,

  LCR  _get_entryaddr;函数运行的时候,首先把下一条指令的地址装载到RPC中,用于该调用返回的时候将PRC的值返回到PC中,进而运行BF  _ExitBoot,UNC。

长调用LCR  _get_entryaddr;把下一条指令的地址装载到RPC中之后,就跳入下面这个函数运行

Uint32 get_entryaddr()
{
    return IAP_RAMLOADER_ENTRYADDR; //    IAP_RAMLOADER_ENTRYADDR     = 0x000000;
}

上面这个函数的返回操作,会把0x00000;这个代表kernel首地址的数装到CPU的ACC寄存器。

然后上面这个函数既然返回了,自然LCR就要执行接下来的步骤了,也就是从执行PC=RPC,

这样CPU开始执行BF  _ExitBoot,UNC,这个函数中有完成把0x00008800;装载到PC中的汇编指令和其他一些必要的操作。之后程序就跳转到了kernel运行了。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

量子力学和生命科学

写作提升自己,打赏更能鼓励我

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值