《最新嵌入式系统设计与实例开发arm与cos-第四讲嵌入式PPT课件.ppt》由会员分享,可在线阅读,更多相关《最新嵌入式系统设计与实例开发arm与cos-第四讲嵌入式PPT课件.ppt(73页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。
1、进入夏天,少不了一个热字当头,电扇空调陆续登场,每逢此时,总会想起进入夏天,少不了一个热字当头,电扇空调陆续登场,每逢此时,总会想起那一把蒲扇。蒲扇,是记忆中的农村,夏季经常用的一件物品。记忆中的故那一把蒲扇。蒲扇,是记忆中的农村,夏季经常用的一件物品。记忆中的故乡,每逢进入夏天,集市上最常见的便是蒲扇、凉席,不论男女老少,个个手持乡,每逢进入夏天,集市上最常见的便是蒲扇、凉席,不论男女老少,个个手持一把,忽闪忽闪个不停,嘴里叨叨着一把,忽闪忽闪个不停,嘴里叨叨着“怎么这么热怎么这么热”,于是三五成群,聚在大树,于是三五成群,聚在大树下,或站着,或随即坐在石头上,手持那把扇子,边唠嗑边乘凉。孩
2、子们却在周下,或站着,或随即坐在石头上,手持那把扇子,边唠嗑边乘凉。孩子们却在周围跑跑跳跳,热得满头大汗,不时听到围跑跑跳跳,热得满头大汗,不时听到“强子,别跑了,快来我给你扇扇强子,别跑了,快来我给你扇扇”。孩。孩子们才不听这一套,跑个没完,直到累气喘吁吁,这才一跑一踮地围过了,这时子们才不听这一套,跑个没完,直到累气喘吁吁,这才一跑一踮地围过了,这时母亲总是,好似生气的样子,边扇边训,母亲总是,好似生气的样子,边扇边训,“你看热的,跑什么?你看热的,跑什么?”此时这把蒲扇,此时这把蒲扇,是那么凉快,那么的温馨幸福,有母亲的味道!蒲扇是中国传统工艺品,在是那么凉快,那么的温馨幸福,有母亲的味
3、道!蒲扇是中国传统工艺品,在我国已有三千年多年的历史。取材于棕榈树,制作简单,方便携带,且蒲扇的表我国已有三千年多年的历史。取材于棕榈树,制作简单,方便携带,且蒲扇的表面光滑,因而,古人常会在上面作画。古有棕扇、葵扇、蒲扇、蕉扇诸名,实即面光滑,因而,古人常会在上面作画。古有棕扇、葵扇、蒲扇、蕉扇诸名,实即今日的蒲扇,江浙称之为芭蕉扇。六七十年代,人们最常用的就是这种,似圆非今日的蒲扇,江浙称之为芭蕉扇。六七十年代,人们最常用的就是这种,似圆非圆,轻巧又便宜的蒲扇。蒲扇流传至今,我的记忆中,它跨越了半个世纪,圆,轻巧又便宜的蒲扇。蒲扇流传至今,我的记忆中,它跨越了半个世纪,也走过了我们的半个人
4、生的轨迹,携带着特有的念想,一年年,一天天,流向长也走过了我们的半个人生的轨迹,携带着特有的念想,一年年,一天天,流向长长的时间隧道,袅长的时间隧道,袅嵌入式系统设计与实例开发arm与cos-第四讲嵌入式2第四讲、第四讲、ARMARM微处理器体系统结构分析微处理器体系统结构分析1 13 32 25 54 46 6嵌入式微处理器分类嵌入式微处理器分类ARM嵌入式微处理器简介嵌入式微处理器简介ARM体系结构体系结构ARM指令集指令集ARMJTAG调试调试3456789和工业控制计算机相比,嵌入式微处理器具有体积和工业控制计算机相比,嵌入式微处理器具有体积小、重量轻、成本低、可靠性高的优点。目前主要
5、的小、重量轻、成本低、可靠性高的优点。目前主要的嵌入式处理器类型有嵌入式处理器类型有Am186/88、386EX、SC-400、PowerPC、68000、MIPS、ARM/StrongARM系列等系列等10SoC就是就是SystemonChip,SoC嵌入式系统嵌入式系统微处理器就是一种电路系统。微处理器就是一种电路系统。它结合了许多功能区块,将功能做在一个芯片上,它结合了许多功能区块,将功能做在一个芯片上,像是像是ARMRISC、MIPSRISC、DSP或是其他的微处或是其他的微处理器核心,加上通信的接口单元,像是通用串行端口理器核心,加上通信的接口单元,像是通用串行端口(USB)、)、T
6、CP/IP通信单元、通信单元、GPRS通信接口、通信接口、GSM通信接口、通信接口、IEEE1394、蓝牙模块接口等等,这些单元、蓝牙模块接口等等,这些单元以往都是依照各单元的功能做成一个个独立的处理芯以往都是依照各单元的功能做成一个个独立的处理芯片。片。(4 4)、嵌入式片上系统)、嵌入式片上系统(System On Chip)(System On Chip)11SoC是追求产品系统最大包容的集成器件,是追求产品系统最大包容的集成器件,SOC最大的特点是成功实现了软硬件无缝结合,最大的特点是成功实现了软硬件无缝结合,直接在处理器片内嵌入操作系统的代码模块。直接在处理器片内嵌入操作系统的代码模
7、块。运用运用VHDL等硬件描述语言不需要再像传统的等硬件描述语言不需要再像传统的系统设计一样,绘制庞大复杂的电路板,一点点系统设计一样,绘制庞大复杂的电路板,一点点的连接焊制,只需要使用精确的语言,综合时序的连接焊制,只需要使用精确的语言,综合时序设计直接在器件库中调用各种通用处理器的标准,设计直接在器件库中调用各种通用处理器的标准,然后通过仿真之后就可以直接交付芯片厂商进行然后通过仿真之后就可以直接交付芯片厂商进行生产。生产。12由于由于SOC往往是专用的,所以大部分都不为用户往往是专用的,所以大部分都不为用户所知,如所知,如Philips的的SmartXA。Siemens的的TriCore
8、,Motorola的的M-Core,某些,某些ARM系列器件,系列器件,Echelon和和Motorola联合研制的联合研制的Neuron芯片等。芯片等。SOC芯片也将在声音、图像、影视、网络及系统芯片也将在声音、图像、影视、网络及系统逻辑等应用领域中发挥重要作用。逻辑等应用领域中发挥重要作用。13SoC嵌入式系统微处理器所具有的其他的好处可嵌入式系统微处理器所具有的其他的好处可以分为下列几点:以分为下列几点:l利用改变内部工作电压,降低芯片功耗。利用改变内部工作电压,降低芯片功耗。l减少芯片对外管脚数,简化制造过程。减少芯片对外管脚数,简化制造过程。l减少外围驱动接口单元及电路板之间的信号传
9、递,减少外围驱动接口单元及电路板之间的信号传递,可以加快微处理器数据处理的速度。可以加快微处理器数据处理的速度。l内嵌的线路可以避免外部电路板在信号传递时所内嵌的线路可以避免外部电路板在信号传递时所造成系统杂讯。造成系统杂讯。14lARM即即AdvancedRISCMachines的缩写。的缩写。l1985年年4月月26日,第一个日,第一个ARM原型在英国剑桥的原型在英国剑桥的Acorn计算机有限计算机有限公司诞生,由美国加州公司诞生,由美国加州SanJoseVLSI技术公司制造。技术公司制造。l20世纪世纪80年代后期,年代后期,ARM很快开发成很快开发成Acorn的台式机产品,形成英的台式
10、机产品,形成英国的计算机教育基础。国的计算机教育基础。l1990年成立了年成立了AdvancedRISCMachinesLimited。l20世纪世纪9年代,年代,ARM32位嵌人式位嵌人式RISC(ReducedInstructionSetComputer)处理器扩展到世界范围,占据了低功耗、低成本和高性能的)处理器扩展到世界范围,占据了低功耗、低成本和高性能的嵌入式系统应用领域的领先地位。嵌入式系统应用领域的领先地位。l32位位RISC处处理器受到青理器受到青睐睐,领领先的是先的是ARM嵌入式微嵌入式微处处理器系列。理器系列。lARM公司公司虽虽然只成立然只成立10多年,但在多年,但在19
11、99年因移年因移动电话动电话火爆市火爆市场场,其,其32位位RISC处处理器占市理器占市场场份份额额超超过过了了50%,成,成为业为业界界龙头龙头老大。老大。2001年初,年初,ARM公司的公司的32位位RISC处处理器市理器市场场占有率超占有率超过过了了75%,引起,引起业业界的极大关界的极大关注。注。ARM公司是知公司是知识产权识产权供供应应商,是商,是设计设计公司。公司。ARM公司本身不生公司本身不生产产芯芯片,靠片,靠转让设计许转让设计许可,由合作伙伴公司来生可,由合作伙伴公司来生产产各具特色的芯片。各具特色的芯片。二、二、ARMARM结构微处理器简介结构微处理器简介15lARM公司商
12、公司商业业模式的模式的强强大之大之处处在于其价格合理,全世界范在于其价格合理,全世界范围围有有超超过过100个合作伙伴个合作伙伴-包括半包括半导导体工体工业业的著名公司。的著名公司。ARM公司公司专专注于注于设计设计,其内核耗,其内核耗电电少、成本低、功能少、成本低、功能强强,特有,特有16/32位双指令集。位双指令集。ARM已成已成为为移移动动通信、手持通信、手持计计算、多媒体数字消算、多媒体数字消费费等嵌入式解决方案等嵌入式解决方案的的RISC标标准。准。l在所有在所有ARM处处理器系列中,理器系列中,ARM7处处理器系列理器系列应应用最广,采用用最广,采用ARM7处处理器作理器作为为内核
13、生内核生产产芯片的公司最多。芯片的公司最多。16ARM处理器的处理器的3大特点如下大特点如下:l小体积、低功耗、成本低、高性能;小体积、低功耗、成本低、高性能;l16位位/32位双指令集;位双指令集;l全球众多的合作伙伴。全球众多的合作伙伴。当前当前ARM体系结构的扩充包括:体系结构的扩充包括:lThumb:16位指令集,用以改善代码密度;位指令集,用以改善代码密度;lDSP:用于:用于DSP应用的算术运算指令集;应用的算术运算指令集;lJazeller:允许直接执行:允许直接执行Java安节码的扩充。安节码的扩充。ARM处理器系列提供的解决方案包括:处理器系列提供的解决方案包括:l在无线、消
14、费电子和图像应用方面的开放平台;在无线、消费电子和图像应用方面的开放平台;l存储、自动化、工业和网络应用的嵌入式实时系统;存储、自动化、工业和网络应用的嵌入式实时系统;l智能卡和智能卡和SIM卡的安全应用。卡的安全应用。ARMARM处理器的特点处理器的特点17ARM处理器本身是处理器本身是32位设计,但也配备位设计,但也配备16位指令集,以允许位指令集,以允许软件编码为更短的软件编码为更短的16位指令。与等价的位指令。与等价的32代码相比,占用的存储器代码相比,占用的存储器空间节省高达空间节省高达35%,然而保留了,然而保留了32位系统所有的优势。位系统所有的优势。ARM还提供了两个前沿特性还
15、提供了两个前沿特性嵌入式嵌入式ICERT逻辑和嵌入逻辑和嵌入式跟踪宏核系列,用以辅助带深嵌入式处理器核的、高集成的式跟踪宏核系列,用以辅助带深嵌入式处理器核的、高集成的SOC器件的调试。器件的调试。ARM业界领先的跟踪解决方案业界领先的跟踪解决方案嵌入式跟踪宏单元嵌入式跟踪宏单元(ETM,EmbeddebTraceMacrocell),被设计成驻留在),被设计成驻留在ARM处处理器上,用以监控内部总线,并能以核速度无妨碍地跟踪指令和数理器上,用以监控内部总线,并能以核速度无妨碍地跟踪指令和数据的访问。据的访问。18ARM处理器当前有处理器当前有5个产品系列:个产品系列:ARM7、ARM9、AR
16、M9E、ARM10和和SecurCore。进一步的产品来自于合作伙伴,例如。进一步的产品来自于合作伙伴,例如IntelXccale微体系结构和微体系结构和StrongARM产品。产品。ARM7、ARM9、ARM9E和和ARM10是是4个通用处理器系列。每个通用处理器系列。每个系列提供一套特定的性能来满足设计者对功耗、性能、和体积的个系列提供一套特定的性能来满足设计者对功耗、性能、和体积的需求。需求。SecurCore是第是第5个产品系列,是专门为安全设备而设计的。个产品系列,是专门为安全设备而设计的。性能高达性能高达1200MIPS(Xscale微体系结构),功耗测量为微体系结构),功耗测量为
17、W/MHz,并且所有体系结构兼容。,并且所有体系结构兼容。ARMARM产品系列产品系列19三、三、ARM汇编指令汇编指令20ARM体系结构的主要特征体系结构的主要特征大量的寄存器,都可用于多种用途;大量的寄存器,都可用于多种用途;Load-Store体系结构体系结构3地址指令(两个源操作数寄存器和结果寄存器独立设定)地址指令(两个源操作数寄存器和结果寄存器独立设定)每条指令都条件执行包含非常强大的多寄存器每条指令都条件执行包含非常强大的多寄存器Load和和Store指令指令能在单时钟周期执行的单条指令内完成一项普通的移位操作和一能在单时钟周期执行的单条指令内完成一项普通的移位操作和一项普通的项
18、普通的ALU操作操作能过协处理器指令集来扩展能过协处理器指令集来扩展ARM指令集,包括在编程模式下增加指令集,包括在编程模式下增加了新的寄存器和数据类型了新的寄存器和数据类型在在Thumb体系结构中以高密度体系结构中以高密度16位压缩形式表示指令集位压缩形式表示指令集21ARM有三种类型的数据指令有三种类型的数据指令1)数据处理指令:这类指令只能使用和改变寄存器中的值)数据处理指令:这类指令只能使用和改变寄存器中的值2)数据传送指令:这类指令把存储器中的值拷贝寄存器()数据传送指令:这类指令把存储器中的值拷贝寄存器(Load)或把寄存器的值拷贝到存储器中(或把寄存器的值拷贝到存储器中(Stor
19、e)3)控制流指令:一般指令在执行时使用存储于连续的存储器地址中)控制流指令:一般指令在执行时使用存储于连续的存储器地址中的指令。控制流指令使执行切换到不同的地址。切换是永久的或的指令。控制流指令使执行切换到不同的地址。切换是永久的或保存返回地址以恢复原来的执行顺序,或者陷入系统代码。保存返回地址以恢复原来的执行顺序,或者陷入系统代码。221、数据处理指令、数据处理指令l功能:完成寄存器的数据的算术和逻辑操作功能:完成寄存器的数据的算术和逻辑操作l典型特征:需要两个操作数,产生单个结果典型特征:需要两个操作数,产生单个结果l使用原则:使用原则:1)所有的操作数是)所有的操作数是32位宽,或来自
20、寄存器,或在指令中定义的立即数位宽,或来自寄存器,或在指令中定义的立即数2)如果有结果,则结果为)如果有结果,则结果为32位宽,放在一个寄存器中位宽,放在一个寄存器中3)每一个操作数寄存器和结果寄存器都在指令中独立的指定,即使用)每一个操作数寄存器和结果寄存器都在指令中独立的指定,即使用3地址地址模式模式例:例:ADDr0,r1,r2;r0=r1+r223ARM数据处理指令一览数据处理指令一览1)简单的寄存器操作)简单的寄存器操作l算术操作:算术操作:ADD、ADC、SUB、SBC、RSB、RSCl按位逻辑与:按位逻辑与:AND、ORR、EOR、BICl寄存器传送操作:寄存器传送操作:MOV、
21、MVNl比较操作:比较操作:CMP、CMN、TST、TEQ2)立即数操作:如)立即数操作:如ADDr1,r1,#13)寄存器移位操作:)寄存器移位操作:LSL、LSR、ASL、ASR、ROR、RRX例例ADDr3,r2,r1,LSL#34)设置条件码)设置条件码5)乘法:)乘法:MUL、MLA242、数据传送指令、数据传送指令1)单寄存器的)单寄存器的Load和和Store指令指令2)多寄存器的)多寄存器的Load和和Store指令指令3)单寄存器交换指令)单寄存器交换指令253、控制流指令、控制流指令1)转移指令)转移指令2)子程序返回指令)子程序返回指令3)监控程序调用指令)监控程序调用指
22、令26AREAHelloW,CODE,READONLY;声明代码区声明代码区SWI_WriteCEQU&0;输出;输出r0中的字符中的字符SWI_ExitEQU&11;程序结束;程序结束ENTRY;代码入口;代码入口STARTADRr1,TEXT;r1-“HelloWorld”LOOPLDRBr0,r1,#1;读取下一字节读取下一字节CMPr0,#0;检查文本终点;检查文本终点SWINESWI_WriteC;若非终点,则打印;若非终点,则打印BNELOOP;并返回;并返回LOOPSWISWI_Exit;执行结束;执行结束TEXT=“HelloWorld”,&0a,&0d,0END;程序结束;程
23、序结束例子例子27四、四、ARMJTAG调试调试2829几种常用的调试方法几种常用的调试方法l指令集模拟器指令集模拟器一种利用一种利用PC机端的仿真开发软件模拟调试的方法。机端的仿真开发软件模拟调试的方法。l驻留监控软件驻留监控软件驻留监控程序运行在目标板上,驻留监控程序运行在目标板上,PC机端调试软件可通过并口、串机端调试软件可通过并口、串口、网口与之交互,以完成程序执行、存储器及寄存器读写、断口、网口与之交互,以完成程序执行、存储器及寄存器读写、断点设置等任务点设置等任务lJTAG仿真器仿真器通过通过ARM芯片的芯片的JTAG边界扫描口与边界扫描口与ARM核进行通信,不占用目核进行通信,不
24、占用目标板的资源,是目前使用最广泛的调试手段标板的资源,是目前使用最广泛的调试手段l在线仿真器在线仿真器使用仿真头代替目标板上的使用仿真头代替目标板上的CPU,可以完全仿真,可以完全仿真ARM芯片的行为。芯片的行为。但结构较复杂,价格昂贵,通常用于但结构较复杂,价格昂贵,通常用于ARM硬件开发中硬件开发中30ARM的的JTAG调试结构调试结构AngelJTAG31宿主机调试器宿主机调试器l宿主机调试器通过固定的协议控制下位机(协议转换器)宿主机调试器通过固定的协议控制下位机(协议转换器)。比如,。比如,SDT中通过中通过Angel协议或者第三方调试器所提协议或者第三方调试器所提供的协议供的协议
25、l宿主机调试器只发送宏观的命令,比如:宿主机调试器只发送宏观的命令,比如:程序运行、终止。读些内存、程序运行、终止。读些内存、ARM寄存器等寄存器等l通讯的介质可以是串口、并口、以太网、通讯的介质可以是串口、并口、以太网、USB等等32JTAG与与AngellJTAG调试:协议转换器解释上位机传送过来的命令,调试:协议转换器解释上位机传送过来的命令,通过通过JTAG控制控制ARM执行。执行。lAngel调试:协议转换器可以直接做为目标板的调试:协议转换器可以直接做为目标板的Firmware的一部分。直接执行从宿主机传送过来的调的一部分。直接执行从宿主机传送过来的调试命令;并回送相应的数据。试命
26、令;并回送相应的数据。lAngel可以节省专门的可以节省专门的JTAG仿真器,但是,它需要软仿真器,但是,它需要软件,或者是嵌入式操作系统的支持,做不到完全的实件,或者是嵌入式操作系统的支持,做不到完全的实时仿真。而时仿真。而JTAG仿真是通过硬件和控制仿真是通过硬件和控制ARM的的EmbeddedICE实现的,可以做到实时仿真。实现的,可以做到实时仿真。33什么是什么是JTAG?lJTAG是是JointTestActionGroup的缩写;的缩写;是是IEEE1149.1标准标准lJTAG的建立使得集成电路固定在的建立使得集成电路固定在PCB上,只通过边界上,只通过边界扫描便可以被测试扫描便
27、可以被测试l在在ARM7TDMI处理器中,可以通过处理器中,可以通过JTAG直接控制直接控制ARM的内部总线,的内部总线,IO口等信息,从而达到调试的目的口等信息,从而达到调试的目的34JTAG的典型接口的典型接口lTMS:测试模式选择(测试模式选择(TestModeSelect),通过),通过TMS信号控制信号控制JTAG状态机的状态状态机的状态lTCK:JTAG的时钟信号的时钟信号lTDI:数据输入信号:数据输入信号lTDO:数据输出信号:数据输出信号lnTRST:JTAG复位信号,复位复位信号,复位JTAG的状态机和内部的状态机和内部的宏单元(的宏单元(Macrocell)35JTAG的
28、状态机(的状态机(TAP)36JTAG链的组成链的组成37ARM7TDMI的的JTAG标准链(标准链(1)38ARM7TDMI的的JTAG标准链(标准链(2)lScanChain0:包括:包括ARM核的所有的核的所有的IO和总线的输入输出控制信和总线的输入输出控制信号号lScanChain1:包括:包括ARM核的数据总线和一个断点控制信号。通核的数据总线和一个断点控制信号。通过控制这个条链,可以控制过控制这个条链,可以控制ARM核执行指定的指令。核执行指定的指令。lScanChain2:通过控制:通过控制EmbeddedICE宏单元,实现对宏单元,实现对ARM执执行指令的断点、观察点的控制行指
29、令的断点、观察点的控制39EmbeddedICE的结构的结构40ARM7TDMI中断点的设置中断点的设置l设置设置EmbeddedICE的两个的两个watchpoint单元单元主要包括:地址、数据、控制信号等主要包括:地址、数据、控制信号等l当一个(或者两个)当一个(或者两个)watchpoint中的地址(也可以包中的地址(也可以包括数据)和括数据)和ARM所执行的当前的指令相同的时候,所执行的当前的指令相同的时候,ARM就从运行状态进入就从运行状态进入Debug状态状态41断点的类型断点的类型l硬件断点:在硬件断点:在ARM中直接设定中直接设定watchpoint中的地址,中的地址,当当AR
30、M运行到制定的地址时,就进入运行到制定的地址时,就进入Debug状态状态l软件断点:改变存储器中的软件断点:改变存储器中的ARM指令为一个特殊的数指令为一个特殊的数据据X(ARM的未定义指令),同时,设置的未定义指令),同时,设置watchpoint中的断点数据也为中的断点数据也为X,当,当ARM把把X数据作为指令读入的数据作为指令读入的时候,时候,ARM就进入就进入Debug状态状态42硬件断点和软件断点的优缺点硬件断点和软件断点的优缺点l硬件断点:数目受硬件断点:数目受EmbeddedICE中的中的Watchpoint数数目的限制;但是,可以在任何地方设置断点目的限制;但是,可以在任何地方
31、设置断点l软件断点:数目不受限制,但是,软件断点是通过替换软件断点:数目不受限制,但是,软件断点是通过替换系统的断点地址的指令实现的,所以,软件断点只能在系统的断点地址的指令实现的,所以,软件断点只能在可写的存储器的地址中设置(比如:可写的存储器的地址中设置(比如:RAM),而不能),而不能在在ROM(比如:(比如:Flash)中设置)中设置43五、五、ARMARM体系结构体系结构ARM体系结构的主要特征体系结构的主要特征大量的寄存器,都可用于多种用途;大量的寄存器,都可用于多种用途;Load-Store体系结构体系结构3地址指令(两个源操作数寄存器和结果寄存器独立设定)地址指令(两个源操作数
32、寄存器和结果寄存器独立设定)每条指令都条件执行包含非常强大的多寄存器每条指令都条件执行包含非常强大的多寄存器Load和和Store指令指令能在单时钟周期执行的单条指令内完成一项普通的移位操作和一能在单时钟周期执行的单条指令内完成一项普通的移位操作和一项普通的项普通的ALU操作操作能过协处理器指令集来扩展能过协处理器指令集来扩展ARM指令集,包括在编程模式下增加指令集,包括在编程模式下增加了新的寄存器和数据类型了新的寄存器和数据类型在在Thumb体系结构中以高密度体系结构中以高密度16位压缩形式表示指令集位压缩形式表示指令集44SamsungS3C44B0XlSamsungS3C44B0X微微处
33、处理理器器是是三三星星公公司司专专为为手手持持设设备备和和一一般般应应用用提提供供的的高高性性价价比比和和高高性性能能的的微微控控制制器器解解决决方方案案,它它使使用用ARM7TDMI核核,工工作作在在66MHZ。为为了了降降低低系系统统总总成成本本和和减减少少外外围围器器件件,这这款款芯芯片片中中还还集集成成了了下列部件:下列部件:l8KBCache、外外部部存存储储器器控控制制器器、LCD控控制制器器、4个个DMA通通道道、2通通道道UART、1个个多多主主I2C总总线线控控制制器器、1个个IIS总总线线控控制制器器,5通通道道PWM定定时时器器及及一一个个内内部部定定时时器器、71个个通
34、通用用I/O口口、8个个外外部部中中断断源源、实实时时时时钟钟、8通通道道10位位ADC等。等。45S3C44B0X S3C44B0X 体系结构:体系结构:l用于手持设备和通用嵌入式应用的完整系统;用于手持设备和通用嵌入式应用的完整系统;l16/32位位RISC结结构构和和带带ARM7DMICPU核核的的功功能能强强大的指令集;大的指令集;lThumb协协处处理理器器在在保保证证性性能能的的前前提提下下使使代代码码密密度度最最大;大;l片上片上ICE中断调试中断调试JTAG调试方式调试方式l32 8位硬件乘法器;位硬件乘法器;46系统管理:系统管理:l支持大支持大/小端模式小端模式l地址空间:
35、每个地址空间:每个Bank32MB(一共(一共256MB););l每个每个Bank支持支持8/16/32位数据总线编程;位数据总线编程;l固定的固定的Bank起始地址和起始地址和7个可编程的个可编程的Bank;l1个起始地址和尺寸可编程的个起始地址和尺寸可编程的Bank;l8个个 内内 存存 Bank::个个 用用 于于 ROM、SRAM;2个个 用用 于于ROM/SRAM/DRAM;l所有内存所有内存Bank的可编程寻址周期;的可编程寻址周期;l在能量低的情况下支持在能量低的情况下支持DRAM/SDRAM自动刷新模式;自动刷新模式;l支持支持DRAM的非对称的非对称/对称寻址;对称寻址;47
36、l缓冲内存和内部缓冲内存和内部SRAMl4路带路带8K字节的联合缓存;字节的联合缓存;l不使用缓存的不使用缓存的0/4/8K内容内容SRAMl伪伪LRU(最近最少使用)的替代算法;(最近最少使用)的替代算法;l通通过过在在主主内内存存和和缓缓冲冲区区内内容容之之间间保保持持一一致致的的方方式式写写内内存;存;l当缓冲区出错时,请求数据填充技术;当缓冲区出错时,请求数据填充技术;48时钟和能量管理时钟和能量管理l l低能耗;低能耗;l l时钟可以通过软件选择性地反馈回每个功能块时钟可以通过软件选择性地反馈回每个功能块l l能量模式:能量模式:u u正常模式:正常运行模式;正常模式:正常运行模式;
37、u u低能模式:不带低能模式:不带PLL的底频时钟;的底频时钟;u u休眠模式:只使休眠模式:只使CPU的时钟停止;的时钟停止;u u停止模式:所有时钟都停止;停止模式:所有时钟都停止;l l用用EINT或或RTC警告中断从停止模式唤醒警告中断从停止模式唤醒49中断控制器中断控制器l l30个个中中断断源源(看看门门狗狗定定时时器器,6个个定定时时器器,6个个UART,8个个外外部部中中断断,4个个DMA,2个个RTC,1个个ADC,1个个I2C,1个个SIO;l l矢量矢量IRQ中断模式减少中断响应周期;中断模式减少中断响应周期;l l外部中断源的水平外部中断源的水平/边缘模式;边缘模式;l
38、 l可编程的水平可编程的水平/边缘极性;边缘极性;l l对紧急中断请求支持对紧急中断请求支持FIQ(快速中断请求);(快速中断请求);50带带PWMPWM的定时器的定时器l l5个个16位位带带PWM的的定定时时器器/1个个16位位基基于于DMA或或基基于于中中断断的的定时器;定时器;l l可编程的工作循环,频率和极性可编程的工作循环,频率和极性l l死区产生死区产生l l支持外部时钟源支持外部时钟源51实时时钟实时时钟l l全时钟特点:毫秒、秒、分、小时、天、星期、月、年全时钟特点:毫秒、秒、分、小时、天、星期、月、年l l32.768KHz运行运行CPU唤醒的警告中断唤醒的警告中断时钟记号
39、中断时钟记号中断52通用输入输出端口通用输入输出端口l l8个外部中断端口个外部中断端口l l71个多路输入输出口;个多路输入输出口;UARTl l2个带个带DMA和中断的和中断的UART;l l支持支持5位,位,6位,位,7位,位,8位串行数据传送位串行数据传送/接收;接收;l l当传送当传送/接收时支持双向握手接收时支持双向握手l l可编程波特率;可编程波特率;l l支持支持IrDA1.0(115.2KBPS););l l测试的循环返回模式;测试的循环返回模式;l l每个通道有每个通道有2个内部个内部32位位FIFO53DMA与与A/DDMA控制器l l2路通用无需要路通用无需要CPU干涉
40、的干涉的DMA控制器;控制器;l l2路桥式路桥式DMA控制器;控制器;l l采采用用6种种DMA请请求求的的桥桥式式DMA支支持持IO到到内内存存,内内存存到到IO,IO到到IO:软件,:软件,4个内部功能块(个内部功能块(UART,SIO,实时器,实时器,IIS),外部管脚;),外部管脚;l lDMA之间可编程优先级次序;之间可编程优先级次序;l l突突发发传传送送模模式式提提高高到到FPDRAM、EDODRAM和和SDRAM的的传传送率;送率;A/D转换l l10位多路位多路ADC;l l最大最大500KSPS/10位;位;54LCDLCD控制器控制器l l支持彩色支持彩色/单色单色/灰
41、度灰度LCD;l l支持单扫描和双扫描显示;支持单扫描和双扫描显示;l l支持虚拟显示功能支持虚拟显示功能l l系统内存作为显示内存系统内存作为显示内存l l专用专用DMA用于从系统内存中提取图象数据;用于从系统内存中提取图象数据;l l可编程屏幕尺寸;可编程屏幕尺寸;l l灰度:灰度:16级级l l256色色55看门狗定时器与看门狗定时器与I I2 2C C总线接口总线接口l l16位看门狗定时器;位看门狗定时器;l l定时中断请求和系统复位;定时中断请求和系统复位;l l1个带中断的多主机个带中断的多主机I2C总线;总线;l l串串行行,8位位,双双向向数数据据传传送送器器能能够够以以10
42、0KB/S的的标标准准模模式式和和400KB/S的快速模式传送的快速模式传送56IIS总线接口l l1个个I带带DMA的音频的音频IS总线接口;总线接口;l l串行,每路串行,每路8/16位数据传送器;位数据传送器;支持支持MSB数据格式;数据格式;SIO(同步串行(同步串行I/O)l l1个带个带DMA和中断的和中断的SIOl l可编程波特率;可编程波特率;l支持支持8位串行数据传送位串行数据传送/接收操作接收操作57l操作电压范围l内核:内核:2.5V;I/O:3.0V到到3.6V;l运行频率l最高到最高到75MHz;l封装l160LQFP/160FBGA;58S3C44B0XS3C44B
43、0X微处理器体系结构框图微处理器体系结构框图59S3C44B0XS3C44B0X微处理器管脚定义图微处理器管脚定义图 60基于基于ARMARM的嵌入式硬件平台体系结构的嵌入式硬件平台体系结构61lS3C44B0X把把外外部部复复位位信信号号,也也作作为为一一个个中中断断来来处处理理。在在系系统统复复位位的的时时候候,程程序序(PC)指指针针被被设设置置成成0,使使程程序序跳跳转转到到0 x00000000开开始始运运行行。此此空空间间对对应应的的是是Bank0。因因为为在在系系统统的的1MB的的线线性性Flash和和处处理理器器的的Bank0相相连连接接。在在线线性性Flash里里存存储储的的
44、是是供供系系统统的的初初始始化化的的程程序序。此此程程序序负负责责的的配配置置处处理理器器的的结结构构、工工作作模模式式以以及及自自动动检检测测嵌嵌入入式式控控制制器器的的各各个个硬硬件件是是否否工工作作正正常常。此此程程序序负负责责把把存存储储在在16MB的的非非线线性性处处理理器器里里面面的的system.bin文文件件复复制制到到0 xc5f0000地地址址(此此地地址址是是系系统统8MB的的SDRAM的的首首地地址址)。引引导程序把程序(导程序把程序(PC)指针指向)指针指向0 xc000000地址,系统开始运行。地址,系统开始运行。lsystem.bin是嵌入式操作系统引导的执行文件
45、。编译以后的操作是嵌入式操作系统引导的执行文件。编译以后的操作系统和应用程序就是这个文件。系统和应用程序就是这个文件。62S3C44B0X存储系统的特征存储系统的特征l支持数据存储的大支持数据存储的大/小端选择小端选择(通过外部引脚进行选择通过外部引脚进行选择)l地地址址空空间间:具具有有8个个存存储储体体,每每个个存存储储体体可可达达32Mb,总总共共可可达达256Mb。l对所有存储体的访问大小均可进行改变(对所有存储体的访问大小均可进行改变(8位位16位位32位)位)l8个个存存储储体体中中,Bank0Bank5可可支支持持ROM、SRAM;Bank6、Bank7可支持可支持ROM、SRA
46、M和和FPEDOSDRAM等。等。l7个存储体的起始地址固定,个存储体的起始地址固定,1个存储体的起始地址可变。个存储体的起始地址可变。l支持数据存储的大支持数据存储的大/小端选择小端选择(通过外部引脚进行选择通过外部引脚进行选择)l地地址址空空间间:具具有有8个个存存储储体体,每每个个存存储储体体可可达达32Mb,总总共共可可达达256Mb。l对所有存储体的访问大小均可进行改变(对所有存储体的访问大小均可进行改变(8位位16位位32位)位)l8个个 存存 储储 体体 中中,Bank0 Bank5可可 支支 持持 ROM、SRAM;Bank6、Bank7可支持可支持ROM、SRAM和和FPED
47、OSDRAM等。等。l7个存储体的起始地址固定,个存储体的起始地址固定,1个存储体的起始地址可变。个存储体的起始地址可变。63典型系统中存储体的分配情况典型系统中存储体的分配情况存储体存储体与存储体的接口与存储体的接口Bank0BIOS512K2FlashBank116MFlash硬盘硬盘Bank2USB接口接口Bank3LCD显示模块显示模块Bank4保留保留Bank5保留保留Bank6系统内存系统内存SDRAMBank7保留保留64复位后的复位后的S3C44B0X的存储器映射表的存储器映射表65l使使用用Bank0上上的的两两片片512Kb2来来放放置置系系统统BIOS,系系统统上上电电以
48、以后后,PC指指针针自自动动指指向向Bank0的的第第一一个个单单元元,开开始始进进行行系系统统自自举举。系系统统自自举举完完成成以以后后,便便从从硬硬盘盘中中将将系系统统文文件件和和用用户户应应用用程程序序复复制制到到SDRAM内存中执行。内存中执行。lBank1上上接接16M非非线线性性Flash,当当做做系系统统硬硬盘盘使使用用,可可以以构构造造文件系统,存放海量数据。文件系统,存放海量数据。l用用SDRAM当当作作系系统统内内存存,只只有有Bank6/Bank7能能支支持持SDRAM,所所以以将将SDRAM接接在在Bank6上上。如如果果同同时时使使用用Bank6/Bank7,则则要求
49、连接相同容量的存储,而且其地址空间在物理上是连续的。要求连接相同容量的存储,而且其地址空间在物理上是连续的。66lBank0:系统的启动:系统的启动ROM(FlashRom)。在系统复位的时候,)。在系统复位的时候,处理器的处理器的PC(程序计数器)指针指向(程序计数器)指针指向0 x0地址。在地址。在Bank0的起始的起始地址的程序,就是系统的初始化程序。此程序的主要任务是:地址的程序,就是系统的初始化程序。此程序的主要任务是:1、管理处理器的中断服务程序、管理处理器的中断服务程序l处理器的中断是从处理器的中断是从0 x0地址开始,引导地址开始,引导ROM负责把这一部分的中负责把这一部分的中
50、断映射到另一个区域,以便系统处理。具体的做法,可以参考断映射到另一个区域,以便系统处理。具体的做法,可以参考44binit.s里面的代码。(这部分代码是三星主页可以提供,它把里面的代码。(这部分代码是三星主页可以提供,它把系统的中断,映射到了不同的指针所指向的地址空间(主要就是系统的中断,映射到了不同的指针所指向的地址空间(主要就是系统系统RAM的空间)。的空间)。672、初始化硬件平台,配置其他的、初始化硬件平台,配置其他的BanklS3C44B0X的的Bank0是通过外部的一个管脚提供的上拉、下拉电是通过外部的一个管脚提供的上拉、下拉电阻来配置的。主要包括:数据位数(阻来配置的。主要包括: