OpenEuler中C语言中的函数调用测试

C语言中的函数调用

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指令在64位的机器上产生32位汇编,然后使用gdb main指令进入gdb调试器:
  • 进入之后先在main函数处设置一个断点,再run一下,使用disassemble指令获取汇编代码,用i(info) r(registers)指令查看各寄存器的值:

    看到这一步的时候u,v被压入栈中

    所以u,v栈的地址为

longjump

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");
}

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);
}
  • 在64位Linux中,编译t.c生成64位汇编的t.s文件:

    然后,编辑t.s文件,删除编译器生成的非必要行,并添加注释来解释代码操作。下面给出了带有添加的注释行的简化t.s文件。

openeuler环境下只能运行64位.C代码

posted @ 2021-12-02 17:33  20191213兰毅达  阅读(57)  评论(0编辑  收藏  举报