`
isiqi
  • 浏览: 16489834 次
  • 性别: Icon_minigender_1
  • 来自: 济南
社区版块
存档分类
最新评论

MIPS构架简介

阅读更多

  MIPS体系结构首先是一种RISC架构1 MIPS32架构中有32个通用寄存器,其中$0(无论你怎么设置,这个寄存器中保存的数据都是0)和$31(保存函数调用jal的返回地址)有着特殊的用途,其它的寄存器可作为通用寄存器用于任何一条指令中。

虽然硬件没有强制性的指定寄存器使用规则,在实际使用中,这些寄存器的用法都遵循一系列约定。这些约定与硬件确实无关,但如果你想使用别人的代码,编译器和操作系统,你最好是遵循这些约定。

寄存器编号助记符用法0 zero永远返回值为0 1 at用做汇编器的暂时变量2-3 v0, v1子函数调用返回结果4-7 a0-a3子函数调用的参数8-15 t0-t7 24-25 t8-t9暂时变量,子函数使用时不需要保存与恢复16-25 s0-s7子函数寄存器变量。子函数必须保存和恢复使用过的变量在函数返回之前,从而调用函数知道这些寄存器的值没有变化。

26,27 k0,k1通常被中断或异常处理程序使用作为保存一些系统参数28 gp全局指针。一些运行系统维护这个指针来更方便的存取“static”和“extern"变量。

29 sp堆栈指针30 s8/fp第9个寄存器变量。子函数可以用来做桢指针31 ra子函数的返回地2 MIPS32中如果有FPA(浮点协处理器),将会有32个浮点寄存器,按汇编语言的约定为$f0~$f31,MIPS32中只能实用偶数号的浮点寄存器,奇数号的用途是:在做双精度的浮点运算时,存放该奇数号之前的偶数号浮点寄存器的剩余无法放下的32位。比如在做双精度的浮点运算时,$1存放$0的剩余的部分,所以在MIPS32中可以通过加载偶数号的浮点寄存器而把64位的双精度数据加载到两个浮点寄存器中,每个寄存器存放32位。

比如:l.d $02, 24(t1)

被扩充为两个连续的寄存器加载:lwc1 $f0, 24(t1)

lwc1 $f1, 28(t1)

3 MIPS架构中没有X86中的PC(程序计数)寄存器,它的程序计数器不是一个寄存器。因为在MIPS这样具有流水线结构的CPU中,程序计数器在同一时刻可以有多个给定的值,如jal指令的返回地址跟随其后的第二条指令。

……

jal printf move $4, $6 xxx # return here after call MIPS32中也没有条件码,比如在X86中常见的状态寄存器中的Z、C标志位在MIPS32中是没有的,但是MIPS32中是有状态寄存器4 MIPS32中不同于其它的RISC架构的地方是其有整数乘法部件,这个部件使用两个特殊的寄存器HI、LO,并且提供相应的指令mfhi/mthi,mthi/mtlo来实现整数乘法结果——hi/lo寄存器与通用寄存器之间的数据交换5数据加载与存储MIPS CPU可以在一个单一操作中存储1到8个字节。文档中和用来组成指令助记符的命名约定如下:C名字MIPS名字大小(字节)汇编助记符long long dword 8 "d"代表ld int/long word 4 "w"代表lw short halfword 2 "h"代表lh char byte 1 "b"代表lb 5.1数据加载包括这样几条记载指令LB/LBU、LH/LHU、LW byte和short的加载有两种方式。带符号扩展的lb和lh指令将数据值存放在32位寄存器的低位中,剩下的高位用符号位的值来扩充(位7如果是一个byte,位15如果是一个short)。这样就正确地将一个带符号整数放入一个32位的带符号的寄存器中。

不带符号指令lbu和lhu用0来扩充数据,将数据存放纵32位寄存器的低位中,并将高位用零来填充。

例如,如果一个byte字节宽度的存储器地址为t1,其值为0xFE(-2或254如果是非符号数),那么将会在t2中放入0xFFFFFFFE(-2作为一个符号数)。t3的值会是0x000000FE(254作为一个非符号数)

lb t2, 0(t1)

lbu t3, 0(t1)

5.2数据存储包括这样几条指令SB、SH、SW由于加载就是把寄存器中的数据加载到内存中,所以不存在位扩展的问题。

6 CP0 (协处理器0)——MIPS处理器控制用于控制和设置MIPS CPU,里面包含了一些寄存器,同过对这些寄存器的不同的位的操作可以实现对处理器的设置CP0类似于X 86只能有内核(高优先级权限)访问的一些处理器资源而前面提到的通用寄存器GPR和FPR则可以有由所有的优先级权限访问CP0提供了中断异常处理、内存管理(包括CACHE、TLB)、外设管理等途径(而这些只能由高优先级的内核才能访问到)。

6.1常见的MIPS CPU控制寄存器包括:SR(状态寄存器) 12 Config (CPU参数设置寄存器)-16 EPC (例外程序寄存器)13、CAUSE(导致中断和异常的原因寄存器) 14、BadVaddr(地址错误时存放地址的寄存器)8 Index- 0、Random-1、EntryLo0-2、EntryLo1-3、EntryHi-10、PageMask Count-9、Compare-11共同组成了高精度的时钟6.2CP0寄存器的访问指令mtc0 ts, #把通用寄存器ts中的数据送到协处理器0中的寄存器nn mfc0 ts, #把送到协处理器0中寄存器nn的值送到通用寄存器ts dmtc0 ts, #把通用寄存器ts中的数据送到协处理器0中的寄存器nn dmfc0 ts, #把送到协处理器0中寄存器nn的值送到通用寄存器ts 6.3起作用的寄存器及其作用时机加电后:你需要设置SR和Config寄存器,以确保CPU进入正确的引导状态,并且SR寄存器还设置了中断码。以决定系统响应哪些中断。

进入任何异常:处理任何例外都会调用一个“通用异常处理程序”。MIPS体系并没有为进入异常作任何的寄存器保存,也没有关于堆栈方面的任何支持,进入异常时唯一保存的就是异常返回地址保存在EPC中。所以这些都需要操作系统的软件实现。操作系统可以使用K0或者K1寄存器作为堆栈指针,指向某个位置,并且在需要保存的寄存器保存到这个栈上。然后通过Cause寄存器找到发生异常的原因,这样才能跳转到对应的中断处理程序中。

从异常返回:从异常返回到EPC制定的地址之前要把CPU的状态回复到异常之前,好象什么事情都没有发生一样。在R3000中使用rfe指令作这样的事情,但是着条指令仅仅恢复了一些寄存器中的内容,但是并没有转移控制指令,你需要把EPC内容保存到一个通用寄存器中,然后调用jr指令返回到EPC指向的地址处,7 MIPS的存储管理模型MIPS32中的存储器模型被划分为四个大块,其中:0x0000,0000~0x7fff,ffff(0~2G-1) USEG must be mapped (set page table and TLB)and set cache before use 0x8000,0000~0x9fff,ffff(2G~2.5G-1) KSEG0 directly mapped(no need to set page table and TLB) but need to set cache before use 0xa000,0000~0xbfff,ffff(2.5G~3G-1) KSEG1 directly mapped(no need to set page table and TLB) and never use cache 0xc000,0000~0xffff,ffff(3G~4G-1) KSEG2 muse be mapped(set page table and TLB) and set cache before use这样的存储器管理模型和X86差距比较大,X86有一个实模式,内核在启动保护模式之前,运行在实模式之下,直到设定了保护模式之后才能运行在保护模式下。在MIPS32中没有保护模式那么系统是如何启动的呢?

MIPS32中的系统启动向量位于KSEG1中0xbf10,0000,由于KSEG1是directly mapped的,所以直接对应了物理地址0x1fc0,0000,你可以在内核中一直使用0xa000,0000~0xbfff,ffff之间的虚拟地址来访问物理地址0~512M-1,在设置了KSEG0的cache之后,也可一使用0x8000,0000~0x9fff,ffff之间的虚拟地址来访问0~512M-1之间的物理地址。对于512M以上的物理地址只能由KSEG2和USEG通过页表访问。

8 MIPS32中的状态寄存器SR状态寄存器来设置处理器的一些功能集合,包括设置设置协处理器0~3的可用性的位CU0~CU3(28~31)

复位向量BEV中断屏蔽位8~15 KUc、IEc0~1,基本的CPU保护单位KUc为1时表示运行在内核态,为0时运行在用户模式。在内核态下,可以访问所有的地址空间和协处理器0,运行在用户态下值只能访问0x0000,0000~0x7fff,ffff之间的地址空间。

KUp、IEp2~3当异常发生时,硬件把KUc、IEc的值保存到KUp、IEp中,并且将KUc、IEc设置为[1,0]——内核态、关中断。异常返回时rfe指令可以把KUp、IEp的内容复制到KUc、IEc中KUo、IEo当异常发生时,硬件把KUp、IEp的值保存到KUo、IEo中;返回时把KUo、IEo的内容复制到KUp、IEp中。

上面三对KU/IE位构成了深度2的栈,异常发生时,硬件自动压栈,rfe指令从异常返回时,从栈中恢复数值还有一些其它的功能和状态位,可以参考相应的文档9 MIPS32中的Cause寄存器BD位:EPC中正常情况下存放了发生异常的指令,但是当着条指令存放在调转指令的延迟槽中时,那么EPC中存放的是这个跳转指令,否则这条跳转指令将得不到执行。

IP位:告诉用户来临的中断ExcCode:这是一个5位的代码,告诉你哪一条异常发生了,可以根据这个从通用异常处理程序跳装到特定异常处理程序中。

10 MIPS32的C语言中参数传递和返回值的约定caller至少使用16bytes堆栈空间存放参数,然后把这16 bytes存放到通用寄存器a0~a3中,called subroutine直接使用寄存器中的参数,同时caller堆栈中的16bytes的数据可以不去理会了。

需要理解的是带有浮点参数和结构体的参数传递,对于带有浮点参数的传递需要看第一个参数是否是浮点,如果是浮点则将参数放到$f12和$f14这两个浮点寄存器中,如果第一个参数不是浮点数,则不用浮点寄存器存放参数。对于结构体的参数传递和x86类似对于整数和指针类型的参数返回值一般通过通用寄存器v0($2)返回,对于浮点返回类型,一般存放在$f0中返回。

分享到:
评论

相关推荐

    MIPS跑LINUX-MIPS体系结构剖析

    《MIPS跑LINUX——MIPS体系结构剖析》是一份深度探讨MIPS架构与Linux操作系统交互的资源。本文将从MIPS(Microprocessor without Interlocked Pipeline Stages)处理器的体系结构出发,逐步揭示其在Linux操作系统下...

    mips相关资料

    网上摘录的一些资料,请勿用作商业用途,谢谢。 包括: 1.ARM 与 MIPS 比较 (X86) ...6.MIPS构架简介 7.MIPS 架构上函数调用过程中的堆栈和栈帧 8.基于MIPS架构的BackTrace实现 9.MIPS oprofile Add callgraph support

    go-cqhttp-mips-v1.0.0

    自己编译的二进制文件,mips 构架,实测 GPON GS3101 移动光猫可用。

    mips64el构架麒麟V10SP1国产操作系统身份证读卡器社保卡读卡器网页web开发包下载

    广东东信智能科技有限公司DONSEE系列多功能身份证社保卡读卡器麒麟国产系统、统信UOS国产系统mips64el构架等网页SDK接口SDK开发包,支持 EST-100、EST-100GS、EST-J13X、EST-100G、EST-100U等机型,功能包括身份证...

    MIPS构建的介绍入门.pdf

    本文档侧重于从汇编语言的角度介绍MIPS构架。不同于硬件层面的详细分析,这里将重点放在内存调用架构的编写上。MIPS汇编语言比高级语言更原始,不具备复杂的控制流(如for和while循环)。MIPS汇编指令通常有严格的...

    perl 写的MIPS 汇编器

    用perl编写的mips 32构架的汇编器

    国产系统奔图打印机驱动

    中标麒麟主要支持MIPS64架构,这是针对 MIPS(Microprocessor without Interlocked Pipeline Stages)处理器的一种64位架构,常见于高性能计算和嵌入式设备中。而统信UOS则主要支持ARM架构,这是一种广泛应用在移动...

    嵌入式系统/ARM技术中的基于MIPS架构的RISC微处理器RM7000A

    摘要:概要介绍基于MIPS指令集的RM...自从1983年John Hennessy在斯坦福大学成功地完成了第一个采用RISC理念的MIPS微处理器以来,基于MIPS构架的CPU在网络、通信、多媒体娱乐等领域得到了广泛应用。Cisco的路由器,IB

    Windows CE简介 特性 系统构架 开发流程 开发工具介绍

    1. **硬件平台支持**:Windows CE不局限于x86架构,它支持ARM、Xscale、MIPS、PowerPC、SH等多种处理器架构,这使得它能够广泛应用于不同类型的嵌入式设备。 2. **小型化镜像**:与桌面版Windows相比,Windows CE的...

    ARM_Cortex_A8构架比ARM11强多少

    它采用了 65 纳米工艺,功耗低于 300 毫瓦,而性能高达 2000 MIPS,相比 ARM11,在相同功耗下能提供至少三倍的性能提升。这得益于其优化的微架构和更高频率的运行能力。Cortex-A8 内部集成了多个处理单元,包括图像...

    IP STB系统构架及规划

    例如,Broadcom的BCM7318系统单芯片就提供了MPEG-2影音解码功能、32位MIPS微处理器、10/100Mbps以太网控制器和USB2.0主控制器等。 IP STB的系统规划着重于如何在有限的频宽条件下提供高质量的影音内容。为了解决这...

    嵌入式常用软件构架总结.pdf

    在嵌入式软件开发中,理解常用的软件构架至关重要,因为它们构成了系统的基础,并影响着程序的性能、可移植性和可维护性。以下是对标题和描述中提到的几个关键知识点的详细说明: **一、芯片架构** 1. **X86架构**...

    嵌入式系统/ARM技术中的Powerpc构架系统内核和内核模块调试

     此文档的目标系统为freescale MPC8349E-mITX,对其他采用POWERPC,MIPS,ARM的芯片的系统亦具有参考意义。 此文档中内核调试为了简化,采用目标系统中的UBOOT初始化目标板,并通过UBOOT或者BDI2000加载内核到目标板...

    展讯手机平台软件简介

    - **展讯应用软件构架SAF**:作为软件的核心框架,SAF集成了各类软件服务,如多媒体处理、网络连接等,为上层应用开发提供了丰富的功能。 - **外设驱动程序**:支持多种外部设备,如摄像头、键盘等,通过统一的...

    展讯 2G2.5G (GSMGPRS)手机平台软件简介

    5. **展讯应用软件构架SAF**:为上层应用提供统一的开发框架和支持。 6. **外设驱动程序**:针对LCD、键盘等外部设备,实现硬件接口功能。 7. **AT命令接口**:用于与外部设备或应用交互的标准命令集。 此外,该...

    基于OpenWrt对路由器的智能扩展.pdf

    本文还介绍了OpenWrt系统的软硬件环境,包括MQ7620平台、MIPS24KEc构架、5个以太网口、USB2.0、2.4GHz Wi-Fi等。同时,本文还介绍了相关技术,包括虚拟机工具、虚拟机系统、Visual Studio Code、WinSCP等。 OpenWrt...

    嵌入式系统概述(嵌入式linux开发课件).ppt

    1. **构架**:包括硬件层、操作系统层、中间件层和应用层。 2. **硬件层**:由嵌入式微处理器、外围硬件设备等组成。 3. **操作系统层**:提供硬件抽象层(HAL)、设备驱动程序、文件系统等。 4. **中间件层**:用于...

Global site tag (gtag.js) - Google Analytics