首页 > 编程语言 >AVR汇编(五):算术和逻辑指令

AVR汇编(五):算术和逻辑指令

时间:2023-08-13 17:34:25浏览次数:46  
标签:R16 汇编 R17 算术 LDI 符号 AVR 指令 result

AVR汇编(五):算术和逻辑指令

算术运算指令

AVR中对于算术运算提供了加法、减法和乘法指令,没有除法指令。

ADD

image.png

ADD 指令用于执行加法操作,相关的变体指令有:一般加法 ADD 、带进位加法 ADC 、16位立即数加法 ADIW

例如:

LDI R16, 0x01    ; R16 = 0x01
LDI R17, 0x02    ; R17 = 0x02
ADD R16, R17     ; R16 = 0x03

SEC              ; C = 1
ADC R16, R17     ; R16 = 0x06, C = 0

LDI R25, 0x0F    ; R25 = 0x0F
LDI R24, 0xF0    ; R24 = 0xF0
ADIW R24, 0x10   ; R25:R24 = 0x1000

注意:AVR不支持8位数的立即数加法,即没有 ADDI / ADCI 这样的指令!

SUB

image.png

SUB 指令用于执行减法操作,相关的变体指令有:一般减法 SUB 、立即数减法 SUBI 、带进位的减法 SUBC 、带进位的立即数减法 SBCI 、16位立即数减法 SBIW

例如:

LDI R16, 0x81     ; R16 = 0x81
LDI R17, 0x80     ; R17 = 0x80
SUB R16, R17      ; R16 = 0x01

SUBI R17, 0x10    ; R17 = 0x70

SEC               ; C = 1
LDI R16, 0x80     ; R16 = 0x80
SBC R16, R17      ; R16 = 0x0F, C = 0

SEC               ; C = 1
SBCI R16, 0x02    ; R16 = 0x0C, C = 0

LDI R25, 0x02     ; R25 = 0x02
LDI R24, 0x03     ; R24 = 0x03
SBIW R24, 0x04    ; R25:R24 = 0x01FF

INC / DEC

image.png

INC 指令用于执行加一操作, DEC 指令用于执行减一操作。需要注意的是,这两条指令都不会影响标志位 C

例如:

LDI R16, 0x7F    ; R16 = 0x7F
INC R16          ; R16 = 0x80
DEC R16          ; R16 = 0x7F

MUL

image.png

MUL 指令用于执行乘法操作,计算结果存放在 R0R1 寄存器中。默认执行的是无符号数乘法,后缀带 S 表示执行的是符号数乘法,后缀带 SU 表示执行的是符号数与无符号数乘法,前缀带 F 表示执行分数乘法。

例如:

LDI R16, 0xFE      ; R16 = 0xFE (-2/254)
LDI R17, 0x03      ; R17 = 0x03 (3)
MUL R16, R17       ; R1:R0 = 0x02FA (762)
MULS R16, R17      ; R1:R0 = 0xFFFA (-6)
MULSU R16, R17     ; R1:R0 = 0xFFFA (-6)
FMUL R16, R17      ; R1:R0 = 0x05F4 (1524)
FMULS R16, R17     ; R1:R0 = 0xFFF4 (-12)
FMULSU R16, R17    ; R1:R0 = 0xFFF4 (-12)

逻辑运算指令

AND / OR / EOR

image.png

AND 用于执行“与”操作, OR 用于执行“或”操作, EOR 用于执行“异或”操作,后缀带 I 表示操作数是立即数。

例如:

LDI R16, 0xAA     ; R16 = 0xAA
LDI R17, 0x0F     ; R17 = 0x0F
AND R16, R17      ; R16 = 0x0A

ANDI R16, 0x03    ; R16 = 0x02

OR R16, R17       ; R16 = 0x0F
ORI R16, 0xAA     ; R16 = 0xAF

EOR R16, R17      ; R16 = 0xA0

注意:AVR中“异或”操作不支持立即数,即没有 EORI 这样的指令!

COM / NEG

image.png

COM 指令用于计算反码(对原码取反), NEG 指令用于计算补码(对原码取反加一)。

例如:

LDI R16, 0xA5    ; R16 = 0xA5
COM R16          ; R16 = 0x5A
NEG R16          ; R16 = 0xA6

SBR / CBR

image.png

SER 指令用于根据掩码 K 设置寄存器中的某些位,与 ORI 指令作用相同。 CBR 指令用于根据掩码 K 清除寄存器中的某些位,即执行“与非”操作。

LDI R16, 0x0F    ; R16 = 0x0F
SBR R16, 0x55    ; R16 = 0x5F
CBR R16, 0x55    ; R16 = 0x0A

TST / CLR / SER

image.png

TST 指令用于测试寄存器的值是否是零或者负数, CLR 指令将寄存器值设为0, SER 指令将寄存器值设为0xFF。

例如:

LDI R16, 0xAA    ; R16 = 0xAA
TST R16          ; S = 1, V = 0, N = 1, Z = 0
CLR R16          ; R16 = 0, S = 0, V = 0, N = 0, Z = 1
SER R16          ; R16 = 0xFF

状态标志位

和上一篇介绍的数据传送指令不同,算术和逻辑指令会改变 SREG 寄存器中的标志位,下面介绍其中最常用的4个: ZNVC

Z 标志位

Z 标志位指示计算结果是否为0,当结果为0时置位。

例如:

LDI R16, 5     ;             Z = ?
SUBI R16, 2    ; result = 3, Z = 0
SUBI R16, 3    ; result = 2, Z = 1

N 标志位

N 标志位指示计算结果是否为负数,当结果小于0时置位。

例如:

LDI R16, 1      ;              N = ?, Z = ?
LDI R17, 2      ;              N = ?, Z = ?
ADD R16, R17    ; result = 3,  N = 0, Z = 0
SUBI R16, 3     ; result = 0,  N = 0, Z = 1
SUBI R16, 1     ; result = -1, N = 1, Z = 0

C / V 标志位

C 标志位指示计算结果是否超过无符号数范围,当结果超过[0, 255]时置位。

V 标志位指示计算结果是否超过符号数范围,当结果超过[-128, 127]时置位。

比如,对于0x7F+0x01=0x80,从无符号数角度看,就是127+1=128,没有超过无符号数范围,故 C 为0。从符号数角度看,127+1=128(-128),超过了符号数范围,故 V 为1。

再比如,对于0xFE+0x02=0x00,从无符号数角度看,为254+2=256(0),超过了无符号数范围,故 C 为1。从符号数角度看,-2+2=0,没有超过符号数范围,故 V 为0。

更多例子:

LDI R17, 4      ;                           N = ?, Z = ?, V = ?, C = ?
LDI R18, 2      ;                           N = ?, Z = ?, V = ?, C = ?
LDI R19, 1      ;                           N = ?, Z = ?, V = ?, C = ?
LDI R16, 250    ;                           N = ?, Z = ?, V = ?, C = ?
ADD R16, R17    ; result = 0xFE/-2/254,     N = 1, Z = 0, V = 0, C = 0
ADD R16, R18    ; result = 0x00/0/256(0),   N = 0, Z = 1, V = 0, C = 1
ADD R16, R19    ; result = 0x01/1/1,        N = 0, Z = 0, V = 0, C = 0
SUBI R16, 2     ; result = 0xFF/-1/-1(255), N = 1, Z = 0, V = 0, C = 1

参考资料

  1. ATmega328P Datasheet
  2. AVR Instruction Set Manual
  3. Programming and Interfacing ATMEL's AVRs

标签:R16,汇编,R17,算术,LDI,符号,AVR,指令,result
From: https://www.cnblogs.com/chinjinyu/p/17626856.html

相关文章

  • 汇编-错误代码
      errorA2005:Symbolismultidefined:DATA此错误信息提示DATA符号重复定义了。 errorA2009:Symbolnotdefined:NO汇编提示标号NO没有定义        ......
  • AVR汇编(四):数据传送指令
    AVR汇编(四):数据传送指令AVR指令主要分为五类:算术和逻辑指令、分支指令、位操作指令、数据传送指令、MCU控制指令,今天我们先来认识其中最常用的数据传送指令。汇编程序的编写、编译和调试学习任何技术都离不开实践,汇编语言也是如此。在正式学习指令前,我们先来体验一下汇编程序从......
  • AVR汇编(二):AVR架构介绍
    AVR汇编(二):AVR架构介绍ATmega328P介绍ATmega328P是Atmel公司(现Microchip公司)推出的一个基于AVR架构的高性能低功耗单片机,拥有32KB的Flash、1KB的EEPROM以及2KB的SRAM等资源,具体如下表:资源主要特征Flash32KB频率16MHzEEPROM1024B定时器2个8bit,1个16bitP......
  • AVR汇编(一):搭建交叉编译环境
    AVR汇编(一):搭建交叉编译环境几年间,陆陆续续接触了很多热门的单片机,如STC、STM8S、STM32、ESP32等。但一直都是抱着急功近利的心态去学习他们,基本上都是基于库函数和第三方组件进行开发,很少静下心来去研究这些不同内核单片机的底层工作原理。因此我打算接下来一段时间好好研究一番,......
  • 汇编-xor异或
     XOR指令在两个操作数的对应位之间进行(按位)逻辑异或(XOR)操作如果两个位值相同(同为0或同为1),则结果位等于0;否则结果位等于1【相同为0,不同为1】      ......
  • 汇编语言开发环境搭建
    汇编语言开发环境搭建简述学习汇编的意义:汇编语言有着简单的语法,它更加贴近硬件,而不像高级语言有着自己的语言抽象层关于主引导扇区主引导扇区:处理器上电或复位后,如果系统由硬盘启动,那么ROM-BIOS将试图读取硬盘0面0道1扇区,这块就是主引导扇区(MainBootSector)缩写:M......
  • 正点原子ARM裸机开发003----汇编LED驱动实验1-原理分析
    一、汇编LED原理分析为什么要学习Coretex-A汇编?需要用汇编初始化一些SOC外设使用汇编初始化DDR,IMX6U不需要设置sp指针,一般指向DDR,设置好C语言运行环境ALPHA开发板LED灯硬件原理分析:STM32 IO初始化流程:使能GPIO时钟设置IO复用,将其复用为GPIO配置GPIO的电气属性使用G......
  • 【汇编随笔】在汇编中使用数据
    在内存中怎么存储数据需要将数据放在连续的内存单元中。DWdw0123h,0456hdw是定义字型数据,这里定义了2个字型数据,4个字节。如何寻得数据地址assumecs:codecodesegmentdw0123h,0456h...codeendsend因为数据定义在代码段中,代码段的所有数据都存放在CS中,定义......
  • 恶意c2家族反汇编
     协议当日家族TOP5及数量HTTPtrojan:win32/emotetcrypt:2162trojan:win32/emotet:453trojan:win32/wacatac:342trojan:win32/smokeloader:181trojan:win32/woreflint:164HTTPStrojan:win32/smokeloader:744virtool:win32/ceeinject:118trojan:win32/wacatac:6......
  • idea查看java代码汇编指令
    将下列jar包放入到jre的bin目录下面   hsdis-amd64.dll指定java的jvm参数-server-Xcomp-XX:+UnlockDiagnosticVMOptions-XX:+PrintAssembly-XX:CompileCommand=compileonly,*VolitaleDemo.main运行......