ttxs_2013 发表于 2013-10-31 19:53:10

课后检测点11.4

关于pushf和popf的用法
1 mov ax,0
2 push ax
3 popf
4 mov ax,0fff0h
5 add ax,0010h
6 pushf
7 pop ax
8 and al,11000101B
9 and ah,00001000B

pushf:将标志寄存器的值压入栈
popf:从栈中弹出数据,送入标志寄存器
第3行popf 栈中数据送入标志寄存器,标志寄存器有那么多位,送入的是哪位呢?同样的pushf标志寄存器的值指的是什么值?哪一位的?
这两个指令需要说明的是什么问题?有什么作用?不太明白!


福禄娃娃 发表于 2013-10-31 21:36:02

标志寄存器有16位,入栈出栈每次操作一个字,也就是16位。不是送入哪一位,而是把EFLAG标志寄存器的值压入栈中。
可参考书的211页的flag寄存器各位示意图


popf后,标志寄存器中,本章节介绍的那些标志位都为0(但是此时标志寄存器并不是所有位置都为0,这个不用关心,没学过的位置用*先代替),向下进行,那么pushf将计算后的当时状态的标志寄存器入栈,然后pop给ax,这是ax是寄存器的值(这个值中包含了我们的*号),接下来就是对那些没有学过的标志位的屏蔽操作,这就是最后两条指令的意义所在,将不确定的位置都归0,那么只剩下我们能够确定的位置了,所以,结果就可以推理出来了。

mov ax,0   

push ax   

popf   

mov ax,0fff0h   

add ax,0010h   

pushf

pop ax               0000of df if tf sf zf 0af 0pf 0cf

                     000000**010*0101

                     ax=flag=000000** 010*0101b

and al,11000101B   al=01000101b=45h

and ah,00001000B   ah=00000000b=0h

忘掉自私非爱人 发表于 2013-11-1 18:39:53

福禄娃娃 发表于 2013-10-31 21:36 static/image/common/back.gif
标志寄存器有16位,入栈出栈每次操作一个字,也就是16位。不是送入哪一位,而是把EFLAG标志寄存器的值压入栈 ...

版主你回复的太快了搞得我们都木有帮助别人的机会{:7_177:}

ttxs_2013 发表于 2013-11-2 12:34:35

嗯,明白了。
页: [1]
查看完整版本: 课后检测点11.4