码迷,mamicode.com
首页 > 系统相关 > 详细

Linux中程序的栈帧分析以及修改函数地址

时间:2016-06-23 01:15:18      阅读:270      评论:0      收藏:0      [点我收藏+]

标签:linux   栈帧分析   修改函数地址   

下面有一段代码:
#include <stdio.h>
#include <unistd.h>
#include <stdlib.h>

void fun()
{
   printf("i am the evil func\n");
   exit(1);
}

int fun1(int a,int b)
{
    int *p=&a;
    p--;
    *p=fun;
    int c=0xcccc;
    return c;
}

int main()
{
    printf("begin run..\n");
    int a=0xaaaa;
    int b=0xbbbb;
    fun1(a,b);
    printf("right end");
    return 0;
    
}

linux下执行结果:

main调用fun1调用fun---exit退出

对于此结果的问题:

明明没有调用fun函数,为什么会执行fun函数,函数是如何进行跳转的?

栈帧是怎么样保存信息并返回的?

分析原因:

查看汇编代码中的重要的栈段

技术分享

技术分享

简易栈帧图


技术分享

下面一个程序通过指针访问变量y的值,而不是变量名y

#include <stdio.h>

int fun(int x,int y)
{
    int *p = x;
    p--;
    return *p;
}

int main()
{
    int x=1;
    int y=2;
    int ret=fun(x,y);
    printf("y的值是%d\n"ret);
    return 0;
}

原理就是p-->x,p--之后,p指向y

此时*p访问的就是y的值

本文出自 “momo就是辣么萌” 博客,请务必保留此出处http://momo462.blog.51cto.com/10138434/1791894

Linux中程序的栈帧分析以及修改函数地址

标签:linux   栈帧分析   修改函数地址   

原文地址:http://momo462.blog.51cto.com/10138434/1791894

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!