网页 新闻 贴吧 知道 网盘 图片 视频 地图 文库 资讯 采购 百科
百度首页
登录
注册
首页
秒懂百科
特色百科
知识专题
加入百科
百科团队
权威合作
个人中心

CMP指令

播报 讨论 上传视频
单芯片多处理器
收藏
查看 我的收藏
0有用+1
0
CMP指令是由美国 斯坦福大学提出的,英文名称是Chip multiprocessors,翻译成中文就是 单芯片多处理器,也指 多核心其思想是将大规模 并行处理器中的SMP( 对称多处理器)集成到同一芯片内,各个处理器 并行执行不同的进程。与CMP比较, SMT 处理器结构的灵活性比较突出。
中文名
CMP指令
外文名
Chip multiprocessors
提出单位
美国 斯坦福大学
全    称
单芯片多处理器

目录

  1. 1 CMP
  2. 格式
  3. 执行操作
  1. 功能
  2. 2 指令算法
  3. 3 指令集
  1. 4 指令详解

CMP

播报
编辑
但是,当半导体工艺进入0.18微米以后,线延时已经超过了 门延迟,要求 微处理器的设计通过划分许多规模更小、局部性更好的基本单元结构来进行。相比之下,由于CMP结构已经被划分成多个处理器核来设计,每个核都比较简单,有利于 优化设计,因此更有发展前途。IBM 的Power 4芯片和Sun的 MAJC5200芯片都采用了CMP结构。 多核处理器可以在处理器内部共享缓存,提高缓存 利用率,同时简辩拔化 多处理器系统设计页旋危的 复杂度
微型计算机 汇编语言中,CMP(compare)是其中一条指令,叫做比较指令。cmp的功能相当于减法指令,只是对 操作数之间运算比较,不保存结果。cmp指令执行后,将对 标志寄存器产生影响。其他相关指令通过识别这些被影响的标志寄存器位来得知比较结果。 [1]
使用例子达旬请如:CM旋龙享P ax, bx

格式

CMP OPR1船员 , 放棕拳OPR2.

执行操作

(OPR1)-垫誉再船(O渗垫白PR2)

功能

该指令与SUB指令一样执行减法的操作,但它并不保存运算结果,只是根据结果设置相关的条件标志位(SF、ZF、CF、OF)。CMP指令后往往跟着 条件转移指令,实现根据比较的结果产生不同的程序分支的功能。

指令算法

播报
编辑
cmp是比较指令, cmp的功能相当于减法指令,只是不保存结果。cmp指令执行后,将对 标志寄存器产生影响。其他相关指令通过识别这些被影响的标志寄存器位来得知比较结果。
比如:mov ax,8
mov bx,3
cmp ax,bx
执行后:ax=8,ZF=0,PF=1,SF=0,CF=0,OF=0.
通过cmp指令执行后,相关标志位的值就可以看出比较的结果。
cmp ax,bx的逻辑含义是比较ax,bx中的值。如果执行后:
ZF=1则AX=BX
ZF=0则AX!=BX
SF=1则AX<BX
SF=0则AX≥BX
SF=0并ZF=0则AX>BX
SF=1或ZF=1则AX≤BX
CPU在执行cmp指令的时候,也包含两种含义:进行无符号运算和进行 有符号数运算。
cmp ah,bh
如果ah=bh则ah-bh=0所以ZF=1
如果ah≠bh则ah-bh≠0所以ZF=0
所以我们根据cmp指令执行后ZF的值,就可以知道两个数据是否相等。如果ah<bh则 可能发生什么情况呢?
对于有符号数运算,在ah<bh情况下,ah-bh显然可能引起SF=1既结果为负比如:
ah=1,bh=2则ah-bh=0FFH,0FFH为-1的 补码,因为结果为负,所以SF=1。
ah=0FEH,bx=OFFH;则ax-bx=-2-(-1)=OFFH,因为结果为负,所以SF=1。
再看两个例子:
ah=22H,bh=OAOH则ah-bh=34-(-96)=82H,82H是-126的 补码
所以SF=1。这里虽然SF=1,但是并不能说明ah<bh因为显然34>-96
两个 有符号数A和B相减,得到的是负数,那么可以肯定A<B这个思路没有错误,关键在于我们根据什么来断定得到的是一个负数,CPU将cmp指令得到的结果记录在flag的相关标志位中,我们可以根据指令执行后,相关标志位的值来判断比较的结果。单纯的考察SF的值不可能知道结果的正负。因为SF记录的只是可以在计算机中存放的相应位数的正负,cmpah,bh执行后,SF记录的是ah-bh所得到的8位结果数据的正负,虽然这个结果没有在我们能够使用的 寄存器 内存单元中保存,但是在指令执行的过程中,它暂存在cpu内存的 暂存器中。

指令集

播报
编辑
IBM-PC 汇编语言 指令集
数据传送指令集
MOV
功能: 把源 操作数送给目的操作数
语法: MOV 目的操作数,源操作数
格式: MOV r1,r2
MOV r,m
MOV m,r
MOV r,data
XCHG
功能: 交换两个操作数的数据
语法: XCHG
格式: XCHG r1,r2 XCHG m,r XCHG r,m
PUSH,POP
功能: 把 操作数压入或取出 堆栈
语法: PUSH操作数POP 操作数
格式: PUSH r PUSH M PUSH data POP r POP m
PUSHF, POPF,PUSHA,POPA
功能:堆栈指令群
格式: PUSHF POPF PUSHA POPA
LEA,LDS,LES
功能: 取地址至 寄存器
语法: LEA r,m LDS r,m LES r,m
XLAT(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,O
SUB,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,O
INC,DEC
功能: 把OP的值加一或减一
语法: INC OP DEC OP
格式: INC r/m DEC r/m
影响标志: P,A,Z,S,O
NEG
功能: 将OP的符号反相(取二进制 补码)
语法: NEG OP
格式: NEG r/m
影响标志: C,P,A,Z,S,O
MUL,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/m
CBW,CWD
功能: 有符号数扩展指令
语法: CBW CWD
AAA,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,O
ROR,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
标志位: C
CLD,STD
功能: 设定方向标志
语法: CLD STD
标志位: D
CLI,STI
功能: 设定中断标志
语法: CLI STI
标志位: I
CMP
功能: 比较OP1与OP2的值
语法: CMP r/m,r/m/data
标志位: C,P,A,Z,O
JMP
功能: 跳往指定地址执行
语法: 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,O
SCASB,SCASW
功能: 字符串搜索指令
语法:SCASBSCASW
标志位: C,P,Z,S,O
LODSB,LODSW,STOSB,STOSW
功能: 字符串载入或存贮指令
语法:LODSBLODSWSTOSBSTOSW
标志位: 无
REP,REPE,REPNE
功能: 重复前缀指令集
语法: REP 指令S REPE 指令S REPNE 指令S
标志位: 依指令S而定
对于IBM PC机它有它的 指令系统,其中包括: 数据传送指令、串处理指令、算术指令、控制移动指令、 逻辑指令 处理机控制指令。
这里将简单介绍其指令类型及指令说明,如有要求给具体的指令格式及应用,请与amay联系,amay加以更新。
1、数据传送指令:负责把数据、地址或 立即数传送到寄存器或 存储单元中。
数据传送指令类型指 令 说 明
通用数据传送指令 MOV(传送)、PUSH( 进栈)、POP( 出栈)、XCHG(交换)
累加器专用传送指令 IN(输入指令)、OUT(输入指令)
地址传送指令 LEA( 有效地址送寄存器)、LDS(指针送寄存器和DS)、LES(指针送寄存器和ES)
标志寄存器传送指令LAHF(标志送AH)、 SAHF(AH送标志寄存器)、PUSHF(标志进栈)、 POPF(标志出栈)
2、算术指令:用来执行 算术运算
算术指令类型指 令 说 明
加法指令 ADD(加法)、ADC(带 进位加法)、INC(加1)
减法指令 SUB(减法)、SBB(带 借位减法)、DEC(减1)、NEG(求补)、CMP(比较)
乘法指令 MUL( 无符号数乘法)、IMUL( 带符号数乘法)
除法指令 DIV(无符号数除法)、IDIV(带符号数除法)、CBW(字节转换为字)、CWD(字转换为双字)
3、逻辑指令:对字或字节执行 逻辑运算
逻辑指令类型指 令 说 明
逻辑运算指令 AND( 逻辑与)、OR( 逻辑或)、NOT( 逻辑非)、XOR( 异或)、TEST(测试)
移动指令 SHL(逻辑 左移)、SAL(算术左移)、SHR(逻辑右移)、SAR( 算术右移)、ROL(循环左移)、ROR(循环右移)、RCL(带进位循环左移)、RCR(带进位右移)
4、串处理指令:处理存放 存储器里的数据串。
串处理指令类型指 令 说 明
指 令 MOVS(串传送)、 CMPS(串比较)、 SCAS(串扫描)、 LODS(从串取)、STOS(存入串)
5、控制 转移指令:用来 控制程序的执行流程。
控制转移指令类型指 令说 明
无条件转移指令 JMP(段间和段内转移)
条件转移指令 JZ(结果为0(或相等)则转移)、 JS(结果为负则转移)、 JNS(结果为正则转移)、JO(溢出则转移)、JNO(不溢出则转移)、JP(奇偶位为1则转移)、JNP(奇偶位为0则转移)
循环指令 LOOP(循环指令)、LOOPPZ/LOOPE(当为0或相等时循环指令)、LOOPNZ/LOOPNE(当不为0或不相等时循环指令)
子程序指令 CALL(调用指令)、RET(返回指令)
中断指令INT(中断)、INTO(如溢出则中断)、RIET(从 中断返回
6、 处理机 控制指令
处理机控制指令类型指 令 说 明
标志处理指令 CLC(进位位置0指令)、CMC(进位位求反指令)、STC(进位位置为1指令)、CLD(方向标志置1指令)、STD(方向标志位置1指令)、CLI(中断标志置0指令)、STI(中断标志置1指令)
其他处理机控制指令 NOP(无操作)、 HLT(停机)、WAIT(等待)、 ESC(换码)

指令详解

播报
编辑
cmp(compare)指令进行比较两个 操作数的大小
例:cmp oprd1, oprd2
为第一个操作减去第二个操作数,
但不影响第两个操作数的值
它影响flag的CF,ZF,OF,AF,PF
我们怎么判断大小呢?
执行指令
ZF=1 这个简单,则说明两个数相等,因为zero为1说明结果为0
当无符号时:
CF=1 则说明了有进位或 借位,cmp是进行的减操作,故可以看出为借位,所以,此时oprd1<oprd2
CF=0 则说明了无借位,但此时要注意ZF是否为0,若为0,则说明结果不为0,故此时oprd1>oprd2
当有符号时:
若SF=0,OF=0 则说明了此时的值为 正数,没有溢出,可以直观的看出,oprd1>oprd2
若SF=1,OF=0 则说明了此时的值为负数,没有溢出,则为oprd1<oprd2
若SF=0,OF=1 则说明了此时的值为正数,有溢出,可以看出oprd1<oprd2
若SF=1,OF=1则说明了此时的值为负数,有溢出,可以看出oprd1>oprd2
最后两个可以作出这种判断的原因是,溢出的本质问题:
两数同为正,相加,值为负,则说明溢出
两数同为负,相加,值为正,则说明溢出
故有,正正得负则溢出,负负得正则溢出

玻璃钢生产厂家宁波定制玻璃钢雕塑山西玻璃钢鹿雕塑南京小品系列玻璃钢雕塑价格南安玻璃钢雕塑厂家玻璃钢会动雕塑河北大型商场美陈生产企业上海室内商场美陈订购宣城玻璃钢糖果雕塑保定玻璃钢动物雕塑牛广州番禺玻璃钢雕塑福建节庆商场美陈销售公司西安公园玻璃钢雕塑制作银川道教玻璃钢雕塑海口玻璃钢大型雕塑设计多少钱专业的玻璃钢雕塑卡通茂名人物玻璃钢雕塑品牌玻璃钢滑梯雕塑玻璃钢字母雕塑上海特色玻璃钢雕塑哪家便宜宝鸡公园景观校园玻璃钢雕塑商场店铺美陈佛山校园玻璃钢人物雕塑东莞能透光玻璃钢雕塑乳山玻璃钢胸像雕塑福建特色商场美陈哪家好宝鸡景观标识玻璃钢彩绘雕塑宜兴商场周年美陈西平玻璃钢雕塑厂家玻璃钢花盆组合定制商场美陈选哪家香港通过《维护国家安全条例》两大学生合买彩票中奖一人不认账让美丽中国“从细节出发”19岁小伙救下5人后溺亡 多方发声单亲妈妈陷入热恋 14岁儿子报警汪小菲曝离婚始末遭遇山火的松茸之乡雅江山火三名扑火人员牺牲系谣言何赛飞追着代拍打萧美琴窜访捷克 外交部回应卫健委通报少年有偿捐血浆16次猝死手机成瘾是影响睡眠质量重要因素高校汽车撞人致3死16伤 司机系学生315晚会后胖东来又人满为患了小米汽车超级工厂正式揭幕中国拥有亿元资产的家庭达13.3万户周杰伦一审败诉网易男孩8年未见母亲被告知被遗忘许家印被限制高消费饲养员用铁锨驱打大熊猫被辞退男子被猫抓伤后确诊“猫抓病”特朗普无法缴纳4.54亿美元罚金倪萍分享减重40斤方法联合利华开始重组张家界的山上“长”满了韩国人?张立群任西安交通大学校长杨倩无缘巴黎奥运“重生之我在北大当嫡校长”黑马情侣提车了专访95后高颜值猪保姆考生莫言也上北大硕士复试名单了网友洛杉矶偶遇贾玲专家建议不必谈骨泥色变沉迷短剧的人就像掉进了杀猪盘奥巴马现身唐宁街 黑色着装引猜测七年后宇文玥被薅头发捞上岸事业单位女子向同事水杯投不明物质凯特王妃现身!外出购物视频曝光河南驻马店通报西平中学跳楼事件王树国卸任西安交大校长 师生送别恒大被罚41.75亿到底怎么缴男子被流浪猫绊倒 投喂者赔24万房客欠租失踪 房东直发愁西双版纳热带植物园回应蜉蝣大爆发钱人豪晒法院裁定实锤抄袭外国人感慨凌晨的中国很安全胖东来员工每周单休无小长假白宫:哈马斯三号人物被杀测试车高速逃费 小米:已补缴老人退休金被冒领16年 金额超20万

玻璃钢生产厂家 XML地图 TXT地图 虚拟主机 SEO 网站制作 网站优化