嵌入式系统基础B习题及答案Word格式.docx
- 文档编号:7748148
- 上传时间:2023-05-09
- 格式:DOCX
- 页数:14
- 大小:22.94KB
嵌入式系统基础B习题及答案Word格式.docx
《嵌入式系统基础B习题及答案Word格式.docx》由会员分享,可在线阅读,更多相关《嵌入式系统基础B习题及答案Word格式.docx(14页珍藏版)》请在冰点文库上搜索。
第2章嵌入式处理器体系结构
1、具体说明ARM7TDMI的含义,其中的T、D、M、I分别代表什么?
ARM7TDMI是ARM7处理器系列成员之一,采用V4T版本指令。
T表示Thumb,该内核可从16位指令集切换到32位ARM指令集;
D表示Debug,该内核中放置了用于调试的结构,支持片内Debug调试;
M表示Multiplier,支持位乘法;
I表示EmbeddedICE,内含嵌入式ICE宏单元,支持片上断点和观察点。
10、ARMV4及以上版本的CPSR的哪一位反映了处理器的状态?
若CPSR=0x000000090,分析系统状态。
CPSR=0x000000090表示当前处理器工作于ARM状态,系统处于用户模式下。
CPSR的BIT5(T)反映当前处理器工作于ARM状态或Thumb状态。
11、ARM有哪几个异常类型,为什么FIQ的服务程序地址要位于0x1C?
在复位后,ARM处理器处于何种模式,何种状态?
ARM的7种异常类型:
复位RESET异常、未定义的指令UND异常、软件中断SWI异常、指令预取中止PABT异常、数据访问中止DABT异常、外部中断请求IRQ异常、快速中断请求FIQ异常。
在有快速中断发生时,CPU从0x1C处取出指令执行。
ARM复位后处于管理模式,工作于ARM状态。
12、为什么要使用Thumb模式,与ARM代码相比较,Thumb代码的两大优势是什么?
为了兼容数据总线宽度为16位的应用系统,使用了ARM指令系统的一个子集Thumb指令系统。
与等价的32位代码相比,Thumb指令集在保留32位代码优势时,大大节省了系统的存储空间。
13、说明AMBA、AHB、ASB以及APB的英文全称及其含义。
AMBA(AdvancedMicrocontrollerBusArchitecture)即先进的微控制器总线体系结构,是ARM公司公布的总线标准,这一标准定义了AHB、ASB、APB及AMBA共4种高性能的系统总线规范。
AHB(AdvancedHigh_performanceBus)先进的高性能总线,用于连接高性能系统组件或高宽带组件。
它支持突发数据传输方式及单个数据传输方式,所有时序参考同一个时钟。
ASB(AdvancedSystemBus)即先进的系统总线,用于连接高性能的系统模块。
它支持突发数据传输。
APB(AdvacnedPeripheralBus)即先进的外围接口总线,是一个简单的接口。
它支持低性能的外围接口,APB是用来连接系统的周边组件。
16、简述MMU从虚拟地址到物理地址的转换过程和方法。
虚拟地址到物理地址的转换过程:
当ARM要访问存储器时,MMU先查找TLB中的虚拟地址表,如果ARM的结构支持分开的地址TLB和指令TLB,那么它在取指令时使用指令TLB,其它的所有访问类别使用数据TLB;
如果TLB中没有虚拟地址的入口,则是转换表遍历硬件从存储在主存储器中的转换表中获取访问权限,一旦取到,这些信息放在转换TLB中,它会放在1个没有使用的入口处或覆盖1个已有的入口。
虚拟地址到物理地址的转换方法:
(1)确定1级页表的基地址。
(2)合成转换表的1级描述符。
(3)根据不同的1级描述符获取第2级描述符地址并找出第2级描述符。
(4)将第2级页描述符指示的页基地址,与虚拟地址指示的页内偏移地址相加,得到相应页的物理地址,完成虚拟地址到物理地址的转换。
第三章典型嵌入式处理器
1、简述LPC2000系列微控制器的内部有哪些重要的外设组件?
向量中断控制器、外部存储控制器、I2C中行总线控制器、SPI同步接口控制器、UART串口控制器、定时器、AD转换器、CAN总线控制器、看门狗定时器等。
8、S3C44B0X如何组织8、16、32位的存储器,地址线如何连接?
S3C44B0X不同宽度的存储器地址线连接方法。
存储器地址引脚
8位总线
16位总线
32位总线
A0
A1
A2
A3
A4
A5
…
Am-1
Am-2
Am-3
18、说明I2C的数据有效性和起停条件。
数据有效性:
当SCL信号为高电平时,SDA上的数据传输有效,传输时高位在前,低位在后,每个字节长度限制为位,而每次传送的字节总数没有限制。
满足启动条件后的第一个字节应为地址域。
每一个字节有一个应答位。
起停条件:
启动条件,在SCL信号保持高电平时SDA信号由高电平变为低电平;
停止条件,要求在SCL信号保持高电平时SDA信号由低电平变为高电平。
26、简述AT91FR40162处理器的特点。
AR91FR40162采用ARM7TDMI处理器核,内部集成了256KB的片内SRAM和1024K字的16位Flash存储器、完全可编程的外部总线接口,8个优先级且可以独立屏蔽的向量中断控制器、32个可编程的I/O接口线、3通道16位定时/计数器、2个同步/异步收发器及可编程的看门狗定时器,能完成全静态操作,具有先进的省电特性。
第四章嵌入式处理器指令系统
1、填空题
(1)在源操作数为立即数时,应在前加#作为前缀,在#后加0x或&
表示十六进制数,在#后加%表示二进制数,#后加0d或默认表示十进制数。
(2)根据堆栈指针指向的数据位置不同,堆栈可分为满堆栈和空堆栈。
(3)用一条指令完成人条件加法运算,并更新CPSR中的条件码,R1+R2->
R3ADDSR3,R1,R2。
(4)在程序执行过程中,是通过寄存器R15控制程序的运行的。
(5)转移指令的跳转范围是-32MB-32MB。
2、选择题
(2)堆栈随着存储器地址的增大而向上增长,基址寄存指向存贮有效数据的最高地址或者说指向第一个要读出的数据位置,是(A)堆栈。
A、满递增B、空递增C、满递减D、空递减
(3)在指令LDRR0,[R1,#4]!
执行后,R1中的值为(C)。
A、R1不变B、R1=R1+1C、R1=R1+4D、R1=4
3、说明下列指令完成的功能
(1)ADDR0,R1,R3,LSL#2;
R0=R1+4R2
(2)ANDNESR0,R1,#0x0F;
if(CPSR寄存器中Z=0)R1的高28位清零后送寄存器R0并更新CPSR寄存器,else执行下一条指令。
(3)LDRBR0,[R1,R2,LSR#2];
把存储器地址为(R1+R2>
>
2)的字节数据加载到R0,R0的高24位清零。
(4)ADCHIR1,R2,R3;
if(CPSR寄存器中Z=0并且C=1)执行R1=R2+R3加法操作,else执行下一条指令。
(5)EORR0,R0,R3,RORR4;
R3寄存器中的内容根据R4寄存器中的内容循环右移后与R0寄存器进行逻辑异或操作后,其结果存在R0寄存器内。
(7)MLAR0,R1,R2,R3;
R0=R1×
R2+R3MLA是32位乘加指令,运算结果的高32位自动丢掉。
(8)LDRR1,[R0,-R5,LSL#4];
将存储器地址为R0-16R5的字数据加载到寄存器R1中。
4、用汇编语言实现下列功能的程序段,令R1=a,R2=b。
(1)if(a!
=b)&
a-b>
5))a=a+b
CMPR1,R2
BEQNext
ADDR3,R2,#5
CMPR1,R3
BLSNext
ADDR1,R1,R2
NextBNext
(2)while(a!
=0)
{
b=b+b*2;
a--;
}
AREATestWhile,CODE,READONLY
aequ5
bequ1
ENTRY
MOVR1,#a
MOVR2,#b
LOOPCTLCMPR1,#0
ADDNER2,R2,R2,LSL#1
SUBNESR1,R1,#1
BNELOOPCTL
END
(3)从a所指向的地址,拷贝20个32位数据到b所指向的地址
AREADataCopy,CODE,READONLY
ENTRY
LDRR0,=SrcData
LDRR1,=DstData
MOVR2,#20
LOOPCTLLDRR3,[R0],#4
STRR3,[R1],#4
SUBSR2,R2,#1
BNELOOPCTL
WaitBWait
AREADataDef,DATA,READWRITE
SrcDataDCD1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20
DstDataSPACE4*10
END
6、试比较TST与ANDS,CMP与SUBS,MOV与MVN指令的区别。
(1)TST指令把两个操作数进行按位的与操作,并根据运算结果更新CPSR中的条件标志位的值。
该指令通常用来检测是否设置了特定的位,一般操作数1是要测试的数据,而操作数2是一个位掩码。
ANDS指令用于在两个操作数上进行逻辑与运算,并把结果放到目的寄存器中,操作数1应是一个寄存器,操作数2可以是一个寄存器,被移位的寄存器,或是1个立即数。
该指令常用于设置操作数1的某些位。
TST和ANDS两条指令都影响CPSR寄存器;
TST指令不改变参与运算的数据,而ANDS指令对目的寄存器进行更新。
(2)CMP指令用于把2个操作数进行比较,同时更新CPSR中条件标志位的值。
该指令进行一次减法运算,但不保存运算结果,只更改条件标志位。
标志位表示的是操作数1和操作数2的关系(大、小、相等)。
SUBS指令用于把操作数1送去操作数2,并将结果存放到目的寄存器中。
操作数1应是一个寄存器,操作数2可以是一个寄存器、被移位的寄存器、或是一个立即数。
指令影响CPSR值。
CMP和SUBS指令都影响CPSR寄存器;
CMP指令不保存运算结果,而SUBS指令可以保存运算结果,并且减数和被减数的值也不发生变化。
(3)MOV指令将一个寄存器、被移位的寄存器或一个立即数的值装入目的寄存器内,可以指定相同的寄存器实现NOP的效果,还可以移位一个寄存器。
MVN指令与MOV指令的不同之处是在传送数据之前先按位取反,即把一个被取反的值传送到目的寄存器中。
8、写一段ARM汇编程序:
循环累加队列中的所有数据,直到碰到零值位置,结果放在R4。
源程序末尾队列如下:
Array:
DCD0x11
DCD0x22
DCD0x33
DCD0
R0指向队列头,ADRR0,ARRAY。
使用命令LDRR1,[R0],#4来装载,累加至R4,循环直到R1为0,用死循环来停止。
程序:
AREACond_Sum,CODE,READONLY
LDRR0,=Array
MOVR4,#0
LooPCtlLDRR1,[R0],#4
CMPR1,#0
ADDNER4,R4,R1
BNELooPCtl
WaitBWait
AREASrcData,CODE,READONLY
ArrayDCD0x11
DCD0x22
DCD0x33
DCD0
9、写一个汇编程序,求一个含64个带符号的16位数组组成的队列的平方和。
AREASquareSum,CODE,READONLY
MOVR3,#4
LooPCtlLDRHR1,[R0],#2
MLAR4,R1,R1,R4
SUBSR3,R3,#1
NOP
ArrayDCD0x00010002
DCD0x00030004
END
第五章嵌入式系统程序设计基础
4、简要说明EXPORT和IMPORT的使用方法。
答:
EXPORT伪指令用于在程序中声明一个全局的标号,该标号可在其它的文件中引用。
EXPORT可用GLOBAL代替。
标号在程序中区分大小写。
[WEAK]选项声明其它的同名标号优先于该标号被引用。
IMPORT伪指令用于通知编译器要使用的标号在其它的源文件中定义,但要在当前源文件中引用,而且无论当前源文件中是否引用该标号,该标号均会被加入到当前源文件的符号表中。
5、分析说明下段程序完成什么功能
AREAChangeState,CODE,READONLY
CODE32
LDRR0,=Start+1
BXR0
CODE16
StartMOVR1,#1
END
解:
程序功能实现程序的跳转并从ARM状态切换到Thumb状态。
6、设计一段程序完成数据块的复制,数据从源数据区snum复制到目标数据区dnum。
复制时,以8个字为单位进行。
对于最后所剩不足8个字的数据,以字为单位进行复制。
AREABlockDataCopy,CODE,READONLY
numEQU20
StartLDRR0,=snum
LDRR1,=dnum
MOVR2,#num
MOVR13,#400
BlockCopyMOVSR3,R2,LSR#3
BEQCopyWords
STMFDR13!
{R4-R11}
OctCopyLDMIAR0!
STMIAR1!
SUBSR3,R3,#1
BNEOctCopy
LDMFDR13!
CopyWordsANDSR2,R2,#7
BEQStop
WordsCopyLDRR3,[R0],#4
STRR3,[R1],#4
SUBSR2,R2,#1
BNEWordsCopy
StopBStop
AREABlockData,DATA,READWRITE
snumDCD1,2,3,4,5,6,7,8,9,10,11
DCD12,13,14,15,16,17,18,19,20
dnumSPACE20*4
END
7、利用跳转表的思想编写一个汇编程序,实现当R0分别为0,1,2时完成跳转到3个不同的子程序。
AREAJumpTable,CODE,READONLY
numEQU3
StartMOVR0,#1
MOVR1,#3
MOVR2,#2
BLJumpTblCtl
JumpTblCtlCMPR0,#num
MOVHSPC,LR
ADRR3,JumpTblEntry
LDRPC,[R3,R0,LSL#2]
JumpTblEntryDCDSubroutine1
DCDSubroutine2
DCDSubroutine3
Subroutine1MOVR3,#0x55
MOVPC,LR
Subroutine2MOVR4,#0xAA
Subroutine3MOVR5,#0x5A
第六章嵌入式操作系统
2、简述μCLinux的特点,说明其主要应用的环境。
μCLinux主要是为控制领域定做的LINUX版本,其设计思想就是对标准LINUX内核进行裁剪,去除虚拟管理部分代码,并且对内存分配进行优化,以达到提高系统运行效率的目的。
特点:
(1)包含通用LINUXAPI函数。
(2)内核体积小于512KB
(3)内核及文件系统体积小于900KB
(4)具有完整的TCP/IP协议栈
(5)支持多种文件系统。
6、简述μCLinux的移植过程。
(1)配置内核
(2)编译内核
(3)下载、运行、调试内核
第七章嵌入式系统的BootLoader
2、简述BootLoader与嵌入式系统的关系。
BootLoader是在操作系统内核或用户应用程序运行之前运行的一段小程序.其作用为:
初始化硬件设备,建立内存空间的映射图,将系统的软件件环境带到一个合适的状态,为最终调用操作系统内核或用户应用程序准备好正确的环境。
3、BootLoader的主要功能有哪些?
初始化硬件设备,检测系统内存映射,将内核映像和根文件系统从Flash传到RAM空间,并为内核设置启动参数,最后调用内核。
4、BootLoader分为几个阶段,各阶段主要完成什么功能?
答:
BootLoader通常分为2个阶段。
阶段1完成基本硬件的初始化,加载阶段2的RAM空间,复制阶段2到RAM,设置堆栈指针,跳转到阶段2的C程序入口点。
在阶段2初始化阶段2要使用的硬件设备,检测系统内存映射,加载内核映像和根文件系统映像,调用内核。
第八章嵌入式系统设计
2、简述嵌入式系统设计的一般步骤。
⑴需求分析;
⑵体系结构设计;
⑶硬件、软件、执行机构设计;
⑷系统集成
⑸系统测试
3、简述软、硬件协同设计的过程。
⑵软、硬件协同设计;
⑶软、硬件实现;
⑷软、硬件协同测试和验证。
1、
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 嵌入式 系统 基础 习题 答案