【文档说明】嵌入式系统软件开发基础课件.pptx,共(77)页,1.903 MB,由小橙橙上传
转载请保留链接:https://www.ichengzhen.cn/view-50455.html
以下为本文档部分文字说明:
第3章嵌入式系统软件开发基础3.1嵌入式系统软件组成3.2嵌入式系统软件开发方法3.3嵌入式系统软件开发主要内容3.4嵌入式系统软件调试方法.3.5嵌入式软件集成开发环境3.6嵌入式软件开发语言第3章嵌入式系统的设计方法2
典型嵌入式系统组成处理器MMUGPIOUSBLCDCANDMA以太网LCD/触摸屏/鼠标FlashSDRAMSRAM看门狗复位电路电源管理驱动层OS应用BSP/driver/HALLinux、u/COS、Wince…文件系统/GUI/API软
件硬件输入输出第3章嵌入式系统的设计方法33.1嵌入式软件组成BSPBootloader操作系统内核文件系统库,应用软件第3章嵌入式系统的设计方法43.2嵌入式系统软件开发方法采用宿主机/目标机交叉开发方
式嵌入式系统本身不具备自举开发能力,即使设计完成以后用户通常也是不能对其中的程序功能进行修改的。嵌入式软件以宿主机/目标机模式开发,所需要的开发环境称为交叉开发环境,分为宿主机部分和目标机部分,两者以统一的通信协议进行通信,宿主机向目标机发送命令,目标机接收
、执行命令并将结果返回宿主机,从而实现两机之间的交互控制。第3章嵌入式系统的设计方法53.3嵌入式系统软件设计和调试流程编辑创建工程添加文件、编写程序汇编语言加C语言编译配置编译、汇编和连接参数编写连接脚本文件编译第3章嵌入式
系统的设计方法6调试连接调试器下载程序运行、调试固化通过仿真器烧写flash专用或通用的编程器通过bootloader烧写flash第3章嵌入式系统的设计方法73.4嵌入式软件开发主要内容无操作系统的软
件开发主要包括两部分启动代码应用程序基于操作系统的软件开发包括:Bootloader开发操作系统开发移植BSP板级支持包开发移植应用程发开发移植第3章嵌入式系统的设计方法8无操作系统软件开发-启动代码开发启动代码功能和特征功能硬件初始化引导C代码特征通常用汇编语言编写
程序复位运行入口点代码量非常小第3章嵌入式系统的设计方法9无操作系统软件开发-启动代码启动代码程序流程设置中断、异常入口关中断硬件寄存器初始化(GPIO配置、总线配置、PLL时钟)初始化栈指针数据区初始化C入口函数调用BLMai
n第3章嵌入式系统的设计方法10无操作系统软件开发-应用软件开发应用软件功能和特征功能硬件驱动应用特征通常用C语言或者嵌入式汇编语言编写程序较复杂,代码量较大第3章嵌入式系统的设计方法11基于操作系统的软件开发-bootloader开发Bootloader功
能和特征功能硬件初始化引导操作系统下载程序(串口、网口、USB)烧写flash特征程序复位运行入口点通常用汇编语言+C语言编写代码量较小(相对)第3章嵌入式系统的设计方法12基于操作系统的软件开发-
嵌入式操作系统移植LinuxWindowsCEuC/OSIIuClinuxNucleus第3章嵌入式系统的设计方法13基于操作系统的软件开发-BSP设计BSP功能和特征功能为应用程序提供统一的硬件操作接口特征高度硬件相关高度依赖于具体硬件平台各种
操作系统各异第3章嵌入式系统的设计方法14基于操作系统的软件开发-应用程序设计应用程序功能功能GUI图形、人机交互控制算法特征硬件依赖程度小部分可仿真调试各种操作系统各异第3章嵌入式系统的设
计方法153.5嵌入式软件调试技术1.模拟器方式2.在线仿真器方式3.监控器方式4.在线调试器方式第3章嵌入式系统的设计方法161.模拟器方式调试工具和待调试的嵌入式软件都在主机上运行,通过软件手段模拟执行为某种嵌入式处理器编写的源程序。简单的模拟器可以通过指令解释方式逐条
执行源程序,分配虚拟存储空间和外设,进行语法和逻辑上的调试。第3章嵌入式系统的设计方法172.在线仿真器方式在线仿真器ICE是一种完全仿造调试目标CPU设计的仪器,目标系统对用户来说是完全透明的、可控的。仿真器与目标板通过仿真头
连接,与主机有串口、并口、以太网口或USB口等连接方式。该仿真器可以真正地运行所有的CPU动作,并且可以在其使用的内存中设置非常多的硬件中断点,可以实时查看所有需要的数据,从而给调试过程带来很多便利。由于仿真器自成体系,调试时可以连接目标板,也可以不接目标板。使用ICE同使用一般的目标硬件一
样,只是在ICE上完成调试后,需要把调试好的程序重新下载到目标系统上而已。由于ICE价格昂贵,而且每种CPU都需要一种与之对应的ICE,使得开发成本非常高。第3章嵌入式系统的设计方法18主机和目标板通过某种接口(通常是串口)连接,主机上提供调试界
面,被调试程序下载到目标板上运行监控程序是一段运行于目标机上的可执行程序,主要负责监控目标机上被调试程序的运行情况,与宿主机端的调试器一起完成对应用程序的调试。监控程序包含基本功能的启动代码,并完成必要的硬件初始化,等待宿主机的命令。被调试程序通过监控程序下载到目标机,就可以开始进行调试。监控器
方式操作简单易行,功能强大,不需要专门的调试硬件,适用面广,能提高调试的效率,缩短产品的开发周期,降低开发成本。正因为以上原因,监控器方式才能够广泛应用于嵌入式系统的开发之中。监控器调试主要用于调试运行在目标机操作系
统上的应用程序,不适宜用来调试目标操作系统。有的微处理器需要在目标板工作正常的前提下,事先烧制监控程序,而且功能有限,特别是硬件调试能力较差。3.监控器方式第3章嵌入式系统的设计方法194.在线调试器方式使用ICD和目标板的调试端口连接,发送调试命令和接收调试信
息,可以完成必要的调试功能。一般情况下,在ARM芯片的开发板上采用JTAG边界扫描口进行调试。摩托罗拉公司采用专用的BDM调试接口。使用合适的开发工具可以利用这些接口。例如,ARM开发板,可以将JTAG调试器接在开发板的JTAG口上,通过JTAG口与ARM处理器
核进行通信。由于JTAG调试的目标程序是在目标板上执行,仿真更接近于目标硬件,因此许多接口问题,如高频操作限制、电线长度的限制等被最小化了。该方式是目前采用最多的一种调试方式。第3章嵌入式系统的设计方法203.6嵌入式系统软件开发工具Windows操作系统ARMADS/SDT+调试器GNU+
Cygwin+调试器ARMSDT+简易电缆Linux操作系统GNU+GDB第3章嵌入式系统的设计方法21开发环境的作用C/C++编译器目标文件C/C++编译器目标文件汇编语言汇编器目标文件连接器可重定位程序定址器可执
行文件第3章嵌入式系统的设计方法22ADSIDE(集成开发环境)ARM应用软件的开发工具根据功能的不同,可以分为编辑软件、编译软件、汇编软件、链接软件、调试软件、嵌入式实时操作系统、函数库、评估板,JTAG仿真器以及在线仿真器
等。目前有多家公司可以提供以上不同类型的开发工具,用户采用ARM处理器进行嵌入式系统开发时,选择合适的开发工具可以加快开发进度,节省开发成本。第3章嵌入式系统的设计方法23ADS工具包的组成ADS是ARM公司推出的集成开发工具包,是专门用于ARM相关应用开发和调试的综合性软件。目
前常用的版本是1.2,在功能和易用性上比早期的SDT都有提高,是一款功能强大又易于使用的开发工具。ARMADS包含有编译器、链接器、CodeWarriorIDE、调试器、指令集模拟器、ARM开发包和应用库等部分,可以用ADS来开发、编译、调试采用包括C、C
++和ARM汇编语言编写的程序。第3章嵌入式系统的设计方法24ADS开发工具集1.命令行开发工具ANSIC编译器-armccandtccISO/EmbeddedC++编译器-armcppandtcppARM/Thumb汇编器–armsLinker-ar
mlink第3章嵌入式系统的设计方法252.图形开发工具:Windows集成开发环境–CodeWarriorDebugger–AXD(ARMeXtendedDebugger)armsdARM(符号调试器)可向前兼容3.库
文件:CandC++库4.辅助工具/支持软件:格式转换器-fromelf指令级仿真–ARMulator库管理器–armar第3章嵌入式系统的设计方法26fromELF:ARM映像文件转换工具该命令将ELF格式的文件作为输入文
件,将该格式转换为各种输出格式的文件,包括plainbinary(BIN格式映像文件),Motorola32-bitS-recordformat(Motorola32位S格式映像文件),IntelHex32
format(Intel32位格式映像文件),和Verilog-likehexformat(Verilog16进制文件)第3章嵌入式系统的设计方法27Armar:ARM库函数生成器将一系列ELF格式的目标文件以库函数的形式集合在一起,用户可以把一个库传递给一个链接器以代替几个ELF
文件。Flashdownloader:用于把二进制映像文件下载到ARM开发板上的Flash存储器的工具ARMulator:ARM指令集仿真器,集成在ARM的调试器AXD中,它提供对ARM处理器的指令集的仿真,为ARM和Thumb提供精确的模拟,用户可以在硬件尚未
做好的情况下,开发程序代码。第3章嵌入式系统的设计方法28名称描述使用方式代码生成工具ARM汇编器ARMC/C++编译器ThumbC/C++编译器ARM链接器由CodeWarrior调用集成开发环境CodeWarrior工程管理,编译链接调试器AXD/ADW/ADU/armsd仿真调
试指令模拟器ARMulator由AXD调用ARM开发包一些底层的例程,实用程序(如fromELF)由CodeWarrior调用ARM应用库C/C++等函数库用户程序调用工具调用及流程第3章嵌入式系统的设计方法29集成开发环境CodeWarrio
r使用CodeWarrior集成开发环境为管理和开发项目提供了简单、多样化的图形用户界面。用户可以使用ADS的CodeWarriorIDE为ARM处理器开发用C,C++,或ARM汇编语言的程序代码。全面的项目管理功能。可以在CodeWarriorIDE为ARM配置以上所介绍的各种命
令工具,实现对工程代码的编译,汇编和链接。第3章嵌入式系统的设计方法30C/C++BrowserC/C++SensitiveEditorProjectManager第3章嵌入式系统的设计方法31建立工程第3章
嵌入式系统的设计方法32第3章嵌入式系统的设计方法33ARMExecutableImage:用于由ARM指令的代码生成一个ELF格式的可执行映像文件。ARMObjectLibrary:用于由ARM指令的代
码生成一个armar格式的目标文件库。EmptyProject:用于创建一个不包含任何库或源文件的工程。第3章嵌入式系统的设计方法34MakefileImporterWizard:用于将VisualC的nmake或GN
Umake文件转入到CodeWarriorIDE工程文件。ThumbARMInterworkingImage:用于由ARM指令和Thumb指令的混和代码生成一个可执行的ELF格式的映像文件。ThumbExecutable
image:用于由Thumb指令创建一个可执行的ELF格式的映像文件。ThumbObjectLibrary:用于由Thumb指令的代码生成一个armar格式的目标文件库。第3章嵌入式系统的设计方法35新建文件第3章嵌入
式系统的设计方法36添加文件到工程第3章嵌入式系统的设计方法37生成目标设置第3章嵌入式系统的设计方法38每个工程项目都有下面3种生成目标:Debug:包含所有调试信息DebugRel:包含部分调试信息Release:不包含调试信息注:若项目编译只是为了调试使用,则选择Debug或者De
bugRel;若要生成最后可以运行的文件,则最好选择Release。第3章嵌入式系统的设计方法39编译链接进入编译链接设置:第3章嵌入式系统的设计方法40设置窗口:第3章嵌入式系统的设计方法41目标设置:第3章嵌入式系统的设计方法42在TargetsSettings选项组中,P
ost-Linker用于选择链接器输出文件的处理方式。用户可以选择的值如下:None:不进行连接的处理。ARMfromELF:使用ARM工具fromELF处理链接器输出的ELF格式文件,它可以将ELF格式的文件转换为各种二进制文件格式。Batc
hFileRunner:在连接完成后运行一个DOS格式的批处理文件。第3章嵌入式系统的设计方法43若用户在编译完成后只是用AXD来调试程序,建议选择None;若要生成最后的编程文件,建议选择ARMfromELF,该选项与Linker面板中的A
RMfromELF选项结合来产生最终的编程文件。第3章嵌入式系统的设计方法44CPU设置:第3章嵌入式系统的设计方法45Linker设置:第3章嵌入式系统的设计方法46在Outputformat下拉框中,为用户提供了多种可
以转换的目标格式,这里选择Plainbinary,这是一个二进制格式的可执行文件,可以被烧写在目标板的Flash中。在Outputfilename文本域输入期望生成的输出文件存放的路径,或通过点击Choose...按钮从文件对话框中选择输出文件路径。如果在这个文本域不输入路径名,则生成的二进
制文件存放在工程所在的目录下。第3章嵌入式系统的设计方法47第3章嵌入式系统的设计方法48在标签页Output中,Linktype中提供了3种链接方式:Partia:表示链接器只进行部分链接,经过部分链接生成的目标文
件,可以作为以后进一步链接时的输入文件。Simple:默认的链接方式,也是使用最为频繁的链接方式,它链接生成简单的ELF格式的目标文件,使用的是链接器选项中指定的地址映射方式。Scattered:使得链接器要根据sca
tter格式文件中指定的地址映射,生成复杂的ELF格式的映像文件。一般情况下这个选项使用不太多。第3章嵌入式系统的设计方法49在选中Simple方式后,就会出现Simpleimage。R0Base:这个文本框设置包含有R0段的加载域和运行域为同一个地址,默认是0x8000。这里用户要根据硬件的
实际SDRAM的地址空间来修改这个地址,保证在这里填写的地址是程序运行时SDRAM地址空间所能覆盖的地址。RWBase:这个文本框设置包含RW和ZI输出段的运行域地址。如果选中split选项,链接器生成的映像文件将包含2个加载域和2个运行域,此时,在RWBase中所输入的地址为包含RW和ZI输
出段的域设置了加载域和运行域地址。第3章嵌入式系统的设计方法50第3章嵌入式系统的设计方法51在Options选项中,需要注意的是Imageentrypoint文本框。它指定映像文件的初始入口点地址值,当映像文件被加载程序加载时,加载程序会
跳转到该地址处执行。如果需要,用户可以在这个文本框中输入下面格式的入口点。入口点地址:这是一个数值,例如-entry0x0。符号:该选项指定映像文件的入口点为该符号所代表的地址处。比如:-entryint_handler。在此处指定的入口点用于设置
ELF映像文件的入口地址。需要注意的是,这里不可以用符号main作为入口点地址符号,否则将会出现“Imagedosenothaveanentrypoint(Notspecifiedornotsetduetomultiplechoice)”的出错信息。第3
章嵌入式系统的设计方法52Layout选项在连接方式为Simple时有效,用来安排一些输入段在映像文件中的位置。在上图中,PlaceatBeginningofImage选项用于指定某个输入段放置在它所在的运行时域的开头。第3章嵌入式系统的设计方法53
编译链接:第3章嵌入式系统的设计方法54第3章嵌入式系统的设计方法55文件输出第3章嵌入式系统的设计方法56AXD调试工具的使用在软件开发的最初阶段,可能还没有具体的硬件设备。如果要测试所开发的软件是否达到了预期的效果,这可以由软件仿
真来完成。当然,也可以搭建一个PCB板,这个板上可以包含一个或多个处理器,在这个板上可以运行和调试应用软件。只有当通过硬件或者是软件仿真所得到的结果达到了预期的效果,才算是完成了应用程序的编写工作。第3章嵌入式系统的设计方法57调试器能够发送以下指令:装载映像文件到目标
内存;启动或停止程序的执行;显示内存,寄存器或变量的值;允许用户改变存储的变量值。第3章嵌入式系统的设计方法58进入AXD调试工具第3章嵌入式系统的设计方法59在菜单File中选择“Loadimage…”选项,打开LoadImage对话框,找到要装载的.axf映像文件,
点击“打开”按钮,就把映像文件装载到目标内存中了。第3章嵌入式系统的设计方法60DockingwindowsDockingtoolbarsRegistersSource/DisassemblyMemory第3章嵌入式系统的设计方法61选择调试目标:点击AD
X窗口菜单【Options】选择【ConfigureTarget…】,即弹出ChooseTarget窗口,在没有添加其它仿真驱动程序前,Target项中只有两项,分别为ADP(JTAG硬件仿真)和ARMUL(软件仿真)。第
3章嵌入式系统的设计方法62调试工具条,从左到右依次为:全速运行(Go)停止运行(Stop)单步运行(StepIn),与Step命令不同之处在于对函数调用语句,StepIn命令将进入该函数。单步运行(S
tep),每次执行一条语句,这时函数调用将被作为一条语句执行。单步运行(StepOut),执行完当前被调用的函数,停止在函数调用的下一条语句。运行到光标(RunToCursor),运行程序直到当前光标所在行时停止。设置断点(ToggleBreakPoint)第3章嵌入式
系统的设计方法63调试观察窗口工具条,从左到右依次为:打开寄存器窗口(ProcessorRegisters)打开观察窗口(ProcessorWatch)打开变量观察窗口(ContextVariable)打开堆栈观察窗口(BackTrace)打开存
储器观察窗口(Memory)打开反汇编窗口(Disassembly)第3章嵌入式系统的设计方法64处理器状态观察:包括:寄存器变量存储器第3章嵌入式系统的设计方法65存储器窗口:包括:显示格式修改操作第3章嵌入式系统的设计方法66单步执行、断点:第3章嵌入式系统的
设计方法67添加变量进行观察:第3章嵌入式系统的设计方法68WigglerJTAG仿真器的安装与应用简介H-JTAG调试代理使用WigglerJTAG仿真器第3章嵌入式系统的设计方法69简介MagicARM2410实验箱配套的WigglerJTAG仿真器,支持A
DS1.2集成开发环境,支持单步、全速及断点等调试功能。仿真器采用ARM公司提出的标准20脚JTAG仿真调试接口,与计算机连接采用标准25针并口(即打印机口)。第3章嵌入式系统的设计方法70要使用WigglerJTAG仿真器来调试ARM处理器,除了ADS1.2集成开发环境外,还需要安
装一个ARM调试代理软件;推荐使用H-JTAG软件,H-JTAG软件的特点如下:支持ARM7/ARM9,支持自动检测和手动指定内核;使用RDI接口,支持SDT2.51、ADS1.2、REALVIEW和IAR集
成开发环境;支持ARM/Thumb模式;支持LittleEndian&BIGEndian模式;支持Wiggler、SDTJTAG和自定义接口;H-JTAG调试代理第3章嵌入式系统的设计方法71使用WigglerJTAG仿真器双击桌面“H-JTAG”快捷方式启动H-JTA
G会自动检测ARM内核,如果JTAG连接正确将会在H-JTAG主窗口中显示S3C2410A处理器的内核ARM920T在进行JTAG仿真调试时,不要关闭H-JTAG软件第3章嵌入式系统的设计方法72将计算机并口与Wiggle
rJTAG仿真器连接;将仿真器JTAG口接头插入MagicARM2410实验箱主板的J29上;通过AXD软件的设置即可进行JTAG仿真调试;第3章嵌入式系统的设计方法73程序固化在JTAG仿真调试通过后,要将程序调试生成十六进制文件
并下载到外部的NORFlash(即固化程序),才可脱机运行。生成HEX文件。使用FlashProgrammer烧写Flash。第3章嵌入式系统的设计方法74生成HEX文件在当前工程窗口中选用Release生成目标,打开工程的DebugRelSettings窗口,在Target
Settings项中设置Post-linker选取ARMfromELF。在ARMformELF项中设置输出文件类型,如设置为Intel32bitHex,然后设置输出文件名。生成文件默认存放在当前工程
的”第3章嵌入式系统的设计方法75使用FlashProgrammer烧写Flash将MagicARM2410实验箱主板上的JP8跳线器断开,选用NORFlash启动方式,按RST键复位系统将Wigg
lerJTAG仿真器的25针接口通过并口延长线与PC机的并口LPT1连接,将WigglerJTAG仿真器的20针接口通过20PIN连接电缆接到MagicARM2410实验箱主板的J29上将配置文件DeviceARM2410.ocd复制D:\目录下。启动FlashProgrammer点击Pr
ogram按钮,下载程序至目标板的Flash中脱机运行第3章嵌入式系统的设计方法763.8嵌入式软件开发语言C语言汇编语言JAVA语言,C++第3章嵌入式系统的设计方法77一个困扰我的问题?ADS,arm,Linux等相互之间什么关
系?ADS集成开发环境能开发什么东西?它与我们后面所学的GNU开发工具有什么关系?