- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
3.2指令系統【例3.28】ADDAL,BLDAA如指令執行前:AL=18H,BL=03H,則執行ADD指令後:AL=1BH,CF=0,AF=1。執行DAA指令時,因AF=1,而做AL←AL+06H得AL=21H,CF=0,AF=1,結果正確。3.2指令系統(2)DAS減法的十進位調整指令。執行的操作:AL←把AL中的差調整到壓縮的BCD碼格式。執行這條指令之前必須執行SUB或SBB指令,減法指令必須把2個壓縮的BCD碼相減並把結果存放在AL寄存器中。本指令的調整方法是:如果AF的標誌為1,或者AL寄存器的低4位是十六進制的A~F,則使AL寄存器的內容減去06H,並將AF位置1。如果CF的標誌為1,或者AL寄存器的高4位是十六進制的A~F,則使AL寄存器的內容減去60H,並將CF位置1。DAS指令對OF標誌無定義,但影響所有其他條件標誌。3.2指令系統【例3.29】SUBAL,AHDAS如指令執行前:AL=86H,AH=07H,執行SUB指令後:AL=7FH,CF=0,AF=1。執行DAS指令時,因AF=1,而做AL←AL-60H得AL=79H,CF=0,AF=1,結果正確。3.2指令系統2)非壓縮的BCD碼調整指令這一組指令適於數字ASCII的調整,也適用於一般的非壓縮BCD碼的十進位調整。(1)AAA加法的ASCII調整指令。執行的操作:AL←把AL中的和調整到非壓縮的BCD格式,AH←AH+調整產生的進位值。這條指令執行之前必須執行ADD或ADC指令,加法指令必須把2個非壓縮的BCD碼相加,並把結果存放在AL寄存器中。3.2指令系統本指令的調整步驟是:①如AL寄存器的低4位在0~9之間,且AF位為0,則跳過②,執行③。②如AL寄存器的低4位在十六進制數A~F之間或AF為1,則AL寄存器的內容加6,AH寄存器的內容加1,並將AF位置1。③清除AL寄存器的高4位。④AF位的值送CF位。AAA指令除影響AF和CF標誌外,其餘標誌位均無定義。3.2指令系統【例3.30】ADDAL,BLAAA如指令執行前,AX=0038H,BL=33H,可見AL和BL寄存器的內容分別為8和3的ASCII碼。第1條指令執行完後,AL=0BH,AF=0;第2條指令進行ASCII調整的結果使(AX)=0101H,AF=1,CF=1。3.2指令系統(2)AAS減法的ASCII調整指令。執行的操作:AL←把AL中的差調整到非壓縮的BCD格式,AH←AH-調整產生的借位值。這條指令執行之前必須執行SUB或SBB指令,減法指令必須把2個非壓縮的BCD碼相減,並把結果存放在AL寄存器中。3.2指令系統本指令的調整步驟是:①如AL寄存器的低4位在0~9之間,且AF位為0,則跳過②,執行③。②如AL寄存器的低4位在十六進制數A~F之間或AF為1,則AL寄存器的內容減去6,AH寄存器的內容減1,並將AF位置1。③清除AL寄存器的高4位。④AF位的值送CF位。AAS指令除影響AF和CF標誌外,其餘標誌位均無定義。3.2指令系統(3)AAM乘法的ASCII調整指令。執行的操作:AX←把AL中的和調整到非壓縮的BCD格式。執行這條指令之前必須執行MUL指令把2個非壓縮的BCD碼相乘(此時要求其高4位為0),結果放在AL寄存器中。本指令的調整方法是:把AL寄存器的內容除以0AH,商放在AH寄存器中,餘數保存在AL寄存器中。本指令根據AL寄存器的內容設置條件碼SF、ZF和PF,但OF、CF和AF位無定義。3.2指令系統【例3.31】MULAL,BLAAM如指令執行前:AL=08H,BL=05H,執行MUL後:AL=28H,執行AAM後:AH=04H,AL=00H。3.2指令系統(4)AAD除法的ASCII調整指令。前面所述的加法,減法和乘法的ASCII調整指令都是用加法、減法和乘法指令對2個非壓縮的BCD碼運算以後,再使
文档评论(0)