uboot 2013.01.01 start.S部分分析

uboot 2013.01.01 start.S部分分析

#if !(defined(CONFIG_OMAP44XX) && defined(CONFIG_SPL_BUILD))
    /* Set V=0 in CP15 SCTRL register - for VBAR to point to vector */
    mrc p15, 0, r0, c1, c0, 0   @ Read CP15 SCTRL Register
    bic r0, #CR_V       @ V = 0
    mcr p15, 0, r0, c1, c0, 0   @ Write CP15 SCTRL Register

    /* Set vector address in CP15 VBAR register */
    ldr r0, =_start
    mcr p15, 0, r0, c12, c0, 0  @Set VBAR
#endif

这是对cp15寄存器的操作

这一句:mrc p15, 0, r0, c1, c0, 0   @ Read CP15 SCTRL Register

就是把cp15的c1 c0中的值放到 r0寄存器中

#define CR_V    (1 << 13)   /* Vectors relocated to 0xffff0000  */
bic r0, #CR_V       @ V = 0

就是把r0的第13位清零

mcr p15, 0, r0, c1, c0, 0   @ Write CP15 SCTRL Register

然后再写回c1 c0寄存器

我们看一下手册中的c1 c0的第13位清零是什么作用

这里写图片描述

这里写图片描述

这个寄存器对异常向量起作用,描述上大概是第13位为0 异常向量地址会被映射到0x00000000 如果为1 会被映射到0xffff0000

个人记录使用

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

无敌的娃哥

你的鼓励将是我创作的最大动力

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

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

打赏作者

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

抵扣说明:

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

余额充值