ucos-ii 在skyeye上的移植分析

ucos-ii 在skyeye上的移植分析

ID:34159380

大小:184.50 KB

页数:8页

时间:2019-03-04

ucos-ii 在skyeye上的移植分析_第1页
ucos-ii 在skyeye上的移植分析_第2页
ucos-ii 在skyeye上的移植分析_第3页
ucos-ii 在skyeye上的移植分析_第4页
ucos-ii 在skyeye上的移植分析_第5页
资源描述:

《ucos-ii 在skyeye上的移植分析》由会员上传分享,免费在线阅读,更多相关内容在应用文档-天天文库

1、SkyEye技术报告uC/OS-II在SkyEye上的移植分析uC/OS-II在SkyEye上的移植分析李明lmcs00@mails.tsinghua.edu.cnSkyEye仿真调试器是基于ARM7TDMI核的,因此移植uC/OS-II到SkyEye上可以借鉴网上已有的例如SansungS3C3410X的移植代码,这在uC/OS-II的主页上很容易找到。当然自己动手做移植也是对ARM体系结构和汇编语言的进一步熟悉,同时对于uC/OS-II内核的调度机制会有更深的认识。整个移植工作可以分为两个方面,一部分是和ARM相关,一部分是和移植原理相关。在开始实际的移植工作前,需要对这两

2、部分有一定的背景知识,尤其是和侧重于和移植工作相关的概念和原理。下面分别做一些介绍:一、ARM的体系结构ARM(AdvancedRISCMachines)是目前在嵌入式领域里应用最广泛的RISC微处理器结构,以其低成本、低功耗、高性能的特点占据了嵌入式系统应用领域的领先地位。ARM系列的处理器当前有ARM7、ARM9、ARM9E、ARM10等多个产品,此外ARM公司合作伙伴,例如Intel也提供基于XScale微体系结构的相关处理器产品。所有的ARM处理器都共享ARM通用的基础体系结构,所以开发者在不同的ARM处理器上做操作系统移植时,可以将节省相当多的工作量,这无疑将大大降低

3、软件开发成本。要详细完整的了解ARM的体系结构,当然是去读ARMArchitecturReferenceManual,这是一个13M的pdf文档,有800多页,可以从ARM的网站下载,也可以到阿卡嵌入式兴趣小组的FTP服务器(ftp://159.226.40.150)上找到。北航出的一本《ARM嵌入式处理器结构与应用基础》基本上翻译了这个pdf中大部分重要的内容,可以作为入门的中文教材。这里我们仅仅对其中和移植工作密切相关的概念做简要介绍,1、处理器模式:(cpumode)ARM的处理器可以工作在7种模式,如下图所示:这里除usr模式以外的其他模式都叫做特权模式,除usr和sy

4、sSkyEye技术报告第8页2021-7-13SkyEye技术报告uC/OS-II在SkyEye上的移植分析外的其他5种模式叫做异常模式。在usr模式下对系统资源的访问是受限制的,也无法主动地改变处理器模式。异常模式通常都是和硬件相关的,例如中断或者是试图执行未定义指令等。这里需要强调的是和移植相关的两种处理器模式:svc态和irq态,分别指操作系统的保护模式和通用中断处理模式。这两种模式之间的转换可以通过硬件的方式,也可以通过软件的方式。uC/OS-II内核在执行过程中,大部分时间都是工作在svc态,当有硬件中断,例如时钟中断到来时,cpu硬件上会自动完成从svc态进入irq

5、态,在中断处理程序的结束处,则需要通过编程的方法使得cpu从irq态恢复到svc态,这个在移植代码中可以找到。1、程序状态寄存器:(PSR:Programstatusregister)在任何一种处理器模式中,都使用同一个寄存器来标识当前处理器的工作模式:这个寄存器叫做CPSR(CurrentProgramStatusRegister),它的[0--4]位用来表示cpumode:每一种处理器异常模式,都有一个对应的SPSR(SavedProgramStatusRegister)寄存器,用来保存进入异常模式前的CPSR。SPSR的作用就是当从异常模式退出时,可以通过一条简单的汇编指

6、令就能够恢复进入异常模式前的CPSR,而这个值都是保存在当前异常模式的SPSR中的。例如:当从usr态进入中断irq态时,原先的CPSR_all将被保存在当前的SPSR_irq中,类似的异常模式下的SPSR还有SPSR_fiq、SPSR_svc、SPSR_abt、SPSR_und。非异常模式的usr和sys模式下没有SPSR,只有CPSR。不能显式的指定把CPSR保存到某个异常模式下的SPSR,比如SPSR_irq,而必须是变更到irq态之后cpu自动完成的,不能在其他态下硬性赋值,因为SPSR_irq是其他状态下不可见的。2、ARM寄存器:(register)ARM处理器一共

7、有37个寄存器,其中31个是通用寄存器,包括一个程序计数器PC。另外6个就是上面提到的程序状态寄存器。a)通用寄存器:i.R0-R7:与所有处理器模式无关的寄存器,可以用作任何用途。ii.R8-R14:与处理器模式有关的寄存器,在不同的模式下,对应到不同的物理寄存器。其中R13又叫做SkyEye技术报告第8页2021-7-13SkyEye技术报告uC/OS-II在SkyEye上的移植分析sp,一般用于堆栈指针。R14又叫做lr,一般用于保存返回地址。这两个寄存器在每种异常模式下都对应到不同的

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。