ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

2.4 OpenEuler中C语言中的函数调用测试(选做)

2021-12-05 13:34:32  阅读:173  来源: 互联网

标签:选做 sub int 代码 函数调用 C语言 jump printf main


任务详情

  1. 在X86_64架构下实践2.4中的内容
  2. 通过GDB查看寄存器的内容,把教材中的图填入具体的值
  3. 把2.4的C代码在OpenEuler中重新实践一遍,绘制出ARM64的逻辑框图
  4. 实验内容要经过答辩才能得到相应分数

一、32位gcc中的运行时堆栈使用情况

main.c代码:

main(){
int a,b,c;
a=1;b=2;c=3;
c=sub(a,b);
printf("c=%d\n",c);
}

sub.c代码

int sub(int x,int y){
        int u,v;
        u=4;v=5;
        return x+y+u+v;
}

使用指令gcc -g main.c sub.c -o main -m32进入gdb调试
在main处设置断点

disas:查看汇编代码

i(info) r(registers):查看寄存器的值

可以看到U和v入栈(int的字节为4)
以及他们存放的地址

传递参数:此时pc指向的是sub()的入口地址

进入sub后的堆栈内容:现在我们已经知道u、v的内容以及物理地址

我们可以由此写出函数的调用序列。

long jump

代码:

include<stdio.h>
#include<setjmp.h>
jmp_buf env;

int main()
{
        int r,a=100;
        printf("call setjmp to save environmen\n");
        if((r=setjmp(env))==0){
                A();
                printf("normal return\n");
        }
        else
                printf("back to main() via long jump,r=%d,a=%d",r,a);
}

int A()
{
        printf("enter A()\n");
        B();
        printf("exit A()\n");

}

int B()
{
        printf("enter B()\n");
        printf("long jump?(y|n) ");
        if(getchar()=='y')
                longjmp(env,1234);
        printf("exit B()\n");
}

编译指令:gcc jump.c -o jump -m32
运行结果:
运行结果

在main处设置断点,查看汇编代码:

二、64位gcc中的运行时堆栈使用情况

代码:

#include <stdio.h>
int sub(int a, int b, int c, int d, int e, int f, int g, int h)
{
int u, v, w;
u = 9;
v = 10;
w= 11;
return a+g+u+v;
}

int main()
{
int a, b, c, d, e,f, g, h,i;
a = 1;
b = 2;
c = 3;
d = 4;
e = 5;
f = 6;
g = 7;
h = 8;
i = sub(a,b,c,d,e,f,g,h);
}

运行结果:
不会产生结果。
生成.s文件,查看汇编代码:

标签:选做,sub,int,代码,函数调用,C语言,jump,printf,main
来源: https://www.cnblogs.com/zzjjyy123/p/15645287.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有