嵌入式系统_软硬件接口.pptVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
刘 健 培 嵌入式系统与网络通信研究中心 北京邮电大学 计算机学院 嵌入式系统 软硬件接口 Bootloader、驱动、 BSP 本节内容 WHY? 功能分化: 启动 控制硬件 支持软件模型 从软件开发角度看板级硬件 硬件系统结构与组成的抽象 从硬件系统抽象出软硬件接口信息,便于软件开发人员开发软件 在嵌入式硬件系统中,软件表现为程序存储器中的二进进制代码(即程序),不管外设的功能和硬件形式如何,对软件来说,可操作的只有:寄存器、存储器、IO接口。一般RISC处理器都是统一编址的,所以最终操作的只有地址。 硬件 开发板实物 提炼 地址 软件 C语言头文件 TQ2440硬件开发板 2440addr.h 从软件开发角度看存储器 存储器地址空间分布图 存储芯片信息 类型、基址、大小、片选、配置参数 存储器控制寄存器 MMU 从软件开发角度看外设 指令能访问到什么 IO管脚配置寄存器 设备寄存器组 数据、控制、状态 寄存器地址 独立编址(I/O端口方式)与统一编址(I/O内存方式) 一个地址可能对应多个寄存器 有些地址可以动态配置(如PCI) 指令如何访问外设 外设操作方式与流程 规范与协议 CPU与外设交互方式 轮询、中断、DMA 从软件开发角度看处理器 ARM ISA 异常与中断处理方式 ARM ABI(API?) ARM ABI API与ABI API:Application Programming Interface,应用程序编程接口 /wiki/Application_programming_interface ABI: Application Binary Interface,应用程序二进制接口 /wiki/EABI EABI: Embedded Application Binary Interface,嵌入式应用程序二进制接口 /wiki/EABI CPU toolchain APP LIBs OS API Compiler Linker Loader Debugger ABI Source code Binary code compile run API定义了源代码和库之间的接口,因此同样的代码可以在支持这个API的任何系统中编译, ABI允许编译好的目标代码在使用兼容ABI的系统中无需改动就能运行(直到现在还没有很成功的例子)。 EABI指定了文件格式、数据类型、寄存器使用、栈帧组织方式和函数参数传递等的标准约定。支持EABI的编译器创建的目标文件可以和使用类似编译器产生的代码兼容,这样允许开发者链接一个由不同编译器产生的库。EABI与关于通用计算机的ABI的主要区别是应用程序代码中允许使用特权指令,不需要动态链接(有时是禁止的),和更紧凑的堆栈帧组织用来节省内存。广泛使用EABI的有Power PC和ARM. ARM EABI /help/index.jsp?topic=/com.arm.doc.subset.swdev.abi/index.html ARM 程序调用标准——AAPCS (Procedure Call Standard for the ARM Architecture) ARM 的C++ABI —— CPPABI(C++ ABI for the ARM Architecture) ARM 异常处理的ABI —— EHABI(The Exception Handling ABI for the ARM Architecture) ARM 的ELF 二进制文件格式—— AAELF(ELF for the ARM Architecture) ARM 的DWARF 二进制文件格式—— AADWARF ( DWARF for the ARM Architecture) ARM 的运行态ABI —— RTABI(The Run-time ABI for the ARM Architecture) ARM 的C 库ABI —— CLIBABI(The C Library ABI for the ARM Architecture) ARM ABI 系统初始化过程 指令执行前硬件初始化 系统上电,执行内部初始固码微程序(如果有),设置处理器上电默认工作状态,最后从复位向量处开始执行 硬件初始化 片级初始化(设置微处理器执行状态) 板级初始化(配置与初始化相关外设) 软件初始化 操作系统执行前初始化 初始化OS所需内存等资源、加载OS、传递参数、跳转 操作系统组件初始化 中断、定时器、任务、内存管理等等 应用程序执行前初始化 加载应用程序,建立应用程序执行环境 跳转到应用程序入口 CPU初始化 目标板初始化 系统初始化 启动任务 初始化 Bootloader=Boot+Loader Boot 处理器复位后

文档评论(0)

xfnzn + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档