《微处理器系统结构与嵌入式系统设计》cha.ppt
《《微处理器系统结构与嵌入式系统设计》cha.ppt》由会员分享,可在线阅读,更多相关《《微处理器系统结构与嵌入式系统设计》cha.ppt(36页珍藏版)》请在三一办公上搜索。
1、微处理器系统结构与嵌入式系统设计,第十一章 基于ARM微处理器的软件系统设计,2023/10/8,2,第十一章 基于ARM的软件系统设计,1、嵌入式软件系统结构及工作流程2、嵌入式软件系统的引导和加载S3C2440启动过程、BootLoader 基本概念、U-boot的分析与移植3、嵌入式Linux操作系统嵌入式操作系统、嵌入式Linux内核4、Linux下驱动程序设计示例打开串口、设置串口、读写串口、关闭串口,第 十一 章 结 束,2023/10/8,4,嵌入式软件系统结构,简单的嵌入式应用 若嵌入式系统的功能需求比较简单,嵌入式系统软件只需完成较简单的监控、驱动和处理功能,则不需要嵌入式操
2、作系统的支持。如基于8051的应用:玩具、家电、汽车等的控制系统复杂的嵌入式应用 若嵌入式系统的功能需求比较复杂,需要图形用户界面、网络管理、存储管理、进程/线程管理或需要支持二次开发等,则通过嵌入式操作系统的帮助,可以加快嵌入式系统软件的开发进度和可靠性。如基于ARM的应用:手机、PDA,2023/10/8,5,简单嵌入式系统软件结构,不需要使用操作系统,基于裸机开发典型单任务程序架构(1)从CPU复位时的指定地址开始执行;(2)跳转至汇编代码startup处执行;(3)跳转至用户主程序main执行,在main中完成:a.初试化各硬件设备;b.初始化各软件模块;c.进入死循环(无限循环),调
3、用各模块的处理函数,2023/10/8,6,用户主程序和各模块的处理函数都以C语言完成。用户主程序最后都进入了一个死循环,直到系统停电或者出现重大错误。void main(void)/变量、参数等的定义及说明 X_init();/系统初始化,一般为汇编代码While(1)X();/超级循环,2023/10/8,7,复杂嵌入式系统软件的一般结构,ARM+M+I/O,HAL、底层封装、部分由OS提供,BOOTLOAD,2023/10/8,8,复杂嵌入式系统软件工作流程,2023/10/8,9,S3C2440启动方式,三星公司的S3C2440支持Nor Flash和Nand Flash启动,可以通过
4、硬件跳线(引脚OM1:0)设置启动方式。具体含义如下:OM1:0=00时,处理器从NAND Flash启动OM1:0=01时,处理器从16位宽度的Nor Flash启动OM1:0=10时,处理器从32位宽度的Nor Flash启动OM1:0=11时,处理器从Test Mode启动,2023/10/8,10,S3C2440 Nand Flash,S3C2440 Nand Flash启动过程,在系统上电后,Nand Flash控制器会自动的把Nand Flash上的前4K U-BOOT数据搬移到内部SRAM的地址最低端(此SRAM被称为Steppingstone);CPU从内部RAM的0 x000
5、00000位置开始启动并在uboot启动代码的前4K里完成S3C2440的核心配置,然后把U-BOOT剩余部分搬到RAM中运行;,2023/10/8,11,引导程序BootLoader,是嵌入式系统在加电启动后执行的第一段代码,功能类似pc机的BIOS和OS Loader,通常需要固化在目标板中;主要负责CPU、存储器及相关硬件的初始化,以及将装载操作系统映像到内存中,然后跳转到规定的地址启动操作系统运行。Bootloader是严重依赖硬件而实现的,每一种不同体系结构的处理器都有不同的Bootloader,甚至同一种处理器的外围硬件配置不同,其Bootloader也有差别。因此开发特定的Boo
6、tloader是构建嵌入式linux系统之前的一项必要的基础工作。,2023/10/8,12,Bootloader的运行步骤,Stage1(汇编实现)基本硬件设备初始化:CPU时钟频率,寄存器,存储器数据宽度、访问周期、刷新周期,中断系统,I/O端口等;为第二阶段准备RAM空间,设置堆栈;复制第二阶段代码到RAM中,并跳转到第二阶段入口点Stage2(C实现)初始化本阶段要使用的硬件设备,实现对板级驱动的支持;检测系统内存映射;将内核镜像和根文件系统镜像从flash读到RAM中;为内核设置启动参数;将PC指针指向内核的入口处,调用内核。挂载文件系统;,2023/10/8,13,Linux 环境
7、下BootLoader种类,2023/10/8,14,U-boot的分析与移植,U-boot全称 Universal Boot Loader,支持ARM体系等多种处理器,包含常见的外设的驱动,是一个开源的、功能强大的板极支持包;由德国DENX软件工程中心的Wolfgang Denk维护。U-boot启动时处于正常的启动加载模式,但是它会延时指定时间(单位秒)等待终端用户按下任意键而切换到下载模式,如果在指定时间内用户没有按键,则继续启动操作系统。,2023/10/8,15,U-boot主要包括以下目录,board:该目录存放了U-Boot支持的一些已有开发板的信息。每一个开发板都以一个子目录出
8、现在当前目录中,如SMDK2410子目录中存放与2410开发板相关的配置文件,但由于自行设计的目标板即使与已有开发板使用相同处理器,但其他硬件配置不一定相同,所以需要参考该目录下的内容来进行修改,例如根据使用的Flash存储器的宽度和容量,可以修改flash.c中对应的参数。common:该目录存放的是U-Boot命令行界面下支持的各条命令的实现源码。每一条命令都对应一个文件,例如bootm命令对应就是cmd_bootm.c。通常主要关心与内核引导有关的cmd_boot.c和cmd_bootm.c等代码。cpu:该目录存放了U-Boot支持的CPU类型。每一款U-Boot下支持的CPU在该目录
9、下对应一个子目录,比如S3C2440A采用的是ARM920T内核,则子目录arm920t下即是对该处理器核的支持源码。CPU相关的文件主要是初始化一个执行环境,包括中断的初始化。其中有一个重要文件start.s,该文件是一个汇编源文件,它是整个U-Boot执行的第一段代码,它的功能是将整个U-Boot目标代码重定位,也就是将U-Boot转移至内存中去运行。,2023/10/8,16,U-boot主要包括以下目录,drivers:U-Boot支持的各种设备驱动程序都放在该目录,比如各种网卡、支持CFI的Flash、串口和USB等。fs:该目录存放U-Boot支持的文件系统,例如fat、fdos、
10、jffs2、cramfs、ext2和reiserfs等。include:U-Boot使用的头文件,还有对各种硬件平台支持的汇编文件,系统的配置文件和对文件系统支持的文件。该目录下configs目录有与开发板相关的配置头文件。该目录下的asm目录有与CPU体系结构相关的头文件,ARM对应的是asm-arm。lib_xxx:与体系结构相关的库文件。与ARM相关的库放在lib_arm中。net:与网络协议栈相关的代码,BOOTP协议、TFTP协议、RARP协议和NFS文件系统的实现。tools:生成U-Boot的工具,如:mkimage,crc等等。doc:文档目录。U-Boot有非常完善的文档,推
11、荐参考阅读。,2023/10/8,17,U-boot的运行过程分析,U-Boot的阶段一代码通常放在start.s文件中,用汇编语言写成,其主要功能是设置处理器状态、初始化中断和内存时序、对整个U-Boot目标代码进行重新定位。,阶段一刚开始的代码是处理器的异常处理向量表:.globl_start;系统复位的位置,由U-Boot.ld决定_start:b reset;0 x00000000,各个异常向量对应的跳转代码 ldr pc,_undefined_instruction;0 x00000004,未定义指令异常 ldrpc,_software_interrupt;0 x00000008,软
12、件中断异常 ldr pc,_prefetch_abort;0 x0000000c,预取中止异常 ldrpc,_data_abort;0 x00000010,数据中止异常 ldrpc,_not_used;0 x00000014,未使用 ldrpc,_irq;0 x00000018,中断异常 ldrpc,_fiq;0 x0000001c,快速中断异常当发生各类异常时,CPU将执行interrupts.c中对应定义的中断处理函数。,2023/10/8,18,U-boot的运行过程分析,reset/*set the cpu to SVC32 mode*/mrsr0,cpsrbicr0,r0,#0 x1
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 微处理器系统结构与嵌入式系统设计 微处理器 系统 结构 嵌入式 设计 cha
链接地址:https://www.31ppt.com/p-6235442.html