《指令系统》PPT课件.ppt
《《指令系统》PPT课件.ppt》由会员分享,可在线阅读,更多相关《《指令系统》PPT课件.ppt(34页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、第三章8086指令系统每种计算机都有一组指令集提供给用户使用,这组指令集称为该计算机的指令系统指令系统。8086微处理器的指令系统具有8位和16位的处理能力。80386、80486等CPU具有32位处理能力。本课程只讲8086指令系统。CPU只能执行二进制代码形式的机器指令,8086机器指令是变字节指令,一条指令一般由一条指令一般由1 16 6个字节组成个字节组成(加上前缀字节,最长的可为7字节指令)。8086 机器指令代码由操作码操作码和操作数代码操作数代码两部分组成。直接用机器指令编写程序是一件十分困难的事。通常是用汇编语言编写程序,输入计算机后,由汇编程序将它翻译成机器语言程序,计算机才
2、能执行。因此这里对8086机器语言格式不作更多的叙述。本课程主要介绍汇编语言格式的8086计算机指令。3.18086指令的寻址方式一条指令主要包括两方面内容:一是指令进行什么操作,这由指令操作符操作符表明。二是操作涉及的操作数操作数存放在什么地方,操作的结果存放在什么地方(有些指令不涉及操作数)。8086指令涉及的操作数的存放地点可分为4类:操作数直接存放在指令中,即指令本身就含有操作数。操作数在寄存器中,指令中指眀寄存器的名称。操作数在内存单元中,指令中指明内存单元的地址。当操作数在内存单元中,寻址所需的偏移地址又叫有效地址有效地址,用EA表示,它是一个16位的无符号数。数据存放在I/O端口
3、中,指令中指明I/O端口的地址。寻址方式寻址方式就是指令中用于说明操作数所在地址的方法。8086可采用许多不同的方法来说明操作数所在的地址。在后面要用到下列表示方法:DS1000H,表示DS寄存器的内容为1000H。(2300H)8CH,表示物理地址为2300H的内存单元的内容为8CH。AX5000H表示数值5000H传到AX寄存器中AX(8000H),表示物理地址为8000H的内存字单元的内容传到AX中。(8000H)AX,表示AX的内容传到物理地址为8000H的内存字单元中。AX(DS:5000H),表示逻辑地址为DS:5000H的内存字单元的内容传到AX中。DS内容为段地址,5000H为
4、偏移量)AL(DS:BX),表示逻辑地址为DS:BX的内存单元的内容传到AL中。AL(DS:BX5),表示逻辑地址为DS:BX5的内存单元的内容传到AL中。寻址方式可分为数据的寻址方式数据的寻址方式和转移地址的寻址方式两种。3.1.1 数据的寻址方式数据的寻址方式1、立即寻址方式 立即寻址方式立即寻址方式即操作数直接存放在指令中,紧跟在操作码以后,作为指令的一部分存放在代码段区域中。这种操作数称为立即数。立即数。它只能用于源操作数字段,不能用于目的操作数字段.【例】MOVAL,42H指令的执行:AL42H42H为8位立即数,它是指令的一个组成部分。指令执行后,AL=42H。【例】MOVDX,2
5、345H;指令的执行:DX2345H2345H为16位立即数,它是指令的一个组成部分。指令执行后,DX=2345H。2、寄存器寻址方式寄存器寻址方式即操作数在寄存器中,指令中指明寄存器名称;对于8位操作数,寄存器可以是AL、AH、BL、BH、CL、CH、DL和DH之一。在这种寻址方式中,寄存器可以用作源操作数,也可以存放目的操作数。【例】MOVAX,BP指令的执行:AXBP如果指令执行前,AX=3664H,BP=2758H,则指令执行后AX=2758H,BP保持不变。【例】MOVCH,BL指令的执行:CHBL如果指令执行前,CH=64H,BL=58H,则指令执行后CH=58H,BL保持不变。立
6、即寻址和寄存器寻址指令,执行速度最快,后面要讲到的存储器寻址指令执行速度较慢。3、直接寻址方式直接寻址方式直接寻址方式中,操作数一般在内存数据段中,而操作数的有效有效地址地址直接包含在指令中。操作数的物理地址是由数据段寄存器DS的值乘以16再加上这16位的有效地址得到。【例】MOVAX,2500H指令的执行:AX(DS:2500H)该指令默认DS中为数据段的段地址,指令括号指明的偏移量为2500H,从而可计算出字单元的物理地址,指令执行把该单元内容送到AX中。如果指令执行前DS8000H,(82500H)02,(82501H)03,则指令执行后AX0302H通常指令中不出现DS段寄存器名称,这
7、种情况叫做默认段寄存器默认段寄存器(或叫缺省缺省段寄存器段寄存器)。但是也允许段超越段超越,即允许操作数在代码段或堆栈段或附加段中,只是必须在指令中指明。【例】MOVAX,SS:2500H指令的执行:AX(SS:2500H)该指令将SS指明的堆栈段中偏移量为2500H的字单元的内容送到AX中。直接寻址方式中,存储器操作数的有效地址常常用已经定义的变量名表示,此时指令中可不写括号。【例】MOVBH,ARRY指令的执行:BH(DS:ARRY)指令中ARRY是已经定义的变量名。如果ARRY表示有效地址为3000H的字节变量,则指令执行后,数据段中偏移量为3000H的字节单元的内容送到BH中。4、寄存
8、器间接寻址操作数的有效地址EA在寄存器中,指令中指明寄存器名称。寄存器可以是下列几个中的一个:BX、BP、SI、DI如果指令中指定的寄存器是BX,SI,DI,则操作数在数据段中,段地址由DS提供。如果指令中指定BP寄存器,则操作数在推栈段中,段地址在SS中。【例】MOVAX,SI指令的执行:AX(DS:SI)若初始条件为DS=2000H,SI=1000H,则该指令源操作数的物理地址为:2000H10H+1000H=21000H指令中也可以不使用缺省的段寄存器,而另指定其它的段寄存器,这就是段超越。指令指令中写眀段超越前缀从而指定其它的段寄存器。如指令:MOVAX,ES:BX原来BX默认的是DS
9、段寄存器,现在用段超越前缀指定ES段寄存器。用ES:BX计算出源操作数的物理地址。寄存器间接寻址方式中EA可以表示为BXBPSIDIEA5、寄存器相对寻址在寄存器相对寻址中,有效地址EA是位移量值和16位寄存器(BX、BP、SI、DI之一)的内容之和。可表示为:BXBP8位位移量SI或16位位移量DI【例】MOVAX,CountBPAX(SS:BPCount)指令中Count表示8位或16位位移量,如果Count8,BP20H,SS1F00H,则存储器单元物理地址1F00H10H20H81F028H。即:AX(1F028H)EA寄存器相对寻址指令可以有下面两种形式:即:MOVAX,CountB
10、P或:MOVAX,Count+BP两种形式等价。6、基址加变址寻址方式基址加变址寻址方式中,操作数的有效地址是一个基址寄存器(BX或BP)和一个变址寄存器(SI或DI)的内容之和。EABXBPSIDI由基址寄存器决定哪一个段寄存器作为默认段寄存器。若基址寄存器为BX时,段寄存器使用DS;若基址寄存器为BP时,段寄存器则用SS;若在指令中规定了段超越,也可用其它段寄存器作地址基准。【例】MOVCL,BXSI指令的执行:CL(DS:BXSI)指令中源操作数有效地址为BX内容与SI内容之和。上面指令也可以写为:MOVCL,BX+SI7、基址加变址相对寻址方式这种寻址方式中,操作数的有效地址是一个基址
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 指令系统 PPT 课件
限制150内