R单片机指令系统
- 格式:docx
- 大小:38.36 KB
- 文档页数:11
汇编语言的所有指令数据传送指令集MOV功能: 把源操作数送给目的操作数语法: MOV 目的操作数,源操作数格式: MOV r1,r2MOV r,mMOV m,rMOV r,dataXCHG功能: 交换两个操作数的数据语法: XCHG格式: XCHG r1,r2 XCHG m,r XCHG r,mPUSH,POP功能: 把操作数压入或取出堆栈语法: PUSH 操作数POP 操作数格式: PUSH r PUSH M PUSH data POP r POP mPUSHF,POPF,PUSHA,POPA功能: 堆栈指令群格式: PUSHF POPF PUSHA POPALEA,LDS,LES功能: 取地址至寄存器语法: LEA r,m LDS r,m LES r,mXLAT(XLATB)功能: 查表指令语法: XLAT XLAT m算数运算指令ADD,ADC功能: 加法指令语法: ADD OP1,OP2 ADC OP1,OP2格式: ADD r1,r2 ADD r,m ADD m,r ADD r,data影响标志: C,P,A,Z,S,OSUB,SBB功能:减法指令语法: SUB OP1,OP2 SBB OP1,OP2格式: SUB r1,r2 SUB r,m SUB m,r SUB r,data SUB m,data影响标志: C,P,A,Z,S,OINC,DEC功能: 把OP的值加一或减一语法: INC OP DEC OP格式: INC r/m DEC r/m影响标志: P,A,Z,S,ONEG功能: 将OP的符号反相(取二进制补码)语法: NEG OP格式: NEG r/m影响标志: C,P,A,Z,S,OMUL,IMUL功能: 乘法指令语法: MUL OP IMUL OP格式: MUL r/m IMUL r/m影响标志: C,P,A,Z,S,O(仅IMUL会影响S标志)DIV,IDIV功能:除法指令语法: DIV OP IDIV OP格式: DIV r/m IDIV r/mCBW,CWD功能: 有符号数扩展指令语法: CBW CWDAAA,AAS,AAM,AAD功能: 非压BCD码运算调整指令语法: AAA AAS AAM AAD影响标志: A,C(AAA,AAS) S,Z,P(AAM,AAD)DAA,DAS功能: 压缩BCD码调整指令语法: DAA DAS影响标志: C,P,A,Z,S位运算指令集AND,OR,XOR,NOT,TEST功能: 执行BIT与BIT之间的逻辑运算语法: AND r/m,r/m/data OR r/m,r/m/data XOR r/m,r/m/data TEST r/m,r/m/data NOT r/m 影响标志: C,O,P,Z,S(其中C与O两个标志会被设为0) NOT指令不影响任何标志位SHR,SHL,SAR,SAL功能: 移位指令语法: SHR r/m,data/CL SHL r/m,data/CL SAR r/m,data/CL SAL r/m,data/CL影响标志: C,P,Z,S,OROR,ROL,RCR,RCL功能: 循环移位指令语法: ROR r/m,data/CL ROL r/m,data/CL RCR r/m,data/CL RCL r/m,data/CL 影响标志: C,P,Z,S,O程序流程控制指令集CLC,STC,CMC功能: 设定进位标志语法: CLC STC CMC标志位: CCLD,STD功能: 设定方向标志语法: CLD STD标志位: DCLI,STI功能: 设定中断标志语法: CLI STI标志位: ICMP功能: 比较OP1与OP2的值语法: CMP r/m,r/m/data标志位: C,P,A,Z,OJMP功能: 跳往指定地址执行语法: JMP 地址JXX功能: 当特定条件成立则跳往指定地址执行语法: JXX 地址注:A: ABOVE,当C=0,Z=0时成立B: BELOW,当C=1时成立C: CARRY,当弁时成立CXZ: CX寄存器的值为0(ZERO)时成立E: EQUAL,当Z=1时成立G: GREATER(大于),当Z=0且S=0时成立L: LESS(小于),当S不为零时成立N: NOT(相反条件),需和其它符号配合使用O: OVERFLOW,O=1时成立P: PARITY,P=1时成立PE: PARITY EVEN,P=1时成立PO: PARITY ODD,P=0时成立S: SIGN,S=1时成立Z: ZERO,Z=1时成立LOOP功能: 循环指令集语法: LOOP 地址LOOPE(Z)地址LOOPNE(Z) 地址标志位: 无CALL,RET功能: 子程序调用,返回指令语法: CALL 地址RET RET n标志位: 无INT,IRET功能: 中断调用及返回指令语法: INT n IRET标志位: 在执行INT时,CPU会自动将标志寄存器的值入栈,在执行IRET时则会将堆栈中的标志值弹回寄存器字符串操作指令集MOVSB,MOVSW,MOVSD功能: 字符串传送指令语法: MOVSB MOVSW MOVSD标志位: 无CMPSB,CMPSW,CMPSD功能: 字符串比较指令语法: CMPSB CMPSW CMPSD标志位: C,P,Z,S,OSCASB,SCASW功能: 字符串搜索指令语法: SCASB SCASW标志位: C,P,Z,S,OLODSB,LODSW,STOSB,STOSW功能: 字符串载入或存贮指令语法: LODSB LODSW STOSB STOSW标志位: 无REP,REPE,REPNE功能: 重复前缀指令集语法: REP 指令S REPE 指令S REPNE 指令S标志位: 依指令S而定对于IBM PC机它有它的指令系统,其中包括:数据传送指令、串处理指令、算术指令、控制移动指令、逻辑指令、处理机控制指令。
第五章A V R单片机指令系统计算机的指令系统是一套控制计算机操作的代码,称之为机器语言。
计算机只能识别和执行机器语言的指令。
为了便于人们理解、记忆和使用,通常用汇编语言指令来描述计算机的指令系统。
汇编语言指令可通过汇编器翻译成计算机能识别的机器语言。
AVR单片机指令系统是RISC结构的精简指令集,是一种简明易掌握﹑效率高的指令系统。
SL-DIY02-3开发实验器使用AT90S8535单片机,有118条指令,而我们所做的11个实验程序仅用了34条指令,我们重点讲这34条指令,其余指令就可自学了。
AVR器件(指令速查表)118条指令器件1.不带进位加法ADD一不带进位加说明:两个寄存器不带进位C标志加,结果送目的寄存器Rd。
操作:Rd✍Rd+Rr语法:操作码:程序计数器:ADDRd,RrO≤d≤31,0≤r≤31PC✍PC+1例子:。
(实践操作程序4411.ASM)实践操作例子*.ASM,必须编译生成*.OBJ文件才可调试,如要修改*.ASM,必须修改文件属性,去掉*.ASM只读文件属性2.带进位加法ADC-一带进位加说明:两个寄存器和C标志的内容相加,结果送目的寄存器Rd。
操作:Rd←Rd+Rr+C语法:操作码:程序计数器:ADCRd,Rr0≤d≤31,0≤r≤31PC←PC+1例子:(实践操作程序4412.ASM)3.减1指令DEC一减1说明:寄存器Rd的内容减1,结果送目的寄存器Rd中。
操作:Rd✍Rd-l语法:操作码:程序计数器:DECRd0≤d≤31PC✍PC十1例子:(实践操作程序4426.ASM)4.立即数比较CPI——带立即数比较说明:该指令完成寄存器Rd和常数的比较操作。
寄存器的内容不改变。
该指令后能使用所有条件转移指令。
操作:Rd-K语法:操作码:程序计数器:CPIRd,K16≤d≤31,0≤K≤255PC✍PC+1例子:(实践操作程序4463.ASM)5.带立即数与ANDI——立即数逻辑与;全1为1,有0即0说明:寄存器Rd的内容与常数逻辑与,结果送目的寄存器Rd。
单片机的指令系统习题一、选择题1、执行下列3条指令后,30H单元的内容是()。
MOV R0,#30HMOV 40H,#0EHMOV @R0,40HA)40H B)30H C)0EH D)FFH2、在堆栈中压入一个数据时()。
A)先压栈,再令SP+1 B)先令SP+1,再压栈C)先压栈,再令SP-l D)先令SP-1,再压栈3、在堆栈操作中,当进栈数据全部弹出后,这时的SP应指向()。
A)栈底单元 B)7FHC)栈底单元地址加1 D)栈底单元地址减l4、指令MOVC A,@A+PC源操作数的寻址方式是()。
A)寄存器寻址方式 B)寄存器间接寻址方式C)直接寻址方式 D)变址寻址方式5、ANL 20H,#30H指令中,源操作数的寻址方式是()。
A)立即寻址方式 B)直接寻址方式C)位寻址方式 D)相对寻址方式6、ANL C,/30H指令中,源操作数的寻址方式是()。
A)立即寻址方式 B)直接寻址方式C)位寻址方式 D)相对寻址方式7、Jz rel指令中,操作数rel的寻址方式是()。
A)立即寻址方式 B)直接寻址方式C)位寻址方式 D)相对寻址方式8、Jz rel指令中,是判断()中的内容是否为0。
A) B)B C)C D)PC9、MOVX A,@DPTR指令中源操作数的寻址方式是()A)寄存器寻址(B)寄存器间接寻址(C)直接寻址(D)立即寻址10、下面条指令将MCS-51的工作寄存器置成3区()A)MOV PSW,#13H (B)MOV PSW,#18H11、MOV C,00H指令中源操作数的寻址方式是()A)位寻址 B)直接寻址 C)立即寻址 D)寄存器寻址二、填空题1、8051单片机共有种寻址方式。
访问外部数据存储器应采用寻址方式。
2、访问外部数据存储器应采用寻址方式;查表应使用寻址方式。
3、在8051单片机中,堆栈操作的指令有两个。
4、在8051单片机中,子程序调用的指令有两个。
5、CJNE指令都是字节指令。
第3章MCS-51单片机指令系统3.1概述3.1.1指令格式3.1.2指令的三种表示形式3.1.3指令的字节数1. 单字节指令(49条)图3-1 MOVA,Rn指令的格式2单片机原理及其接口技术(第2版)2. 双字节指令(46条)3. 三字节指令(16条)3.1.4指令的分类1. 数据传送指令(28条)2. 算术运算指令(24条)3. 逻辑操作和环移指令(25条)4. 控制转移指令(17条)5. 位操作指令(17条)3.1.5指令系统综述1. 指令系统中所用符号的说明2. 指令对标志位的影响3.2寻址方式3.2.1寄存器寻址图3-2寄存器寻址示意图单片机原理及其接口技术(第2版) 3 3.2.2直接寻址图3-3直接寻址示意图3.2.3立即寻址3.2.4寄存器间址图3-4寄存器间址寻址示意图3.2.5变址寻址图3-5变址寻址示意图4单片机原理及其接口技术(第2版)3.2.6相对寻址图3-6相对寻址示意图3.2.7位寻址3.3数据传送指令3.3.1内部数据传送指令(15条)1. 立即寻址型传送指令2. 直接寻址型传送指令3. 寄存器寻址型传送指令4. 寄存器间址型传送指令5. 内部数据传送指令的使用图3-7 8×C552/8051指令的数据传送方式单片机原理及其接口技术(第2版) 5 3.3.2外部数据传送指令(7条)1. 16位数传送指令2. 外部ROM的字节传送指令图3-8 0~9平方值表3. 外部RAM的字节传送指令3.3.3堆栈操作指令(2条)图3-9例3.8的堆栈变化示意图6单片机原理及其接口技术(第2版)3.3.4数据交换指令(4条)3.4算术与逻辑运算和移位指令3.4.1算术运算指令(24条)1. 加法指令2. 减法指令3. 十进制调整指令4. 乘法和除法指令3.4.2逻辑运算指令(20条)1. 逻辑与运算指令2. 逻辑或指令3. 逻辑异或指令4. 累加器清零和取反指令3.4.3移位指令(5条)单片机原理及其接口技术(第2版)7图3-10例3.26附图3.5控制转移和位操作指令3.5.1控制转移指令(17条)1. 无条件转移指令图3-11 AJMP指令转移范围8单片机原理及其接口技术(第2版)图3-12例3.29附图图3-13带符号数的比较方法3. 子程序调用和返回指令图3-14二级子程序嵌套及断点地址存放单片机原理及其接口技术(第2版)9图3-15例3.33附图10单片机原理及其接口技术(第2版)4. 空操作指令3.5.2位操作指令(17条)1. 位传送指令2. 位置位和位清零指令3. 位运算指令4. 位控制转移指令习题与思考题3.1指令通常有哪三种表示形式?各有什么特点?3. 2 MCS-51指令按功能可以分为哪几类?每类指令的作用是什么?3. 3 MCS-51共有哪七种寻址方式?各有什么特点?3. 4指出下列每条指令源操作数的寻址方式和功能。
单片机指令的位操作和逻辑运算单片机是在嵌入式系统中广泛应用的一种微处理器,它具有尺寸小、功耗低、集成度高等特点,常用于控制和管理各种电子设备。
在单片机的编程中,位操作和逻辑运算是非常重要的概念和技巧。
一、位操作位操作是指对单片机中的位进行操作,包括位的读取、置位、清零、取反等操作。
单片机中的数据通常以位的形式存储,对位的操作可以很方便地实现对数据的控制和处理。
1. 位的读取在单片机中,可以通过使用逻辑与运算符来读取某一位的值。
逻辑与运算符可以用来判断某一位是否为1或者0,从而进行相应的逻辑处理。
例如,在使用单片机控制LED灯时,可以通过读取一个特定位的值来确定LED灯的状态,进而进行灯的亮灭的控制。
2. 位的置位位的置位意味着将某一位设置为1。
在单片机编程中,可以使用逻辑或运算符和位运算符来实现位的置位操作。
通过位的置位操作,可以实现对某一位的控制。
例如,在使用单片机控制电机时,可以通过位置位操作来控制电机的启动。
3. 位的清零位的清零意味着将某一位设置为0。
与位的置位类似,位的清零操作同样可以使用逻辑与运算符和位运算符来实现。
通过位的清零操作,可以实现对某一位的复位。
例如,在单片机控制温度传感器时,可以通过清零操作来复位传感器的状态。
4. 位的取反位的取反意味着将某一位的值从1变为0,或者从0变为1。
在单片机中,可以使用位运算符来实现位的取反操作。
通过位的取反操作,可以实现对某一位状态的改变。
例如,在单片机输入输出控制中,可以通过取反操作来改变IO口的输出状态。
二、逻辑运算逻辑运算是指对单片机中的位进行逻辑判断和运算,包括逻辑与、逻辑或、逻辑非等操作。
逻辑运算可以对多位数据进行综合处理,从而实现各种逻辑功能。
1. 逻辑与运算逻辑与运算是指对两个数据进行逻辑与操作,结果为1的条件是两个数据都为1,否则结果为0。
在单片机编程中,可以使用逻辑与运算符来实现逻辑与运算。
逻辑与运算在逻辑判断和逻辑运算中广泛应用,常用于状态判断和位操作等方面。
一个单片机所需执行指令的集合即为单片机的指令系统。
单片机使用的机器语言、汇编语言及高级语言,但不管使用是何种语言,最终还是要“翻译”成为机器码,单片机才能执行之。
现在有很多半导体厂商都推出了自己的单片机,单片机种类繁多,品种数不胜数,值得注意的是不同的单片机它们的指令系统不一定相同,或不完全相同。
但不管是使用机器语言、汇编语言还是高级语言都是使用指令编写程序的。
所谓机器语言即指令的二进制编码,而汇编语言则是指令的表示符号。
在指令的表达式上也不会直接使用二进制机器码,最常用的是十六进制的形式。
但单片机并不能直接执行汇编语言和高级语言,都必须通过汇编器“翻译”成为二进制机器码方能执行,但如果直接使用二进制来编写程序,那将十分不便,也很难记忆和识别,不易编写、难于辨读,极易出错,同时出错了也相当难查找。
所以现在基本上都不会直接使用机器语言来编写单片机的程序。
最好的办法就是使用易于阅读和辨认的指令符号来代替机器码,我们常称这些符号为助记符,用助记符的形式表示的单片机指令就是汇编语言,为便于记忆和阅读,助记符号通常都使用易于理解的英文单词和拼音字母来表示。
每种单片机都有自己独特的指令系统,那么指令系统是开发和生产厂商定义的,如要使用其单片机,用户就必须理解和遵循这些指令标准,要掌握某种(类)单片机,指令系统的学习是必须的。
MCS-51共有111条指令,可分为5类:[1].数据传送类指令(共29条)[2].算数运算类指令(共24条)[3].逻辑运算及移位类指令(共24条)[4].控制转移类指令(共17条)[5].布尔变量操作类指令(共17条)一些特殊符号的意义在介绍指令系统前,我们先了解一些特殊符号的意义,这对今后程序的编写都是相当有用的。
Rn——当前选中的寄存器区的8个工作寄存器R0—R7(n=0-7)。
Ri——当前选中的寄存器区中可作为地址寄存器的两个寄存器R0和R1(i=0,1)direct—内部数据存储单元的8位地址。
arm系列contex的a,r,m的区别
从cortex开始,分为三个系列,a系列,r系列,m系列。
m系列与arm7相似,不能跑操作系统(只能跑ucos2),偏向于控制⽅⾯,说⽩了就是⼀个⾼级的单⽚机。
a系列主要应⽤在⼈机互动要求较⾼的场合,⽐如pda,⼿机,平板电脑等。
a系列类似于cpu,与arm9和arm11相对应,都是可以跑草错系统的。
linux等。
r系列,是实时控制。
主要应⽤在对实时性要求⾼的场合。
arm7和m3,m4是同⼀类型。
这三个⾥⾯,arm7是最早的arm产品。
m3是cortex m系列的过渡品,其低端市场被cortex m0的⾼端替代,其⾼端市场⼜被cortex m4的低端取代。
现在m系列,是m4内核的。
典型的芯⽚是st公司和飞思卡尔公司的。
arm9 和cortex a8 是⼀个类型的,都是跑操作系统的,现在的⾼端⼿机,三星,htc等智能⼿机,就是⽤的cortex a8,cortex a9 内核的芯⽚作为cpu。
(1)ARM7,ARM9属于v4T或v5E架构
(2)ARM11属于v6架构
(3)Contex属于v7架构
ARM7,ARM9的区别在于是否有MMU(存储器管理单元)或MPU(存储器保护单元)
架构上v5E相⽐v4T则是在于v5E新加⼊的增强型DSP(数字信号处理)指令,v4T则是Thumb指令集的加⼊,v6架构则是开始⽀持SIMD以及Thumb2的问世.。
单片机指令集和操作系统的关系
1> 首先讨论各种单片机与操作系统的关系
说到单片机,大家第一时间想到的应该是51单片机,对吧。
不错,更高级一点的AVR,把他称为单片机,我们也还觉得可以接受。
那幺再高级一点的ARM7,8086,80386,Core i3,Athlon 等等我们更习惯称他们为CPU,因为学习计算机原理的时候都是这幺叫的,但按照单片机的定义,他们也是归属于单片机。
这也不怪大家,中国的教育都是这样,只注重告诉你是什幺,而不告诉你他们之间的联系。
上述几种单片机或者芯片(如果你还是觉得把core i3叫做单片机你不习惯的话)在原理上都是一样,即都是有运算器控制器寄存器构成的,不同之处在于它们的硬件电路实现不同,个数不同,功耗不同,计算能力不同,但都提供相同的基本功。
OK,终于让cpu找到了组织,那幺就介绍为什幺有的单片机要操作系统,有的在我们学习的过程中压根就跟操作系统不挨边。
51/AVR单片机在学习他们的时候,都是先介绍它们有哪些资源有几个寄存器,有几个时钟等,然后就是怎幺用汇编,用C或者是C与汇编混合编程。
这里我们用的语言都是可以直接操作硬件资源的,因此我们可以自己决定什幺时候使用哪个寄存器,什幺时候将寄存器内容写到辅存储器中。
ARM单片机在学习它的时候,我们可以给他搭载操作系统,如MicroC/OS,iOS X, Android或者其他定制的Linux操作系统,但有时我们也经常不让它搭载操作系统,而是直接像使用51单片机那样来操作它。
单片机指令系统及其执行过程的详解单片机是现代电子设备中不可或缺的组成部分,其指令系统和执行过程对于单片机的工作和性能起着至关重要的作用。
本文将详细介绍单片机指令系统的组成和执行过程,并探讨其在实际应用中的意义。
一、单片机指令系统的组成单片机的指令系统由指令集、寄存器和地址计算单元组成。
1. 指令集指令集是单片机能够执行的所有指令的集合。
它包含了各种不同类型的指令,如算术指令、逻辑指令、数据传输指令等。
不同的单片机具有不同的指令集,但通常都包括基本的算术和逻辑运算指令,以及控制流指令(如条件分支和循环)。
2. 寄存器寄存器是单片机内部用于存储数据和执行运算的存储器组件。
常见的寄存器包括通用寄存器、标志寄存器、程序计数器等。
通用寄存器用于存储临时数据,标志寄存器用于存储运算结果的状态信息,程序计数器用于存储当前正在执行的指令地址。
3. 地址计算单元地址计算单元用于计算指令中的操作数的地址。
它根据指令中的寻址方式和地址模式,将指令中的操作数地址计算出来,并将其传递给存储器或寄存器。
二、单片机指令执行过程单片机的指令执行过程包括指令取指、指令译码和指令执行三个阶段。
1. 指令取指在指令取指阶段,程序计数器(PC)从存储器中读取下一条指令的地址,并将其存储在指令寄存器(IR)中。
同时,PC的值自动递增,准备读取下一条指令。
2. 指令译码在指令译码阶段,单片机将指令寄存器中的指令译码为对应的操作。
根据指令的类型和操作码,单片机确定需要执行的具体操作,如运算、数据传输或控制流操作。
3. 指令执行在指令执行阶段,单片机根据译码结果执行具体的操作。
这包括算术和逻辑运算、数据传输等。
执行结果可以存储在寄存器中,也可以写入存储器。
同时,单片机还会根据程序的控制流进行条件分支或循环。
三、单片机指令系统的应用意义单片机指令系统的优化对于提高单片机的执行效率和性能至关重要。
通过合理设计指令集,可以充分发挥单片机的计算和控制能力,提高其运算速度和响应能力。
第五章AVR单片机指令系统计算机的指令系统是一套控制计算机操作的代码,称之为机器语言。
计算机只能识别和执行机器语言的指令。
为了便于人们理解、记忆和使用,通常用汇编语言指令来描述计算机的指令系统。
汇编语言指令可通过汇编器翻译成计算机能识别的机器语言。
AVR单片机指令系统是RISC结构的精简指令集,是一种简明易掌握﹑效率高的指令系统。
SL-DIY02-3开发实验器使用AT90S8535单片机,有118条指令, 而我们所做的11个实验程序仅用了34条指令, 我们重点讲这34条指令, 其余指令就可自学了。
AVR器件(指令速查表) 118条指令器件1.不带进位加法ADD一不带进位加说明:两个寄存器不带进位C标志加,结果送目的寄存器Rd。
操作: RdRd+ Rr语法:操作码:程序计数器:ADD Rd,Rr O≤d≤31,0≤r≤31 PCPC+1 例子:。
(实践操作程序实践操作例子*.ASM,必须编译生成*.OBJ文件才可调试,如要修改*.ASM,必须修改文件属性,去掉*.ASM只读文件属性2.带进位加法ADC-一带进位加说明:两个寄存器和C标志的内容相加,结果送目的寄存器Rd。
操作: Rd←Rd+Rr+C语法:操作码:程序计数器:ADC Rd,Rr 0≤d≤31,0≤r≤31 PC←PC+1例子:(实践操作程序3.减1指令DEC一减1说明:寄存器Rd的内容减1,结果送目的寄存器Rd中。
操作:RdRd-l语法:操作码:程序计数器:DEC Rd 0≤d≤31 PCPC十1 例子:(实践操作程序4.立即数比较CPI——带立即数比较说明:该指令完成寄存器Rd和常数的比较操作。
寄存器的内容不改变。
该指令后能使用所有条件转移指令。
操作:Rd-K语法:操作码:程序计数器:CPI Rd, K 16≤d≤31, 0≤ K≤255 PCPC + 1例子:(实践操作程序5.带立即数与ANDI——立即数逻辑与 ;全1为1,有0即0说明:寄存器Rd的内容与常数逻辑与,结果送目的寄存器Rd。
应用: 清0,使某位为0,用0去与;保留,用1去逻辑与;代硬件与门操作:RdRd·K;语法:操作码:程序计数器:ANDI Rd K 16≤d≤31, 0≤K≤255 PCPC+ 1 例子:(实践操作程序6.寄存器逻辑或OR一逻辑或;有1即1,全0为0,应用: 置数,使某位为1,用1去或;保留,用0去逻辑或;代硬件或门说明:完成寄存器Rd与寄存器Rr的内容逻辑或操作,结果进目的寄存器Rd中。
操作: RdRd ∨ Rr语法:操作码:程序计数器: OR Rd Rr 0≤d≤31, 0≤r≤31 PCPC+ 1 例子:(实践操作程序7.清除寄存器CLR-一寄存器清零说明:寄存器清零。
该指令采用寄存器Rd与自己的内容相异或实现的。
寄存器的所有位都被清零。
操作: RdRd ⊕Rd语法:操作码:程序计数器:CLR Rd 0≤d≤31 PCPC+ 1 例子:(实践操作程序8.相对跳转RJMP一相对跳转说明:相对跳转到 PC -2K和 PC+2K(字)范围内的地址。
在汇编程序中,标号用于替代相对操作。
AVR微控制器的程序存储器空间不超过4K字(8K字节),该指令能寻址整个存储器空间的每个地址位置。
操作: PC(PC+1)+ k语法:操作码:程序计数器:RJMP k — 2K≤k≤2K PC(PC+1)+k 例子:(实践操作程序9.相等转移BREQ相等转移说明:条件相对转移,测试零标志(Z),如果 Z位被置位,则相对PC 值转移。
如果在执行CP、CPI、SUB或SUBI指令后立即执行该指令,且当寄存器Rd中无符号或有符号二进制数与寄存器 Rr中无符号或有符号H进制数相等时,转移将发生。
操作:If Rd=Rr(z=1)then PC(PC十1)+k,PCPC十1语法:操作码:程序计数器:BREQ k -64≤k≤+63 PC(PC+ 1)+ kPCPC+ l例子:(实践操作程序10.不相等转移BRNE——不相等转移说明:条件相对转移,测试零标志(Z),如果Z位被清零,则相对PC 值转移。
如果在执行CP。
CPI、SUB或SUBI指令后立即执行该指令,且当在寄存器Rd中的无符号或带符号二进制数不等于寄存器Rr中的无符号或带符号二进制数时,转移将发生。
该指令相对PC转移的方向为:PC- 64≤目的≤PC+ 63。
参数K为PC的偏移,用2的补码表示(相当于指令BRBCIK)。
操作, If Rd≠Rr(Z=0) then PC(PC+1)+k,elesPCPC+1语法:操作码:程序计数器:BRNE k -64≤ k ≤+63 PC(PC+1)+ kPCPC+l 例子:(实践操作程序11.寄存器位清零跳行SBRC一寄存器位被清零跳行说明:该指令测试寄存器某位,如果该位被清零,则跳下一行执行指令。
操作:If Rd(b)= 0 then PCPC+2(or 3)eles PCPC+ 1语法:操作码:程序计数器:SBRC Rr,b 0≤ r≤ 31, 0≤ b≤7 PCPC十1pCpC+ 2PCPC+ 3例子:(实践操作程序12.寄存器位置位跳行SBRS一寄存器位置位跳行说明:该指令测试寄存器某位,如果该位被置位,则跳下一行执行指令。
操作: If Rr(b)=l then PCPC+ 2(or 3)elesPCPC+ l语法:操作码:程序计数器:SBRS Rr,b ≤r≤31,0≤b≤7 PCPC+1PCPC+2PCPC+3例子:(实践操作程序13.I/O寄存器位置位跳行SBIS-I/O寄存器的位置位跳行说明:该指令测试1/O寄存器某位,如果该位被置位,则跳一行执行指令。
该指令在低32个1/O寄存器内操作,地址为0~31。
操作: If I/OP, b=l then PCPC+2(or 3)else PCPC+1语法:操作码:程序计数器:SBIS p ,b 0≤ P≤ 31, 0≤ b≤ 7 PCPC+ 1PCPC+ 2PCPC+ 3例子:(实践操作程序14.相对调用RCALL——相对调用于程序说明:在PC+1后(2K字(4K字节)范围内调用子程序。
返回地址(RCALL 后的指令地址)存储到堆栈(见CALL)。
操作:PC(PC+1)+k语法:操作码:程序计数器:RCALL k -2K≤ k ≤2K PC(PC+1)+ k 例子: (实践操作程序15.从子程序返回RET——子程序返回说明:从子程序返回。
返回地址从堆栈中弹出。
操作: PC(15-0)STACKPC(21-0)STACK语法:操作码:程序计数器:堆栈: RET None See Operation SPSP+ 2 RET None See Operation SPSP+ 3 例子:(实践操作程序见16.从中断程序返回RETI——中断返回说明:从中断程序中返回。
返回地址从堆栈中弹出,且全局中断标志被置位。
注意:1.主程序应跳过中断区,防止修改补充中断程序带来麻烦;2.不用的中断入口地址写上RETI-中断返回,有抗干扰作用;操作: PC(15-0)STACKPC(21-0)STACK语法:操作码:程序计数器:堆栈:RETI None See Operation SPSP十2RETI None See Operation SPSP +3例子:( 程序,摘自”乐曲.ASM”部分程序,仅供参考),能执行程序请阅”乐曲.ASM”程序及AVR单片机在儿童智能玩具中的应用--音乐玩具(电脑放音机)一文17.寄存器拷贝数据MOV寄存器拷贝说明:该指令将一个寄存器拷贝到另一个寄存器。
源寄存器Rr的内容不改变,而目的寄存器Rd拷贝了Rr的内容。
操作:Rd ← Rr语法:操作码:程序计数器:MOV Rd Rr 0≤d≤31,0≤r≤31 PCPC+ 1例子:(实践操作程序18.SRAM数据直接送寄存器LDS直接从SRAM装入说明:把SRAM中1个字节装入到寄存器。
必须提供一个16位地址。
存储器访问被限制在当前64K字节的SRAM页。
超过64K字节,LDS指令使用RAMPZ寄存器访问。
操作:Rd(k)语法:操作码:程序计数器:LDS Rd k 0≤ d≤ 31,0≤ k≤65535 PCPC+2例子:(实践操作程序19.寄存器数据直接送SRAMSTS寄存器数据直接送SRAM说明:将寄存器的内容直接存储到SRAM。
必须提供一个16位的地址。
存储器访问被限制在当前64K字节的SRAM页。
STS指令使用RAMPZ寄存器访问存储器可超过64K字节。
操作:(k)Rr语法:操作码:程序计数器:STS k,Rr 0≤r≤31,0≤k≤65535 PCPC+2例子:(实践操作程序与相同)20.立即数送寄存器LDI——装入立即数说明:装入一个8位立即数到寄存器R16~R31中。
操作:RdK语法:操作码:程序计数器:LDI Rd K 16≤ d≤ 31, 0≤K≤ 255 PCPC+2例子:(实践操作程序21.使用变址Z间接将SRAM中的内容传送到寄存器LD(LDD)——使用变址Z间接将SRAM中的内容传送到寄存器说明:带或不带偏移间接从SRAM中传送一个字节到寄存器,SRAM中的位置由寄存器区中的 Z(16位)指针寄存器指出。
存储器访问被限制在当前64K字节的 SRAM页中。
为访问另外SRAM页,则 I/O范围内的寄存器RAMPZ需改变。
在指令执行后,Z指针寄存器值要么不改变,要么就加1或减1操作。
使用Z指针寄存器的这些特性,特别适合于堆栈指针,因为Z指针寄存器能用于直接子程序调用,直接跳转和查表。
Z指针寄存器用作为专用堆栈指针要比X、Y指针方便。
用Z指针在程序存储器中查表,可参见LPM指令。
操作:Rd(Z)Rd(Z)Z Z-1Rd (Z+q)语法:操作码:操作流程: 程序计数器:LD Rd,Z 0≤ d≤31 送数,Z指针不改变 PCPC+1 LD Rd Z+ 0≤d≤31 先送数,后Z指针加1 PCPC+1LD Rd,-Z 0≤d≤31 先Z指针减1, 后送数 PCPC+lLDD Rd Z+q 0≤ d≤31,先Z指针加q,后送数, PCPC+10≤q≤63 执行后Z指针(Z不含q)不变例子:(实践操作程序22. LPM——装入程序存储器说明:将Z寄存器指向的一个字节传送到寄存器0(RO)。
该指令使100 %空间有效,常量初始化或常数取数特别有用。
程序存储器被编为16位字,Z(16位)指针的最低位(LSB)选择为0是低字节,选择为1是高字节。
该指令能寻址程序存储器第一个64K字节(32字)。
操作:R0(Z)语法:操作码:程序计数器: LPM None PCPC+ 1 例子:(实践操作程序,更详细资料阅”按钮猜数.ASM”)23.I/O口数据传送到寄存器IN——I/O口数据传送到寄存器说明:将I/O空间(口,定时器,配置寄存器等)的数据传送到寄存器区中的寄存器Rd中。