注册 登录
编程论坛 汇编论坛

一段反汇编的代码谁帮我解释下!特别是里面几个左右移的命令!

wtyj112 发布于 2010-05-04 21:01, 855 次点击
linux下的gaz格式代码
一个函数的汇编码:
函数头为  int  decode2 (int x, int y, int z);
参数x y z分别放在相对于寄存器%ebp中的地址偏移量为8 12 16 的地方返回值 放在%eax
1   movl 16(%ebp), %eax
2   movl 12(%ebp), %edx
3   subl %eax, %edx
4   movl %edx, %eax
5   imull 8(%ebp), %edx
6   sall  $31, %eax
7   sarl  $31, %eax
8   xorl  %edx, %eax

前面挺好理解就是最后三句 左移31位 接着算术右移31位 是为了让eax全为1吗? 但是好像最低的一位是不能清为0的吧?
谁能给我解释下最后三句的含义!如果有人能给我反汇编成c代码最好了 谢谢啊!
1 回复
#2
ONEPROBLEM2010-05-05 08:09
这题我也整不明白,就说点自己所能理解的吧:

1.在函数int decode2中,不知道是哪个数先入栈的,我当作是最左边的先入栈。
所以,前5句就可理解为:(y-z)*x

2.imul是带位扩展的乘法指令,如果结果是在32位以内,则当(y-z)*x结果为负数时,edx全为1,否则全为0;

3.当(y-Z)*x结果是偶数或奇数时,通过xor指令,则有如下返回值:
结果  返回
负偶   -1
负奇   0
正偶   0
正奇   -1
水平有限,我就明白到地步了
1