嵌入式系统
• 嵌入式系统上的软件具有结构精简,代码轻量化,占用存储资源少的特点。
• 嵌入式系统和计算机操作系统的共同特征是:引导加载程序、外设驱动程序、操作系统、文件系统、网络协议栈、图形用户界面、数据库。
• 嵌入式系统应用开发工具的主要目的:提高开发质量,缩短开发周期,降低开发成本。
• 按照软硬件技术的复杂程度进行分类,可以把嵌入式系统分为:高端系统、终端系统和低端系统三大类。
• 仿真平台指嵌入式系统开发中使用的虚拟机管理软件、仿真软件或者指令集模式器
• 对应内存容量而言1KB = 1024B,对应外存(磁盘、U盘)等容量而言,1KB=1000B
• OS装载方式:串口、以太网和USB装载。
• 嵌入式应用程序经过交叉工具链生成映像文件后,需要下载到目标机进行调试。
调试完毕后映像文件必须有专用工具烧写到ROM中去,这种烧写工具俗称编程器!
• 文本根据排版格式可分为:纯文本和丰富文本。windows环境下,txt就是纯文本。相对于线性文本,超文本按着网状结构组织信息。WWW网页是最为常见超文本。
• 当前速度最快的CPU已经超过10GHz。
• 嵌套向量中断控制器缩写为NVIC
• GCC是GNU套件的编译链接器,能编译C语言,汇编语言。
• GDB调试下,file命令是装入需要调试的可执行文件,run命令执行当前被调试的程序。
• 源文件到可执行文件的步骤:预处理->编译->汇编->连接。
• 前向通道和后向通道
• 前向通道 - 输入接口,A/D
• 后向通道 - 输出接口,D/A
• AX88796芯片内部寄存器的地址范围:0x10000000 ~ 0x100003FF
嵌入式系统硬件的逻辑组成
• 硬件主体中央处理器和存储器,他们通过IO接口或者IO设备与外部世界联系,并借助总线相互连接
• 中央处理器主要由运算器、控制器、寄存器和高速缓冲区(cache)组成
嵌入式系统的特点
• 专用型
• 隐蔽型
• 资源受限
• 高可靠性
• 软件固化
• 实时性
嵌入式系统的CPU特点
• 实时处理
• 低功耗
• 结构特拓展性
• 集成了测试电路
• 4、8、16、32位字长
CPU
• 嵌入式系统的CPU主要使用的有DSP、RAM以及FPGA。
• DSP介绍
• 适用于数字信号处理的微处理器(DSP并非高性能通用处理器,它是一种专用于数字信号处理的微处理器)
• 支持单指令多数据(SIMD)并行处理的指令
• 显著提高音频、视频等数字信号的数据处理效率
• 手机和数码产品均有DSP
嵌入式开发流程
• 需求分析和规格说明 -> 系统设计 -> 构件设计 -> 系统集成与测试
• 测试的目的是验证模块/系统的功能和性能,以及时发现错误
• 基于嵌入式WEB的应用系统中,构件设计阶段需要设计支持以太网通信的电路,包括以太网控制电路和以太网驱动电路。AX8879芯片内部寄存器的读/写地址,其首地址一般是0x1000 0000
嵌入式开发特点
• 宿主机 - 目标机的开发架构
• 与底层硬件控制程序的关系密切
• 软硬件资源受限制
• 需要固化程序
嵌入式系统开发调试工具
• 在线仿真器
• JTAG适配器
• 示波器
GPIO
• GPIO引脚一般是多功能复用的,具有0态,1态和高阻态。
• 作为输入接口时一般具有缓冲功能,作为输出接口时一般具有锁存功能。
• GPIO可以实现并行IO,SPI、UART、I2C都是串行。
UART
• UART由发生器、接收器、控制单元以及波特率发生器等组成。
• 可实现全双工通信!
• RAM芯片中的UART收发信息时,可以采用FIFO,也可以采用普通模式
• 一般接收和发送缓冲区的FIFO字节数一样的,长度可编程选择4B、8B、16B、64B。
• UART传送消息的格式是以起始位开始以停止位结束
• UART传送信息时,一次可传输的数据位可以是5,6,7,8位,由编程决定
• 基于UART可组成RS-232接口
• RS232 - 最远15m
• RS485 - 最远1.2k
• RAM实现485总线的功能,需要采用S3C2410芯片内部的UART部件外加转换芯片等来实现。在软件设计时,初始化波特率9600bps,数据格式格式为:8位数据位,无数据检验位,1位停止位。那么1s时间内最多传输960个字节。(注意计算还得加上起始位和停止位)
CAN
• 即: 控制器局域网
• 能够实现多主通信
• CAN总线的数据帧由7个不同的域组成,其中域的长度可以是0~8位
• 采用CRC校验
• RAM芯片内部嵌入CAN控制器
键盘
• 8个GPIO脚最多构成64个按键的键盘
• 矩阵键盘通常有行扫描法和反转法读取按键的特征值(还有一种方法叫做中断方式)
嵌入式处理器内核的分类
• 按照字长可以分为:8/16/32/64 位结构
• 按照存储可以分为:冯诺依曼和哈佛(程序和数据分开存储)结构
• 按照指令集可以分为:CISC、 RISC结构
• CISC(complex instruction set computer 复杂指令集)
• RISC(reduced instruction set computer 精简指令集)
SOC片上系统
• SOC已成为嵌入式处理器芯片的主流发展趋势
• 它是集成电路进入深亚微米时代的产物
• 既能把数字电路也能把模拟电路集成到单个芯片上
• 包含数字电路、模拟电路以及射频电路
• 单个芯片即可完成采集、转换、存储、处理和I/O等多种功能
• SOC有通用SOC芯片和专用SOC芯片之分
• 专用SOC芯片按其工艺分为定制芯片和现场可编程芯片两类
集成电路
• 集成电路有小规模(SSI)、中规模(MSI)、大规模(LSI)、超大规模(VLSI)和极大规模(ULSI)组成,嵌入式处理芯片一般属于VLSI和USLI。
• 集成电路大多是在硅衬底上制作,硅衬底是单晶硅锭经切割,研磨和抛光而成的圆形薄片。
• 集成电路中的电路及电子元件,需要反复交叉氧化、光刻、掺杂和互连等工序才能制成。
嵌入式最小系统组成
嵌入式系统一般包括嵌入式处理器、时钟电路、电源电路、复位电路、存储器和调试测试接口。
JTAG调试技术
• JTAG标准中规定的TAP接口具有5根信号线
• 构建一个宿主机 - 目标机的开发环境,若目标机是裸机,那么为了调试和下载软件需要将调试仿真器连接到目标机的JTAG接口!
• JATG是一种嵌入式测试技术,大多数嵌入式CPU、DSP、FPGA器件都支持JTAG
• JTAG允许多个芯片的边界扫描寄存器BSR通过JTAG接口串联在一起,实现对多个器件的测试
• 通过JTAG可以实现在线编程功能
主频时钟
• 0.01s基准定时时间选用S3C2410芯片内部的Timer0部件产生。若系统的主频参数PCLK=264MHz,分频器选择16,预分频系数选择为3,那么,Timer0的计数常数为:41250
• 计算方法:定时器输入时钟频率 = PCLK/(预分频系数+1)/(分割器值),计数常数 = 定时间间隔/(1/定时器输入时钟频率)
• 带宽 = 总线频率 × 数据线宽度 / 8 × 次数 / 周期
板级升级包(BSP)
• 引导加载程序、初始化程序、设备驱动程序、配置文件
• 含有电路板的初始化程序
• 所有与特定电路板上硬件相关的功能都集成在板级支持包的库里
• 操作系统的上层代码通过板级支持包访问底层硬件
ARM
• 单指令周期和流水线技术是RAM处理器的技术特征。
• RAM都是RISC,但是存储结构有的是哈佛结构,有的是冯诺依曼结构。
• PowerPC、MC68K、MIPS都是RISC,哈佛结构!
• Cortex 系列分为A-R-M ,A系列是面向尖端虚拟内存的操作系统和用户应用,R系列是针对实时系统,M系列是对微控制器。 Cortex - M3系列是哈佛结构。
• RAM内部一般有:UART/I2C/SPI/CAN/USB/Ethernet等多个互连通信组件
• RAM处理器共37个,包括31个通用寄存器(含PC)和6个状态寄存器
RAM异常
• 将CPRS的值保存到将要执行的异常中断对应的SPSR中
• 设置CPSR的相应位
• 断点地址保存到R14
• PC赋值,转入向量地址
ADS
• 按照存储区域类型划分为3类,RO段,RW段,ZI段,RO段是指代码存储区和常数存储区,具有只读属性
• 可执行输出文件有3个生成目标:Debug、Release、DEbugRel
• 工程项目按照一定的逻辑来分组管理文件:
• 文件映射关系较简单时:使用编译、链接选项来确定输入文件的连接关系
• 地址映射关系较复杂时:使用scatter(分散加载)格式的文件来确定输入文件的连接关系
RVDS
• RVDS开发工具套件中,主要包括工程管理器、编译连接器、调试器和指令集仿真器。调试器支持硬件在线调试和软件仿真调试。
电源管理模块
• 正常模式
• 慢速模式
• 休眠模式 - 仅断开RAM内核时钟FCLK,CPU处于休眠模式,仍为外围硬件组件提供时钟。
• 掉电模式 - 切断内部电源,除非唤醒逻辑有效,否则内核不产生功耗
正常模式下,电源管理模式为内核及RAM芯片内部所有硬件组成提供时钟源,用户可以通过软件控制暂时不用的内置硬件组件处于关闭状态降低功耗。
硬件抽象层HAL
• 向操作系统内核提供了访问硬件底层的函数接口
• 嵌入式软件中直接访问底层硬件的例程集合
• 增加的HAL位于硬件电路板和操作系统内核之间
• 嵌入式电路板的最基本软件
• HAL函数是移植操作系统的基础
• HAL隐藏了不同硬件平台的差异性,从而改善了操作系统的可移植性!
AMBA总线
• RAM的总线结构成为 AMBA -先进微控制器总线结构(一种开放式总线结构)
• 从1995的AMBA1.0到目前的AMBA4.0共四个版本!
• RAM7 - AMBA1; RAM11 - AMBA2
• 按照AMBA总线规范,基于RAM内核的嵌入式处理芯片采用系统总线和外围总线两层结构的方式构建片上系统
• 连接系统总线的高带宽组件(AHB接口)主要包括:电源管理和时钟控制器,测试接口(JTAG),外部存储器控制接口,DMA控制器,USB主机,中断控制器。(可以看出大多数为控制器)
• RTC是与外围总线(APB接口)连接的硬件组件
MMU
• MMU,内存管理单元,它是用来管理虚拟存储器、物理存储器的控制线路,同时也负责虚拟地址映射为物理地址,以及提供硬件机制的内存访问授权。
• 虚拟地址到物理地址的转换通过查找页表来完成,每次在访问内存时先插TLB,查不到再到内存中查整个页表。
ARM7 ≠ ARMv7
• RAM7 - 冯诺依曼的结构。 RAM9~RAM11 采用哈佛结构!
• ARMv7是一种构架。ARM7是一种处理器型号,ARM7(冯诺依曼结构)是在ARMv4构架上设计出来的处理器。**RAM11(ARMv6架构)之后便是以Cortex(ARMv7架构)**来命名了!
• ARM7没有MMU(内存管理单元),只能叫做MCU(微控制器),不能运行诸如Linux、WinCE(大型嵌入式操作系统)等这些现代的多用户多进程操作系统,因为运行这些系统需要MMU,才能给每个用户进程分配进程自己独立的地址空间。ucOS、ucLinux这些精简实时的RTOS不需要MMU,当然可以在ARM7上运行。
• ARM9、ARM11,是嵌入式CPU(处理器),带有MMU,可以运行诸如Linux等多用户多进程的操作系统,应用场合也不同于ARM7。
• 此外,Cortex-M系列还细分为M0、M3、M4和超低功耗的M0+,用户依据成本、性能、功耗等因素来选择芯片。
• Cortex-M系列(ARMv7架构)的指令集只有Thumb-2。
ARM处理器 ≠ ARM处理器核
• 处理器核:在某种架构的基础上具有取指令和执行指令的组件。
• 处理器: 以处理器核为中心,加上MMU,中断控制器,浮点运算器,总线接口等就构成了RAM处理器。
• 当然了,单独的处理器核也可以作为某一代RAM处理器的。
RAM常考寄存器
• R13 - SP (堆栈指针)
• R14 - LR(链接寄存器)
• R15 - PC(程序计数器)
• xPSR - (CPSR 和 SPSR)状态寄存器
SP寄存器
• SP有两个,分别为R13(MSP)和R13(PSP)即主堆栈指针(MSP)和进程堆栈指针(PSP),但在同一时刻只能有一个可以看到,这也就是所谓的“banked”寄存器。
• 这些寄存器都是32位的。
CPSR寄存器
• CPSR(当前程序状态寄存器)在任何处理器模式下被访问。它包含了条件标志位、中断禁止位、当前处理器模式标志以及其他的一些控制和状态位。
• RAM中表示程序状态的寄存器是CPSR,其中状态位T的作用是在RAM状态与Thumb状态间进行切换,当T = 1时处理器处于的状态是Thumb状态。
• N为符号标志位 - N=1表示运算结果为负,否则运算结果为正
• F为禁止快读中断为 - F=1表示禁止快速中断控制位,否则允许!
• V为溢出标志位,等于1表示溢出
• Z为全0标志,运算结果为0
SPSR寄存器
• 每一种处理器模式下(看下面的其中运行模式)都有一个专用的物理状态寄存器,称为SPSR(备份程序状态寄存器)。
• 当特定的异常中断发生时,这个寄存器用于存放当前程序状态寄存器的内容。在异常中断退出时,可以用SPSR来恢复CPSR。
• 由于用户模式和系统模式不是异常中断模式,所以他没有SPSR。当用户在用户模式或系统模式访问SPSR,将产生不可预知的后果。
控制寄存器和数据寄存器
• 控制寄存器是4个字节,比如端口E的控制寄存器rGPECON = 0x00005555
• 数据寄存器是2个字节,比如端口E的数据寄存器rGPEDAT=0x0020
关于赋值,也写一个小例子
rGPDCON = ((rGPDCON | 0x00005555) & 0xFFFF5555);//GPD0~GPD7配置为输出模式
先置位,然后再清零。
ARM微处理器的七种运行模式
• 用户模式:user (没有SPSR寄存器):正常程序执行的模式
• 系统模式 – SYS (没有SPSR寄存器): 用于运行特权级的操作系统任务
• 快速中断模式 – FIQ :用于高速数据传输和通道处理、高速中断!
• 外部中断模式 – IRQ :用于通常的中断处理
• 管理模式 – SVC :又称特权模式,操作系统使用的一种保护模式
• 终止模式 – ABT :用于虚拟存储及存储保护,处理存储器故障
• 未定义指令模式 – UND :用于支持通过软件方针硬件的协处理器
经典RAM的七种异常
• 复位RESET
• 未定义指令 UND
• 软件中断 SWI
• 指令预取终止 PABT
• 数据访问终止 DABT
• 外部中断请求 IRQ
• 快速中断FIQ
IRQ
• IRQ异常对应的异常向量地址为:0x00000018
• IRQ异常向量地址和下一个异常向量地址之间的间隔为4个字节
复位异常的异常向量地址是0x00000000。系统上电复位后,将从该地址处执行程序,RAM9的体系结构规定的各异常向量地址间隔通常是4个字节,以此复位异常向量地址处通常存储一条分支指令
S3C2410必备知识
• S3C2410拥有2个串口,UART0/UART1
• 控制组件包括存储器控制器、总线控制器、外部主控器、NAND FLASH(以页为单位进行闪存)
• 存储器控制器提供访问外部存储器所需的存储器控制信号,支持大小端模式,地址空间供1GB,8个BANK,每个BANK128MB。
• 以ARM芯片为信合的嵌入式系统其I/O与存储器采用统一编址的方式,并不像×86那样采用I/O映射编址(独立编址)
• 只有BANK0是总线16、32位的访问,其他BANK均可以进行8、16、32位的访问
• GPIO 有GPIOA~H
• 哈佛体系结构,数据与程序存储分开
• 哈佛体系结构,数据与程序存储分开
• 内部集成ADC
•
矩阵按键代码
#define KEYOUTPUT (*(VOLATILE int8u )0X56000044)
#define KEYINPUT ((VOLATILE int8u *)0X56000044)
INT16U ScanKey()
{
INT16U key = 0xFFFF;
INT16U i;
INT8U temp=0xFF, output;
rGPECON = ((rGPECON & 0xFFFFFF00) | 0x00000055); //初始化GPE0~GPE3为输出
rGPECON = rGPECON & 0xFFFFFF0F; //初始化GPE4~GPE7为输入
//判断键盘中是否有键按下
for(i=1; ((i<=8) && (i>0)); i<<=1)
{
output |= 0xFF;
output &= (~i);
KEYOUTPUT = output;
temp = KEYINPUT;
if((temp & 0xF0) != 0xF0)//判断列信号是否全部为1
{
key = (~i);
key <<= 8;
key |= ((temp & 0xF0)|0x0F);
return key;
}
}
return 0xFFFF;
}
//key返回判断哪个按键的方法:最高4位和最低四位都是1,
//即 1111 ---- ---- 1111,然后次高字节是行,再次高是列,
//比如第2行第3个按键按下, 对应为 1111 1101 1011 1111 - 0xFDBF
网络
• WLAN通信协议是802.11,传输速率可达到11Mbps,54Mbps,108Mbps。
IP
• IP地址分为A类、B类、C类三个基本类。另外两类分别为组播地址和备用地址。
• IP地址解决了网络中所有计算机统一编址的问题
• IP数据报是一种独立于各种物理网络的数据包格式
• 路由器是实现网络与网络互连的关键设备
A类
• 1.0.0.0 到126.255.255.255
• 分配给具有大量主机而局域网络数量较少的大型网络
• 由1个字节的网络地址和3个字节主机地址组成
• 网络地址的最高位必须是“0”,即第一字段的范围 0127,但是由于全0和全1的地址用作特殊用途,实际可指派的第一个字段范围是1126
• 每个IP地址可连16387064台主机,Internet有126个A类地址
• 可以用于多目的地址发送,言外之意可以组播
B类
• 128.0.0.0到191.255.255.255
• 用于国际性大公司和政府机构
• 前两个八位字节指明网络,后两个八位字节指明网络上的主机
C类
• C类IP地址范围192.0.0.0 ~ 223.255.255.255
• 第1、2、3字节为网络地址,第四个字节为主机地址
• C类地址数量较多,使用于局部局域网中,每个网络中最多包含254台计算机
• 用于一般小公司 校园网 研究机构
以太网数据帧(里面不包括IP地址)
• 前导码(7个字节) -> 帧起始界定符(1字节) -> 目的MAC地址(6字节) -> 源MAC地址(6字节)-> 类型/长度(2字节) -> 数据(46~1500字节) ->帧校验序列(4字节)
• 局域网采用分组交换技术
• 发送设备MAC地址 - > 接收设备MAC地址 -> 控制信息 ->有效载荷 -> 校验信息
路由器
• 多个异构或者同构网络进行互联
• 网络层
• 集线器来放大信号实现远距离传输
• 协议转换器:用于传输层及以上各层的协议转换
• 热点 - 正式名称无线接入点,它实际上是一个无线交换机或无线路由器。
局域网
• 按照介质所使用的访问控制方法可分为:以太网,FDDI网和令牌网
• 必不可少的部分是集线器与交换机
指令集
• Thumb指令集是16位的,ARM指令集是32位的,中间有Thumb-2作为桥接。
ARM处理器的三种工作状态
• ARM状态 (指令宽度32)
• Thumb 及 Thumb-2状态
• 调试状态
Thumb状态和ARM状态的切换
• 通过BX指令,写数据到操作数寄存器(R0)的最低位。
• R0[0]=1 – 从RAM状态切换到Thumb状态。 R0[0]=0 – 从Thumb状态切换到RAM状态。
RAM复位后的状态
• ARM处理器复位后的状态都是ARM状态
BootLoader
U-BOOT
• Linux中引导程序加载时所支持不同体系结构处理器种类最多的Bootloader 是- U-BOOT。
• 全称universal-Boot-Loader
• 支持PowerPC、x86、ARM等多种体系结构的处理器
• 支持嵌入式Linux、VxWorks、QNX、RTEMS、Windows CE等操作系统
• 采用两个阶段完成操作系统的引导加载
• 引导加载程序主要完成:加电自检、外设存在自检**、内存地址映射**、初始化外围设备、内存寻址定位、加载并启动操作系统
• BootLoader通常分为stage1和stage2两大部分。依赖于CPU的体系结构,比如设备初始化代码通常放在stage1中,且使用汇编语言实现,以达到短小精悍的目的。stage2通常用于C语言实现更复杂的功能,同时代码也具有更好的可读性和可移植性。
• BootLoader的stage1的基本步骤是:基本硬件初始化,为加载stage2准备RAM空间,拷贝stage2的执行代码到RAM空间中,设置栈区指针SP,跳转到stage2的C程序入口点。
作用
• 改变程序大小端排序
• 关闭看门狗
• 屏蔽中断
• 设置各个时钟
• 设置从SLEEP或者IDLE启动时的程序
• 初始化SDRAM
• 设置各模式指向的堆栈
• 设置好中断向量表
• 判断是从NOR FLASH(行读写,较慢)还是NAND FLASH(页读写)启动,
• 将文件拷到SDRAM中
操作系统
• IOS 的前身是 UNIX-BSD(宏内核架构,但是是微内核操作系统)
内核的概念
• 内核提供任务调度、任务间通信与同步、任务管理、时间管理和存储管理。
• 典型的单片机程序在程序指针复位后,首先进行堆栈、中断、中断向量、定时器、串行口等接口设置、初始化数据存储区和显示内容,然后就来到了一个监测、等待或空循环,在这个循环中,CPU可以监视外设、响应中断或用户输入。 这段主程序可以看作是一个内核,内核负责系统的初始化和开放、调度其它任务,相当于C语言中的主函数。
• 现代操作系统设计中,为减少系统本身的开销,往往将一些与硬件紧密相关的(如中断处理程序、设备驱动程序等)、基本的、公共的、运行频率较高的模块(如时钟管理、进程调度等)以及关键性数据结构独立开来,使之常驻内存,并对他们进行保护。通常把这一部分称之为操作系统的内核。
Linux
• UCLinux、RTLinux、uC/OS - II是开源嵌入式操作系统
• Linux最初以Unix为原型,以实现POSIX标准作为其目标。
• OS服务组件、用户进程、Linux内核、硬件
• 系统调用是Linux中用户进程和操作系统之间的重要接口!
Linux和Unix
• 其两者源码是完全不相同的,尽管函数和命令的功能处理结果、函数名称和参数十分相同,以及Unix的行命令、驱动程序和应用程序在Linux上能够运行。
• Linux运行效率没有Unix高!
Linux命令
• arm - linux - gcc交叉编译器来编译应用程序
• 要对一个应用程序进行调试排错,应在编译指令中加g参数对它进行编译
• Linux内核主要由5个子系统组成
• 进程调度(SCHED)
• 内存(任务)管理(MM)
• 虚拟文件系统(VFS)
• 网络接口(NET)
• 进程间通信(IPC)
• 进程调度模块负责控制进程对CPU资源的使用,所采取的调度策略是使得各个进程能够平均访问CPU,同时保证内核能及时地执行硬件操作。
• 内存管理模块的功能之一是屏蔽各种硬件接口内存结构的差异并向上返回一个统一的访问接口
• 网络接口模块包含网络接口驱动程序
• 支持进程之间的各种通信机制,其通信机制包括:信号、管道、消息队列、信号量、共享内存、套接字(socket)
微内核和宏内核
• 微内核特征
• 内核小巧,传统操作系统中的许多部分都被移出内核。
• 接口一致,所有进程请求使用统一接口,进程不区分内核模式和用户模式服务。
• 各个功能模块之间松散耦合,只完成服务功能,系统管理功能交给一个或多个特权服务程序。
• 微内核扩充方便,但是各个功能之间的切换引起的开销很大!
• 属于微内核的典型嵌入式操作系统有:Symbian、VxWorks、QNX、uC/OS - II、IOS,而Symbian是普通实时操作系统
• VxWorks收取授权费和版权费。
• VxWokrs用于尖端科技中
• 宏内核
• 传统操作系统常采用的结构
• 应用程序效率高
• 切换开销小
• 对外来时间反应速度快
• 内存大
• 拓展性不高,维护困难
• 可预测性较低
• 可靠性较低
• Android OS是典型的宏内核操作系统
• 宏内核又称为单内核!
Tiny OS
• 是开放源代码操作系统,属于深度轻量级的操作系统,专为嵌入式无线传感器网络设计,功耗较低,特别适合传感器这种受内存,功耗限制的设备。
• 轻线程,主动消息和组件化编程。
QNX
• 符合POSIX基本标准和实时标准
• 微内核操作系统
• 内核提供四种服务:进程调度,进程间通信,底层网络通信和中断处理
uC/OS-II
• 抢占式实时操作系统
• 抢占式实时操作系统且每个任务都有自用栈
• 使用它的栈空间校验函数,可以确定每个任务到底需要多少栈空间
• 该系统不包含设备驱动程序,只是一个纯内核
• 不支持时间片轮转调度,所以赋给每个任务的优先级是不相同的
• 允许每个任务之间有不同的栈空间
• 升级版的UC/OS - III是商用操作系统
• II 具有良好的可剪裁性和可移植性
• 能够支持的任务数最多是64(保留8个给系统,实际剩下56个)
• 最多允许的中断嵌套层数可以达到255层
• 软件结构一般具有:应用软件层,API层,内核层和设备驱动层
• 该系统能提供周期性时钟信号(时钟节拍),用于实现任务的正确延时和超时确认,节拍率在10~100Hz之间
• 用户必须在多任务调度启动以后再使能时钟节拍中断
• 在中断返回之前,必须调用退出中断函数 voidIntExit(void)
• 互斥信号量可以解决优先级反转的问题
• 事件控制块用以对信号的管理
• 任务管理中空闲任务是系统创建的第一个任务(空闲任务永远不会处于挂起态,还可能运行态,即使优先级最低,一旦其他任务都被堵塞他就可以执行了!)
• 中断服务子程序的伪码结构:保存全部CPU寄存器到栈,调用OSIntEnter()或者OSIntNesting变量加1,执行中断服务代码或发出IPC信息通知特定任务去执行中断服务,调用OSIntExit()函数,恢复所有CPU寄存器,执行中断返回指令。
• uC/OS-II 移植到一个 嵌入式系统电路板上正常运行,必须具备的条件
• 处理器的C编译器能产生可重入代码,且用C语言就可以打开和关闭中断。
• 处理器支持中断,并且能产生定时中断。(通常在10至100Hz之间)。
• 处理器支持能够容纳一定量数据(可能几千字节)的硬件栈区。
• uC/OS-II 保护任务之间的共享数据和提供任务之间的通信,可达到保护目的方法通常有
• 利用宏OS_ENTER_CRITICAL()和OS_EXIT_CRITCAL来打开和关闭中断。
• 利用函数OSSchedLock()和OSSchedUnlock()对任务调度函数上锁和开锁。
• 利用信号量、互斥量、邮箱和消息队列进行任务间通信。
• 系统启动过程中,Bootloader执行完毕后,调用应用程序主文件(通常是main.c)里的main函数。main函数在执行过程中除了用户函数和硬件初始化函数之外,需要执行下面三个重要函数:OSInit() -> OSTaskCreate() -> OSStart()(注意先后顺序)
• OSInit()函数先建立最初的任务就绪表,然后建立4个空白的数据链表,即:任务控制块链表,事件控制块链表、标志链表、内存控制块链表。
• 系统中任务的五种状态
• 休眠态(任务停留在内存中,还没有交给内核管理。)
• 就绪态(该任务已经准备好,可以运行了,但是由于任务的优先级比正在运行任务的优先级低,还暂时不能运行。)(还有一种情况被更高优先级打断!)
• 运行态(任务得到了CPU的控制权正在运行之中)
• 挂起态
• 被中断态(发生中断执行相应的中断服务,原来在正在运行后的任务暂时停止运行,进入被中断状态)
• 一些系统函数
• OSTaskCreate() - 任务创建相关
• OSCtxSw() - 真正实现任务切换的函数
• OSIntExit() - 中断级的调度
• OSTickISR() - 时钟节拍中断服务子程序,与时间管理相关
• OSSched() - 任务前导函数,任务级的调度函数
• 判断任务调度的三个条件是:
• 中断嵌套层数共享全程变量OSIntNesting = 0,也就是所有的ISR已经执行完毕
• 任务调度加锁层数共享全程变量OSLockNesting = 0,也就是调度没有被禁止
• 就绪表找到最高优先级比当前任务的优先级高
• OSIntExit() - 中断级的调度函数
• 系统事件控制块的相关函数
• OSSemCreate()(信号量创建)
• OSMutexCreate()(创建互斥体)
• OSMboxCreate()(建立一个邮箱)
• OSQCreate()(创建事件控制块)
• 就绪任务登记在就绪表中,OSRdyTbl[ ] 是就绪表的位图映像矩阵,每一位代表了一个优先级任务的就绪状态,成为就绪位,该矩阵最多有64位。
• 一些系统文件
• OS_CPU_C.C - 创建任务的自用栈空间、定义用户接口的hook原型
• OS_CORE.C - 核心调度代码,包括系统初始化、启动多任务调度开始运行、任务创建管理与调度、TCB初始化、就绪表初始化、ECB初始化、任务事件就绪表、空闲任务
• OS_MEM.C - 内存管理,包括创建分区,获得存储块
• OS_TASK.C - 任务管理,包括改变一个任务的优先级、创建或者删除一个任务,恢复一个被挂起的任务
• uC/OS系统时钟内核的基本功能(通过GLIBC调用通用函数和内核的内部功能)
• 任务管理
• 时间管理
• 内存管理
• 任务调度
• 任务间通信和同步
实时操作系统与非实时操作系统
实时系统
• 民航导航系统
• 防空预警系统
• 电力输送控制系统
非实时
• 视频播放系统
• 博客发布系统
• 手机交互式城市交通导航系统
实时操作系统
• RTOS响应中断请求并且完成相应的中断服务子函数的时间非常快!精细衡量这个时间一致性变化的术语是抖动!
• 中断服务子函数也是可以调用函数然后进行事件处理的,中断服务子程序返回的最后一步执行中断返回指令。
RTOS特征(主要特征是能够及时响应外部发生的随机任务请求并且能够在规定的时限内完成任务。)(不包括轮转调度)
• 异步IO和中断处理能力
• 任务切换时间和中断延迟时间确定
• 优先级中断和调度
• 抢占式调度
• 内存锁定
• 连续文件
• 同步
RTOS的实时性能主要由三个指标衡量
• 响应时间(包括中断延迟时间和任务切换时间)(任务切换时间又包括人物抢占时间)
• 吞吐量
• 生存时间
• 响应时间有两个指标 - 中断延迟时间和任务切换时间
• 实时系统对时间约束要求的严格性,使可预测性成为实时系统的一项重要性能要求,它是指RTOS能够对外部事件的响应时间和实时任务的执行时间进行判断,以确定被时间触发的实时任务能否在规定的时间内完成。
• 一般按照相应时间能将实时系统分为三类:强实时系统,其相应时间一般在ms级或us级;普通实时操作系统一般在s级,弱实时系统一般在数十s级。
• 任务时限有两种
• 截止时间:任务开始执行时间到任务必须完成的时间间隔。
• 任务执行预设:又叫任务最快完成时间,这是在无中断响应情况下的任务最快执行时间。
硬实时操作系统和软实时操作系统
• 任务执行时间超过截止时间系统的总损益就为负,这种实时系统成为硬实时系统。而且伴随有严重的后果,比如飞机控制器、核反应堆处理装置。
• 软实时操作系统超过时限并不会造成严重的影响比如:DVD播放机。
存储器
• 半导体存储器芯片的存储容量取决于该芯片的地址总线的条数和数据总线的位数。
• 存储器带宽与存储器总线的工作频率有关,也与数据线的位数和每个总线周期的传输次数有关!
• 系统正在运行的程序的大部分数据和代码存放在主存储器(内存)中
• 系统尚未运行的程序的大部分数据和代码存放在外部存储器中
•
分类
• 按照存取特性分为:RAM和ROM
• 按照物理位置分为:片内存储器和片外存储器以及外部存储器
• 按照存储信息的类型分为:程序存储区和数据存储器
RAM
• RAM - 高速读取, DRAM - 高集成度
• RAM 通常又有DRAM和SRAM之分,SRAM较DRAM电路复杂,但是速度更快,高速缓冲区(cache)就是典型的SRAM。 SRAM的复杂决定了它做不大,至多几十K。
• 内存条就是DRAM,速度较SRAM慢,但是可以做的很大,比如内存条就是典型的DRAM,其容量就上G了。
• FRAM - 铁电随机存取存储器,MRAM - 磁性随机存取存储器。
• (以上两个随机存储器是非易失性存储器)
FLASH
• Flash闪存有两大类,或非型(NOR Flash)和与非型(NAND Flash)。
• 或非以字节为单位进行随机存取,存储在里面的程序可以被CPU执行。与非以页为单位进行存取,速度较前者慢。
• 与非门读出程序或数据时,是先将其预存入RAM,然后才被使用的。虽然速度较慢,但是其寿命,容量成本等方面有很大优势,常用的U盘基本都是NAND Flash。
DDR
• DDR - dual data rate - 双倍数据速率
• DDR2 - 使原来DDR可预取读取2位变成可预取读取4位或8位,把DDR的数据传输速率又提升了两倍或四倍
USB
• USB2.0 的速度可达到 480Mb/s
• USB3.0的速度可达到 5Gb/s, 即640MB/s
• 半双工差分方式通信
编码
ASCII
• ASCII共128个字符,96个可打印字符,32个控制字符。
• ASCII是7位编码,但在计算机里用一个字节存放(计算机最基本的存储和处理单位)
• 每个字节多出的1位在计算机内部常保持为0,在数据传输中是奇偶校验位。
汉字编码
• GB2312 – 两字节编码(每个字节最高位默认为1),包含常用的中国汉字和图形符号。
• GB18030 与国际Unicode相兼容。单字节对应ASCII,双字节对应汉字(GB2312在这完全适用,但是比它范围广),其余四字节对应其他字符。
Unicode
• UTF-8 – 单字节可变长编码,单字节向下兼容ASCII,音节文字对应两字节,CJK汉字(china japan koera 中日韩汉字)对应三字节,其余对应四字节。Linux 常用。
• UTF-16 – 双字节可变长编码,CJK汉字及常用字符两字节,其余四字节。JAVA .NET 常用。
同步IO和异步IO
• CPU的速度远远快于磁盘、网络等IO。在一个线程中,CPU执行代码的速度极快,然而,一旦遇到IO操作,如读写文件、发送网络数据时,就需要等待IO操作完成,才能继续进行下一步操作。这种情况称为同步IO。
• 在IO操作的过程中,当前线程被挂起,而其他需要CPU执行的代码就无法被当前线程执行了。因为一个IO操作就阻塞了当前线程,导致其他代码无法执行,所以我们必须使用多线程或者多进程来并发执行代码,为多个用户服务。每个用户都会分配一个线程,如果遇到IO导致线程被挂起,其他用户的线程不受影响。
• 多线程和多进程的模型虽然解决了并发问题,但是系统不能无上限地增加线程。由于系统切换线程的开销也很大,所以,一旦线程数量过多,CPU的时间就花在线程切换上了,真正运行代码的时间就少了,结果导致性能严重下降。
• 另一种解决IO问题的方法是异步IO。当代码需要执行一个耗时的IO操作时,它只发出IO指令,并不等待IO结果,然后就去执行其他代码了。一段时间后,当IO返回结果时,再通知CPU进行处理。
指令相关
• 子程序返回调用程序除了MOV PC, LR。还可以MOV R15, LR
• 汇编语言调用一个名为My的子程序的指令为: BL My 子程序返回调用程序的指令为:MOV PC, LR。
• Thumb - 2指令集中关外部中断使用的指令是:CPSID I。开外部中断的指令为:CPSIE I。
• EQ表示相等,NE表示不等
• RAM汇编程序采用分支指令B
• 子程序调用指令BL
• 条件转移指令BX
• RAM汇编中没有专门的指令实现循环,一般采用比较指令CMP、ADD、SUB等
才能产生条件的指令,然后再通过带状态的条件转移指令BX来实现。
• 指令后面加个!表示更新基地址寄存器符号
• 寄存器间接寻址就是以寄存器中的值作为操作数地址,而操作数本身存放在存储器中。用于间接寻址的寄存器必须用[ ] 括起来
• Test EQU 50 定义 标号 Test的值为50!
• RAM完成有条件无符号加法运算,并更新CPSR中的状态,条件如果是相等,要求指令执行R1+R2,结果放入R3中,则这条指令ADDCEQ R3, R1, R2。如果条件是大于,要求执行R1 - R2,结果放入R3,则该指令是SUBHIS R3, R1, R2
指令的条件码总结
• EQ - 相等
• NE - 不等
• MI - minus负数
• PL - plus正数或0
• vs - overflow set溢出
• vc - overflow clear未溢出
• GT - greater than带符号数大于
• GE - greater and equal带符号数大于或等于
• LT - lower than带符号数小于
• LE - lower equal带符号数小于或等于
• HI - high无符号数大于
• CS - carry same无符号数大于或等于
• CC - carry clear无符号数小于
• LS - low and same无符号数小于或等于
常考指令
• LDR 字数据加载指令(存储器到寄存器的数据传送指令)
• LDRB 字节数据加载指令
• LDRH 半字数据加载指令
• STR 字数据存储指令
• STRB 字节数据存储指令
• STRH 半字数据存储指令
• STR R0, [R1] - 将R0中一个字的数据,存入以R1的值为地址的存储器中。
• LDR R0, [R1] - 以R1的值为地址的存储器中的字数据(为32位)读入寄存器R0
• LDRH R0, [R1] -以R1的值为地址的存储器中的半字数据(为16位)读入寄存器R0
• LDRB R0, [R1] -以R1的值为地址的存储器的字节数据(为8位)读入寄存器R0
• 注意了,LDR R1, #0x12345678 LDR是加载存储指令,表示存储器到寄存器的数据传送,而#是立即数符号,表示立即数寻址**。所以这样写是不正确的!**
• ADC R1, R2, R3 表示 R1 = R2+R3+C(C表示进位)(ADD表示加法)(ADC表示)
置1清0的操作
• 常见的操作是:or可实现置1,and可实现清0。比如ORR R0,R0,#00000003 该指令设置R0的0、1位,其余位保持不变。再比如AND R0,R0,#FFFFFFFE实现R0的最低位清零。还有一个是用ARM的指令进行位清0,BIC R1, R1 #0X00000088
立即数
• 汇编语言中中操作数有三种:寄存器操作数、存储器操作数和立即数。
• 其中立即数相当于高级语言中的常量(常数),它是直接出现在指令中的数,不用存储在寄存器或存储器中的数,如指令ADD AL,06H中的06H即为立即数。
大小端存储
• 所谓的大端模式就是,低地址存储高位字节。
• 所谓的小端模式就是,低地址存储低位字节。
计算机存储结构
• 冯诺依曼,是一种程序指令储存和数据储存在一起的存储器结构
• 哈佛结构,是一种将程序指令储存和数据储存分开的存储器结构
音频图像
音频
• 数字音频的正确处理顺序是:取样 -> 量化 -> 编码
• 数字音频的主要参数:取样频率、量化位数、声道数目、使用的压缩编码方法、比特率
• 比特率(码率)计算方式:码率 = 取样频率×量化位数×声道数,压缩后的码率和压缩前的码率也就差一个压缩比。
• mp3
• MPEG - 1层③算法进行有损的压缩编码,以8~12倍的比率大幅度降低了声音的数据量
图像
• 包括BMP.、TIF、GIF、JPEG、PNG
• 数字图像的获取过程分为:扫描、分色、取样
• GIF是互联网上广泛使用的一种图像文件格式,它的颜色数目较少,不超过256色,文件特别小,适合互联网传输
• JPEG是静止图像数据压缩编码的国际标准,特别适合处理各种连续色调的彩色和灰度图像,算法复杂度适中,软硬件皆可实现。
屏幕
触摸屏
• 电阻式触摸屏(软屏),结构简单价格低
• 电容式触摸屏(硬屏),结构复杂价格高
• 电容式触摸屏可以实现多点触摸和滑动操作
• 般写硬笔字的触摸屏是电阻屏
LCD显示屏
• LCD显示屏自身不带控制器,没有驱动电路,仅仅是显示器件,价格最低
• LCD显示模块内置LCD显示屏,控制器和驱动模块,有字符型和图形点阵型
• PC机通常使用的是LCD显示器,除具备显示屏外,还包括驱动器,控制器以及外壳,是完整的LCD显示设备
• DVI、VGA以及HDMI是一种接口标准
其他
• 微波通信:手机通信、卫星通信、无线局域网
• 调频广播属于短波以及超短波通信。
加粗样式