uboot初始化中,为何要设置CPU为SVC模式而不是设置为其他模式
来源:互联网 发布:哪个借钱软件好 编辑:程序博客网 时间:2024/06/05 01:53
uboot初始化中,为何要设置CPU为SVC模式而不是设置为其他模式
在看Uboot的start.S文件时候,发现其最开始初始化系统,做的第一件事情,就是将CPU设置为SVC模式,但是S3C2440的CPU的core是ARM920T,其有7种模式,为何非要设置为SVC模式,而不是设置为其他模式呢?对此,经过一些求证,得出如下原因:
首先,先要了解ARM的CPU的7种模式是哪些:
http://www.docin.com/p-73665362.html
表 3.1. ARM中CPU的模式
另外,7种模式中,除用户usr模式外,其它模式均为特权模式。
对于为何此处是svc模式,而不是其他某种格式,其原因,可以从两方面来看:
我们先简单的来分析一下那7种模式:
- 中止abt和未定义und模式
首先可以排除的是,中止abt和未定义und模式,那都是不太正常的模式,此处程序是正常运行的,所以不应该设置CPU为其中任何一种模式,所以可以排除。
- 快中断fiq和中断irq模式
其次,对于快中断fiq和中断irq来说,此处uboot初始化的时候,也还没啥中断要处理和能够处理,而且即使是注册了终端服务程序后,能够处理中断,那么这两种模式,也是自动切换过去的,所以,此处也不应该设置为其中任何一种模式。
- 用户usr模式
虽然从理论上来说,可以设置CPU为用户usr模式,但是由于此模式无法直接访问很多的硬件资源,而uboot初始化,就必须要去访问这类资源,所以此处可以排除,不能设置为用户usr模式。
- 系统sys模式 vs 管理svc模式
首先,sys模式和usr模式相比,所用的寄存器组,都是一样的,但是增加了一些访问一些在usr模式下不能访问的资源。
而svc模式本身就属于特权模式,本身就可以访问那些受控资源,而且,比sys模式还多了些自己模式下的影子寄存器,所以,相对sys模式来说,可以访问资源的能力相同,但是拥有更多的硬件资源。
所以,从理论上来说,虽然可以设置为sys和svc模式的任一种,但是从uboot方面考虑,其要做的事情是初始化系统相关硬件资源,需要获取尽量多的权限,以方便操作硬件,初始化硬件。
从uboot的目的是初始化硬件的角度来说,设置为svc模式,更有利于其工作。
因此,此处将CPU设置为SVC模式。
- 中止abt和未定义und模式
uboot作为一个bootloader来说,最终目的是为了启动Linux的kernel,在做好准备工作(即初始化硬件,准备好kernel和rootfs等)跳转到kernel之前,本身就要满足一些条件,其中一个条件,就是要求CPU处于SVC模式的。
所以,uboot在最初的初始化阶段,就将CPU设置为SVC模式,也是最合适的。
提示 关于满足哪些条件,详情请参考
ARM Linux Kernel Boot Requirements
或者Linux内核文档:
kernel_source_root\documentation\arm\booting
中也是同样的解释:
The CPU must be in SVC mode
所以,uboot在最初的初始化阶段,就将CPU设置为SVC模式,也是最合适的。
综上所述,uboot在初始化阶段,就应该将CPU设置为SVC模式。
原文地址http://www.crifan.com/files/doc/docbook/uboot_starts_analysis/release/htmls/why_svc_not_other.html
- uboot初始化中,为何要设置CPU为SVC模式而不是设置为其他模式
- uboot初始化中,为何要设置CPU为SVC模式而不是设置为其他模式
- uboot初始化中,为何要设置CPU为SVC模式而不是设置为其他模式
- uboot初始化中,为何要设置CPU为SVC模式而不是设置为其他模式
- uboot初始化中,为何要设置CPU为SVC模式而不是设置为其他模式
- uboot初始化中,为何要设置CPU为SVC模式而不是设置为其他模式
- uboot初始化中,为何要设置CPU为SVC模式而不是设置为其他模式
- uboot初始化中为什么要设置CPU为SVC模式
- uboot中为什么设置CPU为SVC模式????????
- bootloader为何开始要将CPU设置为SVC模式
- Objc中为何某些类的属性要设置为copy而不是strong?
- 设置SVC模式
- 设置SVC模式
- 嵌入式学习-uboot-lesson4.2-设置SVC模式
- u-boot设置SVC模式
- 二十四.SVC模式设置
- 设置tiny6410的svc模式
- 设置网卡为混杂模式
- 小小相本
- MyEclipse 快捷键大全
- 电子科技大学 1727
- Ext实现分页
- Java多线程编程--(9)学习Java5.0 并发编程包--线程工具类
- uboot初始化中,为何要设置CPU为SVC模式而不是设置为其他模式
- Apache 配置虚拟主机
- 关于android组播DatagramPacket不能正常接收问题
- (清除)cleanup(终结)finalization (垃圾回收)garbage collection
- asp.net缓存技术
- 【原创】NTFS文件系统底层挖掘
- CheckMenuItem
- GCC和CL的区别
- 我对 回调函数 的理解