嵌入式基础知识(软件|软件设计|硬件|总线逻辑)
一、嵌入式软件
嵌入式软件是指应用在嵌入式计算机系统当中的各种软件,除了具有通用软件的一般特性,还具有一些与嵌入式系统相关的特点,包括:规模较小、开发难度大、实时性和可靠性要求高、要求固化存储。
1.1 嵌入式软件分类
-
系统软件:控制和管理嵌入式系统资源,为嵌入式应用提供支持的各种软件如设备驱动程序、嵌入式操作系统(Linux、Windows、Android、iOS)、嵌入式中间件等。
-
应用软件:嵌入式系统中的上层软件,定义了嵌入式设备的主要功能和用途并负责与用户交互,一般面向特定的应用领域,如飞行控制软件、手机软件、地图等。
-
支撑软件:辅助软件开发的工具软件,如系统分析设计工具、在线仿真工具交叉编译器等。
1.2 板级支持包(BSP)
板级支持包(BSP)是介于主板硬件和操作系统中驱动层程序之间的一层,一般认为它属于操作系统一部分,主要是实现对操作系统的支持,为上层的驱动程序提供访问硬件设备寄存器的函数包,使之能够更好的运行于硬件主板。
BSP主要包括两个方面的内容:自引导加载程序BootLoader和设备驱动程序。
具体功能包括:
-
1.单板硬件初始化,主要是CPU的初始化,为整个软件系统提供底层硬件支持;
-
2.为操作系统提供设备驱动程序和系统中断服务程序;
-
3.定制操作系统的功能,为软件系统提供一个实时多任务的运行环境;
-
4.初始化操作系统,为操作系统的正常运行做好准备。
主要具有以下两个特点:
-
1.硬件相关性,因为嵌入式实时系统的硬件环境具有应用相关性,而作为上层软件与硬件平台之间的接口,BSP需为操作系统提供操作和控制具体硬件的方法
-
2.操作系统相关性,不同的操作系统具有各自的软件层次结构,因此不同操作系统具有特定的硬件接口形式。
1.3 BootLoader
BootLoader是嵌入式系统加电后运行的第一段软件代码,是在操作系统内核运行之前运行的一小段程序,通过这段程序,可以初始化硬件设备、建立内存空间的映射图,从而将系统的软硬件环境设置到一个合适的状态,以便为最终调用操作系统内核做好准备。一般包括以下功能:
-
片级初始化:主要完成微处理器的初始化,包括设置微处理器的核心寄存器和控制寄存器、微处理器的核心工作模式及其局部总线模式等。片级初始化把微处理器从上电时的默认状态逐步设置成系统所要求的工作状态。这是一个纯硬件的初始化过程。
-
板级初始化:通过正确地设置各种寄存器的内容来完成微处理器以外的其他硬件设备的初始化。例如,初始化LED显示设备、初始化定时器、设置中断控制寄存器、初始化串口通信、初始化内存控制器、、建立内存空间的地址映射等。在此过程中,除了要设置各种硬件寄存器以外,还要设置某些软件的数据结构和参数。因此,这是一个同时包含有软件和硬件在内的初始化过程。
-
加载内核(系统级初始化):将操作系统和应用程序的映像从Flash存储器复制到系统的内存当中,然后跳转到系统内核的第一条指令处继续执行。
1.4 设备驱动程序
在一个嵌入式系统当中,操作系统是可能有也可能无的。但无论如何,设备驱动程序是必不可少的。所谓的设备驱动程序,就是一组库函数,用来对硬件进行初始化和管理,并向上层软件提供良好的访问接口。
对于不同的硬件设备来说,它们的功能是不一样的,所以它们的设备驱动程序也是不一样的。但是一般来说,大多数的设备驱动程序都会具备以下的一些基本功能。
-
硬件启动:在开机上电或系统重启的时候,对硬件进行初始化。
-
硬件关闭:将硬件设置为关机状态。
-
硬件停用:暂停使用这个硬件。
-
硬件启用:重新启用这个硬件。
-
读操作:从硬件中读取数据。
-
写操作:往硬件中写入数据。
二、嵌入式软件设计
基本开发工具是交叉编译器、交叉链接器和源代码调试器。
一个典型的交叉平台开发环境,包含三个高度集成的部分:
-
1.运行在宿主机和目标机上的强有力的交叉开发工具和实用程序。
-
2.运行在目标机上的高性能、可裁剪的实时操作系统。
-
3.连接宿主机和目标机的多种通信方式,例如,以太网、USB、串口等。
2.1 编码
编辑器:用于编写嵌入式源代码程序,从理论上来说,任何一个文本编辑器都可以用来编写源代码。各种集成开发环境会提供功能强大的编辑器,如vs系列、eclipse、keil、css等。常见的独立编辑器:UE、Source insight、vim等。
2.2 交叉编译
嵌入式软件开发所采用的编译为交叉编译。所谓交叉编译就是在一个平台上生成可以在另一个平台上执行的代码。编译的最主要的工作就在将程序转化成运行该程序的CPU所能识别的机器代码,由于不同的体系结构有不同的指令系统。因此,不同的CPU需要有相应的编译器,而交叉编译就如同翻译样,把相同的程序代码翻译成不同CPU的对应可执行二进制文件。
嵌入式系统的开发需要借助宿主机(通用计算机)来编译出目标机的可执行代码。
编译器gcc:编译阶段的工作是用交叉编译工具处理源代码,生成可执行的标文件,在嵌入式系统中,由于宿主机和目标机系统不一样,需要使用交叉编译,GNU C/C++(gcc)是目前常用的一种交叉编译器,支持非常多的宿主机/目标机组合。
2.3 交叉调试
嵌入式软件经过编译和链接后即进入调试阶段,调试是软件开发过程中必不可少的一个环节,嵌入式软件开发过程中的交叉调试与通用软件开发过程中的调试方式有很大的差别。
在嵌入式软件开发中,调试时采用的是在宿主机和目标机之间进行的交叉调试调试器仍然运行在宿主机的通用操作系统之上,但被调试的进程却是运行在基于特定硬件平台的嵌入式操作系统中,调试器和被调试进程通过串口或者网络进行通信,调试器可以控制、访问被调试进程,读取被调试进程的当前状态并能够改变被调试进程的运行状态。
调试器gdb:gdb是GNU开源组织发布的一个强大的程序调试工具
三、嵌入式系统硬件的分类
- 根据嵌入式微处理器的字长宽度,可分为4位、8位、16 位、32 位和64 位。
-
16 位及以下的称为嵌入式微控制器(Embedded Micro Controller);
-
32 位及以上的称为嵌入式微处理器。
-
- 按系统集成度划分,可分为两类:
-
一种是微处理器内部仅包含单纯的中央处理器单元,称为一般用途型微处理器;
-
另一种则是将CPU、ROM、RAM 及1/0 等部件集成到同一个芯片上,称为单芯片微控制器(Single chipMicrocontroller)。
-
3.1 根据用途分类
-
嵌入式微控制器MCU;
-
嵌入式微处理器MPU;
-
嵌入式数字信号处理器DSP;
-
嵌入式片上系统SOC等。
-
微控制器(Microcontroller Unit,MCU):又称单片机,把核心存储器和部分外设封装在片内。优点是单片化、体积小、功耗和成本下降,可靠性提高。包括 8501,P5IXA,MCS-251,MCS-96/196/296,C166/167,MC68HC05/11/12/16,68300 和数目众多的 ARM 系列。
-
微处理器(Microprocessor Unit,MPU):微处理器+专门设计的电路板,集成度低、可靠性高,主要有:Am186/88、386EX、SC-400、PowerPC、68000、MIPS、ARM 系列等。
-
数字信号处理器(Digital Signal Processing,DSP):采用哈佛结构,对系统结构和指令进行了特殊设计,适合执行大量数据处理。包括 TMS320 系列(含 C2000、C5000、C6000、C8000系列)、DSP56000 系列、实时 DSP 处理器等。
-
片上系统(System on Chip,SoC):由多个具有特定功能的集成电路组合在一个芯片上形成的系统或产品,其中包含完整的硬件系统,如处理器、IP(Intellectual Property)核、存储器等及其承载的嵌入式软件,如操作系统和定制的用户软件。
3.2 存储器分类
- 随机存取存储器(Random Access Memory,RAM)。工作需要持续电力提供,可随机读写。
- 动态随机存取存储器(Dynamic RAM,DRAM),采用电容存储信息。
-
优点是集成度高、容量大、成本低。
-
缺点是访问速度较慢、需要定期刷新。常作主存。
-
- 静态随机存取存储器(Static RAM,SRAM),采用多个晶体管自锁的方式保存状态。
-
优点是访问速度快、不需要刷新。
-
缺点是集成度低、容量小、成本高。常用作高速缓存。
-
- 动态随机存取存储器(Dynamic RAM,DRAM),采用电容存储信息。
- 只读存储器(Read Only Memory,ROM),存储的数据不会因掉电而丢失,读取的速度比 RAM 快,常见的有以下几种:
- 掩膜型只读存储器(Mask Programmed ROM,MROM)
-
优点是通过掩膜大批量制造、成本低。
-
缺点是同批数据全部一致且不可修改,只适合大批量生产。
-
-
可编程只读存储器(Programmable ROM,PROM),可以用专用编程设备一次性烧录数据,适合少量制造。
-
可擦可编程只读存储器(Erasable Programmable ROM,EPROM),优点是写入的数据可以通过紫外线擦除重写。
-
电可擦可编程只读存储器(Electrically Erasable Programmable ROM,EEPROM),优点是写入的数据可以通过电压来清除,但是清除的速度很慢。
-
快闪存储器(Flash Memory),优点是可以联机擦写数据且擦写的次数多、速度快,缺点是读取的速度慢(相对其他 ROM 的速度而言)。
- 掩膜型只读存储器(Mask Programmed ROM,MROM)
四、内(外)总线逻辑
各类总线在嵌入式系统的位置
-
根据传输的信息种类分类,可分为以下几种。
-
数据总线,用于传送需要处理或者需要存储的数据。
-
地址总线,用于指定在 RAM 之中存储的数据的地址。
-
控制总线,将微处理器控制单元的信号传送到周边设备。
-
-
根据连接部件分类,可分为以下几种。
-
片内总线,连接芯片内部各元件。
-
系统总线(板级总线),连接计算机系统的核心组件。
-
局部总线,连接局部少数组件。
-
通信总线,主机连接外设的总线。
-
-
按照数据传输的方向,总线可以分为单工总线和双工总线。
-
单工总线只能从一端向另一端传输而不能反向;
-
双工总线能在两个方向传输。
-
-
双工总线又分为半双工总线和全双工总线。
-
半双工总线只能轮流向两个方向传输;
-
全双工总线可以同时在两个方向传输。
-
-
按照总线使用的信号类型,总线可以分为并行总线和串行总线。
-
并行总线包含多位传输线,在同一时刻可以传输多位数据,但一致性要求高,传输距离较近;
-
串行总线只使用一位传输线,同一时刻只传输一位数据,但距离可以较远。
-
- 点赞
- 收藏
- 关注作者
评论(0)