免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12下一页
最近访问板块 发新帖
查看: 3714 | 回复: 10
打印 上一主题 下一主题

[C] c语言的i386汇编问题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2007-08-20 20:17 |只看该作者 |倒序浏览
int p1(int x,int y)
  {
    return x+y;
  }

int main(void)
{
     int x,y,z;
     x=1;
      y=2;
      z=p1(x,y);
}
反汇编
main
{.
.
  80484b4:       c7 45 fc 01 00 00 00   movl   $0x1,0xfffffffc(%ebp)
80484bb:       c7 45 f8 02 00 00 00    movl   $0x2,0xfffffff8(%ebp)
80484c2:       ff 75 f8                pushl  0xfffffff8(%ebp)
80484c5:       ff 75 fc                pushl  0xfffffffc(%ebp)
80484c8:       e8 bf ff ff ff          call   804848c <p1>
.
.
}

0804848c <p1>:
804848c:       55                      push   %ebp
804848d:       89 e5                   mov    %esp,%ebp
804848f:       8b 45 0c                mov    0xc(%ebp),%eax
8048492:       03 45 08                add    0x8(%ebp),%eax
8048495:       c9                      leave
8048496:       c3                      ret
8048497:       90                      nop
谁能给解释一下0xfffffffc(%ebp)是什么意思?

论坛徽章:
0
2 [报告]
发表于 2007-08-20 20:29 |只看该作者
AT&T汇编格式, 表示ebp+0xfffffffc.

论坛徽章:
0
3 [报告]
发表于 2007-08-20 20:48 |只看该作者
原帖由 kornrock 于 2007-8-20 20:17 发表
int p1(int x,int y)
  {
    return x+y;
  }

int main(void)
{
     int x,y,z;
     x=1;
      y=2;
      z=p1(x,y);
}
反汇编
main
{.
.
  80484b4:       c7 45 fc 01 00 00 00    ...

注意这里0xfffffffc是个负数,也就是-12.对应参数x

论坛徽章:
0
4 [报告]
发表于 2007-08-20 20:51 |只看该作者
偏移~

论坛徽章:
7
丑牛
日期:2013-10-18 14:43:21技术图书徽章
日期:2013-11-03 09:58:03辰龙
日期:2014-01-15 22:57:50午马
日期:2014-09-15 07:04:39丑牛
日期:2014-10-16 14:25:222015年亚洲杯之伊朗
日期:2015-03-16 10:24:352015亚冠之城南
日期:2015-05-31 09:52:32
5 [报告]
发表于 2007-08-20 20:54 |只看该作者
原帖由 zx_wing 于 2007-8-20 20:48 发表

注意这里0xfffffffc是个负数,也就是-12.对应参数x

-4吧

论坛徽章:
0
6 [报告]
发表于 2007-08-20 21:21 |只看该作者
原帖由 smalloc 于 2007-8-20 20:54 发表

-4吧

呵呵,是-4,看错了。直接看到p1函数中取参的地方去了,0xc(%ebp)取的参数y的值,0x8(%ebp)取的才是x的值。多谢纠正

论坛徽章:
0
7 [报告]
发表于 2007-08-20 21:35 |只看该作者
这是gas的一个令人迷感的地方

论坛徽章:
0
8 [报告]
发表于 2007-08-20 23:18 |只看该作者
小弟还有一事不明.
p1中
804848f:       8b 45 0c                mov    0xc(%ebp),%eax
8048492:       03 45 08                add    0x8(%ebp),%eax
将传入的两个参数相加.使用ebp+8和ebp+12来寻址两参数.
可我怎摸算都是应该使用ebp+12和ebp+16来寻址.
因为我认为在ebp和参数之间有12个字节:main函数将参数压栈后,call指令将cs(4字节)和ip(4字节)压栈 p1函数中push %ebp将4字节压栈.总共12字节.
小弟菜鸟,请大侠们不要笑话.多多指教.

论坛徽章:
2
2015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:56:11
9 [报告]
发表于 2007-08-21 09:17 |只看该作者
还是INTEL的汇编指令看着舒服。
MOV DWORD PTR [EBP-4],1
MOV DWORD PTR [EBP-8],2

论坛徽章:
0
10 [报告]
发表于 2007-08-21 09:57 |只看该作者
大家谁能给研究一下8楼的问题.谢谢了
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP