《嵌入式软件开发简介以linux为例.ppt》由会员分享,可在线阅读,更多相关《嵌入式软件开发简介以linux为例.ppt(223页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。
1、嵌入式软件开发简介以linux为例 Still waters run deep.流静水深流静水深,人静心深人静心深 Where there is life,there is hope。有生命必有希望。有生命必有希望2课程安排嵌入式Linux开发环境搭建嵌入式Linux概述Linux快速入门熟悉嵌入式开发平台熟悉引导启动代码和内核的烧写NFS环境构建3课程安排嵌入式Linux下的应用程序开发嵌入式Linux开发工具与开发流程理解交叉编译 嵌入式Linux下的应用程序调试技巧Make工程管理器4嵌入式系统的特点嵌入式系统低功耗、体积小,专用性强。嵌入式系统与PC机的最大不同就是嵌入式CPU大多工作
2、在为特定用户群设计的系统中,能够把PC机中许多由板卡完成的任务集成在芯片内部,从而有利于嵌入式系统设计趋于小型化。为了提高执行速度和系统可靠性,嵌入式系统中的软件一般都固化在存储器芯片或单片机本身中,而不是存贮于磁盘等载体中。嵌入式系统的硬件和软件都必须高效率地设计,系统要精简。操作系统一般和应用软件集成在一起。对软件代码质量要求很高。应该尽最大可能避免死机的情况发生。嵌入式系统开发需要专门的开发工具和开发环境。5如何选择嵌入式CPU?ARMPowerPCMIPSXscaleDSPX866典型的嵌入式操作系统LinuxuC/OS Windows CE VxWorks Palm OS Symbi
3、an7嵌入式系统开发流程8嵌入式系统开发的内容9嵌入式Linux开发模式BootLoader内核内核FlashTargetHostNFS模式模式Root fs10Linux快速入门11Linux简介Linus Torvalds于1991编写Linux是一个Unix兼容的系统,大部分通用的Unix工具和程序都可以在Linux系统下运行。UNIX-堂兄 Linux表弟使用GNU工具开发:gcc,glibc,binutils,make等GNU=GNU is Not UnixGPL=General Public License12一些发行版RedHatFedora CoreSuseDebianUbun
4、tuCent OSAisanux13认识Linux内核版本主版本主版本1.02.02.22.42.6 2,3年更新年更新稳定版稳定版2.0.402.2.12 2.4.18 2.6.7 2.6.301,2月更新月更新稳定版更新稳定版更新2.6.23.1 2.6.23.71,2周更新周更新14Linux体系结构用户空间用户空间内核空间内核空间文件文件系统系统I/O内存内存管理管理Cache调度调度内核内核15内核结构16Linux优点提供了先进的网络支持多任务、多用户符合IEEE POSIX标准核心能仿真FPU支持数十种文件系统格式完全运行于保护模式开放源代码采用先进的内存管理机制,更加有效地利用
5、物理内存 17Linux分区Linux分区的形式Swap分区根分区/Boot分区其他18Linux的基本命令Shell命令行使用技巧:Tab自动补齐、ctrl+a+e等cd:转换目录ls:列出文件名(根目录浏览)ll:查看文件属性(文件属性与权限)cp:复制文件(cp/mnt/hgfs/share/*.*/root/)mv:移动文件(可用于文件或目录的改名)rm:删除文件(rm rf (目标))mkdir:创建目录rmdir:删除目录19Linux的基本命令(2)cat:显示文本文件less/more:分屏显示文件grep:查找字符串(ls all|grep*)head:显示文件开头tail:
6、显示文件结尾sort:按次序显示文件uniq:去掉文件中重复的行diff:比较两个文件file:测试文件内容20Linux的基本命令(3)echo:显示文本date:显示时间和日期gzip:压缩文件gunzip:解压缩文件bzip2:压缩文件tar:打包和解包文件whereis:查找命令which:查找实用程序21Linux的基本命令(4)ps:列出进程df:检查文件系统空间占用情况 du:显示磁盘空间的使用情况 kill:杀死进程chmod:改变文件或目录的访问权限 chown:改变文件或目录的属主和组 chgrp:改变文件或目录所属的组 info:获得帮助22Linux的基本命令(5)pw
7、d:显示当前工作目录的绝对路径rpm:文件包管理clear:清屏ln:创建文件链接who:列出系统上的用户名单write:发送消息talk:与其他用户通信man:获取帮助23熟悉嵌入式开发平台熟悉引导启动代码和内核的烧写24需要熟悉的内容开发板硬件基本配置开发板与PC机连接方式PC机相关配置熟悉bootloader的使用深入理解开发内容巩固开发流程25Bootloader烧写示范Linux环境(虚拟机)简介超级终端和DNW的配置Bootloader的显示信息简介(标准BIOS)内核、文件系统的演示26嵌入式Linux下的应用程序开发27开发工具-编辑器vivi的基本使用方法 输入模式输入模式
8、命令模式命令模式28vi-开始编辑开始编辑新增新增(append)-a a 从 光 标 所 在 位 置 後 面 开 始 新 增 资 料,光 标 後 的 资 料 随 新 增 资 料 向 後 移 动。-A A 从 光 标 所 在 列 最 後 面 的 地 方 开 始 新 增 资 料。插插 入入(insert)-i i 从 光 标 所 在 位 置 前 面 开 始 插 入 资 料,光 标 後 的 资 料 随 新 增 资 料 向 後 移 动。-I I 从 光 标列 的 第 一 个 非 空 白 字 符 前 面 开 始 插 入 资 料。开开 始始(open)-o o 在 光 标 所 在 列 下 新 增 一 列
9、 并 进 入 输 入 模 式。-O O 在 光 标 所 在 列 上 方 新 增 一 列 并 进 入 输 入 模 式。29vi-删除与修改删除与修改 x x 删除光标所在字符。dddd 删除光标所在的列。r r 修改光标所在字符,r後接著要修正的字符 R R进入取代状态,新增资料会覆改原先资料,直到按ESC回到指令模式下为止。s s 删除光标所在字符,并进入输入模式。S S 删除光标所在的列,并进入输入模式。30vi-退出命令退出命令不保存退出不保存强制性退出保存编辑存入文件filename 中强制性存入文件filename 中()保存并退出(shift+zz)31vi-光标移动命令光标移动命令
10、移动到当前单词的开始移动到当前单词的结尾向前移动一个单词向前移动一个字符向上移动一行向下移动一行向后移动一个字符32vi-改变与替换操作命令改变与替换操作命令替换光标所在的字符替换字符序列替换一个单词同替换光标所在的前一字符替换自光标位置至行尾的所有字符同替换当前行33vi-拷贝与粘贴命令拷贝与粘贴命令将光标所在单词拷入剪贴板将光标至行尾的字符拷入剪贴板同将当前行拷入剪贴板将剪贴板中的内容粘贴在光标后将剪贴板中的内容粘贴在光标前利用利用Vi编写一个编写一个helloworld程序!程序!3435开发工具-编译器GCC全称为GNU CC,GNU项目中符合ANSI C标准的编译系统 编译如C、C+
11、、Object C、Java、Fortran、Pascal、Modula-3和Ada等多种语言一个交叉平台编译器,适合在嵌入式领域的开发编译 36GCC编译器GNU Compiler CollectionC,C+,Objective-C,Fortran,Java,Adahttp:/gcc.gnu.orgGCC 4.2.2 GCC 2.95 July 31,1999 GCC 3.0 June 18,2001 GCC 3.2 August 14,2002 GCC 3.3 May 13,2003 Oct 9,2007 December 3,1997 37GCC简介gcc所支持后缀名解释.c C原始程
12、序.C/.cc/.cxxC+原始程序.mObjective-C原始程序.i 已经过预处理的C原始程序.ii 已经过预处理的C+原始程序.s/.S 汇编语言原始程序.h 预处理文件(头文件).o 目标文件.a/.so编译后的库文件38编译器的作用源代码*.c预处理器头文件*.h编译器目标代码*.o可执行文件引导代码库函数汇编处理链接Gcc的编译流程分为四个步骤 预处理(Pre-Processing)编译(Compiling)汇编(Assembling)链接(Linking)39“hello”的演变历程Pre-processor(cpp/Gcc-E)Compiler(cc1/Gcc-S)Assem
13、bler(as/Gcc-c)Linker(ld)hello.c(text)hello.i(text)hello.s(text)hello.o(binary)hello(binary)printf.o(binary)40理解交叉编译及环境建立41GCC交叉编译器GNU BinutilsGNU Binutils 的主要工具有两个,一个是连接程序ld,另外一个是汇编程序as。其主要目的是为GNU 系统,提供汇编和连接工具。GNU GCCGNU GCC 就是上面提到的GCC,GCC 主要是为GNU 系统提供C 编译器。现在支持多种语言,这其中包括C/C+、Fortran、Java、Objective-
14、C、甚至还有Ada。GNU GLibc用于定义系统调用和其它一些基本的函数调用。42GCC交叉编译器的生成第1步,取得Binutils、GCC、Glibc 源码。第2步,配置并编译Binutils 取得我们所需要的汇编和连接程序。第3步,配置并编译GCC 源码生成GCC 编译器。一般是C 编译器首先生成,然后以这个为基础在结合下一步生成的Glibc 的C 函数库,再编译生成其它编译器。第4步,配置Glibc 并编译生成Glibc 的C 函数库。第5步,再次配置和编译GCC 源码,生成其它语言的编译器,如C+编译器等。43工具链代码结构44TARGET常用的值实际平台TARGET的值PowerP
15、Cpowerpc-linuxARMarm-linuxMIPS(big endian)mips-linuxMIPS(little endian)mipsel-linuxSuperH 4sh4-linux45交叉编译流程crosstool介绍crosstool是由Dan Kegel开发的一套脚本程序,可以自动编译不同版本的gcc、glibc,并做出测试。在crosstool软件包中,提供了从互联网下载软件包的脚本,例如glibc-get.sh脚本可以下载glibc软件包。有关crosstool的详细信息,读者可以访问其官方网站和其他一些网络资源:http:/ profile。然后arm-linux
16、-gcc v,如果显示是2.9.53。则说明环境配置成功。更改环境变量有几种方法,其中之一是更改etc/profile文件(开机启动时配置)中的PATH,将相冲突的屏蔽掉。另一种方法是重新定义PATH,然后用export导出(export命令可以修改,但重启之后?):可编辑/etc/bashrc文件,在最后增加路径 export PATH=/usr/local/arm/2.95.3/bin:|$PATH,则以后编译内核或其它程序均可用arm-linux-来制定交叉编译器。49嵌入式Linux下的应用程序调试技巧50 调试器-Gdb调试流程 首先使用gcc对test.c进行编译,注意一定要加上选
17、项-g#gcc-g test.c-o test#gdb test GNU gdb Red Hat Linux(6.3.0.0-1.21rh)Copyright 2004 Free Software Foundation,Inc.GDB is free software,covered by the GNU General Public License,and you arewelcome to change it and/or distribute copies of it under certain conditions.Type show copying to see the condit
18、ions.There is absolutely no warranty for GDB.Type show warranty for details.This GDB was configured as i386-redhat-linux-gnu.Using host libthread_db library/lib/libthread_db.so.1.(gdb)51 Gdb调试流程 查看文件(gdb)l设置断点(gdb)b 6查看断点情况查看断点情况(gdb)info b运行代码运行代码(gdb)rv查看变量值(gdb)p nv单步运行(gdb)n(gdb)sv恢复程序运行(gdb)cv帮
19、助(gdb)help command 52Gdb的使用切记点在Gcc编译选项中一定要加入-g。只有在代码处于“运行”或“暂停”状态时才能查看变量值。设置断点后程序在指定行之前停止 53Gdb调试运行被调试程序,设置所有的能影响该程序的参数和变量。保证被调试程序在指定的条件下停止运行。当被调试程序停止时,让开发工程师检查发生了什么。根据每次调试器的提示信息来做响应的改变,以便修正某个错误引起的问题54嵌入式程序调试-NFS熟悉Uboot的烧写方法和使用按照实验指导配置tftp服务按照实验指导配置NFS服务利用NFS调试经交叉编译后的程序55 Makefile简介56工程管理器-Make工程管理器
20、,顾名思义,是指管理较多的文件 Make工程管理器也就是个“自动编译管理器”,这里的“自动”是指它能构根据文件时间戳自动发现更新过的文件而减少编译的工作量,同时,它通过读入Makefile文件文件的内容来执行大量的编译工作 MakeMake将只编译改动的代码文件,而不用完全编译。将只编译改动的代码文件,而不用完全编译。将只编译改动的代码文件,而不用完全编译。将只编译改动的代码文件,而不用完全编译。57Makefile基本结构Makefile是Make读入的唯一配置文件 由make工具创建的目标体(target),通常是目标文件或可执行文件要创建的目标体所依赖的文件(dependency_fil
21、e)创建每个目标体时需要运行的命令(command)Makefile格式target:dependency_filescommand例子hello.o:hello.c hello.hgcc c hello.c o hello.o58Makefile规则 隐式规则隐含规则能够告诉make怎样使用传统的技术完成任务,这样,当用户使用它们时就不必详细指定编译的具体细节,而只需把目标文件列出即可 C编译:.c变为.o$(CC)c$(CPPFLAGS)$(CFLAGS)C+编译:.cc或或.C变为.o$(CXX)-c$(CPPFLAGS)$(CXXFLAGS)59Makefile规则 模式规则 模式规则
22、是用来定义相同处理规则的多个文件的。它不同于隐式规则,隐式规则仅仅能够用make默认的变量来进行操作,而模式规则还能引入用户自定义变量,为多个文件建立相同的规则,从而简化了Makefile的编写 模式规则的格式类似于普通规则,这个规则中的相关文件前必须用“%”标明 60Make使用直接运行make 选项-C dir读入指定目录下的Makefile-f file读入当前目录下的file文件作为Makefile-i忽略所有的命令执行错误-I dir指定被包含的Makefile所在目录-n只打印要执行的命令,但不执行这些命令-p显示make变量数据库和隐含规则-s在执行命令时不显示命令-w如果mak
23、e在执行过程中改变目录,打印当前目录名61Autotools简介对于一个较大的项目而言编写Makefile难度较大autotools系列工具只需用户输入简单的目标文件、依赖文件、文件目录等就可以轻松地生成Makefileautotools工具还可以完成系统配置信息的收集,从而可以方便地处理各种移植性的问题Linux上的软件开发一般都用autotools来制作Makefile 62 autotools使用流程 aclocalaclocalautoscanautoscanautoconfautoconfautoheaderautoheaderautomakeautomake63使用Makefile
24、make 键入make默认执行make all命令,即目标体为all make install 把该程序安装到系统目录中去 make clean 清除之前所编译的可执行文件及目标文件(object file,*.o)make dist 将程序和相关的文档打包为一个压缩文档以供发布 Shell脚本简介Shell脚本的本质编译型语言解释型语言Shell脚本语言是解释型语言Shell脚本的本质:ShellShell命令的有序集合命令的有序集合命令的有序集合命令的有序集合。shell 编程的基本过程编程的基本过程基本过程分为三步:Step1.建立 shell 文件 包含任意多行操作系统命令或shell
25、命令的文本文件;Step2.赋予shell文件执行权限 用chmod命令修改权限;Step3.执行shell文件 直接在命令行上调用shell程序.Step1:建立建立shell文件文件(可用任何建立文本文件的方法可用任何建立文本文件的方法)$cat prog1 who|grep$1Step2:赋予执行权限赋予执行权限:(初始文本文件无执行权限初始文本文件无执行权限)$chmod 740 prog1Step3:执行该执行该shell程序程序$prog1 wdl prog1:not found (shell在标准搜索目录中找不到prog1命令)Step4:指定路径或修改环境变量指定路径或修改环境
26、变量PATH后执行后执行shell程序程序$./prog1 wdl wdl tty06 Feb 8 09:12实例Shell变量Shell允许用户建立变量存储数据,但不支持数据类型(整型、字符、浮点型),将任何赋给变量的值都解释为一串字符Variable=value命名规则同C+中的命名规则count=1Echo$countDATE=dateEcho$DATEshell变量Bourne Shell主要有如下三种变量:用户自定义变量 位置变量即 shell script之参数 环境变量用户自定义变量在在shell编程中通常使用全大写变量,方便识别编程中通常使用全大写变量,方便识别$COUNT=1
27、变量的调用:在变量前加变量的调用:在变量前加$echo$HOME Linux Shell/bash从右向左赋值从右向左赋值$Y=y$X=$Y$echo$X y 使用使用unset命令删除变量的赋值命令删除变量的赋值$Z=hello$echo$Z hello$unset Z$echo$Z 位置变量$0 与键入的命令行一样,包含脚本文件名$1,$2,$9 分别包含第一个到第九个命令行参数$#包含命令行参数的个数$包含所有命令行参数:“$1,$2,$9”$?包含前一个命令的退出状态$*包含所有命令行参数:“$1,$2,$9”$包含正在执行进程的ID号shell环境变量CDPATH:用于cd命令的查找
28、路径 HOME:/etc/passwd文件中列出的用户主目录 IFS:Internal Field Separator,默认为空格,tab及换行符 MAIL:/var/mail/$USERNAME mail等程序使用 PATH:路径PS1,PS2:默认提示符($)及换行提示符()TERM:终端类型,常用的有vt100,ansi,vt200,xterm等 文件测试-d name 测试name 是否为一个目录-f name 测试name 是否为普通文件-L name测试name 是否为符号链接-r name 测试name 文件是否存在且为可读-w name 测试name 文件是否存在且为可写-x
29、name 测试name 文件是否存在且为可执行-s name 测试name 文件是否存在且其长度不为0f1-nt f2 测试f1 是否比f2 更新f1-ot f2 测试f1 是否比f2 更旧ifthenfi语法结构:if 表达式表达式 then 命令表命令表 fi 如果表达式为真,则执行命令表中的命令;否则退出if语句,即执行fi后面的语句.if和fi是条件语句的语句括号,必须成对使用;命令表中的命令可以是一条,也可以是若干条.条件语句caseesac 多路分支语句case用于多重条件测试,语法结构清晰自然.其语法结构为:case 字符串变量 in 模式1)命令表1 ;模式2)命令表2 ;模式
30、n)命令表n ;esaccase语句只能检测字符串变量各模式中可用文件名元字符,以右括号结束命令表以单独的双分号行结束,退出case语句模式 n常写为字符*表示所有其它模式最后一个双分号行可以省略多路分支语句fordodone 当循环次数已知或确定时,使用for循环语句来多次执行一条或一组命令。循环体由语句括号do和done来限定。格式为:for 变量名 in 单词表 do 命令表 done变量依次取单词表中的各个单词,每取一次单词,就执行一次循环体中的命令.循环次数由单词表中的单词数确定.命令表中的命令可以是一条,也可以是由分号或换行符分开的多条。如果单词表是命令行上的所有位置参数时,可以在
31、for语句中省略“in 单词表”部分。循环语句whiledodone语法结构为:while 命令或表达式 do 命令表 donewhile语句首先测试其后的命令或表达式的值,如果为真,就执行一次循环体中的命令,然后再测试该命令或表达式的值,执行循环体,直到该命令或表达式为假时退出循环。while语句的退出状态为命令表中被执行的最后一条命令的退出状态。循环语句78实验内容熟悉开发环境的搭建熟悉BIOS、Uboot的使用,NFS的配置编写简单的C程序使用GDB调试有问题的C代码编写简单的Makefile编写简单的SHELL脚步Bootloaderwww.embedu.org80内容提纲Bootlo
32、ader简介简介1U-Boot2移植移植U-Boot3什么是BootloaderBootloader是硬件启动的引导程序,是启动操作系统的根本;是在操作系统内核或用户应用程序运行之前运行的一段小程序。通过这段小程序,可以初始化硬件设备、建立内存空间的映射图,从而将系统的软硬件环境带到一个合适的状态,以便为最终调用准备好环境;在一般典型的系统中,整个系统的加载启动任务就完全由Bootloader来完成。www.embedu.org81Bootloader不属于操作系统内核,采用汇编语言编写,因此针对不同的CPU体系结构,这一部分代码不具有可移植性;在移植操作系统时,这部分代码必须加以改写。Boo
33、tloader不但依赖于CPU的体系结构,而且依赖于嵌入式系统板级设备的配置。Bootloader的特点启动加载模式启动加载模式:在这种模式下,Bootloader从目标机上的某个固态存储设备上将操作系统加载到RAM中运行,整个过程并没有用户的介入。下载模式下载模式:在这种模式下,目标机上的Bootloader将通过串口或网络等通信手段从开发主机(Host)上下载内核映像和根文件系统映像等到RAM中。然后可以再被 Bootloader写到目标机上的固态存储媒质中,或者直接进行系统的引导。Bootloader的操作模式 初始化硬件将操作系统内核从Flash拷贝到SDRAM中,如果是压缩格式的内核
34、,还要解压缩改写系统的内存映射,原先Flash起始地址映射为0地址,这时需要将RAM的起始地址映射为0提供Linux内核的启动参数启动Linux内核设置堆栈指针并将bss段清零将来执行C语言程序和调用子函数时要用到改变pc值,使得CPU开始执行真正的操作系统内核。Bootloader的特征Bootloader的启动系统加电或复位后,所有CPU都会从某个地址开始执行嵌入式系统的开发板都要把板上ROM或FLASH映射到这个地址。因此,必须把Bootloader程序存储在相应的FLASH位置。系统加电后,CPU将首先执行它。www.embedu.org85屏蔽所有的中断。为中断提供服务通常是 OS
35、设备驱动程序的责任,因此在 Boot Loader 的执行全过程中可以不必响应任何中断 设置 CPU 的速度和时钟频率 RAM 初始化。包括正确地设置系统的内存控制器的功能寄存器以及各内存库控制寄存器等初始化 LED。其目的是表明系统的状态。如果板子上没有 LED,可以通过初始化 UART 向串口打印 Bootloader 的 Logo 字符信息来完成这一点 关闭CPU内部I/D cache 为加载 stage2 准备 RAM 空间,跳转到 stage2的C入口点 Bootloader的第一阶段 初始化本阶段要使用到的硬件设备;检测系统内存映射;将内核映像和根文件系统映像从Flash读到RAM
36、;为内核设置启动参数;调用内核。Bootloader的第二阶段BootloaderMonitor描述x86ARMPowerPCLILO否Linux磁盘引导程序是否否GRUB否GNU的LILO替代程序是否否Loadlin否从DOS引导Linux是否否ROLO否从ROM引导Linux而不需要BIOS是否否Etherboot否通过以太网卡启动Linux系统的固件是否否LinuxBIOS否完全替代BUIS的Linux引导程序是否否BLOB否LART等硬件平台的引导程序否是否一些bootloader介绍Configuration file/boot/grub/menu.lst /boot/grub/gr
37、ub.confdefault=0timeout=10splashimage=(hd0,1)/boot/grub/splash.xpm.gztitle MicroSoft Windows XProotnoverify(hd0,0)chainloader+1title Red Hat Linux(2.4.20-8)root(hd0,1)kernel/boot/vmlinuz-2.4.20-8 ro root=LABEL=/initrd/boot/initrd-2.4.20-8.img配置GRUBU-Boot是ARM bootloader标准armboot 加入到 ppcboot 形成了 u-boo
38、t支持arm720,arm920,arm926,sa1100,xscalehttp:/ ARM BootloadersFS2410开发板提供的BIOSwww.embedu.org910号功能:号功能:USB下载下载1号功能:号功能:串口下载串口下载2号功能:号功能:执行执行NAND Flash的烧的烧写写3号功能:号功能:从从NAND Flash启动启动程序程序4号功能:号功能:擦除擦除NAND Flash分区分区5号功能:号功能:烧写烧写Nor Flash6号功能:号功能:设置启动参设置启动参数数7号功能:号功能:设置自启动设置自启动参数参数DRAM控制器DRAM芯片不能向其它微处理器总线资
39、源那样直接读写,它们需要特殊的硬件控制器使能读写循环。设置DRAM控制器需要详细了解DRAM体系结构、控制器本身、DRAM芯片使用的规范和全面的硬件设计。Bootloader首先要完成的就是使能内存子系统。初始化内存以后,内存可以作为一种资源进行使用。www.embedu.org92www.embedu.org93内容提纲1U-Boot2移植移植U-Boot3u-boot(Universal Boot Loader)是德国DENX小组的开发用于多种嵌入式CPU的bootloader程序。遵循GPL条款;从FADSROM、8xxROM、PPCBOOT逐步发展演化而来;当前版本号:见include
40、/version.h中的定义。U-boot介绍平台相关board,cpu,lib_ppc,lib_arm,include平台无关common,net,fs,drivers工具和文档tools,docU-Boot程序结构boardBoard dependent files,RPXlite(mpc8xx),smdk2410(arm920t),sc520_cdp(x86)cpuCPU specific files,mpc8xx,ppc4xx,arm720t,arm920t,xscale,i386lib_ppcFiles generic to PowerPC architecturelib_armFi
41、les generic to ARM architecturelib_i386Files generic to X86 architectureincludeHeader Files and board configsU-Boot程序结构commonMisc functionslib_genericGeneric library functionsnetNetworking codefsFile System CodepostPower On Self TestdriversCommon used device driversdiskHard disk interface codertcRea
42、l Time Clock driversdttDigital Thermometer and Thermostat driversU-Boot程序结构在 Flash 中运行汇编程序,将 Flash 中的启动代码部分复制到 SDRAM 中,同时创造环境准备运行 C 程序;在 SDRAM 中执行,对硬件进行初始化;设置内核参数的标记列表,复制镜像文件,进入内核的入口函数 U-Boot 启动过程的几个阶段 99初始化硬件设置UART设置网口设置USB检测存储器设置启动参数内核硬件信息波特率 跳转到Linux内核的首地址消亡 BootLoader的生命周期 设置异常的入口地址和异常处理函数;配置 PL
43、LCON 寄存器,确定系统的主频;屏蔽看门狗和中断;初始化 I/O 寄存器;关闭 MMU 功能;调用/board/smdk2410 中的lowlevel_init.S,初始化存储器空间,设置刷新频率;将 U-Boot 的内容复制到 SDRAM 中;设置堆栈的大小(ldr pc,_start_armboot);设置程序编译连接的起始地址(config.mk:TEXT_BASE=0 x33F80000)。U-Boot入口函数start.S 系统复位代码ldr pc,_start_armboot_start_armboot:.word start_armboot表示u-boot完成cpu初始化,将跳
44、转到C程序中间。start_armboot完成设备初始化过程,进入main_loop循环。start_armboot-lib_arm/board.ccpu/arm920t/start.Smrsr0,cpsrbicr0,r0,#0 x1f ;位清零 orrr0,r0,#0 xd3 ;逻辑或0 xd3=1101 0011msrcpsr,r0复位模式位含义ldr r0,=pWTCONmov r1,#0 x0str r1,r0关闭看门狗mov r1,#0 xffffffffldrr0,=INTMRstrr1,r0关闭中断movr0,#0mcrp15,0,r0,c7,c7,0 /*flush v3/v4
45、 cache*/mcrp15,0,r0,c8,c7,0 /*flush v4 TLB*/刷新指令/数据缓存mrcp15,0,r0,c1,c0,0bicr0,r0,#0 x00002300 clear bits 13,9:8(-V-RS)bicr0,r0,#0 x00000087 clear bits 7,2:0(B-CAMorrr0,r0,#0 x00000002 set bit 2(A)Alignorrr0,r0,#0 x00001000 set bit 12(I)I-Cachemcrp15,0,r0,c1,c0,0禁用MMU和缓存板级相关,/board/lowlevel_init.Smov
46、ip,lrbllowlevel_initmovlr,ipmovpc,lr设置RAM1.globl lowlevel_initlowlevel_init:2.ldr r0,=SMRDATA3.ldrr1,_TEXT_BASE4.subr0,r0,r15.ldrr1,=BWSCON6.add r2,r0,#13*40:7.ldr r3,r0,#48.str r3,r1,#49.cmp r2,r010.bne 0blowlevel_init调试u-boot时,开始一般是让它在RAM中运行,当RAM运行通过后才将其固化到FLASH中;这样如果我们当前的代码是通过BDI2000等Load到内存直接运行的
47、话,u-boot就不需要去将自己从Flash搬移到内存了;而如果u-boot是固化在Flash中在CPU复位后由第一个片选信号指向开始执行的话,则有一个从Flash搬移到内存的过程。重定位(Relocate)的概念 1.relocate:/*relocate U-Boot to RAM*/2.adrr0,_start/*当前代码的地址信息*/3.ldrr1,_TEXT_BASE/*test if we run from flash or RAM*/4.cmp r0,r1 /*dont reloc during debug*/5.beq stack_setup6.ldrr2,_armboot_s
48、tart7.ldrr3,_armboot_end8.subr2,r3,r2/*r2-size of armboot*/9.addr2,r0,r2/*r2 printenvbaudrate=115200ipaddr=192.168.1.1ethaddr=12:34:56:78:9A:BCserverip=192.168.1.5www.embedu.org116U-boot命令介绍setenv 设置新的变量Uboot setenv myboard AT91RM9200DKUboot printenvbaudrate=115200ipaddr=192.168.1.1ethaddr=12:34:56:
49、78:9A:BCserverip=192.168.1.5myboard=AT91RM9200DKEnvironment size:102/8188 bytessaveenv 将当前定义的所有的变量及其值存入flash中。www.embedu.org117U-boot命令介绍tftp 通过网络下载程序Uboot setenv ethaddr 12:34:56:78:9A:BCUboot setenv ipaddr 192.168.1.1Uboot setenv serverip 192.168.1.254Uboot tftp 20000000 application.binUboot tftp
50、30200000 zImageLoadb 通过串口Kermit协议下载二进制数据。www.embedu.org118U-boot命令介绍md 显示内存区的内容。mm 修改内存,地址自动递增。nm 修改内存,地址不自动递增。mw 填充内存。mtest 测试内存。cp 拷贝一块内存到另一块。cmp 比较两块内存区。mw 0 x32000000 ff 0 x10000www.embedu.org119U-boot命令介绍Protect 写保护操作protect on 1:0-3(就是对第一块FLASH的0-3扇区进行保护)protect off 1:0-3取消写保护erase 擦除扇区erase:删