免费注册 查看新帖 |

Chinaunix

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

[函数] 计算函数大小/长度,移动到新位置并执行? [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2005-12-27 14:23 |只看该作者 |倒序浏览
如题。

    如果想把一个函数从一个位置转移到另一个位置,并执行之,在c中如何实现?这个问题在汇编中很容易实现。如果想用c来写的话,该如何做?

[ 本帖最后由 flightbird 于 2005-12-27 16:56 编辑 ]

论坛徽章:
1
荣誉版主
日期:2011-11-23 16:44:17
2 [报告]
发表于 2005-12-27 14:34 |只看该作者
&, memcpy, change the EIP register?

论坛徽章:
0
3 [报告]
发表于 2005-12-27 14:46 |只看该作者
什么叫把函数从一个为止移动到另一个位置?

论坛徽章:
0
4 [报告]
发表于 2005-12-27 15:01 |只看该作者
同感

论坛徽章:
0
5 [报告]
发表于 2005-12-27 15:06 |只看该作者
原帖由 albcamus 于 2005-12-27 14:46 发表
什么叫把函数从一个为止移动到另一个位置?


比如函数fun位于:&fun, 现在想把它的代码移动到0x1000处,并且在这个地方执行这个函数,假设没有参数调用。

论坛徽章:
1
荣誉版主
日期:2011-11-23 16:44:17
6 [报告]
发表于 2005-12-27 15:09 |只看该作者
估计就是像引导程序刚开始那样一顿挪位置。

论坛徽章:
0
7 [报告]
发表于 2005-12-27 15:20 |只看该作者

  1. #include <stddef.h>
  2. #include <stdio.h>
  3. #include <stdlib.h>
  4. #include <string.h>

  5. int a(int n)
  6. {
  7.     return n*2;
  8. }

  9. int b(int n)
  10. {
  11.     return n/2;
  12. }

  13. int main()
  14. {
  15.     unsigned char *p = a;
  16.     ptrdiff_t diff = b - a;
  17.     int i;
  18.     int (*f)(int);

  19.     printf("%p:", p);
  20.     for (i=0; i<diff; i++)
  21.         printf(" %02x", p[i]);
  22.     printf("\n");

  23.     f = malloc(diff);
  24.     memmove(f, a, diff);
  25.     printf("function f(100) returns %d\n", f(100));
  26.     free(f);

  27.     return 0;
  28. }
复制代码

是否楼主要的效果?

论坛徽章:
0
8 [报告]
发表于 2005-12-27 15:32 |只看该作者
ELF文件规范允许这么干吗?

或者,就象缓冲区溢出的shell code那样,把数据区当成代码来执行。但这样你需要获得该函数栈帧的大小,有办法吗?

论坛徽章:
2
2015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:56:11
9 [报告]
发表于 2005-12-27 15:43 |只看该作者
这就是动态连接库所要解决的问题

论坛徽章:
2
2015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:56:11
10 [报告]
发表于 2005-12-27 15:55 |只看该作者
LZ,我给您提供一条建议,首先学会exec中的代码,然后您就知道该怎做了
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP