9基本指令和指令类型、指令分类
第3章 ARM9汇编指令系统
第三章
例如
例如: LDR R8,[R10] ;R8←[R10] LDRNE R2,[R5,#960]! ;( 有 条 件 地 ) R2←[R5+960],R5←R5+960 LDR R0,localdata ;加载一个字到R0寄存 器,该字存 于localdata所指地址处 STR R5,[R7],#-8! ;R5→[R7],R7←R7-8 STRB R0,[R3,-R8 ASR #2] ;R0→[R3-R8/4], 存储R0的最低有效字节,R3和R8不变
其中:type 必须是下面所列的形式之一: SH 带符号半字(仅对LDR); H 无符号半字; SB 带符号字节(仅对LDR)。 label 程序相对偏移表达式。偏移量必须是在 当前指令的上下255字节范围内。 offset 加在Rn上的偏移量。其形式是下列两种 之一: ① #expr 是取值范围为-255~+255的整数, 经常是常量或常量表达式。 ② {-} Rm Rm是内含偏移量的寄存器,它不 能是R15。
第三章
存储器访问指令(续)
(3)LDR和STR ----双字:加载/存储两个相邻 的寄存器,64位双字。其句法有4种:
Op {cond} D Rd,[Rn] 零偏移 Op {cond} D Rd,[Rn,offset] {!} 前索引偏移 Op {cond} D Rd,label 程序相对偏移 Op {cond} D {T} Rd,[Rn],offset 后索引偏移
第三章
存储器访问指令(续)
(1) SWP:在寄存器和存储器之间 进行数据交换,其句法是: SWP {cond} {B} Rd,Rm,[Rn] 其中:B是可选后缀,若有B,则交换字 节,否则交换字。该指令作用是数据从 存储器加裁到Rd中,Rm中的内容存储 到存储器,需交换数据存储单元的首地 址在Rn中。在此,Rd和Rm可以相同, 但Rn必须与Rd、Rm不同。
计算机组成原理第4章指令系统课件
4.2 指令的格式
4.2.1 指令的编码格式
操作码OC
AC1
AC2
(1)把保存操作前原来操作数的地址称为源点地址(SS), 把保存指令执行结果的地址称为终点地址或目的地址(DD)。
(2)将源点与终点操作数进行操作码规定的操作后,将 结果存入终点地址。通常二地址指令又称为双操作数指令。
ADD R0,R1表示将R0寄存器的内容和R1寄存器的内容相加以
5 异或XOR
XOR指令对两个操作数进 行按位异或运算。
4.4 指令的种类
4.4.4 移位、循环类指令
CF
位移指令SAL/SHL操作示意图
CF
SAR操作示意图
CF 0
SHR操作示意图
4.4 指令的种类
4.4.4 移位、循环类指令
不带进位标志的循环左移指令ROL MSB 操作数 LSB
CF
不带进位标志的循环右移指令ROR MSB 操作数 LSB
例如:在IBM-PC指令系统中
MOV
AX,05FFH
4.3 寻址方式
4.3.2 常用的寻址方式
2.直接寻址方式
(1)含义: 是指地址字段直接指明操作数在存储器内的位置的寻址 方法。即形式地址等于有效地址。 (2)优缺点: A、优点:简单,不需要进行加法运算。 B、缺点:地址空间指令地址字段长度的限制。
4.2 指令的格式
4.2.3 指令助记符
通常采用一些符号来代表二进制数据,这些符号即指 令助记符。
指令助记符 ADD SUB MUL DIV
助记符示例
含义
指令助记符
相加
AND
相减
OR
相乘
LOAD
相除
STORE
PLC的基本指令
PLC的基本指令一、位操作类指令位操作类指令依靠两个数字1和0进行工作,这两个数字组成了二进制系统,数字1和0称之为二进制数或简称位。
在触点与线圈中,1表示启动或通电,0表示启动或未通电。
1.标准触点指令梯形图表示:语句表表示:“LD bit ”;“LDN bit”。
Bit触点的范围:V、I 、Q、M、SM、T、C、S、L(位)。
功能及说明常开触点在其线圈不带电时,触点是断开的,触点的状态为Off或为0。
当线圈带电时,其触点是闭合的,触点的状态为ON或为1。
该指令用于网络块逻辑运算开始的常开触点与母线的连接。
常闭触点在其线圈不带电时,触点是闭合的,触点的状态为ON或为1。
当线圈带电时,其触点是断开的,触点的状态为OFF或为0。
该指令用于网络块逻辑运算开始的常闭触点与母线的连接。
2.立即触点指令梯形图表示:语句表表示:“LDI bit ”;“LDNI bit”。
Bit触点的范围:I(位)。
功能及说明当常开立即触点位值为1时,表示该触点闭合。
当常闭立即触点位值为0时,表示该触点断开。
指令中的“I”表示立即的意思。
执行立即指令时,CPU直接读取其物理输入点的值,而不是更新映像寄存器。
在程序执行过程中,立即触点起开关的触点作用。
3.输出操作指令(线圈驱动指令)梯形图表示:语句表表示:“=bit ”Bit触点的范围:V、I 、Q、M、SM、T、C、S、L(位)。
功能及说明输出操作是把前面各逻辑运算的结果复制到输出线圈,从而使输出线圈驱动的输出常开触点闭合,常闭触点断开。
输出操作时,CPU是通过输入/输出映像区来读/写输出操作的。
4.立即输出操作指令梯形图表示:语句表表示:“=I bit ”Bit的范围:Q(位)。
功能及说明立即输出操作是把前面各逻辑运算的结果复制到输出线圈,从而使立即输出线圈驱动的输出常开触点闭合,常闭触点断开。
当立即输出操作时,CPU立即输出。
除将结果写到输出映像区外直接驱动实际输出。
5.逻辑与、或操作指令梯形图表示:逻辑与操作由标准触点或立即触点串联构成;逻辑或操作由标准触点或立即触点的并联构成。
第九次课 控制指令及其常用编程电路
图3.1.30 占空比可调脉冲发生图
28
4.【项目3.1】 密码锁控制 输入: 启动SB1→I0.0 SB2→I0.1 SB3→I0.2 SB4→I0.3 SB5→I0.4 SB6→I0.5 SB7→I0.6 输出: 开锁→Q0.0 报警→Q0.1
29
图3.1.31 密码锁控制梯形图 30
3.1.5 比较操作指令 比较操作指令按操作数类型可分为字节比较、字比较、双字比 较和实数比较。
14
3.1.2 基本位操作和置位/复位指令编程举例 1.组合吊灯控制 一个按钮开关控制三盏灯,按钮按下接通一次,一盏灯亮,按 两次,两盏灯亮,按三次,三盏灯亮,按四次,全灭。当开关 再次按下后,重复上述过程。
15
2.互控控制 图3.1.12为一种互控控制梯形图。要求启动时,只有当线圈 Q0.0接通,Q0.1才能接通;切断时,只有当线圈Q0.1断电,线 圈Q0.0才能断电。
图3.1.23 增计数器编程
23
(2) 减计数器(CTD)
图3.1.25 减计数器编程
24
(3) 增减计数器(CTUD)
图3.1.27 增减计数器编程
25
3.1.4 定时器和计数器指令编程举例 1.定时器的并联
26
2.单脉冲发生梯形图
图3.1.29 单脉冲发生梯形图
27
3.占空比可调脉冲(又称振荡器)发生梯形图
37
38
2. 循环指令FOR和NEXT (1)循环指令功能 预置触发信号接通时,反复执行FOR和NEXT之间的程序,每执行一次,当 前计数器INDX增1,达到终值FINAL时,退出循环。 循环开始指令FOR:用来标记循环体的开始。 循环结束指令NEXT:用来标记循环体的结 束。无操作数。 FOR和NEXT之间的程序段称为循环体,
计算机组成原理-第4章_指令系统
7. 段寻址方式(Segment Addressing)
方法:E由段寄存器的内容加上段内偏移地址而形成。
应用:微型机采用段寻址方式,20位物理地址为16位 段地址左移四位加上16位偏移量。
分类:① 段内直接寻址; ② 段内间接寻址; ③ 段间直接寻址; ④ 段间间接寻址;
9 堆栈寻址方式
堆栈:是一组能存入和取出数据的暂时存储单元。
*** 指令字长度
概念 指令字长度(一个指令字包含二进制代码的位数) 机器字长:计算机能直接处理的二进制数据的位数。 单字长指令 半字长指令 双字长指令
多字长指令的优缺点
优点提供足够的地址位来解决访问内存任何单元的寻址问题 ; 缺点必须两次或多次访问内存以取出一整条指令,降低了CPU的运 算速度,又占用了更多的存储空间。
*** 指令系统的发展与性能要求
*** 指令系统的发展
指令:即机器指令,要计算机执行某种操作的命令。
指令划分:微指令、机器指令和宏指令。
简单
复杂
指令系统:一台计算机中所有指令的集合;是表征
计算机性能的重要因素。
系列计算机:基本指令系统相同、基本体系结构相同 的一系列计算机。
*** 对指令系统性能的要求
(2)立即数只能作为源操作数,立即寻址主要用来给寄存 器或存储器赋初值。以A~F开头的数字出现在指令中时,前 面要加0。
(3)速度快(操作数直接在指令中,不需要运行总线周期)
(4)立即数作为指令操作码的一部分与操作码一起放在代 码段区域中。
(5)指令的长度(翻译成机器语言后)较长,灵活性较差。
【例】MOV AX, 10H 执行后(AX)=? 其中:这是一条字操作指令,源操作数为立即寻址 方式,立即数为0010H,存放在指令的下两个单元。
指令的基本格式
4 指令格式
指令格式:用二进制代码表示指令的结 构形式。
操作码字段
地址码字段
操作码表示操作的性质和功能。
地址码表示指令操作的对象,地址码的 位数表示了直接访问的最大存储空间。
5 指令格式分类
三地址指令 OP Ad1 Ad2 Ad3 (Ad1)OP(Ad2) (Ad3)
二地址指令
OP 目的Ad地1址 源地Ad址2
3. 运算器执行操作,将结果存 放到累加器中 图1-32 CPU的运算过程
2 指令
电脑每做的一次动作,一个步骤,都是按 照已经用计算机语言编好的程序来执行的。
程序是计算机要执行的指令的集合。 什么是指令?
2 指令
例如,让计算机计算一个梯形的面积,操 作步骤如下:
输入上底的值a; 输入下底的值b; 输入高的值h; 计算梯形的面积s=(a+b)/2; 把s的值显示在屏幕上。
•隐含约定目的地的双操作数指令 (AC)OP(A1)—> AC;
9 零地址指令
OP
功能描述: •不需要操作数的指令,如停机、空操作、清除 •所需操作数是隐含指定的 对累加器AC内容进行操作 对堆栈内容进行操作
操作码(OP)与地址码(AC): 指令系统中每一条指令对应一个操作码; 操作码的位数取决于指令系统的规模; 地址码包括被操作数,操作数,操作结果
... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ...
0000 X Y Z 三地址指令 1110 X Y Z 15条 1111 0000 Y Z 二地址指令 1111 1110 Y Z 15条 1111 1111 0000 Z 一地址指令 1111 1111 1110 Z 15条 1111 1111 1111 0000 零地址指令 1111 1111 1111 1111 16条
PLC21-功能指令(第九章)
2.减法运算指令 对有符号数进行相减操作,包括整数减法、双整数减法、 实数减法。 梯形图表示:
语句表示:整数减法指令“-I IN1,OUT”;双整数减法指 令“ - D IN1,OUT”;实数减法指令“ - R IN1,OUT”。
当信号EN=1时,被减数IN1与减数IN2相减,其结果传送到 OUT中。
四、比较指令 数值比较指令用于比较两个数值; 字符串比较指令用于比较两个字符串的ASCll码字符。
操作数按指定条件进行比较。
条件成立时,触点闭合,所以实际上是一种位指令。 仅说明数值比较指令 . 类型有:字节比较、整数比较、双字整数比较和实数比较。 字节比较是无符号的,其它类型为有符号的。 比较指令的关系符有:等于=、大于>、小于<、不等<>、 大于等于>=、小于等于<= 等6种。 对比较指令可进行LD、 A和O编程。以关系符“=”为例说明。
4. 正弦、余弦、正切指令
梯形图表示:
语句表示:正弦指令“SIN IN,OUT”;余弦指令“COS IN,OUT”;正切指令“TAN IN,OUT”。
当允许信号EN=1时,将一个双字长(32位)的实数弧度 值IN分别取正弦、余弦、正切,各得到32位的实数结果传送 到OUT中。 如果已知输入值为角度,要先将角度值转化为弧度值, 使用“(*R)MUL_R”指令,用角度值乘以π /180。
当信号EN=l时,被乘数IN1与乘数IN2相乘,结果送到OUT 中。在语句表示中,要先将被乘数送到OUT中,然后和IN1中 的数据进行相乘,溢出以及输入非法参数或运算中产生非法值, 都会使特殊标志SM1.1置位。
4.除法运算指令 对有符号数进行相除操作,包括:整数除法、双整数除法、 完全整数除法和实数除法。
3.块传送指令 字节块(BMB)的传送、字块(BMW)的传送和双字块的 传送(BMD)指令传倒数量的数据到一个新的存储区,数据的 起始地址为IN,数据的长度为N个字节、字或双字。 新块的起站地址为OUT。N的范围从l至255。
计算机组成原理 指令系统
IBM 370机的指令格式
8
4 4
4 4 4 12
RR型 RX型 RS型 SI型 SS型
OP
8
R1 R2 R1 X2
4 4
OP
8
B2
4
D2
12
OP
8
R1 R2
8
B2
4 B1 4
D2
12
OP
8
I2
8
D1
12 4 12
OP
L1
B1
D1
B2
D2
图4-1 IBM 370机的指令格式
2.非规整型
操作码字段的位数丌固定,丏分散地放 在指令字的丌同位置上。 PDP-11机(字长16位)的指令分为单 字长、两字长、三字长三种,操作码字段占4 ~16位丌等,可遍及整个指令长度。 显然,操作码字段的位数和位置丌固定 将增加指令译码和分析的难度,使控制器的设 计复杂化。
入 端口地址 如 出 如 AX, n IN AL, n CPU 的寄存器 OUT n, AL AX CPU 的寄存器 IN AL, DX AX, DX 端口地址 OUT DX, AL AX
4.2 寻址技术
所谓寻址,指的是寻找操作数的地址或下一 条将要执行的指令地址。寻址技术包括编址方 式和寻址方式。
AAA AAS AAM AAD AND OR NOT XOR TEST
3. 移位操作 算术移位
逻辑移位
循环移位(带迚位和丌带迚位)
4. 转移 (1) 无条件转移 JMP
(2) 条件转移 结果为零转 (Z = 1) JZ
如
结果溢出转
(O = 1)JO
300 …
完成触収器
结果有迚位转(C = 1)JC 跳过一条指令 SKP
电气控制与PLC----第九章-PLC的基本指令
注意:设定值可以是VW,T,C,IW,QW,MW,SMW, AC,AIW,K
10
8、逻辑堆栈的操作 S7-200系列PLC中有一个9层堆栈,用于处理所有逻辑操作,
称逻辑堆栈。
11
例
思考题:I0.0并联I0.7,试着写出指令表。
12
9.定时器T
定时器按工作方式分:1)TON:不保持延时通定时器
2)TONR:保持延时通定时器
1)TON梯形图
LD I0.0
很长,而在一次扫描结束之前,
下面的处理是被禁止的(7条P192
⒌子程序调用:子程序入口和子程序返回指令
CALL SBR
CALL n SBR n
CRET:有条件返回
CRET
RET:无条件返回
RET
注意:子程序可以嵌套最多达8层
23
⒍中断程序标号:中断程序的返回指令
INT
改为:
对不可编程电路,按逻辑不变原则重画梯形图
29
§9-4 PLC逻辑指令应用实例
⒈延时断开电路 LD Q0.0 AN I0.0 TON T37,50 LD I0.0 O Q0.0 AN T37 = Q0.0
时序图
30
⒉分频电路
二分频时序图 作业:设计一个四分频梯形图并写指令表
断服务程序内
例:LD I0.0
JMP 4
.
计算机组成与结构2计算机指令
华东师范大学计算机科学技术系
7
二、对指令系统性能的要求
③ 规整性: ⅰ对称性:在指令系统中所有的寄存器和存 储器单元都可同等对待,所有的 指令都可使用各种寻址方式 ⅱ匀齐性:指一种操作性质的指令可以支持 各种数据类型 ⅲ格式一致性:指令长度和数据长度有一定 的关系,以方便处理和存取, 通常为字节长度的整数倍
11
华东师范大学计算机科学技术系
§2 计算机指令
2.1 概述 2.2 计算机硬件的操作
2012
华东师范大学计算机科学技术系
12
2.2 计算机硬件的操作
通过指令要求计算机硬件完成算术运算操作: 使用汇编语言的助记符: 算术运算指令 add a,b,c ;(b)+(c)→a 特点:只执行一种操作 有且只有三个操作数(最多) 操作数取自寄存器 计算四个变量的累加和需要三条指令: add a,b,c ;(b)+(c)→a 硬件设计原则1: add a,a,d ;(a)+(d)→a 操作数格式规整, add a,a,e ;(a)+(e)→a 设计简单 13 华东师范大学计算机科学技术系 2012
不同系列的计算机,采用的指令助记符不一样 MIPS是世界上十分流行的一款RISC处理器 2.2 计算机硬件的操作 (Microprocessor without interlocked piped stages) 一、高级语言程序与汇编语言程序的关系 无内部互锁流水级的微处理器 ·把C语言编译成汇编语言(MIPS) 80年代初期由斯坦福(Stanford)大学Hennessy教授领导的 例1) a=b+c 研究小组研制出来的。MIPS公司在此基础上开发了R系列 d=a-e 的RISC工业产品的微处理器。这些系列产品为很多计算机 C编译器生成的汇编指令: 公司采用,构成各种工作站和计算机系统。如R3000、 add a,b,c R4000、R10000等
计算机组成原理(十二条指令)
计算机学院计算机科学与技术专业《计算机组成原理课程设计》报告(2008/2009学年第一学期)学生姓名:闫全胜学生班级:计算机062202H学生学号: 200620030227指导教师:康葆荣2009年1月3日目录1 关于此次课程设计 (2)1.1 设计的目的: (2)1.2 设计内容及要求: (2)2 分析阶段 (3)2.1指令译码电路分析 (3)2.2 寄存器译码电路分析 (4)2.3 微指令格式分析 (5)2.4 时序分析 (6)3 初步设计阶段 (7)3.1 数据格式 (7)3.2指令描述 (7)3.3 存储器分区 (9)3.4 控制台微程序流程: (10)3.5 运行微程序 (11)4 详细设计阶段 (12)4.1控制台流程分解 (12)4.2 运行微程序子流程 (15)4.3 微程序总流程图 (24)5 实现阶段 (25)5.1 所用模型机数据通路的介绍 (25)5.2 微程序代码设计与编写 (26)微程序二进制代码表 (26)5.3 机器指令的输入及运行 (28)心得体会 (30)参考资料 (31)1 关于此次课程设计1.1 设计的目的:本课程设计是计算机科学与技术专业重要的实践性教学环节之一,是在学生学习完《计算机组成原理》课程后进行的一次全面的综合设计。
目的是通过一个完整的8位指令系统结构(ISA)的设计和实现,加深对计算机组成原理课程内容的理解,建立起整机系统的概念,掌握计算机设计的基本方法,培养学生科学的工作作风和分析、解决实际问题的工作能力。
1.2 设计内容及要求:基于TDN-CM++计算机组成原理实验教学系统,设计和实现一个8位指令系统结构(ISA),通过调试和运行,使设计的计算机系统能够完成指定的功能。
设计过程中要求考虑到以下各方面的问题:1、指令系统风格(寄存器-寄存器,寄存器-存储器,存储器-存储器);2、数据类型(无符号数,有符号数,整型,浮点型);3、存储器划分(指令,数据);4、寻址方式(立即数寻址,寄存器寻址,直接寻址等);5、指令格式(单字节,双字节,多字节);6、指令功能类别(算术/逻辑运算,存储器访问,寄存器操作,程序流控制,输入/输出);7、依据CPI值对指令系统进行性能分析。
白中英《计算机组成原理》(第5版)教材精讲(指令系统 典型指令)
4.5 典型指令一、指令分类与基本指令类型①数据传送类指令;②一般传送指令:MOV AX,BX;③数据交换指令:XCHG;④堆栈操作指令:PUSH,POP;⑤运算类指令;⑥算术运算指令:加、减、乘、除以及加1、减1 、比较;⑦逻辑运算指令;⑧移位指令;⑨程序控制类指令:程序控制类指令用于控制程序的执行方向,并使程序具有测试、分析与判断的能力;⑩输入和输出指令、字符串处理指令、特权指令、其他指令。
二、基本指令系统表4-2-1 典型RISC机指令系统的基本特征型号指令数寻址方式指令格式通用寄存器数主频/Hz RISC-I3122788RISC-lI392213812MIPS5534164SPARC7543120~13625~33 MIPSR300091333225 I86065343250 Power PC64653220%和80%规律:CISC中大约有20%的指令使用频率高,占据了80%的处理机时间,而有80%的不常用指令只占用处理机的20%时间。
VLSI技术发展引起的问题VLSI工艺要求规整性,而大量复杂指令控制逻辑极其不规整,给VLSI工艺造成了很大的困难。
现在用微程序实现复杂指令与用简单指令组成的子程序相比,没有多大的区别。
因为现在控制存储器和主存的速度差缩小。
CISC中,通过增强指令系统的功能,简化了软件,增加了硬件的复杂程度。
然而指令复杂了,指令的执行时间必然加长,从而使整个系统的执行时间反而增加,因而在计算机体系结构设计中,软硬件的功能分配必须恰当。
RISC特点(采用流水线技术): 简单而统一格式的指令译码,大部分指令可以单周期执行,只有LOAD/STORE可以访问存储器,简单的寻址方式,采用延迟转移技术,采用LOAD延迟技术,三地址指令格式,较多的寄存器,对称的指令格式。
三、CISC和RISC1.复杂指令集计算机(CISC)长期来,计算机性能的提高往往是通过增加硬件的复杂性来获得。
随着集成电路技术、超大规模集成电路技术的迅速发展,为了软件编程方便和提高程序的运行速度,硬件工程师采用的办法是不断增加可实现复杂功能的指令和多种灵活的编址方式。
指令1
使用指令举例
将梯形图中的触点00001删掉。
00000 00002 20000 00001 00000 00002 20000
16
LD 00000 NOP(00) AND NOT 00002 OUT 20000
二、块与指令AND LD 和块或指令OR LD
1. AND LD 是将并联触点组相串联的指令
01000
00000
01000
当00000 ON 00001 OFF ON OFF
00005
01000
01000
01001
00001
01000
双线圈输出引起逻辑混乱
26
(4) 梯形图必须遵循从左到右、从上到下的顺序,不允 许两行之间垂直连接触点。
1
5
2
N
3
4
3 1 1 3
5
5
2
4 (b)
N
(a)
(5) 程序结束一定要安排END指令,否则程序不被执行
操作数的个数,取决于各种指令的需要。
操作数设为常数时,在数据前面要加#号。 操作数采用哪种进制,取决于指令的需要。 间接寻址的操作数用*DM××××来表示。 间接寻址的操作数,是以DM××××中的数 据为地址的另一个DM通道中的数据。
DM××××中 的 内容 必须是BCD码,且不 得超出DM区的范围。
00000 00001 20000 01100 00001 20000 00000 01100
LD LD AND NOT OR LD OUT
00000 00001 20000 01100
LD AND NOT OR OUT
00001 20000 00000 01100
不必用 OR LD
Linux基本指令
Linux基本指令Linux基本指令⑴指令格式指令名称 [选择项] [参数]同⼀⾏中可以输⼊⼀个以上的指令,只要指令间以分号(;)隔开,Linux将会按次序执⾏命令序列。
⑵指令选择项为了执⾏动作产⽣不同的结果;选择项以(-)号开头;⑶指令参数参数的⽬的是描述指令所需的⼀些信息(例如:⽂件名称),⽽这些信息在每次执⾏该指令时都不相同。
⑷通配符“*”:可⽤来代表⽂件名中的任意长度的字符串;“?”:可⽤来代表⽂件名中的任⼀字符;“[]”:可⽤来代表⽂件名中的任⼀属于字符组中的字符。
以下这些命令均为shell命令。
1.man 显⽰联机Linux⼿册[格式] $ man[oprion][chapter]title...[描述] man命令打印你所指定的命令。
在你的UNIX系统中,也许有UNIX 系统V⽤户⼿册或Linux程序员⼿册。
在较⼩的Linux 系统中,也许没有man 命令,?因为联机⼿册需要相当⼤的磁盘空间。
[举例]你可使⽤命令man who查看who命令的⼿册[描述]。
2. ls 显⽰当前⼯作⽬录下内容[格式] $ ls [-ltr][描述] ls命令根据⽂件名按字母顺序列出你的⽂件⽬录及⼦⽬录名称。
[选择项] ls命令有多个选择项,下⾯列出⼏个重要的选择项:-l 以长[格式]列出⽂件,其中包括⽂件中的字符个数,?以及最近修改的⽇期和时间。
-t 以最近修改的时间顺序列出⽂件。
-r 将-t选择的列表顺序变反。
--a 显⽰隐藏⽂件[举例]以修改时间的顺序列⽂件,输⼊命令ls -ltr<CR>。
Linux⽂件的类型:“-”为正⽂⽂件——普通⽂件;“d”为⽬录⽂件;“b”为块设备⽂件;“c”为字符设备⽂件;“l”为链接⽂件;“p”为管道⽂件;3. cd 切换⼯作⽬录----在⽬录树中移动[格式] $ cd [路径][描述] cd(change directory)命令建⽴指定的⽬录,并把它作为⼯作⽬录。
计算机组成与系统结构-指令系统
3.2寻址技术 2. 编址单位 (1)字编址
编址单位=访问单位
每个编址单位所包含的信息量(二进制位数)与读或写一 次寄存器、主存所获得的信息量是相同的。早期的大多数机器都 采用这种编址方式。
3.2寻址技术 (2)字节编址
字节编址是为了适应非数值计算的需要。字节编址方式使 编址单位与信息的基本单位(一个字节)相一致,这是它的最大 优点。然而,如果主存的访问单位也是一个字节的话,那么主存 的频带就太窄了。
移量D相加,形成操作数有效地址:
EA=(Rb)+D 基址寄存器的内容称为基址 值,指令的地址码字段是一个位 移量,位移量可正可负。
指令寄存器 OP Rb D20
主存储器
ALU
120 操作数
基1址00值 基址寄存器Rb
操作数S=((Rb)+D)
3.2寻址技术
基址寻址和变址寻址在形成有效地址时所用的算法是相同的, 而且在一些计算机中,这两种寻址方式都是由同样的硬件来实现的。
OP
立即数
在取指令时,操作码和操作数被同时取出,不必再次访问 存储器,从而提高了指令的执行速度。但是,因为操作数是指 令的一部分,不能被修改,且立即数的大小将受到指令长度的 限制。
3.2寻址技术
2.寄存器寻址
指令中地址码部分给出某一通 用寄存器的编号,所指定的寄存器 中存放着操作数。
两个明显的优点:
操作码字段的位数和位置不固定将增加指令译码和分析的 难度,使控制器的设计复杂化。
3.1指令格式
最常用的非规整型编码方式是扩展操作码法: 让操作数地址个数多的指令(如三地址指令)的操作码字
段短些,操作数地址个数少的指令(如一或零地址指令)的操作 码字段长些。
注意
基本指令
注意事项:1)在螺纹切削期间进给速度倍率无效(固定为100%); 2)在螺纹切削期间主轴速度倍率无效(固定为100%) 3)在螺纹切削期间进给暂停无效。因为不停主轴而停 止螺纹切削刀具进给是非常危险的,这将会突然增 加切削深度。
(2)变螺距螺纹切削(G34)
对每一螺距指令一个增加值或减少值就能完成变螺距
例:G31的下一程序段是增量指令。
例:G31的下一程序段是1个轴的绝对指令。
例:G31的下一程序段是2个轴的绝对指令。
多级跳转指令的格式为:
转矩限制跳转指令的格式为:
在执行G31 P99期间,如果达到了电机的转矩极 限,或者接收到了SKIP信号,当前的运动指令立即 停止而执行下一个程序段。 在执行G31 P98期间,如果达到了电机的转矩极 限,当前的运动指令立即停止而执行下一个程序段。 SKIP信号不影响G31 P98。
I_:从起点到圆弧中心的Xp轴距离,带符号,半径值 J_:从起点到圆弧中心的Yp轴距离,带符号,半径值
K_:从起点到圆弧中心的Zp轴距离,带符号,半径值
R_:不带符号的圆弧半径值
F_:沿圆弧的进给速度
注意事项:
1)圆弧终点用地址Xp、Yp、Zp指定,可以绝对 值编程,也可以增量值编程。对于增量值,是指 从圆弧起点向圆弧终点看的距离。 2)圆心用地址I、J、K(分别对应于Xp、Yp、Zp 坐标)指定。I、J、K后面跟的数值是从圆弧起 点向圆心看的矢量分量,并且总是以增量值指定。 I0、J0和K0可以忽略。
3)整圆编程。当Xp、Yp、Zp被忽略(终点与起点相同) 且圆心用I、J、K指定时,即指定了一个360°的圆弧 (整圆)。 4)圆弧半径R指令。它不能指定等于或大于180°的圆 弧。如果Xp、Yp、Zp都被忽略,终点与起点位于同一 位置,用R编程,就是编了一个0°的圆弧,刀具是不 移动的。 5)如果I、J、K和R同时指定,地址R优先,其余被忽略。 6)如果用R编程指定一段接近180°的圆弧,中心坐标的 计算会产生误差。在这种情况下,用I、J、K指定圆 弧圆心。
汇编语言
续上页
多数的程序转移都是在同一个代码段中,大 多数的转移范围实际上很短,往往在当前位置前 后不足百十个字节。如果转移范围可以用一个字 节编码表达、即向地址增大方向转移127字节、 向地址减小方向转移128字节之间的距离,则形
成所谓的短转移(short)。短转移的引入是为了
减少转移指令的代码长度,进而减少程序代码量。
一个32位双字表达,为0x00000001。
[例题9-2]续3
指令“jmp eax‖采用段内寄存器间接寻址转 移到eax指向的位置。因为eax被赋值标号labl3 的偏移地址,所以程序又跳过一个nop指令,开 始执行labl3处的指令。变量nvar保存了labl4的 偏移地址,所以段内存储器间接寻址指令“jmp
int $0x80
[例题9-1]续2
该程序简单地把EAX寄存器加载为1,用来
进行Linux系统调用exit。然后使用无条件指令
JMP跳过把10加载到EBX寄存器并且进行Linux
系统调用部分。程序直接跳到把20赋给EBX寄存
器,再进行Linux系统功能调用位置。
[例题9-1]续3
进行汇编和连接再执行:
续上页
(2)直接寻址方式 直接寻址是指令代码直接提供目标地址。IA-32处理 器只支持段间直接寻址。
(3)间接寻址方式
间接寻址是指令代码指示寄存器或存储单元,目标地 址来自寄存器或存储单元、间接获得。如果用寄存器保存 目标地址,称为目标地址的寄存器间接寻址;如果用存储 单元保存目标地址,则称为目标地址的存储器间接寻址。
近转移,因此,在汇编语言程序中经常不专门表明short
或near。这一点增强了原来这些指令的功能,使得程序员 不必再担心条件转移是否超出了范围。
计算机组成原理第3章-计算机指令和控制器-指令部分刘
A2 A2
A2
9
A3 A3
A3
15条二地址指令
3.1.2 指令的格式
3、扩展操作码技术—— 以指令字长16位为例
OP
A1
A2
A3
12位操作码
1111 1111
:
1111
1111 1111
1111
0000
A3
0001
A3
15条一地址指令
1110
A3
16位操作码 1111
1111
1111
1111
17
3.1.2 指令的格式
3、指令字长度(P119) 指令字长=操作码的位数+(操作数地址个数)*(操作数地 址码位数) 单字长指令——指令字长度等于机器字长度的指令 半字长指令、双字长指令、三/四字长指令、可变字长 等
4、简单指令系统的具体指令格式 ① pentium机指令 ② 嵌入式系统ARM机指令 ③ 模型指令(P121例1、例2)
已被淘汰
400
788
35
基址/变址寻址
指定一个寄存器R,其存放基址/变址,R被称为基址/变址 寄存器。
EA=(R)
MOV AX, [SI]
SI,DI 都称为变址寄存器
Mov AX,[BX]
BX是基址寄存器 内存
OP X
R
300 400
R 300
400
788
36
相对寻址
相对寻址是基址寻址的一 种变通,由程序计数器 PC提供基准地址,即
存储器地址名称:物理地址←→逻辑地址 物理地址——内存中实际地址 逻辑地址——在指令中表现形式 逻辑地址=段地址:偏移地址(8086CPU)
有效地址 EA=(R)+A
9基本指令和指令类型、指令分类
9基本指令和指令类型、指令分类
CHONGQING UNIVERSITY
1944年哈佛⼤学,Mark I
数据传送指令算术运算指令逻辑运算指令数据转换指令输⼊输出指令系统控制指令程序控制指令数据传送指令:
算术运算指令:定点数、浮点数运算和⼗进制数运算逻辑运算指令:
移位指令:
程序控制类指令
⼏个重要的寄存器:程序计数器
转移指令:⽆条件转移指令,有条件转移指令
循环控制指令(
⼦程序调⽤与返回指令(
程序中断指令及返回(
串操作指令(
I/O
堆栈指令:
数制转换指令主要指将⼗进制数转换为⼆进制
执⾏顺序更改的原因。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
CHONGQING UNIVERSITY
1944年哈佛大学,Mark I
数据传送指令算术运算指令逻辑运算指令数据转换指令输入输出指令系统控制指令程序控制指令
数据传送指令:
算术运算指令:定点数、浮点数运算和十进制数运算逻辑运算指令:
移位指令:
程序控制类指令
几个重要的寄存器:程序计数器
转移指令:无条件转移指令,有条件转移指令
循环控制指令(
子程序调用与返回指令(
程序中断指令及返回(
串操作指令(
I/O
堆栈指令:
数制转换指令主要指将十进制数转换为二进制
执行顺序更改的原因
寄存器
子程序的起始位置栈顶
采用寄存器存放返回地址放在子程序的起始位置
子程序调用和转移指令均可改变程序的执行子程序要求返回,可嵌套和递归调用;转移指子程序用于实现程序与程序之间转移;转移指
直接支持高级语言,加快运算VAX-11“
CHONGQING UNIVERSITY
寄存器寄存器存储器
CHONGQING UNIVERSITY。