您好,欢迎访问三七文档
当前位置:首页 > 电子/通信 > 综合/其它 > 计算机系统基础第二次作业
计算机系统基础第二次作业3、对于以下AT&T格式汇编指令,根据操作数的长度确定对应指令助记符中的长度后缀,并说明每个操作数的寻址方式。(1)mov8(%ebp,%ebx,4),%ax(2)mov%al,12(%ebp)(3)add(,%ebx,4),%ebx(4)or(%ebx),%dh(5)push$0xF8(6)mov$0xFFF0,%eax(7)test%cx,%cx(8)lea8(%ebx,%esi),%eax答:如下表所示:题目编号长度后缀源操作数目的操作数(1)w基址+比例变址+位移寄存器(2)b寄存器基址+位移(3)l比例变址寄存器(4)b基址寄存器(5)l立即数栈(6)l立即数寄存器(7)w寄存器寄存器(8)l基址+变址+位移寄存器4.使用汇编器处理以下各行AT&T格式代码时都会产生错误,请说明每一行存在什么错误。(1)movl0xFF,(%eax)(2)movb%ax,12(%ebp)(3)addl%ecx,$0xF0(4)orw$0xFFFF0,(%ebx)(5)addb$0xF8,(%dl)(6)movl%bx,%eax(7)andl%esi,%esx(8)movw8(%ebp,,4),%ax答:(1)书写错误。因为源操作数是立即数0xFF,所以需要在前面加上‘$’(2)由于源操作数(%ax)是16位,而长度后缀是字节‘b’,所以不一致,应改为‘movw’(3)目的操作数不能是立即数寻址(4)操作数位数超过16位,而长度后缀为16位的‘w’,应改为‘orl’(5)不能用8位寄存器作为目的操作数地址所在寄存器(6)源操作数寄存器与目的操作数寄存器长度不一致(7)不存在ESX寄存器(8)源操作数地址中缺少变址寄存器7.假设变量x和y分别存放在寄存器EAX和ECX中,请给出以下每条指令执行后寄存器EDX中的结果。(1)leal(%eax),%edx(2)leal4(%eax,%ecx),%edx(3)leal(%eax,%ecx,8),%edx(4)leal0xC(%ecx,%eax,2),%edx(5)leal(,%eax,4),%edx(6)leal(%eax,%ecx),%edx答:(1)R[edx]=x//把eax的值放到edx中去(2)R[edx]=x+y+4//把eax+ecx+4的值放到edx中去(3)R[edx]=x+8*y//把eax+8*ecx的值放到edx中去(4)R[edx]=y+2*x+12//把ecx+2*eax+12的值放到edx中去(5)R[edx]=4*x//把4*eax的值放到edx中去(6)R[edx]=x+y//把eax+ecx的值放到edx中去8.假设以下地址以及寄存器中存放的机器数如下表所示地址机器数寄存器机器数0x80493000xfffffff0EAX0x80493000x80494000x80000008EBX0x1000x80493840x80f7ff00ECX0x100x80493800x908f12a8EDX0x80分别说明执行以下指令或寄存中的内容交发生改变?改变后的内容是什么条件标志OF、SF、ZF和CF会发生什么改变。(1)指令功能为:R[edx]←R[edx]+M[R[eax]]=0x00000080+M[0x8049300],寄存器EDX中内容改变。改变后的内容为以下运算的结果:00000080H+FFFFFFF0H00000000000000000000000010000000+11111111111111111111111111110000_______________________________________________100000000000000000000000001110000因此,EDX中的内容改变为0x00000070。根据表3.5可知,加法指令会影响OF、SF、ZF和CF标志。OF=0,ZF=0,SF=0,CF=1。(2)指令功能为:R[ecx]←R[ecx]-M[R[eax]+R[ebx]]=0x00000010+M[0x8049400],寄存器ECX中内容改变。改变后的内容为以下运算的结果:00000010H-80000008H。00000000000000000000000000010000+01111111111111111111111111111000_______________________________________________010000000000000000000000000001000根据表3.5可知,减法指令会影响OF、SF、ZF和CF标志。OF=1,ZF=0,SF=1,CF=10=1。(3)指令功能为:R[bx]←R[bx]orM[R[eax]+R[ecx]*8+4],寄存器BX中内容改变。改变后的内容为以下运算的结果:0x0100orM[0x8049384]=0100HorFF00H0000000100000000or1111111100000000_______________________________________________1111111100000000因此,BX中的内容改为0xFF00。由3.3.3节可知,OR指令执行后OF=CF=0;因为结果不为0,故ZF=0;因为最高位为1,故SF=1。(4)test指令不改变任何通用寄存器,但根据以下“与”操作改变标志:R[dl]and0x8010000000and10000000__________________10000000由3.3.3节可知,TEST指令执行后OF=CF=0;因为结果不为0,故ZF=0;因为最高位为1,故SF=1。(5)指令功能为:M[R[eax]+R[edx]]←M[R[eax]+R[edx]]*32,即存储单元0x8049380中的内容改变为以下运算的结果:M[0x8049380]*32=0x908f12a8*32,也即只要将0x908f12a8左移5位即可得到结果。100100001000111100010010101010005=00010001111000100101010100000000因此,指令执行后,单元0x8049380中的内容改变为0x11e25500。显然,这个结果是溢出的。但是,根据表3.5可知,乘法指令不影响标志位,也即并不会使OF=1。(6)指令功能为:R[cx]←R[cx]-1,即CX寄存器的内容减一。0000000000010000+1111111111111111_________________________10000000000001111因此,指令执行后CX中的内容从0x0010变为0x000F。由表3.5可知,DEC指令会影响OF、ZF、SF,根据上述运算结果,得到OF=0,ZF=0,SF=0。
本文标题:计算机系统基础第二次作业
链接地址:https://www.777doc.com/doc-4934470 .html