2023年三级嵌入式系统

上传人:豆*** 文档编号:166174768 上传时间:2022-10-31 格式:DOCX 页数:18 大小:38.01KB
收藏 版权申诉 举报 下载
2023年三级嵌入式系统_第1页
第1页 / 共18页
2023年三级嵌入式系统_第2页
第2页 / 共18页
2023年三级嵌入式系统_第3页
第3页 / 共18页
资源描述:

《2023年三级嵌入式系统》由会员分享,可在线阅读,更多相关《2023年三级嵌入式系统(18页珍藏版)》请在装配图网上搜索。

1、三级嵌入式系统学习总结一 第一章1. 嵌入式系统概论嵌入式系统中的软件一般都固化在只读存储器中,用户不能随意更改其中的程序功能。嵌入式系统的逻辑组成:1)解决器 2)存储器 3)I/O设备与I/O接口 4)数据总线 5)软件嵌入式解决芯片有四种类型:1)微解决器 2)数字信号解决器 3)微控制器(单片机) 4)片上系统微控制器MCU的低端产品并不会由于高端产品的出现而衰落在32位MCU中,绝大多数使用RAM内核EDA:电子设计自动化IP核可以分为三种:软核、硬核、固核2. 嵌入式系统与数字媒体计算机中常用的最广泛的西文字符及其编码是ASCII字符集和ASCII码,即美国标准信息互换码,共有12

2、8个字符,一个字符占一个字节。我国目前广泛使用的汉字编码国家标准有GB2312和GB18030GB2312只有6763个汉字,不够用GB18030字符集与国际标准UCS/Unicode字符集基本兼容。GB18030采用不等长的编码方法,单字节编码表达ASCII码,双字节编码表达汉字,与GB2312保持向下兼容,四字节编码表达其他字符Unicode最新版本是6.3。UCS/Unicode在计算机中具体实现时采用不同的编码方案,最常用的是UTF-8和UTF-16,UTF-8采用的是单字节可变长编码;UTF-16采用的是双字节可变长编码文本的类型可以分为简朴文本、丰富格式文本、超文本图像的数据量=图

3、像水平分辨率*图像垂直分辨率*像素深度/8(像素深度指的是每个像素用多少个二进制数来表达)数字视频的数据量非常大,在进行传输时必须进行压缩,压缩编码标准是国际标准化组织(ISO)制定的,其名称为MPEG。无线局域网采用的协议重要是IEEE 802.11(俗称WIFI)3. 数字通信与计算机网络微波是一种300MHz-300GHz的电磁波计算机网络的组成:1)计算机等智能电子设备 2)数据通信链路 3)通信协议 4)网络软件以太局域网:1)发送数据设备必须把要传输的数据提成小块(帧)进行传输,一次只能传输1帧;2)局域网中的每一个终端都有自己唯一的标记,称为物理地址或MAC地址,在发送的每一帧数

4、据中,必须包含自己的MAC地址和接受终端的MAC地址3)IP协议定义了主机的概念,所有主机及使用一种统一格式的地址标记,称为IP地址。4)以太局域网大多是由集线器或者互换机组网计算机网络的类型:1)局域网 2)城域网 2)广域网IP地址分为A、B、C三类。IP是由四段数字组成,共32位,8位一段。A类IP段0.0.0.0 到127.255.255.255 (0段和127段不使用)B类IP段128.0.0.0 到191.255.255.255C类IP段192.0.0.0 到223.255.255.255XP默认分派的子网掩码每段只有255或0A类的默认子网掩码255.0.0.0一个子网最多可以容

5、纳1677万多台电脑B类的默认子网掩码255.255.0.0一个子网最多可以容纳6万台电脑C类的默认子网掩码255.255.255.0一个子网最多可以容纳254台电脑二 第二章1. 嵌入式解决器嵌入式解决器按照指令集可以分为复杂指令集结构和精简指令集结构,按存储机制可以分为冯诺依曼结构及哈佛结构,按字长可以分为8位、16位、32位等精简指令集结构采用加载和存储两种指令对存储器进行读写操作。ARM内核采用多层次的存储结构,在解决器与主存储器之间加入CACHE,综合了哈佛结构和冯诺依曼结构的优点。ARM解决器的主流为32位,其重要特性如下:1)单周期操作 2)只是用加载/存储指令访问内存 3)指令

6、长度固定 4)三地址指令格式 5)指令流水线格式 6)低功耗设计 ARM由三种指令集,分别是:1)ARM指令集 2)Thumb指令集 3)Thumb-2指令集2. 典型ARM解决器介绍ARM解决器分为5类,分别是:1)经典ARM解决器 2)ARM Cortex嵌入式解决器 3)ARM Cortex实时嵌入式解决器 4)ARM Cortex应用解决器 5)ARM专家解决器ARM Cortex解决器涉及:1)Cortex-A 面向高端应用的解决器 2)Cortex-R 面向实时控制的解决器 3) Cortex-M 面向微控制器的解决器3. ARM解决器体系结构ARM解决器的工作状态:1)ARM状态

7、,即32位状态 2)Thumb 状态,即16位状态 3)调试状态ARM解决器有7种工作模式,分别是1)用户模式User 2)快速中断模式FIQ 3)外部中断模式IRQ 4)管理模式SVC 5)中止模式ABT 6)未定义指令模式UND 7)系统模式SYSARM解决器由37个寄存器,涉及31个通用寄存器和6个状态寄存器,通用寄存器中不分组的有8个,即R0-R7。ARM解决器用两种模式存储数据,一是大端模式,即32位的高字节存放在低地址中,低字节存放在高字节中;二是小端模式,即32位的高字节存放在高地址中,低字节存放在低字节中。MMU,即存储器管理模块,作用是进行虚拟地址到物理地址的映射、存储器访问

8、权限控制MPU是存储器保护单元4. ARM解决器指令集指令的条件码:EQ:相等NE:不相等CS:无符号数大于或等于CC:无符号数小于HI:无符号数大于LS:无符号数小于或等于GE:带符号数大于或等于LT:带符号数小于GT:带符号数小于或等于LE:带符号数小于或等于PL:正数或0块拷贝寻址举例:LDMIA R0,R1,R2,R5,R9 R1R0, R2R0+4, R3R0+8, R4R0+12STMIA R0,R1-R7 R0R1,R0+4R2, R0+8R3,R0+12R4,R0+16R5程序状态寄存器访问指令举例:MRS R0,CPSR 传送CPSR中的值到R0MSR CPSR, R0 传送

9、R0的值到CPSRs5. ARM汇编语言程序设计意会三 第三章1. 嵌入式系统硬件组成概述最小系统的构成:嵌入式解决器、存储器、复位电路、电源电路、时钟电路、调试测试接口典型嵌入式应用系统的硬件组成:最小硬件系统、前向通道、后向通道、人机交互通道以及互相互联通信通道。前向通道即输入接口,由模拟量输入接口和数字量输入接口组成;后巷通道即输出接口,由模拟输出接口和数字输出接口组成;人机交互通道即输入输出接口;2. 嵌入式解决芯片AMBA(Advanced Microcontroller Bus Architecture)先进微控制器总线体系结构AMBA规定了两种类型的总线,分别是系统总线和外围总线

10、,通过桥接器进行连接与系统总线连接的部件:电源及时钟控制器、内核、DMA、外部存储器控制接口、USB主机、SRAM、中断控制器、LCD控制器;与外围总线连接的部件:GPIO、UART、SPI、IIC、IIS、USB设备、WDT、TIMER、RTC、PWM、ADC/DAC、CAN、Ethernent。片内程序存储器常用Flash ROM,片内数据存储器常用SRAM。3. 嵌入式系统的存储器嵌入式系统的存储器结构:嵌入式解决器(内部L1/L2 Cache)、主存储器(内存)、外部存储器(外存),Cache由SRAM承担MROM:掩膜只读存储器,出厂后信息拟定,无法改变;PROM:一次可编程存储器E

11、PROM:紫外线可擦除的只读存储器EEPROM:电擦除可编程存储器FLASH ROM:闪存;NOR FLASH 和NAND FLASH是流行的闪存新存储器:FRAM(铁电存储器)、MRAM(磁性存储器)存储器容量=单元总数*数据位数/单元并行总线的存储器带宽=总线频率*数据宽度/8*传输次数/总线周期串行总线的存储器带宽=总线频率/104. I/O接口及常用的GPIOGPIO提供的输入具有缓冲功能,输出有锁存功能IIC总线有两条数据线,分别是数据线SDA和时钟线SCL。SCL为高,SDA由高变低时启动传输,SCL为高,SDA由高变低时停止传输。传输时高位在前,低位在后,传输的第一个字节为地址,

12、地址的最后一位指示数据传输方向,第9位为应答位。总线控制遵循低电平优先的原则。SPI是同步串行接口,一般使用四条线,分别是时钟、输入、输出、片选。SPI发送数据时,数据从主机中从左向右发送给从机(主机数据左对齐),从机数据从右向左发送给主机(从机数据右对齐),发送数据时,高位在前,低位在后UART:常用于全双工串行异步通信,发数据时,低位在前,高位在后USB:最多可以连接127个设备。USB系统由USB硬件和USB软件组成。硬件中的主控制器涉及一个根集线器,传输时采样翻转不归零。采用半双工差分方式传输数据。触摸屏分为电阻式和电容式5. ARM内核典型解决器芯片S3C2410是韩国三星公司制造的

13、微解决器,以下都是S3C2410的有关介绍电源管理模块有正常模式、慢速模式、休眠模式、掉电模式。任何情况下复位操作均进入正常模式,在掉电模式和休眠模式下,只要有任何一个外部中断EINT或者RTC时钟中断发生,均将返回到正常模式。总共由5个16位定期器timer,4个具有PWM的功能。定期器输入时钟频率=PCLK/(预分频值+1)*时钟因子有三个UART,UBRDIV=INT(UCLK/(波特率*16)-1,UCLK可以是PCLK,也可以是UEXTCLK。看门狗定期器的技术脉冲周期为:t_watchdog=1/(PCLK/(预分频值+1)/分频系数),计数初值为WTCON=T/t_watch_d

14、og6. 嵌入式系统外部通信接口RS-485采用差分信号传输方式CAN总线也使用差分的方式传输四 第四章在uC/OS-II中,任务或者中断服务可以通过事件控制模块(ECB)相其他任务发出信号1. 嵌入式系统的软件组成嵌入式系统的特点:软件与硬件一体化、软件代码时空效率规定高、软件可剪裁、软件应用环境复杂、软件开发难度大、软件面向用户、面向产品、面向应用、软件产业高度分散、软件具有较长的生命周期。嵌入式系统的软件结构:简朴的轮询结构(只进行查询操作)、 带中断的轮询结构、监控式操作系统+应用软件的结构、通用嵌入式操作系统+应用软件的结构。高端嵌入式系统的软件结果层次示例:硬件层、硬件抽象层、操作

15、系统层、中间件层、应用软件层。中间件是指除了操作系统内核、设备驱动程序和应用软件之外的系统软件。硬件抽象层(Hardware Abstract Layer HAL)和板极支持包(Board Support Package BSP)是嵌入式系统的底层软件,引入HAL对硬件进行抽象,通过硬件抽象层应用编程接口(HAL API)向上提供服务。BSP在系统复位之后负责系统软硬件环境的初始化,涉及三个方面的内容,一是系统复位时的硬件初始化,涉及解决器芯片的初始化和电路板的初始化,二是为操作系统提供硬件相关的驱动程序支持,三是引导加载操作系统。BSP是操作系统正常运营的前提,其效率和稳定性直接影响整个系统

16、的性能及稳定性。引导加载程序(引导程序)bootloader是底层软件的一部分,嵌入式系统上电后一方面运营引导加载程序,进行系统上电自检、硬件初始化、建立存储空间映射、配置系统参数、建立上层软件运营环境,加载和启动操作系统等等。嵌入式操作系统的加载方式:1)在ROM中直接运营操作系统代码 2)在RAM中运营操作系统代码 3)从外存储器加载操作系统代码运营 4)从通信端口加载操作系统代码运营。引导加载程序的运营过程,一是让嵌入式系统正常运起来,与解决器体系结构相关的硬件初始化和板极初始化等操作通常在第一步完毕,一般用汇编语言来写。第二是实现操作系统加载的功能,用C语言实现。设备驱动程序是指直接与

17、硬件互相作用并控制硬件的软件,是对硬件操作的抽象。2. 嵌入式操作系统实时系统(Real-Time System)是必须在有限和拟定的时间内对外部事件做出响应的信息系统。实时系统的关键特性:1)时间约束性 2)可预测性 3)可靠性 4)交互性硬实时任务:必须在给定的时间内完毕,超过时限会引起重大的错误软实时任务:超过时限不会引发致命错误,而是导致任务的服务质量下降准实时任务:通常允许偶尔错过最后时限,若超过时限,所进行的操作或计算没有任何意义。实时操作系统采用如下的机制来保持对实时任务的响应和解决的时间拟定性:1)事件驱动 2)多级中断嵌套解决 3)细粒度的任务优先级控制 4)实行抢占式调度。

18、实时操作系统的实时性指标:评价实时操作系统的实时性最重要的指标是响应时间,即系统从事件请求开始到任务完毕的时间间隔。除此之外,尚有以下的几点:1)中断延迟时间:从接受到可屏蔽中断请求到操作系统做出响应并转入中断服务程序所需要的最长时间2)任务切换时间:操作系统在两个独立且具有相同优先级的就绪态任务之间切换所需要的时间3)任务抢占时间:系统将优先权从低优先级的任务转移到高优先级任务所需要花费的时间。嵌入式操作系统的特点:代码固化存储、可裁剪、实时性、强稳定性、硬件适应性。嵌入式操作系统的分类:1)按实时性分硬实时操作系统:如VxWorks、RTEMS、QNX、uC/OS-II、Nucleus;软

19、实时操作系统:如WinCE、多种嵌入式Linux系统2)按开发方式:专门为嵌入式环境开发的嵌入式操作系统从通用计算机操作系统移植而来的嵌入式系统3)按商业模式:免费的嵌入式操作系统商业嵌入式操作系统操作系统是由内核、用户界面、中间件、使用程序等组件组成的,内核起着最重要的作用,其作用是管理系统资源,支持多任务并发执行。单内核可以分为整体结构和分层结构两种类型。单内核的优点是性能较好系统各个组件可以互相调用。缺陷是占用资源多,维护工作量大。单内核的操作系统有: Unix、BSD Unix、Linux、MS-DOS、Windows 9x(Windows 95/98/ME)、Windows CE、A

20、ndroid操作系统。微内核结构:操作系统仅仅将必须的基本功能放入内核,其他功能在内核之外。采用纯粹微内核的操作系统有AIX、Mach、Minix、VxWorks、QNX等。常见的嵌入式操作系统:VxWorks:采用的是微内核结构QNX:类Unix的实时操作系统,是非常成功的微内核操作系统,其内核仅仅提供进程调度、进程间通信、底层网络通信和中断解决。Nucleus PLUS:抢占式多任务商业操作系统内核RTEMS:实时多解决器系统TinyOS:专门为硬件资源极为有限的无线传感器网络应用而量身定制的操作系统eCOS:嵌入式可配置操作系统Linux是单内核结构,采用模块化设计,支持内核线程。Lin

21、ux内核可以分为三个层次:最上层是系统调用接口、中间层是内核的核心部分、最下层是BSP。Linux内核内部包含了若干相关的组成部件,涉及1)初始化部件 2)进程调度器 3)内存管理器 4)虚拟文献系统 5)网络接口 6)进程间通信 7)可加载模块 8)设备驱动程序Linux实时化技术的三个途径:1)内核补丁方式 2)双内核方式 3)超微内核方式嵌入式linux发行版本:uClinux、RTlinux、Monta Vista Linux、Wind River Linux、RTAI、Xenomai。Android系统采用堆层式软件架构,分为四层,从底层到高层分别是Linux内核、系统运营库、应用程

22、序框架和应用程序。其中,系统运营库由android运营环境和组件库两部分组成。IOS操作系统架构分为四个层次,分别是核心操作系统层、核心服务层、媒体层、触控界面层。3. uC/OS-II嵌入式操作系统uC/OS-II的特点:1)公开源码的高质量实时内核2)可以移植3)可裁剪、可固化4)时间拟定性5)多任务6)抢占式内核7)多种系统服务uC/OS-II的源代码重要有以下几部分构成:1) 系统核心2) 任务管理3) 时钟管理4) 任务同步与任务间通信5) 内存管理6) 解决器相关代码在uC/OS-II中,任务是操作系统的基本调度单位,由操作系统内核管理。任务由三部分构成,分别是任务的程序代码、任务

23、堆栈和任务控制块。每一个任务的栈空间大小不同,在文献OS_CPU.H中定义了一个数据类型OS_STK,在应用程序中定义任务堆栈的栈区只需要声明一个OS_STK即可,如OS_STK TaskStkTASK_STK。uC/OS-II的任务处在五种状态之一,分别是等待态、休眠态、就绪态、运营态和被中断态。休眠态指任务代码驻留在内存中还没有交给内核调度的状态;就绪态指任务已经具有运营的条件但因优先级比正在运营的任务低而暂时不能运营的状态;运营态指任务已获得解决器使用权而正在运营的状态;等待态也称为挂起,指正在运营的程序由于等待某一事件发生而将解决器的使用权让出给其他任务而自身挂起;被中断态指因解决器执

24、行中断而被暂停运营的任务状态。uC/OS-II可以管理64个任务,有64个优先级,0是最高优先级别。最低优先级别由OS_LOWEST_PRIO来定义。任务分为用户任务和系统任务,系统预定义了两个系统任务为应用程序服务,即空闲任务和记录任务。系统总是把最低优先级固定赋给空闲任务。uC/OS-II采用的是基于优先级的任务调度。内核通过OSIntExit()判断是否存在更高优先级的就绪任务。运用宏OS_ENTER_CRITICAL()和OS_EXIT_CRITICAL()实现关中断和开中断。运用函数OSSchedLock()和OSSchedUnLock()给调度器上锁和解锁。通过函数OSStart(

25、)开始任务调度之前创建函数OSTaskCreate()和OSTaskCreateExt()都可以创建任务函数OSTaskDel()既可以删除任务自身,也可以删除其他的任务。删除自己的调用形式为:OSTaskDel(OS_PRIO_SELF)函数OSTaskDelRel()的作用是让某个任务使用完资源后先释放资源,再执行OSTaskDel来删除自己函数OSTaskSuspend()可以挂起一个任务,被挂起的任务只能等待其他的任务调用OSTaskResume()函数才干实现任务恢复函数OSTimeTick()返回是否等待超时或等待事件的任务是否超时用UNIT32U OSTimeGet()获得tic

26、k计数器的当前值,可以调用OSTimeSet()改变tick计数器的当前值。通过OSTimeDly()或者OSTimeDlyHMSM()延迟处在运营态的任务由OSSemCreate()函数创建信号量由OSSemDel()函数删除一个信号量由OSSemPost()释放信号量由OSSemPend()等待信号量由OSSemAccept()无等待的请求信号量由OSSenQuery()查询信号量状态调用OSInit()进行内核初始化五 第五章1. 开发嵌入式系统的基础知识(1) 嵌入式系统的开发过程1) 需求分析与规格说明2) 系统设计:根据规格说明书中所描述的系统需要实现的功能,拟定如何实现这些功能的

27、硬件和软件结构。3) 构件设计:设计或者选择符合系统结构和规格说明中所需要的具体构件,有通用的构件,如CPU、存储器芯片,也有专用的构件,如AX88796(不知道是什么玩意)4) 系统集成与测试(2) 嵌入式系统的开发平台与工具嵌入式系统的开发特点1) 使用宿主机-目的机的开发架构2) 与底层硬件控制程序的关系密切3) 软硬件资源受到限制4) 需要固化程序IDE(Integrated Development Environment):集成开发环境(3) 嵌入式系统的调试四种调试技术:1) 在线仿真器(In-Circuit Emulator ICE):ICE具有与索要开发的嵌入式系统相同的嵌入式

28、解决器,进行调试时,用在线仿真器取代被调试系统的解决器。2) 片上调试技术JTAG3) 驻留监控软件调试:使用驻留监控软件(Resident Monitors),即固化在目的机ROM中的程序,在目的机中运营。4) 指令集模拟器(Instruction Set Simulator ISS)在宿主机上模拟应用程序在目的机上润兴行为的一个软件工具。重要应用于没有目的机开发板硬件、有开发板硬件,但使用开发板成本高、被调试的程序模块不需要在实际开发板上执行、对模块代码进行语法检查、避免因对硬件不熟悉而在调试硬件方面花费过多精力。常用的两种指令集模拟器:ARMulator、SkyEye2. 系统开发工具软

29、件(1) ADS1.2工具软件(ARM Developer Suite):支持开发的嵌入式应用软件通常是无操作系统的,即使有,也是uC/OS-II这样的小型系统。ADS1.2的工程项目:一个工程项目至少应涉及一个生产目的,即用于生成特定输出文献的生成选项以及所用的所有文献的集合。生成选项涉及汇编选项、编译选项、连接选项和连接后选项。三个可执行文献的模板:1) Debug:生成的额输出文献涉及所有调试信息,用于在开发过程中使用;2) Release:生成的输出文献中不涉及调试信息,用于生成实际发行的软件3) DebugRel:生成的输出文献包含了基本的调试信息。本地址映射关系比较简朴时,使用编译

30、、连接选项来拟定输入文献的连接顺序本地址映射关系比较复杂时,使用scatter(分散加载)格式的文献来拟定输入文献的连接顺序。连接中的地址映射:ADS把编译后的目的文献信息按照3种存储区域类型进行划分,分别是:1) RO端段:代码存储区和常数存储区,具有只读的性质2) RW段:指初始值为非0的全局变量数据区,具有可读可写的性质3) ZI段:指初始值为0的全局变量数据区,涉及未初始化的全局变量,具有可读可写的性质。下载时域和运营时域:下载时域是下载时的存储空间;运营时域是运营时的存储空间。1) simple连接类型:应用于地址映射简朴的工程项目。RW base文本框配置的是RW字段的和ZI字段运

31、营时域的地址,输入的地址值必须是字对准的,即能被4整除。2) 对地址映射关系较为复杂的项目,使用scatter连接类型,需要提供一个scatter格式的文献(.scf)。配置文献是一个文本文献,使用BNF语法来进行描述。在scatter类型下,下载时域的语法结构如下:Load_name Base_Add Attribute sizeLoad_name是下载时域的名称,是下载时域的唯一标记。Base_Add是下载时域的首地址,Attribute是下载时域的数属性,可省略。size是下载时域的容量大小。在scatter类型下,运营时域的描述语法结构如下:Exec_name Base_Add Att

32、ribute SizeExec_name是运营时域的名称。属性可省略。在scatter类型下,输入端的描述结构如下:*代表若干个任意字符,?代表一个任意字符Load_1 0x0000 0x8000Exec_1 0x0000 0x8000*(+RO)Exec_2 0x10000 0x6000*(+RW,+ZI)上述是一个简朴的配置文献,定义了一个下载时域,名称为Load_1,首地址是0x0000,域的容量是0x8000,定义了两个运营时域,第一个名称为Exec_1,首地址为0x0000,容量为0x8000,域中包含了所有的代码和常数,即包含了所有RO属性的输入段。第二个域中包含了所有的RW、ZI

33、属性的输入段。(2) RVDS(RealView Development Suite)要使用RVDS来调试程序,必须使用RealView-ICE仿真器RVDS的功能模块涉及工程管理器(IDE)、编译链接器(RVCT)、调试器(RVD)和指令集仿真器(RVISS)等。RVDS可以记录ARM CPU从开始执行程序到停止执行程序这段时间所执行的所有操作,称为Trace功能;而Profile功能指RVDS可以对Trace功能所记录的内容进行性能分析。(3) GNU(GNUs Not Unix)是一种常用于基于Linux操作系统的嵌入式软件的工具套件的简称。GCC是GNU开发工具套件中的核心工具软件,是

34、一种针对linux操作系统环境下运营程序的编译工具。它由源文献生成可执行文献的过程是预解决,编译,汇编,连接。汇编阶段,生成二进制目的文献,以为文献的结尾。Linux操作系统中的可执行文献没有统一的文献后缀,按文献的属性来进行区分,若GCC生成可执行文献时没有指定文献名,则GCC生成一个名为a.out的可执行文献。GCC所规定的文献后缀与文献类型的相应关系:.c:用C语言编写的源程序文献.a:由目的文献构成的源文献.C、.cc、.cxx:用C+语言编写的源文献.h:头文献,可以被其他源文献包含.i:已经预解决过的C语言编写的源程序文献.ii:已通过预解决的C+语言编写的源程序文献.o:编译及汇

35、编后生成的目的文献.s:编译后生成的汇编语言程序.S:汇编语言编写的源文献程序。GCC的命令及参数:基本命令格式为gcc options filenames,其中,options代表编译命令所需要的参数,filename表达命令中所涉及到的文献名称。针对不同的嵌入式解决器,GCC的命令格式不同,如针对ARM,GCC基本命令格式为:arm-linux-gcc options filenamesGCC命令的参数(针对ARM)-c:仅完毕编译操作而不进行编译操作,编译器把输入的文献生成后缀为.o的目的文献-E:仅完毕预解决操作而不进行后续解决操作,生成后缀为i的文献-S:仅完毕预解决操作、编译操作而

36、不进行后续操作,输出后缀为.s的文献-o filename_out:拟定编译后的输出文献名为filename_out,可以根据自己的需求拟定生成的输出文献名称,但不能与源文献名称相同。若不指定,则输出为a.out-g:编译时产生一个用于调试的符号表,对元层序进行调试-O:对程序进行优化编译-I dirname:将目录名为dirname的目录加入到源程序头文献的目录列表中-L dirname: 将目录为dirname的目录加入到库文献的目录列表中假设源文献名称为test.c,以下是几个常见的GCC编译命令:arm-linux-gcc-o test test.c:生成文献名为test的输出文献Ar

37、m-linux-gcc-c-o test.o test.c:生成文献名为test.o的目的文献Arm-linux-gcc-S-o test.s test.c:生成文献名为test.s的汇编语言文献Arm-linux-gcc-E-o test.i test.c:生成名为test.i的文献Arm-linux-gcc-g-o test test.c:编译器在生成的输出文献test中加入GDB可以使用的调试信息Arm-linux-gcc-I/test/include o test test.c:将目录test/include加入到都文献的目录列表中。GDB是GNU开发工具套件中的程序调试工具,提供单步

38、执行和断点执行的功能,观测程序执行时变量值的变化。为了是GDB可以进行调试,编译时应当在命令中加入-g参数GDB的基本功能:File:装入需要调试的文献,如file testRun:执行当前被调试的程序Kill:终止当前被调试的程序Next:执行一行源代码,碰到函数调用不进入函数内部Step:执行一行源代码,碰到函数调用进入函数内部Break:设立断点Watch:观测变量的值List:列出部分源代码Quit:终止GDB运营在基于ARM CPU的误操作系统的嵌入式应用系统设计时,设计者需设计一个简易的系统启动引导程序,改程序一方面完毕中断向量表的设立、堆栈指针的设立以及其他的硬件初始化工作,然后

39、直接引导用户程序的主函数运营。第六章 补充摩尔定律:当价格不变时,集成电路上可容纳的元器件的数目,约每隔18-24个月便会增长一倍,性能也将提高一倍。当前世界上集成电路批量生产的主流技术已经达成45nm或者32nm的水平(亚微米)CPU的时钟频率母亲已经达成3-4GHz水平先进的CMOS集成技术已经可以实现水、模拟、射频等不同电路的集成SoC开发流程答题分为总体设计、逻辑设计、综合与仿真、芯片制造四个阶段SoC设计中大量使用已有的通过验证的IC电路设计的文献,以提高设计效率,减少反复开发,这些设计文献属于知识产权保护的范围,通常称为IP核U-Boot的全全称是Universal Bootloa

40、der,是一个规模庞大的bootloader开源软件,以PPCBoot和ARMBoot为基础,除了支持PowerPC系列解决器之外,还支持X86、ARM等多种常用体系结构的解决器,支持嵌入式Linux、VxWorks、QNX、RTEMS、Windows CE等操作系统,用两个阶段完毕操作系统的引导与加载在uC/OS-II操作系统中,每个人物都有自己独立的栈空间。Bootloader的任务是加载和引导启动操作系统。想要移植uc/os-ii系统到特定的嵌入式电路板上,则支持其解决机的C编译器必须可以产生可重入代码。模拟信号数字化的三个环节:采样、量化、编码IPV4的IP长度为32位;IPV6的IP地址有128位uC/OS-II是目前嵌入式操作系统领域中最小的内核之一,它只提供任务调度、任务间通信与同步、任务管理、时间管理和内存管理等功能,内核裁剪到最小状态后编译出来的代码只有8KB,资源小号非常少。

展开阅读全文
温馨提示:
1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
2: 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
3.本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
关于我们 - 网站声明 - 网站地图 - 资源地图 - 友情链接 - 网站客服 - 联系我们

copyright@ 2023-2025  zhuangpeitu.com 装配图网版权所有   联系电话:18123376007

备案号:ICP2024067431-1 川公网安备51140202000466号


本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知装配图网,我们立即给予删除!