嵌入式系统学习

news/2024/11/8 3:08:49/

5.嵌入式系统

对于嵌入式系统来说

首先有硬件 例如 处理器 计时器 中断控制器 输入输出设备 记忆 和接口

然后有软件 可以同时(concurrently)执行一系列任务或多个任务

还有实时操作系统RTOS (real-time operating system)RTOS决定着这个系统的工作方式

它超过了应用软件,小型的嵌入式系统不需要RTOS,它在应用程序执行期间设置规则

一个嵌入式系统的软件设计主要由以下三个限制(constraints)

可获得的系统记忆 可获得的处理速度 可控的能量散耗(dissipation)

不同的处理器

1.GPP(general purpose processor)通用处理器

微处理器 (microprocessor) 微控制器(microcontroller)嵌入式处理器(EP)

数码信号处理器(digital signal processor)

2.ASSP(application specific system processor)

3.multi-processor system

微控制器包含微处理器 微控制器如下图所示,剩下的多种通用处理器可以参考教材

peripheral是外围设备

EP的实例设备有ARM7 INTEL i960 AMD29050

ARM Processor ARM处理器

ARM Cortex-M3结构

用于指令和数据的不同总线–哈佛体系结构

ICode总线:从闪存ROM获取指令

DCode总线:从闪存ROM获取数据或调试信息

系统总线:从RAM或I/O端口读取/写入数据

ISA指令集结构对一个简单电脑

指令作为程序存储在RAM或ROM中

下一条指令的地址由程序计数器(PC)提供program counter

PC和相关控制逻辑是控制单元的一部分

典型的指令指定:

要使用的操作数

待执行的操作

将结果放置在何处,或下一步执行哪条指令

(program status register)程序状态寄存器(PSR)包含有关指令结果的信息,例如,结果是否为零

执行一个指令的步骤

(effective address register)有效地址寄存器(EAR):包含用于获取当前指令所需数据的内存地址

RISC(精简指令集计算)和CISC(复杂指令集计算)比较

RICS

指令不能读取和写入内存中的

同一总线周期

❖ 只有加载和存储(store)指令才能访问内存(memory)

❖ 小型指令集

❖ 固定尺寸指令

❖ 极少数寻址模式

❖ 许多相同的通用寄存器

CISC

长度可变的复杂指令

❖ 大指令集

❖ 多种寻址方式(addressing mode)

❖ 许多指令可以访问内存

❖ 指令可以在同一总线周期中读取和写入内存

❖ 越来越多的专用寄存器(仅数据或仅地址)

易于流水线 easy topipeline

ISA例子

RISC

ARM  

Sun SPARC  

MIPS RX000(使用32位微控制器)

IBM PowerPC(过去在Macintosh中使用)

 Microchip PIC16(通常八位微控制器)

CISC

英特尔(Intel)x86和奔腾(Pentium)系列

Motorola 68000(用于原始Macintosh)

DEC VAX

微处理器

SHARC是来自模拟设备的数字信号处理器(digital signal processor)(DSP)的一个例子。这是一个专门的设备,可以非常快速地为DSP进行计算

流水线可以增加吞吐量,但不会减少总吞吐量任务的计算时间

❖每200ps就有一个答案,但是

❖一次计算仍然需要1ns

❑限制:

❖计算必须可分为阶段大小

❖管道寄存器增加了开销

(了解内容)

为什么使用ARM

世界上许可证最多、使用最广泛的处理器内核之一

核心用于不同类型的嵌入式系统

用于PDA、手机、多媒体播放器、手持游戏机、数字电视和照相机

ARM7:GBA,iPod,2000年左右的手机

ARM9:NDS、PSP、索尼爱立信、明基

ARM11:苹果iPhone、诺基亚N93、N800

75%的32位嵌入式处理器

Cortex-M3使用三级管道进行

指令执行

❖ 获取=>解码=>执行

❖ 管道设计允许有效的吞吐量

增加到每个时钟周期一条指令

❖ 允许在静止时提取下一条指令

解码或执行上一条指令

不同ARM版本

ARM体系结构已扩展到几个版本。

❖ARM7TDMI

❖ARM9-包括“Thumb”指令集

❖ARM10-用于多媒体(图形、视频等)

❖ARM11-高性能+Jazelle(Java)

❖SecureCore-用于安全应用程序(智能卡片)

❖Cortex-M-为微控制器优化

❖Cortex-A-高性能(多媒体系统)

❖Cortex-R-针对实时应用程序的

❖StrongARM-便携式

通信设备

Cortex-M系列

Cortex-M家族有几个成员:

•Cortex-M0–最小,仅56条指令

•Cortex-M0+–功能更强,但MCU的成本低于40

•Cortex-M3–原始版本,用于我们的mbed平台

•Cortex-M4–更强大的数字信号处理功能;也许包括浮点(M4F)

•Cortex-M7–功能更强大新设计更简单,耗电更少。粗略比较:

•ARM7TDMI大约有45k个门,每兆赫使用1兆瓦时钟速度

•Cortex-M0+至少需要12k门,最多需要3个微瓦每兆赫的时钟速度(部分原因是较少的门和现代设计,但主要是更小的晶体管)

5.嵌入式系统

对于嵌入式系统来说

首先有硬件 例如 处理器 计时器 中断控制器 输入输出设备 记忆 和接口

然后有软件 可以同时(concurrently)执行一系列任务或多个任务

还有实时操作系统RTOS (real-time operating system)RTOS决定着这个系统的工作方式

它超过了应用软件,小型的嵌入式系统不需要RTOS,它在应用程序执行期间设置规则

一个嵌入式系统的软件设计主要由以下三个限制(constraints)

可获得的系统记忆 可获得的处理速度 可控的能量散耗(dissipation)

不同的处理器

1.GPP(general purpose processor)通用处理器

微处理器 (microprocessor) 微控制器(microcontroller)嵌入式处理器(EP)

数码信号处理器(digital signal processor)

2.ASSP(application specific system processor)

3.multi-processor system

微控制器包含微处理器 微控制器如下图所示,剩下的多种通用处理器可以参考教材

peripheral是外围设备

EP的实例设备有ARM7 INTEL i960 AMD29050

ARM Processor ARM处理器

ARM Cortex-M3结构

用于指令和数据的不同总线–哈佛体系结构

ICode总线:从闪存ROM获取指令

DCode总线:从闪存ROM获取数据或调试信息

系统总线:从RAM或I/O端口读取/写入数据

ISA指令集结构对一个简单电脑

指令作为程序存储在RAM或ROM中

下一条指令的地址由程序计数器(PC)提供program counter

PC和相关控制逻辑是控制单元的一部分

典型的指令指定:

要使用的操作数

待执行的操作

将结果放置在何处,或下一步执行哪条指令

(program status register)程序状态寄存器(PSR)包含有关指令结果的信息,例如,结果是否为零

执行一个指令的步骤

(effective address register)有效地址寄存器(EAR):包含用于获取当前指令所需数据的内存地址

RISC(精简指令集计算)和CISC(复杂指令集计算)比较

RICS

指令不能读取和写入内存中的

同一总线周期

❖ 只有加载和存储(store)指令才能访问内存(memory)

❖ 小型指令集

❖ 固定尺寸指令

❖ 极少数寻址模式

❖ 许多相同的通用寄存器

CISC

长度可变的复杂指令

❖ 大指令集

❖ 多种寻址方式(addressing mode)

❖ 许多指令可以访问内存

❖ 指令可以在同一总线周期中读取和写入内存

❖ 越来越多的专用寄存器(仅数据或仅地址)

易于流水线 easy topipeline

ISA例子

RISC

ARM  

Sun SPARC  

MIPS RX000(使用32位微控制器)

IBM PowerPC(过去在Macintosh中使用)

 Microchip PIC16(通常八位微控制器)

CISC

英特尔(Intel)x86和奔腾(Pentium)系列

Motorola 68000(用于原始Macintosh)

DEC VAX

微处理器

SHARC是来自模拟设备的数字信号处理器(digital signal processor)(DSP)的一个例子。这是一个专门的设备,可以非常快速地为DSP进行计算

流水线可以增加吞吐量,但不会减少总吞吐量任务的计算时间

❖每200ps就有一个答案,但是

❖一次计算仍然需要1ns

❑限制:

❖计算必须可分为阶段大小

❖管道寄存器增加了开销

(了解内容)

为什么使用ARM

世界上许可证最多、使用最广泛的处理器内核之一

核心用于不同类型的嵌入式系统

用于PDA、手机、多媒体播放器、手持游戏机、数字电视和照相机

ARM7:GBA,iPod,2000年左右的手机

ARM9:NDS、PSP、索尼爱立信、明基

ARM11:苹果iPhone、诺基亚N93、N800

75%的32位嵌入式处理器

Cortex-M3使用三级管道进行

指令执行

❖ 获取=>解码=>执行

❖ 管道设计允许有效的吞吐量

增加到每个时钟周期一条指令

❖ 允许在静止时提取下一条指令

解码或执行上一条指令

不同ARM版本

ARM体系结构已扩展到几个版本。

❖ARM7TDMI

❖ARM9-包括“Thumb”指令集

❖ARM10-用于多媒体(图形、视频等)

❖ARM11-高性能+Jazelle(Java)

❖SecureCore-用于安全应用程序(智能卡片)

❖Cortex-M-为微控制器优化

❖Cortex-A-高性能(多媒体系统)

❖Cortex-R-针对实时应用程序的

❖StrongARM-便携式

通信设备

Cortex-M系列

Cortex-M家族有几个成员:

•Cortex-M0–最小,仅56条指令

•Cortex-M0+–功能更强,但MCU的成本低于40

•Cortex-M3–原始版本,用于我们的mbed平台

•Cortex-M4–更强大的数字信号处理功能;也许包括浮点(M4F)

•Cortex-M7–功能更强大新设计更简单,耗电更少。粗略比较:

•ARM7TDMI大约有45k个门,每兆赫使用1兆瓦时钟速度

•Cortex-M0+至少需要12k门,最多需要3个微瓦每兆赫的时钟速度(部分原因是较少的门和现代设计,但主要是更小的晶体管)


http://www.ppmy.cn/news/291358.html

相关文章

游戏分类

文章目录 游戏分类思维导图详细介绍游戏平台游戏载体电子游戏非电子游戏 游戏内容角色扮演类游戏模拟类游戏策划类游戏冒险类游戏动作类游戏 游戏对抗方式PVEPVP 游戏市场的热点 游戏分类 思维导图 详细介绍 上面是对游戏简略的分类,下面会对游戏的分类进行详细的…

万字详解自动驾驶定位技术

文章目录 车路协同自动驾驶1 高精度地图1.1 高精度地图定义及价值1.1.1 高精度地图的分层结构1.1.2 高精度地图对自动驾驶的价值1.1.3 高精度地图行业现状 1.2 高精度地图关键技术1.2.1 道路元素[图像处理](https://so.csdn.net/so/search?q图像处理&spm1001.2101.3001.70…

再转一篇,回头研究一下 用手机连接笔记本上网

问:本人经常出差,希望用手机连接笔记本进行上网和收发电邮。请指教需要何种硬件和软件。 答:目前手机配合笔记本电脑上网方法主要有三种方式:红外线接入、专用RS-232C 串行电缆接入、PC卡接入 。采用这几种方式接入Internet&…

NDS程序开发可行性分析报告

一、综述 Nintendo Double Screen (简称NDS)是日本任天堂公司于 2004年 12月 2日 所发售的一款便携式的娱乐掌机。它的最大特点是分为上下两屏,上屏为显示屏,下屏为触摸屏,并因此得名。也恰恰是这个与众不同的触摸屏,给它带来了两…

React使用Electron开发桌面端

React是一个流行的JavaScript库,用于构建Web应用程序。结合Electron框架,可以轻松地将React应用程序打包为桌面应用程序。以下是使用React和Electron开发桌面应用程序的步骤: 1. 安装Electron 首先,你需要安装Electron。在终端中…

纤亿通带您了解光开关是如何工作的?

什么是光开关?对光开关最直接的理解是用于打开或关闭光电路的装置。它由封装外壳,光学器件以及电子元器件组成。在光网络中,我们通常需要通过切换路由来保护整个网络链路。这意味着光开关的关键属性必须使其能够在一个位置长时间可靠地运行。…

光电通TOEC OEP810 打印机驱动

光电通TOEC OEP810 打印机驱动是官方提供的一款打印机驱动,本站收集提供高速下载,用于解决打印机与电脑连接不了,无法正常使用的问题,本动适用于:Windows XP / Windows 7 / Windows 8 / Windows 10 32/64位操作系统。有…

【激光与光电子进展投稿 记录】

激光与光电子进展投稿 记录 简单记录一下第一篇投稿第二篇投稿 简单记录一下 “有个外审专家拒稿是不是表示凉了?” “导师放养,外审专家说我对待文章态度堪忧,意见太多是不是表示凉了?” “复审通过的概率有多大?” …