热门标签 | HotTags
当前位置:  开发笔记 > 开发工具 > 正文

Linux嵌入应用:ARM体系结构的技术特征

在开发设计第一个ARM芯片时,当时的一些机器如DigitalPDP-8、Cray-1和IBM801在设计时早就提出了RISC的概念,并且在其后发展中有了许多R

在开发设计第一个ARM芯片时,当时的一些机器如Digital PDP-8、Cray-1和IBM 801在设计时早就提出了RISC的概念,并且在其后发展中有了许多RISC的特征,但RISC惟一的例子仍只有Berkeley的RISC I和II及Stanford的MIPS(Microprocessor without Interlocking Pipeline Stages, 无互锁流水线处理器),而它们当时仅仅用于教学和研究。

ARM处理器是第一个为商业用途而开发的RISC微处理器。ARM所采用的体系结构,对于当时的RISC体系结构既有继承,又有抛弃,即完全根据实际设计的需要仔细研究,没有机械照搬。ARM的体系结构中采用了若干Berkeley RISC处理器设计的特征,但也放弃了其他若干特征。这些采用的特征有:

·Load/Store体系结构

·固定的32位指令

·3地址指令格式

在Berkeley RISC设计采用的特征中被ARM设计者放弃的RISC的技术特征有:

·寄存器窗口

在早期的RISC中,由于Berkeley原型机中包含了寄存器窗口,使得寄存器窗口的机制密切地伴随着RISC的概念,成为一般RISC的一大特征。Berkeley RISC处理器的寄存器堆中使用寄存器窗口,使得任何时候总有32个寄存器是可见的。进程进入和退出都访问新的一组寄存器,因此减少了因寄存器保存和恢复导致的处理器和存储器之间的数据拥塞和时间开销。这是拥有寄存器窗口的优点。但是寄存器窗口的存在以大量寄存器占用较多的芯片资源为代价,使得芯片成本增加,因此在ARM处理器设计时未采用寄存器窗口。尽管在ARM中用来处理异常的影子(shadow)寄存器和窗口寄存器在概念上基本相同,但是在异常模式下对进程进行处理时,影子寄存器的数量是很少的。

·延迟转移

由于转移中断了指令流水线的平滑流动而造成了流水线的“断流”问题,多数RISC处理器采用延迟转移来改善这一问题,即在后续指令执行后才进行转移。在原来的ARM中延迟转移并没有采用,因为它使异常处理过程更加复杂。

·所有指令单周期执行

ARM被设计为使用最少的时钟周期来访问存储器,但并不是所有指令都单周期执行。如在低成本的ARM应用领域中普遍使用的ARM7TDMI,数据和指令占有同一总线,使用同一存储器时,即使最简单的Load和Store指令也最少需要访问2次存储器(1次取指令,1次数据读/写)。当访问存储器需要超过一个周期时,就多用一个周期。因此,并不是所有ARM指令都在单一时钟周期内执行的,少数指令需要多个时钟周期。高性能的ARM9TDMI使用分开的数据和指令寄存器,才有可能把Load和Store指令的指令存储器和数据访问存储器操作单周期执行。

最初的ARM设计最关心的是必须保持设计的简单性。ARM的简单性在ARM的硬件组织和实现上比指令集的结构上体现得更明显。把简单的硬件和指令集结合起来,这是RISC体系的思想基础;但是ARM仍然保留一些CISC的特征,并且因此达到了比纯粹的RISC更高的代码密度,使得ARM在开始时就获得其功率效率和较小的核面积的优势。


推荐阅读
  • PHP 5.2.5 安装与配置指南
    本文详细介绍了 PHP 5.2.5 的安装和配置步骤,帮助开发者解决常见的环境配置问题,特别是上传图片时遇到的错误。通过本教程,您可以顺利搭建并优化 PHP 运行环境。 ... [详细]
  • 构建基于BERT的中文NL2SQL模型:一个简明的基准
    本文探讨了将自然语言转换为SQL语句(NL2SQL)的任务,这是人工智能领域中一项非常实用的研究方向。文章介绍了笔者在公司举办的首届中文NL2SQL挑战赛中的实践,该比赛提供了金融和通用领域的表格数据,并标注了对应的自然语言与SQL语句对,旨在训练准确的NL2SQL模型。 ... [详细]
  • Android LED 数字字体的应用与实现
    本文介绍了一种适用于 Android 应用的 LED 数字字体(digital font),并详细描述了其在 UI 设计中的应用场景及其实现方法。这种字体常用于视频、广告倒计时等场景,能够增强视觉效果。 ... [详细]
  • RecyclerView初步学习(一)
    RecyclerView初步学习(一)ReCyclerView提供了一种插件式的编程模式,除了提供ViewHolder缓存模式,还可以自定义动画,分割符,布局样式,相比于传统的ListVi ... [详细]
  • 扫描线三巨头 hdu1928hdu 1255  hdu 1542 [POJ 1151]
    学习链接:http:blog.csdn.netlwt36articledetails48908031学习扫描线主要学习的是一种扫描的思想,后期可以求解很 ... [详细]
  • 本文详细介绍了如何在 Spring Boot 应用中通过 @PropertySource 注解读取非默认配置文件,包括配置文件的创建、映射类的设计以及确保 Spring 容器能够正确加载这些配置的方法。 ... [详细]
  • This document outlines the recommended naming conventions for HTML attributes in Fast Components, focusing on readability and consistency with existing standards. ... [详细]
  • 本文详细介绍了Java中org.w3c.dom.Text类的splitText()方法,通过多个代码示例展示了其实际应用。该方法用于将文本节点在指定位置拆分为两个节点,并保持在文档树中。 ... [详细]
  • 本文详细介绍了 Apache Jena 库中的 Txn.executeWrite 方法,通过多个实际代码示例展示了其在不同场景下的应用,帮助开发者更好地理解和使用该方法。 ... [详细]
  • 在现代网络环境中,两台计算机之间的文件传输需求日益增长。传统的FTP和SSH方式虽然有效,但其配置复杂、步骤繁琐,难以满足快速且安全的传输需求。本文将介绍一种基于Go语言开发的新一代文件传输工具——Croc,它不仅简化了操作流程,还提供了强大的加密和跨平台支持。 ... [详细]
  • 题目Link题目学习link1题目学习link2题目学习link3%%%受益匪浅!-----&# ... [详细]
  • 解决微信电脑版无法刷朋友圈问题:使用安卓远程投屏方案
    在工作期间想要浏览微信和朋友圈却不太方便?虽然微信电脑版目前不支持直接刷朋友圈,但通过远程投屏技术,可以轻松实现在电脑上操作安卓设备的功能。 ... [详细]
  • 网络运维工程师负责确保企业IT基础设施的稳定运行,保障业务连续性和数据安全。他们需要具备多种技能,包括搭建和维护网络环境、监控系统性能、处理突发事件等。本文将探讨网络运维工程师的职业前景及其平均薪酬水平。 ... [详细]
  • 从零开始构建完整手机站:Vue CLI 3 实战指南(第一部分)
    本系列教程将引导您使用 Vue CLI 3 构建一个功能齐全的移动应用。我们将深入探讨项目中涉及的每一个知识点,并确保这些内容与实际工作中的需求紧密结合。 ... [详细]
  • 本报告涵盖了个人博客账号和码云账号的注册过程,以及对网络工程专业学习的反思与展望。通过回顾初入大学时的专业选择,分析当前的专业知识和技能水平,并对未来的职业规划进行了详细讨论。 ... [详细]
author-avatar
Zhang钰煌_925
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有