: 12MHz 晶振 对应 405 ~ 532 MHz 处理速度;

-- : 16K 指令缓存, 16K 数据缓存;

-- : 32KB 指令缓存, 32KB 数据缓存;

(3) 内存接口对比

: 提供 SDRAM 内存接口;

-- : 提供了 SDRAM, 也提供了 DDR 内存接口;

-- : 提供了 DDR1 和 DDR2 两种内存接口;

(4) 支持的操作系统

 : WinCE | Linux;

--  : 三星宣布停产;

-- 210 : 继续使用;

二. ARM 工作模式

对应手册ARM Architecture Reference Manual.pdf 手册, 在本博客中提供下载;

-- 章节内容 : Programmers’ Model, A2.2 Page 41;

-- 手册下载地址http://download.csdn.net/detail/han1202012/8324641

1. 处理器工作模式

(1) ARM 工作模式图例


工作模式图示 : 图片截图自 ARM Architecture Reference Manual.pdf 手册, Page 41, A2.2 章节;

(2) ARM 工作模式介绍

工作模式介绍 :

-- User 模式 (usr) : 普通应用程序运行的模式;

-- FIQ 模式 (fiq) : 快速中断模式;

-- IRQ 模式 (irq) : 普通中断模式;

-- Supervisor 模式 (svc) : 为操作系统提供的保护模式;

-- Abort 模式 (abt) : 访问虚拟内存导致异常的模式;

-- Undefined 模式 (und) : 未定义指令模式;

-- System 模式 (sys) : armv4 以上版本才有该模式;

Linux 系统工作模式 : 系统运行在 usr 模式, 内核运行在 svc 模式;

三. ARM 寄存器

对应手册 : ARM Architecture Reference Manual.pdf 手册, 在本博客中提供下载;

-- 章节内容 : Programmers’ Model, A2.3 Page 42;

-- 手册下载地址 : http://download.csdn.net/detail/han1202012/8324641

1. 寄存器简介

寄存器简介 :

-- 寄存器个数 : ARM 有 37 个寄存器;

-- 通用寄存器 : 31 个通用寄存器, 程序计数器 也是一个通用寄存器;

-- 状态寄存器 : 6 个状态寄存器;

-- 图示 :

-- 寄存器图示 : 截图自 Page 43;

2. 通用寄存器

(1) 通用寄存器分类

通用寄存器分类 :

-- 不分组寄存器 : R0 ~ R7;

-- 分组寄存器 : R8 ~ R14, 不同模式下使用的寄存器都不相同;

-- 程序计数器 : PC 指针, 是 R15;

(2) 常用通用寄存器解析

R13 寄存器 : 通常用来做 SP 堆栈指针;

R14 寄存器 : 通常用来做 链接寄存器;

-- 作用一 : 保存函数返回地址;

-- 作用二 : 异常发生时, 主要用于记录函数返回地址;

R15 寄存器 : PC 指针, 程序计数器;

3. 状态寄存器

(1) 对应各个模式的状态寄存器出现原因

状态寄存器 :

-- 图示 :

-- 对应各个模式的状态寄存器 : 当出现中断后, 执行中断程序, 需要将对应的 CPRS 保存到对应模式的 SPRS_xxx 寄存器中, 如当前在 scv 模式中断, 将状态寄存器保存到 SPSR_svc 寄存器中, 中断执行完后, 将状态从 SPSR_svc 中写回到 CPRS 寄存器中;

(2) CPSR 寄存器位简介

CRSR 寄存器简介 :

-- 图示 :

-- N 位 : 两个数a 和 b比较, 即做减法 (a-b), 如果 a < b, 减法结果是负数, N = 1; 如果 a >= b, 减法结果是正数或0, N = 0;

-- Z 位 : 两个数进行比较, 只有两个数相等时 Z = 1;

-- I 位 : I = 1 时不能产生中断;

-- F 位 : F = 1 时不能产生快速中断;

-- M 位 : 占了 5 个位 0 ~ 4, 主要用于标明处理器模式, 可以读取模式 和 设置模式, 如下图 :

四. ARM 寻址方式

对应手册 : ARM Architecture Reference Manual.pdf 手册, 在本博客中提供下载;

-- 章节内容 : Programmers’ Model, A2.3 Page 42;

-- 手册下载地址 : http://download.csdn.net/detail/han1202012/8324641

寻址方式 : 处理器根据指令给出的信息找到指令的操作数;

1. 立即数寻址

立即数寻址简介

-- 寻址过程 : 操作数本身就在指令中给出, 取出指令同时也可以获取操作数;

-- 操作数 : 指令中取出的操作数就是立即数;

-- 寻址方式 : 这种从指令中取出立即数的方式就是立即数寻址;

立即数寻址示例 :

-- 示例 : ADD R0, R0, #0x3F;

-- 解析 : 将 R0 + #0x3F 相加, 结果放入到 R0 中;

立即数寻址要求 : 第二个源操作数以 "#" 为后缀;

2. 寄存器寻址

寄存器寻址简介 : 利用寄存器中的数值作为操作数;

-- 示例 : ADD R0, R1, R2;

-- 示例解析 : 将 R1 和 R2 寄存器中的数字相加, 结果存放到 R0 中;

3. 寄存器间接寻址

寄存器间接寻址简介 : 寄存器中存放的操作数在内存中, 寄存器存放内存的地址;

-- 示例 : LDR R0, [R2];

-- 示例解析 : 寄存器 R2 中存放的是 操作数的内存地址, 从内存中取出操作数存入 R0 中;

4. 基址变址寻址

基址变址寻址简介 :

-- 基址寄存器 : 寄存器中存放一个基地址;

-- 偏移量 : 指令中给出一个偏移量, 与基址寄存器放在一个中括号号中;

-- 示例 : LDR R0, [R1. #4];

-- 示例解析 : 从 R1 中取出地址, 然后 该地址 加上 4, 从 相加后的地址中取出数据;

5. 相对寻址

相对寻址简介 : PC 指针当前值为基地址, 指令中地址标号是偏移量, 两者相加后是有效地址;

-- 示例 : BL NEXT 时会跳转到 NEXT 处执行, 执行完后会返回到原程序处;

BL NEXT ;跳转到 NEXT 处执行

... ...

NEXT

... ...

MOV PC, LR ;从子程序返回

作者 : 韩曙亮

博客地址 : http://blog.csdn.net/shulianghan/article/details/42375701

相关资源下载 : 

-- 三星 ARM Architecture Reference Manual 文档 : http://download.csdn.net/detail/han1202012/8324641

【嵌入式开发】ARM 芯片简介 (ARM芯片类型 | ARM处理器工作模式 | ARM 寄存器 | ARM 寻址)的更多相关文章

  1. ARM处理器工作模式

    学习ARM处理器参考的首选资料是ARM Architecture Reference Manual,是最专业权威的学习资料. ARM处理器共有7种工作模式,如表1-1和1-2所示: 表1-1 处理器工 ...

  2. [国嵌笔记][021-022][ARM处理器工作模式]

    [ARM处理器工作模式] 处理器工作模式 1.User(urs):用户模式,linux应用程序运行在用户模式 2.FIQ(fiq):快速中断模式 3.IRQ(irq):中断模式 4.Superviso ...

  3. ARM的工作模式和寄存器

    以前学的时候学的是S3C6410的开发板,它是三星公司推出的基于ARM v6架构(指令集),处理器是ARM11. ARM架构是构建每个ARM处理器的基础. 目前最新的是ARM v8架构:http:// ...

  4. 2.2 ARM处理器工作模式

    ARM Architecture Reference Manual Arm 指令框架手册 种工作模式 Processor mode Mode number Description User usr 0 ...

  5. 嵌入式开发之赛灵思 xilinx Zynq芯片简介---Zynq-7000 EPP (XC7Z010 and XC7Z020)

    (1)企业简介 作为DSP 和视频应用领域的头号 FPGA 供应商,赛灵思致力于通过其目标设计平台提供业内领先的 DSP 开发工具.方法.IP 和技术支持.赛灵思面向 DSP 的目标设计平台将这些元素 ...

  6. 【嵌入式开发】裸机引导操作系统和ARM 内存操作 ( DRAM SRAM 类型 简介 | Logical Bank | 内存地址空间介绍 | 内存芯片连接方式 | 内存初始化 | 汇编代码示例 )

    [嵌入式开发]ARM 内存操作 ( DRAM SRAM 类型 简介 | Logical Bank | 内存地址空间介绍 | 内存芯片连接方式 | 内存初始化 | 汇编代码示例 )     一. 内存 ...

  7. 【嵌入式开发】 Bootloader 详解 ( 代码环境 | ARM 启动流程 | uboot 工作流程 | 架构设计)

    作者 : 韩曙亮 博客地址 : http://blog.csdn.net/shulianghan/article/details/42462795 转载请著名出处 相关资源下载 :  -- u-boo ...

  8. ARM体系的7种工作模式

    一.ARM体系的CPU有以下7种工作模式:   用户模式(usr)    大多数程序运行于用户模式 特权模式   系统模式(sys)   运行具有特权的操作系统任务 异常模式 中断模式(irq)   ...

  9. ARM编程模式和7钟工作模式

    一. ARM的基本设定 1.1. ARM 采用的是32位架构 1.2. ARM约定: a. Byte : 8 bits b. Halfword :16 bits (2 byte) c. Word : ...

随机推荐

  1. 如何使用GitHub

    进行版本控制时,我们可以直接通过网页来进行版本控制,也可以下载git客户端.值得注意的是,git的客户端有很多种,具体的可以参考:https://git-scm.com/downloads/guis/ ...

  2. 安装win7提示“我们无法创建新的分区,也找不到现有分区”

    用U盘安装操作系统,但是遇到了这种问题. 来来回删掉主分区,重新建立主分区,都不能搞定.最后还是用古老的方法安装了.安装的方法如下: 大家首先要进入到winpe,这里我用的是大白菜winpe. 将C盘 ...

  3. C语言程序设计预备作业。

    1. 阅读邹欣老师的博客--师生关系,针对文中的几种师生关系谈谈你的看法,你期望的师生关系是什么样的? 答:我理想中的师生关系是Coach/Trainee(健身教练/健身学员)的关系.因为邹老师就如同 ...

  4. SpringBoot中跨域问题

    项目中经常会遇到浏览器跨域的问题,解决方式在启动类中配置 @Bean public FilterRegistrationBean corsFilter() { UrlBasedCorsConfigur ...

  5. IOS和OSX事件传递机制

    本文ios部分转载自: http://zhoon.github.io/ios/2015/04/12/ios-event.html iOS的事件有好几种:Touch Events(触摸事件).Motio ...

  6. tar包和jar包和war包的区别?

    tar:tar是*nix下的打包工具,生成的包通常也用tar作为扩展名,其实tar只是负责打包,不一定有压缩,事实上可以压缩,也可以不压缩,通常你看到xxxx.tar.gz,就表示这个tar包是压缩的 ...

  7. DataOutputStream&DataInputStream

    DataOutputStream&DataInputStream是对输出输入流的扩展,可以直接读写int double等数据类型 下面是今天的练习,细节都写到注释里面了: package Zh ...

  8. 使用ffmpeg转码时遇到aac报错

    今天尝试用ffmpeg转一个视频的格式,结果报出这个错误: The encoder 'aac' is experimental but experimental codecs are not enab ...

  9. Java面试06|项目相关介绍

    1.明确你的项目到底是做什么的,有哪些功能 广告投放机:项目主要是为移动端有针对性的进行广告展示. 媒体管理平台SSP:为媒体端实现多种变现途径 (1)广告投放机中关于广告检索与排序的功能 1.广告检 ...

  10. 【C#复习总结】匿名类型由来

    1 属性 这得先从属性开始说,为什么外部代码访问对象内部的数据用属性而不是直接访问呢,这样岂不是更方便一些,但是事实证明直接访问是不安全的.那么,Anders Hejlsberg(安德斯·海尔斯伯格) ...