ARM嵌入式系统基础与开发教程丁文龙整理精品文档.docx

上传人:b****5 文档编号:6768691 上传时间:2023-01-10 格式:DOCX 页数:8 大小:19.85KB
下载 相关 举报
ARM嵌入式系统基础与开发教程丁文龙整理精品文档.docx_第1页
第1页 / 共8页
ARM嵌入式系统基础与开发教程丁文龙整理精品文档.docx_第2页
第2页 / 共8页
ARM嵌入式系统基础与开发教程丁文龙整理精品文档.docx_第3页
第3页 / 共8页
ARM嵌入式系统基础与开发教程丁文龙整理精品文档.docx_第4页
第4页 / 共8页
ARM嵌入式系统基础与开发教程丁文龙整理精品文档.docx_第5页
第5页 / 共8页
点击查看更多>>
下载资源
资源描述

ARM嵌入式系统基础与开发教程丁文龙整理精品文档.docx

《ARM嵌入式系统基础与开发教程丁文龙整理精品文档.docx》由会员分享,可在线阅读,更多相关《ARM嵌入式系统基础与开发教程丁文龙整理精品文档.docx(8页珍藏版)》请在冰豆网上搜索。

ARM嵌入式系统基础与开发教程丁文龙整理精品文档.docx

ARM嵌入式系统基础与开发教程丁文龙整理精品文档

ARM嵌入式系统基础与开发教程丁文龙

编辑整理:

 

尊敬的读者朋友们:

这里是精品文档编辑中心,本文档内容是由我和我的同事精心编辑整理后发布的,发布之前我们对文中内容进行仔细校对,但是难免会有疏漏的地方,但是任然希望(ARM嵌入式系统基础与开发教程丁文龙)的内容能够给您的工作和学习带来便利。

同时也真诚的希望收到您的建议和反馈,这将是我们进步的源泉,前进的动力。

本文可编辑可修改,如果觉得对您有帮助请收藏以便随时查阅,最后祝您生活愉快业绩进步,以下为ARM嵌入式系统基础与开发教程丁文龙的全部内容。

第1章嵌入式系统概述

1.填空题

(1)嵌入式系统硬件平台嵌入式软件

(2)硬件抽象层HAL板级支持包BSP设备驱动程序

(3)嵌入式微处理器嵌入式微控制器嵌入式片上系统SoC

2.选择题

(1)B

(2)ABD(3)D

3.简答题

(1)什么是嵌入式系统?

列举几个熟悉的嵌入式系统的产品.

嵌入式系统是以应用为中心,以计算机技术为基础,并且软硬件可裁剪,适用于应用系统对功能、可靠性、成本、体积、功耗有严格要求的专用计算机系统.常见的有汽车、手机、MP3等等。

(2)嵌入式系统由哪几部分组成?

嵌入式系统从大的方面分嵌入式系统硬件平台和嵌入式软件两大部分,其中软件部分又具体分为若干层次。

对于包含有操作系统的嵌入式系统来讲,嵌入式系统软件结构包含4个层次:

设备驱动层、实时操作系统RTOS层、应用程序接口API层、应用程序层.

(3)简述嵌入式系统的特点。

系统内核小;专用性强;系统精简;软件固化;嵌入式软件开发要想走向标准化,就必须使用多任务的操作系统;嵌入式系统开发需要开发工具和环境。

第2章ARM体系结构

1.填空题

(1)Cortex-R4处理器Cortex-A8处理器

(2)ARMThumb

(3)R13R14R15

(4)81632

2.选择题

(1)ACD

(2)A(3)BCD

3.简答题

(1)简述ARM可以工作的几种模式。

ARM体系结构支持7种处理器模式:

用户模式、快中断模式、中断模式、管理模式、中止模式、未定义模式和系统模式.

(2)ARM7内部有多少个寄存器?

在ARM7TDMI处理器内部有37个用户可见的32位寄存器,其中31个通用寄存器,6个状态寄存器。

(3)描述一下如何禁止IRQ和FIQ的中断?

在一个特权模式下,都可通过置位CPSR中的I位来禁止IRQ。

在一个特权模式中,可通过置位CPSR中的F标志来禁止FIQ异常。

(4)请描述ARM7TDMI进入异常或退出异常时内核有何操作?

当异常发生时,ARM处理器尽可能完成当前指令(除了复位异常)后,再去处理异常,并执行如下动作:

①进入与特定的异常相应的操作模式;

②将引起异常指令的下一条指令的地址保存到新模式的R14中;

③将CPSR的原值保存到新模式的SPSR中;

④通过设置CPSR的第7位来禁止IRQ;如果异常为快中断,则要设置CPSR的第6位禁止快中断;

⑤给PC强制赋向量地址值。

退出异常时:

①将LR中的值减去偏移量后移入PC,偏移量根据异常的类型而有所不同;

②将SPSR的值复制回CPSR;

③清零在入口置位的中断禁止标志.

第3章ARM7TDMI(-S)指令系统

1.填空题

(1)ARMThumb

(2)存储器目的寄存器

(3)寄存器寻址立即寻址寄存器移位寻址寄存器间接寻址基址寻址

2.选择题

(1)D

(2)C(3)B

3.简答题

(1)BIC指令的作用是什么?

BIC指令用于位清除操作,将寄存器Rn的值与operand2的值的反码按位作逻辑“异或”操作,结果保存到Rd中.

(2)描述B、BL、BX指令的区别。

B指令实现跳转到指定的地址执行程序。

注意:

B指令限制在当前指令的±32MB地址范围内(ARM指令为字对齐,最低两位地址固定为0).

BL指令实现先将下一条指令的地址拷贝到R14(即LR)连接寄存器中,然后跳转到指定地址运行程序。

注意:

BL指令限制在当前指令的±32MB地址范围内,BL指令用于子程序调用,在子程序的最后可以使用MOVPC,LR指令跳回BLLabel指令处的下一条指令继续执行。

BX指令跳转到Rm指定的地址去执行程序.若Rm的bit0为1,则跳转时自动将CPSR中的标志T位置,即把目标地址的代码解释为Thumb代码;若Rm的bit0为0,则跳转时自动将CPRS中的标志T复位,即把目标地址的代码解释为ARM代码。

(3)当执行SWI指令时,会发生什么?

SWI指令用于产生软件中断,以便用户程序能调用操作系统的系统例程。

操作系统在SWI的异常处理程序中提供相应的系统服务,指令中24位的立即数指定用户程序调用系统例程的类型,相关参数通过通用寄存器传递。

当指令中24位的立即数被忽略时,用户程序调用系统例程的类型由通用寄存器R0的内容决定,同时,参数通过其他通用寄存器传递.

(4)编写一段ARM汇编程序,实现数据块复制,将R0指向的8个字的连续数据保存到R1指向的一段连续的内存单元.

第4章基于ARM的嵌入式软件设计

1.填空题

(1)代码数据

(2)32位的ARM

(3)指令伪指令伪操作

2.选择题

(1)A

(2)ABD(3)B

3.简答题

(1)在ARM汇编中如何定义一个全局的算术变量?

GBLA伪指令用于定义一个ARM程序中的全局算术变量并将其初始化。

(2)ADR和LDR的用法有什么区别?

ADR伪指令为小范围地址读取伪指令。

ADR伪指令将基于PC相对偏移地址或基于寄存器相对偏移地址值读取到寄存器中,当地址值是字节对齐时,取值范围为−255~255,当地址值是字对齐时,取值范围为−1020~1020。

当地址值是16字节对齐时其取值范围更大.

LDR伪指令装载一个32位的常数和一个地址到寄存器.

(3)什么是内联汇编?

什么是嵌入式汇编?

两者之间的区别是什么?

内联汇编程序是在C程序中直接编写汇编程序段而形成一个语句块,这个语句块可以使用除了BX和BLX之外的全部ARM指令来编写,从而可以使程序实现一些不能从C获得的底层功能。

嵌入式汇编程序是一个编写在C程序外的单独汇编程序段,该程序段可以像函数那样被C程序调用.与内联汇编不同,嵌入式汇编具有真实汇编的所有特性,数据交换符合ATPCS标准,同时支持ARM和Thumb,所以它可以对目标处理器进行不受限制的低级别访问。

但是不能直接引用C/C++的变量名。

内联汇编与嵌入式汇编的编译有如下区别:

①内联汇编代码使用高级处理器抽象,并在代码生成过程中与C/C++代码集成.因此,编译程序将C和C++代码与汇编代码一起进行优化。

②嵌入式汇编代码从C/C++代码中分离出来单独进行汇编,产生与C/C++源代码编译对象相结合的编译对象。

③可通过编译程序来内联汇编代码,但无论是显式还是隐式,都无法内联嵌入式汇编代码。

(4)汇编代码中如何调用C代码中定义的函数?

首先,为保证程序调用时参数的正确传递,汇编语言程序的设计要遵守ATPCS.其次,在C语言程序中,不需要使用任何关键字来声明被汇编语言程序调用的C语言子程序。

但是在汇编语言程序调用C语言程序之前,需要在汇编语言程序中使用IMPORT伪指令对其进行声明。

汇编语言通过BL指令进行调用。

第5章嵌入式系统常用开发工具

1.填空题

(1)ADS1。

2

(2)MicrocontrollerDevelopmentKit(MDK)RealViewDevelopmentSuite(RVDS)

(3)PROTEUS电路设计PROTEUS源程序设计和生成目标代码文件

PROTEUS仿真

2.选择题

(1)ABC

(2)ABCD

(3)B

3.简答题

(1)如何使用ADS1.2集成开发环境新建一个工程。

略。

(2)新建一个RealView MDK工程,编写一个汇编程序实现3+16的操作。

略。

(3)如何在Proteus软件中搭建硬件开发平台进行源代码级调试.

略。

第6章基于LPC2000系列的嵌入式应用开发实例

1.填空题

(1)JTAG仿真/调试器ISPIAP

(2)片内Flash片内SRAMBootBlock

(3)对内部事件进行计数的间隔定时器;通过捕获输入实现脉宽解调器;自由运行的定时器

2.选择题

(1)C

(2)C

(3)ABCD

3.简答题

(1)LPC2000处理器是如何实现引脚多功能的?

略.

(2)如何对GPIO的输入/输出进行设置?

略。

(3)FIQ、IRQ有什么不同?

向量IRQ与非向量IRQ有何不同?

略。

(4)LPC2000有几种串行通信接口?

各有什么特点?

略。

第7章嵌入式实时操作系统μC/OS—II基础

1.填空题

(1)嵌入式LinuxWindowsCEVxWorks

(2)应用软件层与应用相关的配置代码与处理器无关的核心代码与处理器相关的设置代码

(3)OSStart()

2.选择题

(1)B

(2)C(3)A

3.简答题

(1)μC/OS-II的临界区是如何处理的?

同其他内核一样,μC/OS-II为了处理临界段代码,须关中断,处理完毕后,再开中断。

μC/OS-II定义了2个宏(macros)来关中断和开中断,分别是:

OS_ENTER_CRITICAL()和OS_EXIT_CRITICAL()。

(2)什么是任务控制块?

它有何作用?

任务控制块(OS_TCB)是一个数据结构,全部存放在RAM中。

一旦任务建立,一个任务控制块OS_TCB就被赋值。

当任务的CPU使用权被剥夺时,μC/OS—II用它来保存该任务的状态。

当任务重新得到CPU使用权时,任务控制块能确保任务从当时被中断的那一点丝毫不差地继续执行。

(3)任务调度的功能是什么?

它有哪几种方式?

μC/OS—II是占先式实时内核,优先级最高的任务一旦进入就绪态,立即拥有CPU的控制权并开始运行.μC/OS-II的调度器(scheduler)就是用来查找准备就绪的优先级最高的任务并进行任务切换.任务级的调度是由OSSched()函数完成的,中断级的调度是由OSIntExt()函数完成的。

(4)μC/OS—II是如何处理中断的?

μC/OS-II系统响应中断的过程是:

系统接收到中断请求后,如果这时CPU处于中断允许状态(即中断是开放的),系统就会中止正在运行的当前任务,而按照中断向量的指向转而去运行中断服务子程序;当中断服务子程序的运行结束后,系统将会根据情况返回到被中止的任务继续运行,或者转向运行另一个具有更高优先级别的就绪任务。

第8章μC/OS-II在ARM7上的移植

1.填空题

(1)ChangeToUSRMode()

(2)OS_ENTER_CRITICAL()OS_EXIT_CRITICAL()

(3)①编写或获取启动代码;②挂接SWI软件中断;③中断及时钟节拍中断;④编写应用程序。

2.选择题

(1)B

(2)C(3)B

3.简答题

(1)移植的概念是什么?

略。

(2)μC/OS—II移植的前提是什么?

写出移植的主要内容.

略.

(3)移植μC/OS-II到ARM7为何使用SWI软件中断异常接口?

略.

(4)在LPC2000上编写一个简单的基于μC/OS-II的程序。

略.

第9章综合实例――超声波测距仪设计

1.简答题

(1)列举几个常用的温度传感器。

热电偶、DS18B20、热电阻RTD、AD590

(2)反相器74LS04在发射电路中的作用是什么?

略。

(3)请设计出该系统的电源电路。

略。

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 医药卫生 > 基础医学

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1