免费注册 查看新帖 |

Chinaunix

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

简单汇编函数调用出错 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2010-04-06 00:19 |只看该作者 |倒序浏览
这几天正在学习汇编,函数调用老出错,各位大哥帮忙讲解下
     
  .section .data
format1:
        .ascii  "%%eax : %d\n"
        .ascii  "%%ebx : %d\n"
        .byte   0

format2:
        .ascii  "result : %d\n"
        .byte   0

        .section .text
        .globl  add1
add1:
/*      popl    %ebx                      //这里就是取出靠压栈传进来的两个参数,但是出问题,就改成下面的mov取值了
        popl    %eax*/
        movl    (%esp), %ebx
        movl    4(%esp), %eax       //取出两个值,后相加放入%eax
        addl    %ebx, %eax
/*      pushl   %eax*/
        movl    %eax, (%esp)         //再把返回值放回栈中,前边试过pop、push来代替这个,不过出现莫名其妙的错误,所以换了这个
        ret

        .globl  _start
_start:
        pushl   $4
        pushl   $10
        call    add1
/*      popl    %eax*/
        movl    (%esp), %eax               //调用add1结束,把在esp栈顶存放在返回值取出
        addl    $8, %esp                        //然后add1的两个参数从栈中取出
        pushl   %eax                              //为调用printf传参
        pushl   $format2
        call    printf
        addl    $8, %esp
        pushl   $0
        call    exit

#################################3
这个问题好郁闷啊,我感觉没什么问题啊,试了popl、pushl也没解决问题,试了这个
也不对,很奇怪。运行提试段错误。

各位大哥救急啊!

论坛徽章:
0
2 [报告]
发表于 2010-04-06 09:03 |只看该作者
本帖最后由 qtdszws 于 2010-04-06 09:10 编辑

movl    (%esp), %ebx
movl    4(%esp), %eax

改成

movl    4(%esp), %ebx
movl    8(%esp), %eax


movl    %eax, (%esp)

改成

movl    %eax, 4(%esp)


因为(%esp)中存放的是返回地址,你把它冲掉了

论坛徽章:
3
2015年迎新春徽章
日期:2015-03-04 09:56:11数据库技术版块每日发帖之星
日期:2016-08-03 06:20:00数据库技术版块每日发帖之星
日期:2016-08-04 06:20:00
3 [报告]
发表于 2010-04-06 14:38 |只看该作者
.section .data
format1:
        .ascii  "%%eax : %d\n"
        .ascii  "%%ebx : %d\n"
        .byte   0

format2:
        .ascii  "result : %d\n"
        .byte   0

        .section .text
        .globl  add1
add1:
/*      popl    %ebx                      //这里就是取出靠压栈传进来的两个参数,但是出问题,就改成下面的mov取值了
        popl    %eax*/
        movl    8(%esp), %ebx
        movl    4(%esp), %eax       //取出两个值,后相加放入%eax
        addl    %ebx, %eax
/*      pushl   %eax*/
     //   movl    %eax, (%esp)         //再把返回值放回栈中,前边试过pop、push来代替这个,不过出现莫名其妙的错误,所以换了这个
        ret

        .globl  _start
_start:
        pushl   $4
        pushl   $10
        call    add1
/*      popl    %eax*/
   //     movl    (%esp), %eax               //调用add1结束,把在esp栈顶存放在返回值取出
        addl    $8, %esp                        //然后add1的两个参数从栈中取出
        pushl   %eax                              //为调用printf传参
        pushl   $format2
        call    printf
        addl    $8, %esp
        pushl   $0
        call    exit

论坛徽章:
0
4 [报告]
发表于 2010-04-06 15:49 |只看该作者
movl    (%esp), %ebx
movl    4(%esp), %eax

改成

movl    4(%esp), %ebx
movl    8(%esp), %eax
...
qtdszws 发表于 2010-04-06 09:03



    感谢大哥相救!嚯嚯

论坛徽章:
0
5 [报告]
发表于 2010-04-06 15:52 |只看该作者
.section .data
format1:
        .ascii  "%%eax : %d\n"
        .ascii  "%%ebx : %d\n"
        .b ...
cjaizss 发表于 2010-04-06 14:38



    非常感谢!
我试试先
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP