当前位置:文档之家› 嵌入式系统C源文件结构

嵌入式系统C源文件结构

在低端嵌入式系统如51,STM32,ARM7系列等编程过程中,不同的公司有不同的固件库,有不同的工程结构。若不使用嵌入式操作系统,则应该给出一个规范化的,清晰易懂的统一文件结构,包括头文件及C 文件的包含关系、各文件功能等。

这里提出一个不带操作系统的文件结构标准。

.h与.c文件成对出现,一对文件作为一个模块。系统应分为尽量小的、相互之间联系很少的功能单一的模块。

头文件规范:

C文件规范:

与相应的头文件相同的头部说明

#include “includes.h”

接口变量、函数的定义要加入本模块的前缀,如:UART_p

内部变量、函数定义时应加入static属性,防止与其他模块重名。

特殊文件:

main.h:

此文件需定义基本变量宏,用于整个工程的变量定义,并根据CPU的不同修改比如,对于51:

typedef unsigned char u8;

typedef unsigned int u16;

typedef unsigned long u32;

typedef signed char s8;

typedef signed int s16;

typedef signed long s32;

typedef volatile unsigned char vu8;

typedef volatile unsigned int vu16;

typedef volatile unsigned long vu32;

typedef volatile signed char vs8;

typedef volatile signed int vs16;

typedef volatile signed long vs32;

#define START_TASK(x) SYS_task |= x

#define TASK_××//必须是2的幂次

main.c:

RCC_Configuration(); //最先初始化芯片时钟

NVIC_Configuration();

GPIO_Configuration();

uart_initial();

//最后初始化系统时钟

while(1)

{

for(i=0;i<100;i++)

{

if(SYS_task & TASK_××)

{

任务函数();

SYS_task &= ~ TASK_××;

}

if(SYS_task & TASK_××)

}

SYS_idle++;

}

详解嵌入式系统的发展特点及架构

详解嵌入式系统的发展特点及架构 随着电子产品的发展,嵌入式系统已经广泛地应用我们的生活的各个领域,例如:计算机、汽车、航天飞机等等。提到嵌入式系统首先联想到单片机,是的,MCU是最基础和常用的嵌入式系统。嵌入式系统与模拟电路或其他功能电路组成的SoC(System on Chip,片上系统)或SiP(System in Package,系统级封装)在手机、机顶盒等功能复杂的产品中的应用也越来越多。 嵌入式系统发展呈现如下特点:·由8位处理向32位过渡·由单核向多核过渡·向网络化功能发展·MCU、FPGA、ARM、DSP等齐头并进·嵌入式操作系统呈多元化趋势所有的嵌入式处理器都是基于一定的架构的,即IP核(Intellectual Property,知识产权),生产处理器的厂家很多,但拥有IP核的屈指可数。有自己的IP核,光靠卖IP核即可坐拥城池。嵌入式系统的架构有专有架构和标准架构之分,在MCU(微控制器)产品上,像瑞萨(Renesas)、飞思卡尔(Freescale)、NEC都拥有自己得专有IP核,而其他嵌入式处理器都是基于标准架构。 标准的嵌入式系统架构有两大体系,目前占主要地位的是所谓RISC(Reduced Instruction Set Computer,精简指令集计算机)处理器。RISC体系的阵营非常广泛,从ARM、MIPS、PowerPC、ARC、Tensilica等等,都是属于RISC处理器的范畴。不过这些处理器虽然同样是属于RISC体系,但是在指令集设计与处理单元的结构上都各有不同,因此彼此完全不能兼容,在特定平台上所开发的软件无法直接为另一硬件平台所用,而必须经过重新编译。 其次是CISC(Complex Instruction Set Computer,复杂指令集计算机)处理器体系,我们所熟知的Intel的X86处理器就属于CISC体系,CISC体系其实是非常低效率的体系,其指令集结构上背负了太多包袱,贪大求全,导致芯片结构的复杂度被极大的提升。过去被应用在嵌入式系统的X86处理器,多为旧世代的产品,比如说,工业计算机中仍可常见数年前早已退出个人计算机市场的Pentium3处理器。由于此世代的产品效能与功耗比可以说是过去X86体系的甜蜜点,加上已经被市场长久验证,稳定性高,故常被应用于效能需求不高,但稳定性要求高的应用中,如工控设备等产品。 1、RISC家族之ARM处理器 ARM 公司于1991年成立于英国剑桥,主要出售芯片设计技术的授权。目前,采用ARM技术智能财产(IP)核心的处理器,即我们通常所说的ARM处理器,已遍及工业控制、消费类电子产品、通信系统、网络系统、无线系统等各类产品市场,基于ARM技术的处理器应用约占据了32位RISC微处理器75%以上的市场,ARM技术不止逐步渗入到我们生活的各个方面,我们甚至可以说,ARM 于人类的生活环境中,已经是不可或缺的一环。 目前市面上常见的ARM处理器架构,可分为ARM7、ARM9以及ARM11,新推出的Cortex系列尚在进行开发验证,市面上还未有相关产品推出。ARM也是嵌入式处理器中首先推出多核心架构的厂商。ARM 首个多核心架构为ARM11 MPCore,架构于原先的ARM11处理器核心之上。ARM11核心是发布于2002年10月份,为了进一步提升效能,其管线长度扩展到8阶,处理单元则增加为预取、译码、发送、转换/MAC1、执行/MAC2、内存存取/MAC3和写入等八个单元,体系上属于ARM V6指令集架构。ARM11采用当时最先进的0.13μm制造制程,运行频率最高可达500到700MHz。如果采用90nm制程,ARM11核心的工作频率能够轻松达到1GHz以上—对于嵌入式处理器来说,这显然是个相当惊人的程度,不过显然1GHz在ARM11体系中不算是个均衡的设定,因此几乎没有厂商推出达到1GHz的ARM11架构处理器。 ARM11的逻辑核心也经过大量的改进,其中最重要的当属“静/动态组合转换的预测功能”。ARM11的执行单元包含一个64位、4种状态的地址转换缓冲,它主要用来储存最近使用过的转换地址。当采用动态转换预测机制而无法在寻址缓冲内找到正确的地址时,静态转换预测功能就会立刻接替它的位置。在实际测试中,单纯采用动态预测的准确率为88%,单纯采用静态预测机制的准确率只有77%,而ARM11的静/动态预测组合机制可实现92%的高准确率。针对高时脉速度带来功耗增加的问题,ARM11采用一项名为“IEM (Intelligent Energy Manager)”的智能电源管理技术,该技术可根据任务负荷情况动态调节处理器的电压,进而有效降低自身的功耗。这一系列改进让ARM11的功耗效能比得以继续提高,平均每MHz只需消耗0.6mW(有快取时为0.8mW)的电力,处理器的最高效能可达到660 Dhrystone MIPS,远超过上一代产品。至于ARM11 MPCore,其在架构上与ARM11同样属于V6指令体系。根据不同应用的需要,MPCore可以被配置为1-4个处理器的组合方式,根据官方资料,其最高性能约可达到2600 Dhrystone MIPS的程度。MPCore是标准的同质多核心处理器,组成MPCore的是4个基于ARM11架构的处理器核心,由于多核心设计的优点是在频率不变的情况下让处理器的性能获得明显提升,因此可望在多任务应用中拥有良好的表现,这一点很适合未来家庭消费电子的需要。例如,机顶盒在录制多个频道电视节目的同时,还可通过互联网收看数字视频点播节目、车内导航系统在提供导航功能的同时,仍然有余力可以向后座乘客播放各类视频码流等。 2、RISC家族之MIPS处理器 MIPS是美国历史悠久的RISC处理器体系,其架构的设计,也如美国人的性格一般,相当的大气且理想化。MIPS架构起源,可追溯到1980年代,斯坦福大学和伯克利大学同时开始RISC架构处理器的研究。MIPS公司成立于1984年,随后在1986年推出第一款R2000处理器,在1992年时被SGI所并购,但随着MIPS架构在桌面市场的失守,后来在1998年脱离了SGI,成为MIPS技术公司,并且在1999年重新制定公司策略,将市场目标导向嵌入式系统,并且统一旗下处理器架构,区分为32-bit以及64-bit两大家族,以技术授权成为主要营利模式。 MIPS除了在手机中应用得比例极小外,其在一般数字消费性、网络语音、个人娱乐、通讯、与商务应用市场有着相当不错的成绩,不过近年来因为其它IP授权公司的兴起,其占有比率稍有衰退。MIPS应用最为广泛的应属家庭视听电器(包含机顶盒)、网通产品以及汽车电子方面。对于MIPS,其核心技术强调的是多执行绪处理能力(Multiple issue,国内也通常称作多发射核技术,以下以此称谓)。一般来说,多核心与多发射是两个并不是互斥的体系,可以彼此结合,然而在嵌入式领域,ARM与MIPS这两大处理器IP厂商对这两个架构的态度不同,造成这两个架构在嵌入式市场上对抗的结果。 MIPS 的多发射体系为MIPS34K系列,此为32位架构处理器,从架构上来看,其实多发射核技术只是为了尽量避免处理单元闲置浪费而为的折衷手段,就是将处理器中的闲置处理单元,分割出来虚拟为另一个核心,以提高处理单元的利用率。在技术上,为了实现硬件多重处理,多核心与多发射两者对于软件最佳化的复杂度方面同样都比单核心架构来得复杂许多。34K核心能执行现有的对称式二路SMP操作系统(OSes)与应用软件,通过操作系统的主动管理,现有的应用软件也能善用多发射处理能力。它亦能应用在多个执行线程各自有不同角色的(AMP或非对称式多重处理)环境下。此外,34K核心能设定一或两个虚拟处理组件(VPE)以及多至5个线程内容(Thread Content),提供相当高的设计弹性。MIPS的多发射在任务切换时,有多余的硬件缓存器可以记录执行状态,避免切换任务时,因为必须重新加载指令,或者是重新执行某部分的工作,造成整个执行线程的延迟。不过即便能够达到同时执行多个任务的能力,多发射处理器本质上仍然是单核心处理器,在单一执行绪

《ARM嵌入式系统结构与编程》习题答案

1章绪论 1.国内嵌入式系统行业对“嵌入式系统”的定义是什么?如何理解?答:见教材1.1节。 2.嵌入式系统是从何时产生的,简述其发展历程。答:见教材1.1节。 3.当前最常见的源码开放的嵌入式操作系统有哪些,请举出两例,并分析其特点。 答:见教材1.2.1节的嵌入式Linux和嵌入式实时操作内核UC /OS-I 。 4.举例说明嵌入式设备在工控设备中的应用。答:见教材1.3节的“工业控制领域”。 5.未来嵌入式技术的发展趋势有哪些?答:见教材1.4节的嵌入式技术的发展趋势。 2章ARM技术与ARM体系结构 1.简述ARM处理器内核调试结构原理。答:对教材1.2节的图2-1进行描述。 2.分析ARM7TDMI-S各字母所代表的含义。答:参考教材 2.1.2 ARM核版本命名规则说明。3.ARM处理器的工作模式有哪几种,其中哪些为特权模式,哪些为异常模式,并指出处理器在什么情况下进入相应的模式。 ARM处理器共有7种工作模式: 用户模式:非特权模式,也就是正常程序执行的模式,大部分任务在这种模式下执行。在用户模式下,如果没异常发生,不允许应用程序自行改变处理器的工作模式,如果有异常发生,处理器会自动切换工作模式FIQ模式:也称为快速中断模式,支持高速数据传输和通道处理,当一个高优(fast)中断产生时将会进入这种模式。 IRQ模式:也称为普通中断模式,:当一个低优先级中断产生时将会进入这种模式。在这模式下按中断的处理器方式又分为向量中断和非向量中断两种。通常的中断处理都在IRQ 模式下进行。 SVC模式:称之为管理模式,它是一种操作系统保护模式。当复位或软中断指令执行时处理器将进入这种模式。 中止模式:当存取异常时将会进入这种模式,用来处理存储器故障、实现虚拟存储或存储保护。 未定义指令异常模式:当执行未定义指令时会进入这种模式,主要是用来处理未定义的指令陷阱,支持硬件协处理器的软件仿真,因为未定义指令多发生在对协处理器的操作上。 系统模式:使用和User模式相同寄存器组的特权模式,用来运行特权级的操作系统任务。 在这7种工作模式中,除了用户模式以外,其他6种处理器模式可以称为特权模式,在这些模式下,程序可以访问所有的系统资源,也可以任意地进行处理器模式的切换。在这6种特权模式中,除了系统模式外的其他5种特权模式又称为异常模式 4.分析程序状态寄存器(PSR)各位的功能描述,并说明C、Z、N、V在什么情况下进行置位和清零。PSR的具体格式为 V—溢出标志位 对于加/减法运算指令,当操作数和运算结果为二进制补码表示的带符号数时,V=1表示符号位溢出,其他的指令通常不影响V位。 例如:两个正数(最高位为0)相加,运算结果为一个负数(最高位为1),则符号位溢出,相应V=1。

(完整版)三级嵌入式系统

三级嵌入式系统学习总结 一第一章 1.嵌入式系统概论 嵌入式系统中的软件一般都固化在只读存储器中,用户不能随意更改其中的程序功能。 嵌入式系统的逻辑组成:1)处理器2)存储器3)I/O设备与I/O接口4)数据总线5)软件 嵌入式处理芯片有四种类型:1)微处理器2)数字信号处理器3)微控制器(单片机)4)片上系统 微控制器MCU的低端产品并不会因为高端产品的出现而衰落 在32位MCU中,绝大多数使用RAM内核 EDA:电子设计自动化 IP核可以分为三种:软核、硬核、固核 2.嵌入式系统与数字媒体 计算机中常用的最广泛的西文字符及其编码是ASCII字符集和ASCII码,即美国标准信息交换码,共有128个字符,一个字符占一个字节。 我国目前广泛使用的汉字编码国家标准有GB2312和GB18030 GB2312只有6763个汉字,不够用 GB18030字符集与国际标准UCS/Unicode字符集基本兼容。GB18030采用不等长的编码方法,单字节编码表示ASCII码,双字节编码表示汉字,与GB2312保持向下兼容,四字节编码表示其他字符 Unicode最新版本是6.3。UCS/Unicode在计算机中具体实现时采用不同的编码方案,最常用的是UTF-8和UTF-16,UTF-8采用的是单字节可变长编码;UTF-16采用的是双字节可变长编码 文本的类型可以分为简单文本、丰富格式文本、超文本 图像的数据量=图像水平分辨率*图像垂直分辨率*像素深度/8(像素深度指的是每个像素用多少个二进制数来表示) 数字视频的数据量非常大,在进行传输时必须进行压缩,压缩编码标准是国际标准化组织(ISO)制定的,其名称为MPEG。 无线局域网采用的协议主要是IEEE 802.11(俗称WIFI) 3.数字通信与计算机网络 微波是一种300MHz-300GHz的电磁波 计算机网络的组成:1)计算机等智能电子设备2)数据通信链路3)通信协议4)网络软件 以太局域网: 1)发送数据设备必须把要传输的数据分成小块(帧)进行传输,一次只能传输1帧; 2)局域网中的每一个终端都有自己唯一的标识,称为物理地址或MAC地址,在发送的每一帧数据中,必须包含自己的MAC地址和接收终端的MAC地址 3)IP协议定义了主机的概念,所有主机及使用一种统一格式的地址标识,称为IP地址。4)以太局域网大多是由集线器或者交换机组网 计算机网络的类型:1)局域网2)城域网2)广域网 IP地址分为A、B、C三类。 IP是由四段数字组成,共32位,8位一段。 A类IP段0.0.0.0 到127.255.255.255 (0段和127段不使用)

吉林大学嵌入式系统与结构考题及答案

一、单选题 1. (4分) 通常用作堆栈指针的寄存器叫什么名字? ? A. r13 ? B. r14 ? C. r15 ? D. cpsr 得分:0知识点:嵌入式系统与结构作业题收起解析答案A 解析 2. (4分) ARM使用什么样的总线协议? ? A. AMBA ? B. CAN ? C. 1553b总线 ? D. TCP/IP 得分:0知识点:嵌入式系统与结构作业题收起解析答案A 解析

(4分) 通常用作堆栈指针的寄存器叫什么名字? ? A. r13 ? B. r14 ? C. r15 ? D. cpsr 得分:0知识点:嵌入式系统与结构作业题收起解析答案A 解析 4. (4分) 根据ARM命名规则,ARM7TDMI的T代表什么意思? ? A. debug ? B. 支持Thumb指令 ? C. 多媒体处 ? D. 支持Jazelle加速 得分:0知识点:嵌入式系统与结构作业题收起解析答案B 解析 5.

当前程序状态字寄存器的名称是什么? ? A. CPSR ? B. SPSR ? C. MCR ? D. MSR 得分:0知识点:嵌入式系统与结构作业题收起解析答案A 解析 6. (4分) ARM上的外设中断,通常产生哪种异常? ? A. FIQ ? B. IRQ ? C. Data Abort ? D. SWI 得分:0知识点:嵌入式系统与结构作业题收起解析答案B 解析 7. (4分) ARM中位于主存储器和内核之间的快速存储器叫什么?

? A. Cache ? B. MMU ? C. MPU ? D. SDRAM 得分:0知识点:嵌入式系统与结构作业题收起解析答案A 解析 8. (4分) 下列哪条指令可以实现r1=r0×3? ? A. ADD r1,r0,r0,LSL#1 ? B. ADD r1,r0,r0,LSL#3 ? C. MOV r1,r0,LSL#1 ? D. MOV r1,r0,LSL#3 得分:0知识点:嵌入式系统与结构作业题收起解析答案A 解析 9. (4分) ARM上实现内存管理的单元叫什么? ? A. MMU

浅析C语言嵌入式系统编程软件设计架构

浅析C语言嵌入式系统编程软件设计架构 发表时间:2018-09-04T11:58:13.513Z 来源:《建筑学研究前沿》2018年第10期作者:田壮[导读] 一个方向是自顶向下,从抽象到具体,从最顶层的程序或者逻辑整体描述规范出发向下到具体的操作模块。 美的洗涤电器制造有限公司 528311 摘要:C语言是嵌入式软件开发使用最多的语言,主要是由于C语言兼具高低级语言的特性,简洁高效、灵活方便,支持对硬件的直接操作,但其灵活性也往往会带来复杂的代码管理和维护问题。基于此,本文就从C语言嵌入式系统编程软件设计展开分析。 关键词:C语言;嵌入式系统;编程软件设计 1、系统设计思路 1.1自顶向下与自底向上 一个方向是自顶向下,从抽象到具体,从最顶层的程序或者逻辑整体描述规范出发向下到具体的操作模块,这是目前嵌入式系统应用层开发常用的方法。在嵌入式系统设计过程中,可以将两种方法结合使用,针对硬件的操作采用自底向上,尽可能抽象出所有的元操作,应对不同上层应用的重用要求;在逻辑应用上,则采用自顶向下,对应用逻辑表达进行抽象规范,尽量使得模块划分便于开发实现、重用和维护。 1.2最优模块化 ①紧凑性,封装良好的模块决不互相暴露内部信息,也不去调用其他模块的操作实现,而是通过函数接口来相互通信; ②正交性,任何模块的功能点应当是唯一的、无歧义的,在系统中以确定无疑的方式存在。在纯正交的模块设计中,每一个操作行动只限于该项功能,系统的每一属性只有一条途径改变,不影响其他功能,这有助于将复杂的设计紧凑化。 2、嵌入式系统开发的分层架构 2.1分层原则 ①层次划分兼顾功能颗粒度和重用可能性,每层解决不同的问题,下层要能够为上层应用提供支撑,比如环境温度监测功能,可以从概念上划分为数据采集层、处理层、显示层等,层层递进实现; ②层与层之间的相关性尽量小,确保某一层的软件设计出现问题,只会影响到该层次的上下结构,不会影响到软件系统的整体; ③每层内部按照任务分解、功能优化、重用程度进行模块划分,尽量实现软件功能的高内聚、低耦合。理论上,功能分解得越简单,实现起来越容易,重复使用频次就会越高,但目标过度细化会使设计管理、功能调度的复杂度迅速上升,所以一般划分到概念上能够独立完成一项功能、与其他功能相关性合适的程度。 2.2分层设计方法 首先,采取自顶向下的方法对嵌入式系统应用需求进行梳理,抽象出不同的逻辑功能要求,明确概念层次,再转化成软件层次。 其次,采取自底向上的方法对涉及到的硬件功能进行抽象,应尽可能细化出应用开发需要的硬件操作原语。对于嵌入式系统而言,大量的开发工作是通过软件驱动底层硬件实现相应的专用功能,对硬件功能的封装既有利于降低当前系统开发的复杂度,又便于实现硬件的无关性,提高程序代码的复用性。 再次,采用自顶向下和自底向上相结合的方法,逐层检验相邻层次间的信息交互和调用关系,确保每一个上层的调用都能得到满足。 最后,对每一层的功能进行合并整合,优化功能模块设计,努力实现最优模块化。在实际系统开发中,最优模块化的过程也是对现有程序代码重用的优化选择过程。 2.3分层技术的应用 常见的功能模块划分是围绕中心处理器/控制器来设计系统逻辑架构,采用面向过程的设计思路,区分为输入/输出、应用调度、设备驱动、网络通信等功能模块。这样的划分方式能够充分利用系统的处理能力,进行精细化的存储空间管理,但也带来应用逻辑交叉重复、与硬件依赖关系强等缺点,很难进行功能拓展,代码重用性也较差。 ①应用管理层。主要实现界面交互、业务逻辑调度等功能。 ②算法协议层。主要实现模型算法、协议解析、文件管理、数据库管理等功能,如位置转换计算、罗盘指针方位计算等。 ③功能拓展层。主要实现器件的无关性,提供各种器件的通用性处理、接口访问等功能,如LCD的线、圆、矩形处理,传感器数据转换等功能。 ④硬件驱动层。主要实现硬件的无关性,提供硬件的操作原语功能,如LCD的定位、写点、写字节、传感器数据采集等功能。上述分层设计方案,将同类或相似技术实现的功能进行聚合,减少业务应用、模型算法和硬件操作之间的耦合性,避免功能在分析设计中的交叉混淆,整个应用程序的结构变得更加清晰和灵活,使得一个成熟的模型算法能够支持多个应用逻辑,一个成熟的软件功能模块能够适应不同的硬件环境,提高了软件功能模块的开发效率和可重用性。 3、基于C语言的系统软件设计 3.1代码管理 ①文件目录管理。按照分层原则组织文件目录,主程序文件、全局变量头文件放在根目录,其他文件按照应用管理层、算法协议层、功能拓展层、硬件驱动层分别存放在AppFunc、ModelFunc、HardExt、HardOpt文件夹,所有文件命名遵循统一的规范。如果有第三方的通用函数库,可以建立ComFunc文件夹来存放。这样在开发过程中,可以充分利用分层模型的优势,各层功能的开发人员可以在不同的文件夹内进行并行工作,实现工程化管理。 ②功能模块管理。为了实现模块化设计的高内聚性,应少用或不用全局变量,尽量通过函数参数来传递数据。同一类的业务应用功能、同一硬件的操作功能尽量放在同一文件内实现。上层功能模块的开发可以调用下层功能模块,下层功能模块尽量避免交叉调用或越级调用。

嵌入式系统与结构

?作业详细信息 ?单选题 ?多选题 ?判断题 ?填空题 作业>>详细信息 ?学期:141511 ?课程名称:嵌入式系统与结构 ?作业名称:嵌入式系统与结构 ?本次作业成绩:0分作业综合成绩:0分 ?本次题目信息:多选题:15 单选题:35 ?多选题个数:15个完成次数:1次 ?单选题个数:35个完成次数:1次 ?指导教师:张晋东所在学院:算机科学与技术学院 ?EMail:zhangjindong_100@https://www.doczj.com/doc/5c19190412.html, 作业>>单选题 1.r13 2.r14 3.r15 4.cpsr 1.debug 2.支持Thumb指令 3.多媒体处 4.支持Jazelle加速

1.PowerPC 2.SecurCore 3.OMAP 4.AT91 1.7 2.8 3.9 4.10 1.会 2.不会 3.根据程序的执行状态决定是否影响 4.根据执行的指令决定是否影响 1.Data Abort 2.指令预取异常 3.IRQ中断请求

4.FIQ中断请求 1.37个 2.16个 3.38个 4.39个 1.ADD 2.SUB 3.MUL 4.MOV 1.r1 2.r14 3.spsr 4.cpsr 1.MPU除有内存单元保护功能外,还具有虚拟地址到物理地址的映射 2.两种功能相同,可以在不同的芯片上集成不同的模块

3.MMU的功耗比MPU低 4.MMU除有内存单元保护功能外,还具有虚拟地址到物理地址的映射 1.32位 2.16位 3.除MOV指令32位外,其他指令均为16位 4.可以通过编译器的选项设定其是16位还是32位 1.ADD 2.SUB 3.MUL 4.MOV 1.ADD 2.SUB 3.MUL 4.MOV

嵌入式系统与结构 吉大考试题库答案

嵌入式系统与结构 1:假设r0=0x01,r1=0x03,正确执行MOV r0,r1后,r0的值为?3.0x03 2:ARM上实现内存管理的单元叫什么?1.MMU 3:ARM采用多少位的体系结构?2.32位 4:Thumb指令集的长度是多少?2.16位 5:下列描述中,哪些是正确的?1.ARM包含除法硬件 6:程序状态寄存器CPSR的C位表示什么?3.运算结果产生进位 7:指令MOV r0,r1,LSL,#3中,LSL的作用是?2.逻辑左移 8:下列哪条指令,可以实现将地址单元(r1+r2×4)的数据读到r0?1.LDR r0,[r1,r2,LSL ×2] 9:ARM使用什么样的总线协议?1.AMBA 10:用户模式下的可见通用寄存器个数为多少个?2.16个 11:处理器上电默认进入哪种状态?1.ARM 12:提供了安全解决方案的ARM系列产品是以下系列中的哪一种? 2.SecurCore 13:当前程序状态字寄存器的名称是什么?1.CPSR 14:CPSR寄存器的作用是什么?1.存储当前的处理器状态 15:下面所列指令,哪一条指令语法格式正确?2.ADD r1,r2,r3 16:ARM汇编指令中,用于实现减法运算的是哪条指令?2.SUB 17:ARM上实现内存管理的单元叫什么?1.MMU 18:ARM的全称是什么?1.Advanced RISR Machines 19:下列哪些指令可以协处理器的访问?1.MRC

20:ARM用于响应快速外部中断的处理器模式叫什么?1.FIQ 21:下面哪条指令使用了ARM中的桶型移位寄存器?3.STR r0,[r1,r2,LSL #2] 22:ARM共有几种处理器模式?1.7 23:假设r0=0x05,r1=0x03,正确执行SUB r0,r0,r1后,r0的值为?2.0x02 24:ATPCS中规定,使用哪个寄存器存放堆栈基地址?2.r13 25:如何禁止IRQ中断?1.将CPSR寄存器的I位置1 26:ATPCS中规定,用哪些寄存器传递参数?1.r0~r3 27:ARM上电后进入哪种模式?2.管理模式 28:什么样的ARM指令可以条件执行?1.所有的 29:ATPCS中规定,使用哪个寄存器存放程序的返回地址?1.r14 30:Thumb指令集的长度是多少?1.16 31:当程序直接改写cpsr来切换模式时,cpsr会被复制到spsr?2.不会32:下列哪些指令可以访问程序状态寄存器?1.MRS 33:ARM中位于主存储器和内核之间的快速存储器叫什么?1.Cache 34:ARM使用那个寄存器存放程序的返回地址?1.R14 35:ARM指令中对立即数的操作有一定限制,下面所列立即数中,属于合法立即数的是哪一个?4.0xff 4:下列那个寄存器被当作程序计数器pc?4.r15 5:对MMU和MPU的区别描述正确的是?4.MMU除有内存单元保护功能外,还具有虚拟地址到物理地址的映射功能 7:ARM中哪个异常优先级最高?1.Reset 9:ARM上电执行下列哪种异常?1.Reset

描述嵌入式系统的几个组成部分的层次结构

描述嵌入式系统的几个组成部分的层次结构,并总结她们与开发过程的关系。_百度知道 底层(硬件层):需要您自己对于硬件相当的了解,能够独立绘制PCB并进行焊接,之后调试板子,做好电路板。比如sc2410,您需要绘制至少四层PCB电路板,其中ARM核心板就是最难掌握的部分,外围电路要注意各种走线技巧等等。绘制完PCB 之后就需要您的焊接功夫。将元器件焊接在PCB上。最后调试电路板,这就是这一层设计中的收尾工作,也就是最具有挑战性的工作。调试电路需要大量的经验,对于初学者来说,需要很强的电路知识,对于硬件的性能以及应用要非常了解才行。 中间层(驱动层):电路板已经有现成的。您需要编程使一个死的板子,活起来,就就是把程序下载进去,能叫板子跑起来。这里需要您对于ARM芯片的结构有很好的掌握,要会读芯片资料(datasheet)通常都就是英文的。了解其内部资源我们就可以进行驱动编程了。我们平时所使用单片机,一般都就是写好的程序,各个管脚在什么时序下输出什么信号(1或0),来操作实现相应借口的外围设备,比如液晶屏、LED灯等。单片机也可以叫做简单的嵌入式。原理相同。ARM也可以向单片机一样使用,但我们更多的就是要对ARM加入操作系统的,这才就是我们最常说的嵌入式。加入操作系统了以后,芯片对于个个资源的调度有了更系统的统筹规划,可以更充分的利用ARM芯片的系统资源,提高性能,使资源合理分配。而通常的驱动就是在操作系统下工作的。比如基于LINUX或WINCE等等下的驱动程序。驱动程序就是链接硬件平台与操作系统的纽带,当然编写驱动要同时兼顾操作系统特点与硬件接口的特点。做驱动的开发,需要对于软硬件都要有所了解,其中更偏重操作系统的理解。这部分工作也就是最难做的。 上层(应用层):应用层,即我们所说的软件编程了。就相我们手机里QQ与飞信一样,我们需要根据我们手机的操作系统来编写应用程序。对于各个开发板,我们同样需要根据它里边的系统进行应用开发。这部分,应该就是几乎脱离硬件了,我们只需简单的了解硬件即可。我们只需深刻理解操作系统的中各个系统函数与接口函数,即可进行开发。需要很强的C++水平。 以上就是我总结出的一些东西,希望对于楼主能有所帮助。 嵌入式系统的硬件基本结构与软件层次结构 - Veket的专栏 - 博客频道 嵌入式系统就是专用计算机应用系统,它具有一般计算机组成的共性,也就是由硬件与软件组成。本文完整地描述了嵌入式系统的软硬件各部分的组成结构。 嵌入式系统的硬件基本结构

嵌入式系统

第一章绪论 1.嵌入式系统的定义、特点和分类 2.嵌入式操作系统 3.嵌入式系统的选型 4.嵌入式系统的发展趋势 5.嵌入式系统的关键技术 6.嵌入式系统的应用 思考与练习 1.什么是嵌入式系统?嵌入式系统的特点是什么? 2.请说出嵌入式系统与其它商用计算机系统的区别。 3.嵌入式系统的关键技术有哪些? 4.请说明嵌入式系统技术发展及开发应用的趋势。 5.你知道嵌入式系统在我们日常生活中哪些设备中应用?说明其采用的处理器是什么?采用的哪一个嵌入式操作系统? 6.开发嵌入式系统的计算机语言主要有哪几种?分别用在什么场合?7. 嵌入式系统和专用集成电路的关系是什么? 第二章嵌入式系统设计方法 1. 需求分析与系统分析法 2.软硬件协同设计方法 3.嵌入式硬件开发方法 4.嵌入式软件开发方法 5.构件式开发方法 6.软件调试与软件测试方法 思考与练习 1.请说出嵌入式系统设计的主要方法及设计流程。在嵌入式系统开发的总体设计中,需要进行哪几方面的工作? 2.嵌入式硬件调试的主要方法及技术手段有哪些? 3.什么是构件式开发方法?说明该方法对嵌入式系统开发具有什么意义,并举例说明。4.需求分析阶段分为哪几个步骤?每个步骤完成什么工作? 5.在进行系统设计时,概要设计和详细设计的工作内容有什么不同? 6.在嵌入式系统实现阶段,需要选择开发平台,通常开发平台的选择包括哪些内容?7.在当今IT 时代,为了使产品尽快进入市场,就产品开发阶段,你认为有哪些方法可以加快产品的开发速度? 8.什么是“黑盒”测试?什么是“白盒”测试?什么是“灰盒”测试? 9.嵌入式系统开发中,使用软件组件技术有什么好处? 10.什么是知识产权核(Intellectual Property Core,简称IP Core)?指出“软知识产权核(Soft IP Core)”、“硬知识产权核(Hard IP Core)”、“固知识产权核(Firm IP Core)”的意义和差别。 11.根据嵌入式软件开发的不同阶段,嵌入式开发工具有哪些种类? 12.从底层硬件到上层应用,嵌入式软件的开发可以分为哪几种? 13.什么是交叉开发环境? 14.什么是OCD 调试方法?指出OCD 的主要形式JTAG 和BDM 的特点和区别? 15.嵌入式软件的调试运行环境和固化运行环境主要区别是什么?

嵌入式系统架构发展趋势及比较分析

嵌入式系统架构发展趋势及比较分析 范虎 嵌入式系统已经广泛地应用到当今各个领域,与我们的生活息息相关,小到掌上的数字产品,大到汽车、航天飞机。提到嵌入式系统我们很快会联想到单片机,不错,MCU是最基础和常用的嵌入式系统,但是目前像FPGA、ARM、DSP、MIPS 等其他嵌入式系统应用也越来越广泛。 总的来说,嵌入式系统发展呈现如下特点:·由8位处理向32位过渡·由单核向多核过渡·向网络化功能发展·MCU、FPGA、ARM、DSP等齐头并进·嵌入式操作系统呈多元化趋势,所有的嵌入式处理器都是基于一定的架构的,即IP 核(IntellectualProperty,知识产权),生产处理器的厂家很多,但拥有IP 核的屈指可数。嵌入式系统的架构有专有架构和标准架构之分,在MCU(微控制器)产品上,像瑞萨(Renesas)、飞思卡尔(Freescale)、NEC等都拥有自己的专有IP核,而其他嵌入式处理器都是基于标准架构。 标准的嵌入式系统架构有两大体系,目前占主要地位的是所谓RISC (ReducedInstructionSetComputer,精简指令集计算机)处理器。RISC体系的阵营非常广泛,从ARM、MIPS、PowerPC、ARC、Tensilica等等,都是属于RISC 处理器的范畴。不过这些处理器虽然同样是属于RISC体系,但是在指令集设计与处理单元的结构上都各有不同,因此彼此完全不能兼容,在特定平台上所开发的软件无法直接为另一硬件平台所用,而必须经过重新编译。 其次是CISC(ComplexInstructionSetComputer,复杂指令集计算机)处理器体系,我们所熟知的Intel的X86处理器就属于CISC体系,CISC体系其实是比较低效率的体系,但由于其已经被市场长久验证,稳定性高,故常被应用于效能需求不高,但稳定性要求高的应用中,如工控设备等产品。 下面将简单介绍一下几种比较常见的RISC和CISC嵌入式系统架构。 1、RISC家族之ARM处理器 ARM公司于1991年成立于英国剑桥,主要出售芯片设计技术的授权。目前,采用ARM技术(IP)核心的处理器,即我们通常所说的ARM处理器,已遍及工业控制、消费类电子产品、通信系统、网络系统、无线系统等各类产品市场,基于ARM技术的处理器应用约占据了32位RISC微处理器75%以上的市场。 目前市面上常见的ARM处理器架构,可分为ARM7、ARM9,ARM11以及Cortex 系列。ARM也是嵌入式处理器中首先推出多核心架构的厂商。ARM首个多核心架构为ARM11MPCore,架构于原先的ARM11处理器核心之上。ARM11采用当时最先进的0.13μm制造制程,运行频率最高可达500到700MHz。如果采用90nm制程,ARM11核心的工作频率能够轻松达到1GHz以上—对于嵌入式处理器来说,这显然是个相当惊人的程度。

嵌入式系统架构的发展趋势及比较分析

主要是处理器不一样,一般嵌入式系统用的是arm架构的处理器,属于专用处理器。一般的PC机用的是X86架构的处理器(intel、amd)属于通用处理器。 你可以把arm嵌入式系统看成是一个专用的pc。它比通用pc机所消耗的硬件资源要少。由于在一些特定的场合需要实现一些智能的操纵,使用通用pc机不合算(成本),使用嵌入式系统可以基本满足需要。显然,嵌入式系统的操作系统和硬件资源相对于pc机来说是进过精简的。 应用场合、系统结构、知识背景等等:百度百科上说的就很详细(直接百度百科“嵌入式系统”),这里不在累赘了。以看pc机的眼光看嵌入式系统就很简单了。 嵌入式系统架构的发展趋势及比较分析 嵌入式系统已经广泛地应用到当今各个领域,与我们的生活息息相关,小到掌上的数字产品,大到汽车、航天飞机。 提到嵌入式系统我们很快会联想到单片机,不错,MCU是最基础和常用的嵌入式系统,但是目前像FPGA、ARM、DSP、MIPS等其他嵌入式系统应用越来越广泛。嵌入式系统与模拟电路或其他功能电路组成的SoC(System on Chip,片上系统)或SiP(System in PAC kage,系统级封装)在手机、机顶盒等功能复杂的产品上的应用也越来越多。 总的来说,嵌入式系统发展呈现如下特点: ·由8位处理向32位过渡 ·由单核向多核过渡 ·向网络化功能发展 ·MCU、FPGA、ARM、DSP等齐头并进 ·嵌入式操作系统呈多元化趋势 所有的嵌入式处理器都是基于一定的架构的,即IP核(Intellectual Property,知识产权),生产处理器的厂家很多,但拥有IP核的屈指可数。有自己的IP核,光靠卖IP 核即可坐拥城池。 嵌入式系统的架构有专有架构和标准架构之分,在MCU(微控制器)产品上,像瑞萨(Renesas)、飞思卡尔(Freescale)、NEC都拥有自己得专有IP核,而其他嵌入式处理器都是基于标准架构。本文讨论仅讨论标准架构的嵌入式系统。 标准的嵌入式系统架构有两大体系,目前占主要地位的是所谓RISC(Reduced Instruction Set Computer,精简指令集计算机)处理器。RISC体系的阵营非常广泛,从ARM、MIPS、PowerPC、ARC、Tensilica等等,都是属于RISC处理器的范畴。不过

嵌入式系统的概念

嵌入式系统的概念 一、嵌入式系统的概念着重理解嵌入的概念主要从三个方面上来理解。 1、从硬件上,将基于CPU 的处围器件,整合到CPU 芯片内部,比如早期基于 X86 体系结构下的计算机,CPU 只是有运算器和累加器的功能,一切芯片要造 外部桥路来扩展实现,象串口之类的都是靠外部的16C550/2 的串口控制器芯 片实现,而目前的这种串口控制器芯片早已集成到CPU 内部,还有PC 机有显卡,而多数嵌入式处理器都带有LCD 控制器,但某种意义上就相当于显卡。 比较高端的ARM 类Intel Xscale 架构下的IXP 网络处理器CPU 内部集成PCI 控制器(可配成支持4 个PCI 从设备或配成自身为CPI 从设备);还集成3 个NPE 网络处理器引擎,其中两个对应于两个MAC 地址,可用于网关交换用, 而另外一个NPE 网络处理器引擎支持DSL,只要外面再加个PHY 芯片即可以 实现DSL 上网功能。IXP 系列最高主频可以达到1.8G,支持2G 内存, 1G&TImes;10 或10G&TImes;1 的以太网口或Febre channel 的光通道。IXP 系列应该是目标基于ARM 体系统结构下由intel 进行整合后成Xscale 内核的最高 的处理器了。2、从软件上前,就是在定制操作系统内核里将应用一并选入, 编译后将内核下载到ROM 中。而在定制操作系统内核时所选择的应用程序组 件就是完成了软件的嵌入,比如WinCE 在内核定制时,会有相应选择,其中 就是wordpad,PDF,MediaPlay 等等选择,如果我们选择了,在CE 启动后,就 可以在界面中找到这些东西,如果是以前PC 上将的windows 操作系统,多半 的东西都需要我们重新再装。3、把软件内核或应用文件系统等东西烧到嵌入 式系统硬件平台中的ROM 中就实现了一个真正的嵌入。以上的定义是我在 6、7 年前给嵌入式系统下自话侧重于理解型的定义,书上的定义也有很多,但 在这个领域范围内,谁都不敢说自己的定义是十分确切的,包括那些专家学者

如何正确的设计嵌入式软件架构应该这么做

如何正确的设计嵌入式软件架构应该这么做 一 错误的示范 近公司新招了一个做嵌入式软件开发的同事,该同事是从上海的某一个上市公司出来的,因为我们这边人手不够,因此把他安排了去负责一个新产品的研发,前期让他负责加速度计、NB-IOT、舵机、外置Flash的功能测试,测试完成之后,准备让他做一个该产品的概要设计。然后他花了2个星期的时间,给我们写出来一个概要设计,说实话,我看到这个概要设计,我就觉得是刚毕业的大学生写的。版本一的架构设计 2.1系统体系结构系统分为两层:硬件驱动层、应用层。2.1.1硬件驱动层硬件驱动层包含板载硬件资源正常运行所需的所有驱动程序。1)MCU初始化2)I2C数据存取3)SPI数据读取4)加速度计初始化5)蓝牙模块启动6)BC95模块启动7)485通讯模块启动2.2.2应用层1)Mcu运行模式切换2)震动及倾斜3)数据解析4)开/关锁5)数据发送6)历史数据保存 看到版本一的架构设计之后,说实话,我还是第一次见到这样来写架构设计的,居然是以序号来写的,这个让别人读起来,特别的别扭。版本二的架构设计 看到版本二的架构设计之后,虽然颇感欣慰,但是想到达到我们所要求的,还要很大的一段距离,该架构设计,主要有以下几点问题:1.对架构的理解还不是很清晰,既然是做架构设计,那就应该从整体来看,而不是仅仅只是局限于一个模块,或者功能里面。2.还是每个层次的理解也还不是很清晰,比如讲MCU的初始化,归于硬件驱动层里面。MCU 的初始化,严格意义上来说,是属于流程的一部分了,而不是驱动。比如电脑的开启启动,把这个归于硬件的驱动里面,肯定是属于牛头不对马嘴的。3.还有就是各个模块的启动,也是不能属于硬件驱动层的,也都是业务流程的一部分了,都不应该属于驱动层的一部分。 4.还有就是总线数据的读写,虽然驱动的作用也就是读写,但是数据总线的读写不能写成硬件驱动。 5.应用层的系统参数初始化,也还是属于流程。 6.数据的解析和数据的发生,都是属于通信功能里面的,不应该单独独立出来,属于单个的应用。

(完整版)嵌入式系统课后答案马维华

第1章嵌入式系统概述 1,什么是嵌入式系统嵌入式系统的特点是什么 嵌入式系统概念: (1) IEEE对嵌入式系统的定义:用于控制,监视或者辅助操作机器和设备的装置. (2)一般定义:以应用为中心,以计算机技术为基础,并且软硬件可裁剪,适用于应用系统对功能,可靠性,成本,体积,功耗有严格要求的专用计算机系统. 嵌入式系统的特点: (1) 专用的计算机系统 (2) 必须满足环境要求 (3) 必须能满足对象系统的控制要求 (4) 是集成计算机技术与各行业应用的集成系统 (5) 具有较长的生命周期 (6) 软件固化在非易失性存储器中 (7) 必须能满足实时性要求 (8) 需要专用开发环境和开发工具 2,简单分析几种嵌入式操作系统的主要特点,包括嵌入式Linux,Windows CE,uCOS II 及VxWorks. (1)嵌入式Linux:有多个主流版本,根据应用需求,性能略有差别.μCLinux是Linux小型化后,适合于没有MMU的微处理器芯片而裁剪成的操作系统,μCLinux保持了传统Linux操作系统的主要特性,包括稳定,强大的网络和文件系统的支持,μCLinux裁剪了大量的Linux内核以缩小尺寸,适合像512KB RAM,1MB Flash这样小容量,低成本的嵌入式系统.RT_Linux即能兼容通常的Linux,又能保证强实时性. (2)Windows CE:开发平台主要为WinCE Platform Builder,有时也用EVC环境开发一些较上层的应用.WinCE开发难度远低于嵌入式Linux,实时性略低,常用于手机,PDA等手持设备中. (3)uCOS II:结构小巧,抢先式的实时嵌入式操作系统,具有执行效率高,占用空间小,可移植性强,实时性能好和可扩展性能等优点.主要用于小型嵌入式系统. (4) VxWorks: 集成开发环境为Tornado,Vxworks因出现稍早,实时性很强,并且内核可极微(最小8K),可靠性较高等.通常应用在通信设备等实时性要求较高的系统中. 第2章嵌入式处理器体系结构 1,具体说明ARM7TDMI的含义,其中的T,D,M,I分别代表什么 ARM7TDMI是ARM7处理器系列成员之一,采用V4T版本指令.T表示Thumb,该内核可从16位指令集切换到32位ARM指令集;D表示Debug,该内核中放置了用于调试的结构,支持片内Debug调试;M表示Multiplier,支持位乘法;I表示Embedded ICE ,内含嵌入式ICE宏单元,支持片上断点和观察点. 2,ARMV4及以上版本的CPSR的哪一位反映了处理器的状态若CPSR=0x000000090,分析系统状态.CPSR=0x000000090表示当前处理器工作于ARM状态,系统处于用户模式下. CPSR的BIT5(T)反映当前处理器工作于ARM状态或Thumb状态. 3,ARM有哪几个异常类型,为什么FIQ的服务程序地址要位于0x1C 在复位后,ARM处理器处于何种模式,何种状态 ARM的7种异常类型:复位RESET异常,未定义的指令UND异常,软件中断SWI异常,指令预取中止PABT异常,数据访问中止DABT异常,外部中断请求IRQ异常,快速中断请求FIQ 异常.在有快速中断发生时,CPU从0x1C处取出指令执行.ARM复位后处于管理模式,工作于ARM状态. 4,为什么要使用Thumb模式,与ARM代码相比较,Thumb代码的两大优势是什么

相关主题
文本预览
相关文档 最新文档