AVR汇编(三):寻址方式
AVR汇编(三):寻址方式
AVR具有多种寻址方式,在介绍具体的汇编指令之前,有必要对它们做一定了解。
前面介绍过,AVR将内存空间分为多个部分:寄存器堆、I/O空间、数据空间、程序空间。这些空间支持的指令和寻址方式都各不相同。
寄存器堆的寻址方式
AVR中寄存器堆的寻址方式分为3种:立即寻址、单寄存器寻址、双寄存器寻址。
立即寻址
所谓立即寻址,就是指操作数直接编码在指令中。需要注意的是,只有 R16
~ R31
寄存器支持立即寻址。
例如:
ANDI R16, 0x01 ; R16 <- R16 & 0x01
单寄存器寻址
在单寄存器寻址方式下,操作数存放在目的寄存器 Rd
中。
例如:
INC R16 ; R16 <- R16 + 1
双寄存器寻址
在双寄存器寻址方式下,操作数分别存放在源寄存器 Rr
和目的寄存器 Rd
中。
例如:
ADD R16, R17 ; R16 <- R16 + R17
I/O空间的寻址方式
AVR中I/O空间具有独立的地址,范围为0x00~0x3F,支持直接寻址和位寻址。
直接寻址
在直接寻址方式下,操作数地址 A
直接编码在指令中。
例如:
OUT PORTB, R16 ; PORTB <- R16
位寻址
I/O空间中地址为0x00~0x1F的区域支持按位访问。
例如:
SBI PORTB, 2 ; PORTB.2 <- 1
数据空间的寻址方式
AVR中数据空间具有5种寻址方式:直接寻址、间接寻址、带前缀自减的间接寻址、带后缀自增的间接寻址、带偏移量的间接寻址。
直接寻址
在直接寻址方式下,操作数地址直接编码在指令中, Rd
/ Rr
指定目的寄存器/源寄存器。
例如:
LDS R16, 0X0100 ; R16 <- (0X0100)
间接寻址
在间接寻址方式下,操作数地址存放在 X
/ Y
/ Z
寄存器中。
例如:
LD R16, X ; R16 <- (X)
带前缀自减的间接寻址
在带前缀自减的间接寻址方式下,操作数地址存放在 X
/ Y
/ Z
寄存器中,并且在操作之前 X
/ Y
/ Z
先自减一。
例如:
LD R16, -X ; X <- X - 1, R16 <- (X)
带后缀自增的间接寻址
在带后缀自增的间接寻址方式下,操作数地址存放在 X
/ Y
/ Z
寄存器中,并且在操作之后 X
/ Y
/ Z
再自增一。
例如:
LD R16, X+ ; R16 <- (X), X <- X + 1
带偏移量的间接寻址
在带偏移量的间接寻址方式下,操作数地址由 Y
/ Z
寄存器和编码在指令中的偏移量 q
相加得出。
例如:
LDD R16, Y+2 ; R16 <- (Y + 2)
程序空间的寻址方式
AVR中程序空间具有5种寻址方式:常量寻址、带后缀自增的常量寻址、直接寻址、间接寻址、相对寻址,前两种寻址方式用于访问位于程序空间的常量,后三种用于程序跳转。
常量寻址
在常量寻址方式下,操作数地址(字节地址)存放在 Z
寄存器中, Z
寄存器中高15位指定字地址,最低位为0表示访问的是字的低位字节,1表示访问的是字的高位字节。
例如:
LPM R16, Z ; R16 <- (Z)
带后缀自增的常量寻址
在带后缀自增的常量寻址方式下,操作数地址(字节地址)存放在 Z
寄存器中,并且在操作之后 Z
寄存器自增一。
例如:
LPM R16, Z+ ; R16 <- (Z), Z <- Z + 1
直接寻址
在直接寻址方式下,程序接下来的执行地址(字地址) k
直接编码在指令中。
例如:
JMP FUNC ; PC <- FUNC
...
FUNC:
...
间接寻址
在间接寻址方式下,程序接下来的执行地址(字地址)存放在 Z
寄存器中。
例如:
IJMP ; PC <- Z
相对寻址
在相对寻址方式下,程序接下来的执行地址(字地址)为 PC
+ k
+ 1, k
的范围为-2048~2047。
例如:
RJMP FUNC ; PC <- FUNC 汇编器会自动计算k的值
...
FUNC: ; FUNC与RJMP指令的距离不能超过-2048~2047
...
参考资料
AVR汇编(三):寻址方式的更多相关文章
- AVR之BOOTLOADER技术详解(转)
源:http://blog.csdn.net/zhenhua10/article/details/6442412 ATmega128具备引导加载支持的用户程序自编程功能(In-System Progr ...
- 一步一步pwn路由器之radare2使用全解
前言 本文由 本人 首发于 先知安全技术社区: https://xianzhi.aliyun.com/forum/user/5274 radare2 最近越来越流行,已经进入 github 前 25了 ...
- 成都国嵌-嵌入式linux必修实验手册…
emouse收集整理,转载请注明: emouse的技术专栏 博客园:http://www.cnblogs.com/emouse/ CSDN:http://blog.csdn.net/haozi_198 ...
- C/C++中的预编译指令
工作中遇到的: 一个头文件中的: #pragma warning(disable:4996)#pragma warning(disable:4244)#pragma warning(disable:4 ...
- C/C++中的预编译指令(转)
reference:https://blog.csdn.net/sunshinewave/article/details/51020421 程序的编译过程可以分为预处理.编译.汇编三部分,其中预处理是 ...
- Samsung_tiny4412(驱动笔记02)----ASM with C,MMU,Exception,GIC
/**************************************************************************** * * ASM with C,MMU,Exc ...
- 【Linux】进程的结构,创建,结束,以及程序转化为的进程的过程
本文内容: 1.进程的结构 2.程序转化为进程的过程 3.进程的创建 4.进程的结束 背景知识: 1.进程是计算机中处于运行的程序的实体 2.进程是线程的容器 3.程序本身只是指令,数据以及组织形式的 ...
- Markdown 常用语言关键字
Markdown 语法高亮支持的语言还是比较多的,记下来备用. 语言名 关键字 Bash bash CoffeeScript coffeescript C++ cpp C# cs CSS css Di ...
- ENGG1340 Computer Programming II
课程内容笔记,自用,不涉及任何 assignment,exam 答案 Notes for self use, not included any assignments or exams Module ...
- AI降临,前端启用面壁计划
作者:京东零售 郑炳懿 开篇: "在我们有生之年,你觉得会看到AI兵临城下的那一天吗?就像电影黑客帝国里面演的一样",Barry从红色的烟盒里取出一根烟发问道. "不可能 ...
随机推荐
- 2022-10-15:给你一个整数数组 nums 和一个整数 k ,请你返回其中出现频率前 k 高的元素。 你可以按 任意顺序 返回答案。 要求时间复杂度O(N)。 输入: nums = [1,1,1
2022-10-15:给你一个整数数组 nums 和一个整数 k ,请你返回其中出现频率前 k 高的元素. 你可以按 任意顺序 返回答案. 要求时间复杂度O(N). 输入: nums = [1,1,1 ...
- 2022-04-28:有 n 个城市通过一些航班连接。给你一个数组 flights ,其中 flights[i] = [fromi, toi, pricei] ,表示该航班都从城市 fromi 开始,
2022-04-28:有 n 个城市通过一些航班连接.给你一个数组 flights ,其中 flights[i] = [fromi, toi, pricei] ,表示该航班都从城市 fromi 开始, ...
- 2022-04-17:给定一个数组arr,其中的值有可能正、负、0, 给定一个正数k。 返回累加和>=k的所有子数组中,最短的子数组长度。 来自字节跳动。力扣862。
2022-04-17:给定一个数组arr,其中的值有可能正.负.0, 给定一个正数k. 返回累加和>=k的所有子数组中,最短的子数组长度. 来自字节跳动.力扣862. 答案2022-04-17: ...
- 2021-11-15:四数相加 II。给你四个整数数组 nums1、nums2、nums3 和 nums4 ,数组长度都是 n ,请你计算有多少个元组 (i, j, k, l) 能满足:0 <= i,
2021-11-15:四数相加 II.给你四个整数数组 nums1.nums2.nums3 和 nums4 ,数组长度都是 n ,请你计算有多少个元组 (i, j, k, l) 能满足:0 <= ...
- React Native项目设置路径别名
没有设置路径别名之前代码是这样的: import { px2dp } from '../../utils/screenKits'; 路径相当冗长,看着就头疼.增加了路径别名之后,变成这样 import ...
- SpringIOC和SpringAOP
作为一个Spring使用者条件: 拥有深入的Spring框架知识和开发经验,能够熟练地运用Spring框架来构建复杂的应用程序. 了解Spring框架的核心概念和设计思想,如控制反转(IoC).依赖注 ...
- “古老”编程语言的最新选择!华为云发布CodeArts IDE for C/C++
摘要:华为云CodeArts IDE for C/C++正式上线,欢迎体验. 本文分享自华为云社区<"古老"编程语言的最新选择!华为云发布CodeArts IDE for C ...
- 尚医通-day12【token续期和就诊人管理】(内附源码)
页面预览 就诊人管理 就诊人列表 添加就诊人 查看就诊人 ![image-20230225060710 管理员系统用户管理 前面我们完成了用户登录.用户认证与就诊人管理,现在我们需要把这些信息在我们的 ...
- StencilJs 学习之 JSX
Stencil 组件使用 JSX 渲染,这是一种流行的声明式模板语法.每个组件都有一个渲染函数,它返回在运行时渲染到 DOM 的组件树. 基础用法 render 函数用于输出将绘制到屏幕上的组件树. ...
- Javaweb文件上传至服务器/从服务器下载
Javaweb文件上传至服务器/从服务器下载 思路图 文件上传思路: 也可以直接看代码 判断是不是文件表单(判断form的enctype是不是="multipart/form-data&qu ...