Chinaunix首页 | 论坛 | 博客
  • 博客访问: 498998
  • 博文数量: 223
  • 博客积分: 0
  • 博客等级: 民兵
  • 技术积分: 2145
  • 用 户 组: 普通用户
  • 注册时间: 2014-03-01 10:23
个人简介

该坚持的时候坚持,该妥协的时候妥协,该放弃的时候放弃

文章分类

全部博文(223)

文章存档

2017年(56)

2016年(118)

2015年(3)

2014年(46)

我的朋友

分类: 嵌入式

2016-09-25 13:56:33

在ARM Architecture Reference Manual手册中
2.2 Processor modes

表明svc模式时需要设置0b10111,但是这里的寄存器在哪里呢?
>>在A2.5的状态寄存器中表明了设置模式

可以通过这是M[4:0]位来使CPU进入svc模式,通过阅读文章了解到,这些位是有访问权限的。

设置cpu为svc模式:
  1. /*
  2.      * set the cpu to SVC32 mode
  3.      */
  4.     mrs    r0,cpsr
  5.     bic    r0,r0,#0x1f
  6.     orr    r0,r0,#0xd3
  7.     msr    cpsr,r0
本来如果只是进入svc模式应该是orr r0,r0,#0x13才对。但是uboot中却是#0xd3,arm启动时需要关闭IRQ和FIQ所以I位和F位都要置1.
那么就是0xd3了。


阅读(576) | 评论(0) | 转发(0) |
0

上一篇:异常向量表

下一篇:关闭开门狗

给主人留下些什么吧!~~