- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
微机原理-第4章-赵春文
情况2:设(AL)=’8’=38H ,(BL)=‘6’=36H 执行ADD 0011 1000 +) 0011 0110 0110 1110 执行AAA指令,因为8+6=149,所以进行校正。 (AL)+6= 0110 1110 + 0000 0110 0111 0100 AH+1:0000 0001?AH AL高4位清0: 0000 0100 ?AL,AF、CF置1。最后校正的结果在AH、AL中 (AH)=01H,(AL)=04H 4.3.2 算数运算指令 (2)组合型加法校正指令 指令格式:DAA 指令功能: 若(AL)3~09,或AF=1,则AL?(AL)+6,AF置1。 若(AL)7~49,或CF=1,则AL?(AL)+60H,CF置1。 例:实现两个4位十进制数的加法 4678+2556,结果放在DX中,其程序如下: MOV AL,78H ADD AL,56H DAA MOV DL,AL MOV AL,46H ADC AL,25H DAA MOV DH,AL 4.3.2 算数运算指令 (3)非组合型减法校正指令 指令格式:AAS 在执行AAS指令前,已用SUB/SBB指令完成非组合型BCD码减法,且结果已在AL中。 指令功能: 若(AL)3~09,且AF=0,则将AL高4位清0,AF、CF置0。 若(AL)3~09,或AF=1,则AL?(AL)-6,AH?(AH)-1,AL高4位 清0,AF、CF置1。 4.3.2 算数运算指令 4、组合型减法校正指令 指令格式:DAS 在执行DAS前,已用SUB/SBB指令完成组合型BCD码减法,且结果 已在AL中。 若(AL)3~09,或AF=1, AL?(AL)-6,AF置1; 若(AL)7~49,或CF=1,则AL?(AL)-60H,CF置1。 4.3.2 算数运算指令 6、位操作类指令 包括逻辑运算指令、测试指令和移位指令 (1) 逻辑运算指令 有4条,其格式与功能分别为: 逻辑与指令 AND DEST,SRC 指令功能:DEST ← (SRC)∧(DEST) 逻辑或指令 OR DEST,SRC 指令功能:DEST ← (SRC) ∨(DEST) 逻辑异或指令 XOR DEST,SRC 指令功能:DEST ← (SRC)+(DEST) 上述三条指令影响:SF、ZF、PF、CF和OF置0,AF不确定。 因为它们都是按位进行,不存在进位,借位。 4.3.2 算数运算指令 逻辑非指令 NOT DEST 指令功能: DEST ← DEST ,不影响标志位 例:设(AL),指令“AND AL,0FH”的逻辑与运算及置标志位的过程如下: (AL)= ∧ 0FH= → AL 例:这些指令常用于对操作数的某些位进行操作 AND AL,F0H XOR AX,AX XOR AL,01H 4.3.2 算数运算指令 2、测试指令 指令格式:TEST DEST,SRC 指令功能:(SRC)∧ (DEST),按结果置SF、ZF、PF,结果不保存。标志位CF和OF置0,AF不确定。 例:测试AL中最低位状态,可用指令 TEST AL,01H TEST执行后,如果最低位为0,则ZF=1;如果最低位为1,则ZF=0。 与运算可将低4位分离出来。标志位: SF=0,ZF=0,PF=1 4.3.2 算数运算指令 3、移位指令 有8条,分为算术、逻辑、循环移位指令,有如下共同点: a、具有相同的指令格式:OPR DEST,COUNT; b、每条指令都是 单操作数指令,只需一个操作数DEST; c、DEST只能是8/16位通用寄存器或存储器操作数,不能是立即数; d、COUNT表示移位次数。移位一次,COUNT可用常数1代替;移位多次,则必须用CL替代,CL中存放移位次数。 4.3.2 算数运算指令 四、
文档评论(0)