- 1、本文档共8页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
uCOS-II在SkyEye上的移植分析-Huihoo.org.doc
uC/OS-II 在SkyEye上的移植分析
李明 lmcs00@
SkyEye 仿真调试器是基于ARM7TDMI 核的,因此移植 uC/OS-II 到 SkyEye 上可以借鉴网上已有的例如 Sansung S3C3410X的移植代码,这在 uC/OS-II的主页上很容易找到。 当然自己动手做移植也是对 ARM 体系结构和汇编语言的进一步熟悉,同时对于 uC/OS-II 内核的调度机制会有更深的认识。
整个移植工作可以分为两个方面,一部分是和 ARM 相关,一部分是和移植原理相关。在开始实际的移植工作前,需要对这两部分有一定的背景知识,尤其是和侧重于和移植工作相关的概念和原理。下面分别做一些介绍:
ARM 的体系结构
ARM(Advanced RISC Machines)是目前在嵌入式领域里应用最广泛的RISC微处理器结构,以其低成本、低功耗、高性能的特点占据了嵌入式系统应用领域的领先地位。ARM系列的处理器当前有ARM7、ARM9、ARM9E、ARM10等多个产品,此外ARM公司合作伙伴,例如Intel 也提供基于XScale微体系结构的相关处理器产品。所有的ARM处理器都共享ARM通用的基础体系结构,所以开发者在不同的ARM处理器上做操作系统移植时,可以将节省相当多的工作量,这无疑将大大降低软件开发成本。
要详细完整的了解ARM的体系结构,当然是去读 ARM Architectur Reference Manual ,这是一个13M 的pdf 文档,有800多页,可以从ARM的网站下载,也可以到阿卡嵌入式兴趣小组的FTP服务器( 50 )上找到。北航出的一本《ARM 嵌入式处理器结构与应用基础》基本上翻译了这个pdf中大部分重要的内容,可以作为入门的中文教材。这里我们仅仅对其中和移植工作密切相关的概念做简要介绍,
处理器模式: ( cpu mode )
ARM 的处理器可以工作在 7 种模式,如下图所示:
这里除 usr 模式以外的其他模式都叫做特权模式,除 usr 和 sys 外的其他5种模式叫做异常模式。在 usr 模式下对系统资源的访问是受限制的,也无法主动地改变处理器模式。异常模式通常都是和硬件相关的,例如中断或者是试图执行未定义指令等。这里需要强调的是和移植相关的两种处理器模式:svc 态和 irq 态,分别指操作系统的保护模式和通用中断处理模式。这两种模式之间的转换可以通过硬件的方式,也可以通过软件的方式。uC/OS-II内核在执行过程中,大部分时间都是工作在 svc 态,当有硬件中断,例如时钟中断到来时,cpu 硬件上会自动完成从svc态进入 irq态,在中断处理程序的结束处,则需要通过编程的方法使得 cpu 从irq 态恢复到 svc 态,这个在移植代码中可以找到。
程序状态寄存器: ( PSR:Program status register )
在任何一种处理器模式中,都使用同一个寄存器来标识当前处理器的工作模式:这个寄存器叫做 CPSR ( Current Program Status Register ),它的 [0--4] 位用来表示cpu mode:
每一种处理器异常模式,都有一个对应的SPSR ( Saved Program Status Register )寄存器,用来保存进入异常模式前的CPSR。SPSR的作用就是当从异常模式退出时,可以通过一条简单的汇编指令就能够恢复进入异常模式前的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是其他状态下不可见的。
ARM寄存器:( register )
ARM处理器一共有37个寄存器,其中31个是通用寄存器,包括一个程序计数器 PC。另外6个就是上面提到的程序状态寄存器。
通用寄存器:
R0-R7:与所有处理器模式无关的寄存器,可以用作任何用途。
R8-R14:与处理器模式有关的寄存器,在不同的模式下,对应到不同的物理寄存器。其中 R13又叫做 sp,一般用于堆栈指针。R14又叫做lr,一般用于保存返回地址。这两个寄存器在每种异常模式下都对应到不同的物理寄存器上,例如lr_irq、lr_svc、lr_fiq 等。
R15:又叫做程序计数器,即pc,所有的
您可能关注的文档
- materials.doc-北京大学哲学系.doc
- matlab和VC++混合编程.ppt
- Matlab授课课件.ppt.ppt
- Matlab第一讲快速入门.ppt
- Matlab简易介绍.ppt
- Matlab计算与仿真交互式计算(续).ppt
- MCD1(MPLAB-ICD)用户使用指南-讲解ICD的安装入门-PIC单片机学习网.doc
- Meggie-TeamPal-软件工程项目信息化平台.doc
- MICROMEDEX培训课件1.ppt
- MicrosoftAccess数据库不能支持30个以上的用户同时访问。.ppt
- Haier海尔413升风冷变频多门冰箱 BCD-413WGHFD1BSJU1(白)说明书用户手册.pdf
- Siemens西门子工业抽屉式断路器主回路后垂直连接 抽屉式断路器主回路后垂直连接使用手册.pdf
- Samsung三星智能佩戴设备 Galaxy Fit3安全手册.pdf
- Samsung三星滚筒洗衣机 AI神 黑钻热泵洗烘旗舰 WD18DB8995BZSC使用手册.pdf
- Sakura樱花消毒柜 保洁柜消毒柜 SCQ-130D6用户手册说明书.pdf
- Hifiman头领科技ARYA UNVEILED说明书用户手册.pdf
- Siemens西门子工业抽屉式主回路连接前置端子 支撑件 抽屉式主回路连接前置端子 支撑件使用手册.pdf
- Siemens西门子工业中性线的外部电流传感器 中性线的外部电流传感器使用手册.pdf
- Siemens西门子工业电子脱扣单元 电子脱扣单元使用手册.pdf
- Razer雷蛇Playstation 专用雷蛇战锤狂鲨极速版 RZ12-038203 用户指南 (简体中文)说明书用户手册.pdf
最近下载
- 腰椎的解剖及腰部的层次解剖ppt参考课件.ppt
- 知识产权助推新质生产力发展.pptx VIP
- NB∕T 10805-2021 水电工程溃坝洪水与非恒定流计算规范.pdf
- 2022年鄄城县工会系统招聘考试题库及答案解析.docx VIP
- 2024年医师定期考核必考题库及答案.pdf
- 2023年互联网信息审核员理论考试题库(含答案).pdf VIP
- 2024中考语文《西游记》历年真题专练(学生版+解析版).pdf VIP
- 高中音乐鉴赏测试题.doc VIP
- 人教三上数学《数学广角—集合》单元作业设计方案(13页).pdf VIP
- 省级政府和重点城市一体化政务服务能力调查评估报告2021年.pdf VIP
文档评论(0)