《微处理器系统结构与嵌入式系统设计》cha.ppt
《《微处理器系统结构与嵌入式系统设计》cha.ppt》由会员分享,可在线阅读,更多相关《《微处理器系统结构与嵌入式系统设计》cha.ppt(36页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、微处理器系统结构与嵌入式系统设计第十一章 基于ARM微处理器的软件系统设计2023/4/152第十一章第十一章 基于基于ARM的软件系统设计的软件系统设计1、嵌入式软件系统结构及工作流程嵌入式软件系统结构及工作流程2、嵌入式软件系统的引导和加载、嵌入式软件系统的引导和加载S3C2440S3C2440启动过程启动过程、BootLoader BootLoader 基本概念基本概念、U-bootU-boot的分析与移植的分析与移植3、嵌入式、嵌入式Linux操作系统操作系统嵌入式操作系统嵌入式操作系统、嵌入式嵌入式LinuxLinux内核内核4、Linux下驱动程序设计示例下驱动程序设计示例打开串口
2、、设置串口打开串口、设置串口、读写串口读写串口、关闭串口关闭串口第 十一 章 结 束2023/4/154嵌入式软件系统结构嵌入式软件系统结构l简单的嵌入式的嵌入式应用用 若嵌入式系若嵌入式系统的功能需求比的功能需求比较简单,嵌入式系,嵌入式系统软件只需完成件只需完成较简单的的监控、控、驱动和和处理功能,理功能,则不不需要嵌入式操作系需要嵌入式操作系统的支持。的支持。如基于如基于8051的的应用:玩具、家用:玩具、家电、汽、汽车等的控制系等的控制系统l复复杂的嵌入式的嵌入式应用用 若嵌入式系若嵌入式系统的功能需求比的功能需求比较复复杂,需要,需要图形用形用户界面、网界面、网络管理、存管理、存储管
3、理、管理、进程程/线程管理或需程管理或需要支持二次开要支持二次开发等,等,则通通过嵌入式操作系嵌入式操作系统的帮助,的帮助,可以加快嵌入式系可以加快嵌入式系统软件的开件的开发进度和可靠性。度和可靠性。如基于如基于ARM的的应用:手机、用:手机、PDA2023/4/155简单嵌入式系统软件结构简单嵌入式系统软件结构不需要使用操作系不需要使用操作系统,基于,基于裸机裸机开开发典型典型单任任务程序架构程序架构(1 1)从)从CPUCPU复位时的指定地址开始执行;复位时的指定地址开始执行;(2 2)跳转至汇编代码)跳转至汇编代码startupstartup处执行;处执行;(3 3)跳转至用户主程序)跳
4、转至用户主程序mainmain执行,在执行,在mainmain中中完成:完成:a.a.初试化各硬件设备;初试化各硬件设备;b.b.初始化各软件模块;初始化各软件模块;c.c.进入死循环(无限循环),调用各模块的处理进入死循环(无限循环),调用各模块的处理函数函数2023/4/156用用户主程序和各模主程序和各模块的的处理函数都以理函数都以C语言完言完成。用成。用户主程序最后都主程序最后都进入了一个死循入了一个死循环,直到系直到系统停停电或者出或者出现重大重大错误。void main(void)/变量、参数等的定量、参数等的定义及及说明明 X_init();/系系统初始化,一般初始化,一般为汇编
5、代代码While(1)X();/超超级循循环2023/4/157复杂嵌入式系统软件的一般结构复杂嵌入式系统软件的一般结构ARM+M+I/OHAL、底层封装、部分由、底层封装、部分由OS提供提供BOOTLOAD2023/4/158复杂嵌入式系统软件工作流程复杂嵌入式系统软件工作流程2023/4/159S3C2440启动方式启动方式 三星公司的三星公司的S3C2440支持支持Nor Flash和和Nand Flash启启动,可以通可以通过硬件跳硬件跳线(引脚引脚OM1:0)设置置启启动方式。具体含方式。具体含义如下如下:OM1:0=00时,处理器从理器从NAND Flash启启动OM1:0=01时
6、,处理器从理器从16位位宽度的度的Nor Flash启启动OM1:0=10时,处理器从理器从32位位宽度的度的Nor Flash启启动OM1:0=11时,处理器从理器从Test Mode启启动2023/4/1510S3C2440 Nand FlashS3C2440 Nand Flash启动过程启动过程在系在系统上上电后后,Nand Flash控制器控制器会自会自动的把的把Nand Flash上的前上的前4K U-BOOT数据搬移到内部数据搬移到内部SRAM的地址最低端的地址最低端(此此SRAM被称被称为Steppingstone);CPU从内部从内部RAM的的0 x00000000位置开始启位
7、置开始启动并在并在uboot启启动代代码的前的前4K里完成里完成S3C2440的核心配的核心配置,然后把置,然后把U-BOOT剩余部分搬剩余部分搬到到RAM中运行;中运行;2023/4/1511引导程序引导程序BootLoader是嵌入式系是嵌入式系统在加在加电启启动后后执行的第一段代行的第一段代码,功,功能能类似似pc机的机的BIOS和和OS Loader,通常需要,通常需要固化固化在目在目标板中;板中;主要主要负责CPU、存、存储器及相关硬件的器及相关硬件的初始化初始化,以及,以及将将装装载操作系操作系统映像到内存中,然后跳映像到内存中,然后跳转到到规定的定的地址地址启启动操作系操作系统运
8、行。运行。Bootloader是是严重依重依赖硬件而硬件而实现的,每一种不同的,每一种不同体系体系结构的构的处理器都有不同的理器都有不同的Bootloader,甚至同,甚至同一种一种处理器的外理器的外围硬件配置不同,其硬件配置不同,其Bootloader也也有差有差别。因此开。因此开发特定的特定的Bootloader是构建嵌入式是构建嵌入式linux系系统之前的一之前的一项必要的基必要的基础工作。工作。2023/4/1512Bootloader的运行步骤的运行步骤Stage1(汇编实现)1.基本硬件基本硬件设备初始化:初始化:CPU时钟频率,寄存器,存率,寄存器,存储器数据器数据宽度、度、访问
9、周期、刷新周期,中断系周期、刷新周期,中断系统,I/O端口端口等;等;2.为第二第二阶段准段准备RAM空空间,设置堆置堆栈;3.复制第二复制第二阶段代段代码到到RAM中,并跳中,并跳转到第二到第二阶段入口点段入口点Stage2(C实现)1.初始化本初始化本阶段要使用的硬件段要使用的硬件设备,实现对板板级驱动的支持;的支持;2.检测系系统内存映射;内存映射;3.将内核将内核镜像和根文件系像和根文件系统镜像从像从flash读到到RAM中;中;4.为内核内核设置启置启动参数;参数;5.将将PC指指针指向内核的入口指向内核的入口处,调用内核。挂用内核。挂载文件系文件系统;2023/4/1513Linu
10、x 环境下环境下BootLoader种类种类BootloaderMonitor描描 述述x86ARMPowerPCLILO否否Linux磁盘引导程序磁盘引导程序是是否否否否GRUB否否GNU的的LILO替代程序替代程序是是否否否否Loadlin否否从从DOS引导引导Linux是是否否否否ROLO否否从从ROM引导引导Linux而不需要而不需要BIOS是是否否否否Etherboot否否通过以太网卡启动通过以太网卡启动Linux系系统的固件统的固件是是否否否否LinuxBIOS否否完全替代完全替代BUIS的的Linux引导引导程序程序是是否否否否BLOB否否LART等硬件平台引导程序等硬件平台引导
11、程序否否是是否否U-boot是是通用引导程序通用引导程序是是是是是是RedBoot是是基于基于eCos的引导程序的引导程序是是是是是是2023/4/1514U-boot的分析与移植的分析与移植U-boot全称全称 Universal Boot Loader,支,支持持ARM体系等多种体系等多种处理器,包含常理器,包含常见的外的外设的的驱动,是一个开源的、功能,是一个开源的、功能强大的板极支持包;大的板极支持包;由德国由德国DENX软件工程中心的件工程中心的Wolfgang Denk维护。U-boot启启动时处于正常的于正常的启启动加加载模式,模式,但是它会延但是它会延时指定指定时间(单位秒)等
12、待位秒)等待终端用端用户按下任意按下任意键而切而切换到到下下载模式模式,如果在指定,如果在指定时间内用内用户没有按没有按键,则继续启启动操作系操作系统。2023/4/1515U-boot主要包括以下目录主要包括以下目录lboardboard:该目录该目录存放了存放了U-BootU-Boot支持的一些已有开发板的信息支持的一些已有开发板的信息。每。每一个开发板都以一个子目录出现在当前目录中,如一个开发板都以一个子目录出现在当前目录中,如SMDK2410SMDK2410子子目录中存放与目录中存放与24102410开发板相关的配置文件,但由于自行设计的目开发板相关的配置文件,但由于自行设计的目标板即
13、使与已有开发板使用相同处理器,但其他硬件配置不一定标板即使与已有开发板使用相同处理器,但其他硬件配置不一定相同,所以需要参考该目录下的内容来进行修改,例如根据使用相同,所以需要参考该目录下的内容来进行修改,例如根据使用的的FlashFlash存储器的宽度和容量,可以修改存储器的宽度和容量,可以修改flash.cflash.c中对应的参数。中对应的参数。lcommoncommon:该目录该目录存放的是存放的是U-BootU-Boot命令行界面下支持的各条命令命令行界面下支持的各条命令的实现源码的实现源码。每一条命令都对应一个文件,例如。每一条命令都对应一个文件,例如bootmbootm命令对应命
14、令对应就是就是cmd_bootm.ccmd_bootm.c。通常主要关心与内核引导有关的。通常主要关心与内核引导有关的cmd_boot.ccmd_boot.c和和cmd_bootm.ccmd_bootm.c等代码。等代码。lcpucpu:该目录该目录存放了存放了U-BootU-Boot支持的支持的CPUCPU类型类型。每一款。每一款U-BootU-Boot下支下支持的持的CPUCPU在该目录下对应一个子目录,比如在该目录下对应一个子目录,比如S3C2440AS3C2440A采用的是采用的是ARM920TARM920T内核,则子目录内核,则子目录arm920tarm920t下即是对该处理器核的支
15、持源下即是对该处理器核的支持源码。码。CPUCPU相关的文件主要是初始化一个执行环境,包括中断的初相关的文件主要是初始化一个执行环境,包括中断的初始化。其中有一个重要文件始化。其中有一个重要文件start.sstart.s,该文件是一个汇编源文件,它,该文件是一个汇编源文件,它是整个是整个U-BootU-Boot执行的第一段代码,它的功能是将整个执行的第一段代码,它的功能是将整个U-BootU-Boot目标目标代码重定位,也就是将代码重定位,也就是将U-BootU-Boot转移至内存中去运行。转移至内存中去运行。2023/4/1516U-boot主要包括以下目录主要包括以下目录ldrivers
16、drivers:U-BootU-Boot支持的各种设备驱动程序支持的各种设备驱动程序都放在该目录,比如都放在该目录,比如各种网卡、支持各种网卡、支持CFICFI的的FlashFlash、串口和、串口和USBUSB等。等。lfs:fs:该目录存放该目录存放U-BootU-Boot支持的文件系统,例如支持的文件系统,例如fatfat、fdosfdos、jffs2jffs2、cramfscramfs、ext2ext2和和reiserfsreiserfs等。等。lincludeinclude:U-BootU-Boot使用的使用的头文件头文件,还有对各种硬件平台支持的,还有对各种硬件平台支持的汇编文件,
17、系统的配置文件和对文件系统支持的文件。该目录汇编文件,系统的配置文件和对文件系统支持的文件。该目录下下configsconfigs目录有与开发板相关的配置头文件。该目录下的目录有与开发板相关的配置头文件。该目录下的asmasm目录有与目录有与CPUCPU体系结构相关的头文件,体系结构相关的头文件,ARMARM对应的是对应的是asm-armasm-arm。llib_xxx:lib_xxx:与体系结构相关的与体系结构相关的库文件库文件。与。与ARMARM相关的库放在相关的库放在lib_armlib_arm中。中。lnetnet:与与网络协议栈相关的代码网络协议栈相关的代码,BOOTPBOOTP协议
18、、协议、TFTPTFTP协议、协议、RARPRARP协议和协议和NFSNFS文件系统的实现。文件系统的实现。ltoolstools:生成生成U-BootU-Boot的工具的工具,如:,如:mkimagemkimage,crccrc等等。等等。ldocdoc:文档目录文档目录。U-BootU-Boot有非常完善的文档,推荐参考阅读。有非常完善的文档,推荐参考阅读。2023/4/1517U-boot的运行过程分析的运行过程分析U-Boot的的阶段一段一代代码通常放在通常放在start.s文件中,用文件中,用汇编语言写成,其主要功能是言写成,其主要功能是设置置处理器状理器状态、初始化中断和内存、初始
19、化中断和内存时序、序、对整个整个U-Boot目目标代代码进行重新定位。行重新定位。阶段一刚开始的代码是处理器的阶段一刚开始的代码是处理器的异常处理向量表异常处理向量表:.globl_start;系统复位的位置,由;系统复位的位置,由U-Boot.ld决定决定_start:b reset;0 x00000000,各个异常向量对应的跳转代码,各个异常向量对应的跳转代码 ldr pc,_undefined_instruction;0 x00000004,未定义指令异常,未定义指令异常 ldrpc,_software_interrupt ;0 x00000008,软件中断异常软件中断异常 ldr pc
20、,_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/4/1518U-boot的运行过程分析的运行过程分析reset/*s
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 微处理器系统结构与嵌入式系统设计 微处理器 系统 结构 嵌入式 设计 cha
限制150内