1、1怎样学习怎样学习ARM嵌入式开发?嵌入式开发?JackJack技术收集技术收集技术收集技术收集硅谷芯微技术学院硅谷芯微技术学院硅谷芯微技术学院硅谷芯微技术学院http:/www.threeway.cchttp:/www.threeway.cc2开场介绍本次课程讲什么?How to,not What is本次课程谁来讲?jackthreeway.cc本次课程适合的听众是哪些人?已经知道,了解嵌入式开发的人已经接触并有所实践,但还没摸到门道的人不包括已经从事ARM开发一年以上的熟手本次课程听完后会有什么收获?Know a shortcut(捷径)from a newbie(菜鸟)to a nb(
2、牛人)3今日主题ARM嵌入式开发领域包括什么?软件开发操作系统以下的底层偏硬件驱动在简单操作系统如uC/OS-II之上的程序开发不包括什么?硬件设计类似Linux这样操作系统以上的纯应用开发4首要问题怎样学习ARM嵌入式开发?掌握这个领域的知识全景图然后结合项目开始修炼怎样进入一个陌生的村庄?拿到这个村庄的地图并找到一条进入村庄路线5ARM嵌入式开发专业词汇和所属主题领域ARM内核领域(10个细分领域)ARM芯片领域(5个细分领域)ARM工具平台领域(2个细分领域)ARM软件开发领域(3个细分领域)专业词汇举例SVCJTAGJazelleMDKfromelf6ARM内核领域ARM体系结构Loa
3、d/Store体系,Big/Little Endian大小端格式,RISC/CISC指令集,Pipeline流水线ARM工作模式7种工作模式:USR,SYS,SVC,IRQ,FIQ,UND,ABT;其中5种异常模式 ARM寄存器37个寄存器:R0-R12,R13(SP),R14(LR),R15(PC),CPSR(SPSR)ARM异常7种异常,异常向量表,异常优先级,异常处理程序,处理器现场,现场的保存和恢复AMBA总线AHB(高性能总线),ASB(系统总线),APB(外设总线)7ARM内核领域ARM内核技术TrustZone,Jazelle,NEON,Thumb-2,SIMD,MMU,MPU
4、JTAG标准IEEE1149.1,TDI,TDO,TCK,TMS,TRST,边界扫描链,H-jtag,Banyan,GiveIO ARM内核分类ARM7TDMI,ARM926,StrongARM/XScale,ARM10,ARM11,Cortex-(A/R/M),SecurCoreARM汇编指令mov,add,sub,b,bl,ldr,str,ldmfd,stmfd,mrs,msr,swi,mrc,mcrMMU内存管理单元VA/PA,I-Cache/D-Cache,Write Buffer,Context Switch,CP15,TLB,AP,Domain Access Control,Cac
5、he Coherence8ARM芯片领域ARM芯片外设控制器Memory Controller(内存控制器),WatchDog(看门狗),GPIO(通用IO),UART(串口),Timer(定时器),Interrupt Controller(中断控制器),Nand Flash Controller,Clock&Power Management(时钟和电源管理),DMA(直接存储访问),USB Controller,LCD controller,ADC,IIC,IIS,SPI,AC97,Camera,MMC/SD最小系统处理器,时钟,电源,PLL锁相环,存储器,通讯端口,外设接口存储器件SRAM
6、,SDRAM,Nor Flash,Nand FlashARM处理器Samsung:S3C4510,S3C44B0,S3C2410,S3C2440,S3C6410,SoC设计FPGA,CPLD,VHDL,Verilog9ARM工具平台领域ARM开发调试工具SDT,ADS1.2,AXD,RealView,KEIL MDK 4.11(RVMDK4.11)make,hypertrm(超级终端),minicomARM命令行工具armcc,armasm,armlink,fromelf10ARM软件开发领域嵌入式操作系统VxWorks,RTLinux,uC/OS-II,WinCE/WM外设驱动程序volat
7、ile关键字,位操作bit,时序图Timing,管脚功能Pin function,外设控制/数据/状态寄存器程序的存储,加载和运行RO段,RW段,ZI段,ro-base/rw-base,栈空间,堆空间,位置无关代码PIC,启动搬移代码11细分领域的自我认知人类对于外部世界的认识 在舒适区我们得心应手,但学到的东西很少。在恐慌区我们感到忧虑,恐惧,不堪重负。在学习区我们可以充分锻炼自我,挑战自我。只有持续留在“学习区”内,人才会进步。12课堂讨论以上提到的20个细分知识领域,请您画一张图来表示目前你的掌握了解程度。Panic Zone(恐慌区)完全陌生(从来没有听过,也没有看过)Learning
8、 Zone(学习区)了解(自己看过,听别人说过)熟悉(自己做过,但还不能指导别人)Comfort Zone(舒适区)掌握(能够指导别人,讲述给别人)13第二个问题从哪里入手?重视并深刻掌握其中的核心概念寄存器地址异常和中断14核心概念之一寄存器ARM内核寄存器 R0-R12R13(sp)R14(lr)R15(pc)CPSR,SPSRARM SoC 特殊功能寄存器SFR(Special Function Register)15核心概念之二地址C程序中变量的“地址”:&aSoC 特殊功能寄存器的“地址”:0 x48000000寻址方式里面的“地址”:ldr r0,r1二进制指令里面的“地址”:0
9、xE59FF018存储芯片内部的“地址”:0 x4h操作系统之上应用程序的“(虚)地址”CPLD器件对应的“(假)地址”16核心概念之三异常和中断异常是属于ARM内核体系结构的概念中断是属于ARM SoC处理器的概念了解软件中断(SWI)是实现操作系统提供系统调用的重要手段了解硬件中断(例如Timer定时器)是实现操作系统时间片的重要手段17行胜于言如何实践?如何修炼?第一重找一块开发板,自己动手,给它编写编写一个可以实用的Bootloader,能够实现外部程序的下载,执行和固化。第二重在自己能够完整实现一个Bootloader的基础上,移植移植一个开源的操作系统(如uC/OS-II,或者Li
10、nux)第三重基于或不基于这个操作系统,实现实现一个面向用户的应用。(如一个音频播放器,或者一个U盘)18自我修炼之第一重境界为什么要编写一个Bootloader?从根本上掌握一个嵌入式开发板底层的软硬件系统是怎样运转起来的时钟频率如何设置看门狗所起作用串口如何工作通讯协议如何实现库函数反汇编函数栈空间19自我修炼之第二重境界为什么要移植一个操作系统?了解操作系统和底层硬件之间的依赖关系,知道哪些是移植相关的部分(即接口)定时器中断(时钟节拍)异常处理和现场保存恢复进程,进程控制块处理器现场进程的上下文切换中断级别的进程切换20自我修炼之第三重境界为什么要实现一个用户应用?一个音频播放器DMA
11、控制器,Interrupt中断控制器IIS 总线UDA1341声卡芯片驱动WAV/Mp3 音频文件格式LCD液晶显示驱动一个U盘USB协议FAT文件系统格式SCSI命令集NandFlash存储芯片驱动21推荐参考资料ARM Architecture Reference ManualPDF,Part AARM体系结构与编程清华大学出版社,杜春雷著源码开放的嵌入式系统软件分析与实践:基于SkyEye和ARM开发平台北京航空航天大学出版社,陈渝 李明 杨晔著uCOS-II源码公开的实时嵌入式操作系统中国电力出版社,邵贝贝 译22总结怎样学习ARM嵌入式开发?怎样入手?怎样修炼?Q&A23 硅谷芯微技术中心:硅谷芯微技术中心:网址:网址:www.threeway.ccJACK技术收集技术收集