免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
楼主: Godbach
打印 上一主题 下一主题

Linux下实现劫持系统调用的总结 [复制链接]

论坛徽章:
36
IT运维版块每日发帖之星
日期:2016-04-10 06:20:00IT运维版块每日发帖之星
日期:2016-04-16 06:20:0015-16赛季CBA联赛之广东
日期:2016-04-16 19:59:32IT运维版块每日发帖之星
日期:2016-04-18 06:20:00IT运维版块每日发帖之星
日期:2016-04-19 06:20:00每日论坛发贴之星
日期:2016-04-19 06:20:00IT运维版块每日发帖之星
日期:2016-04-25 06:20:00IT运维版块每日发帖之星
日期:2016-05-06 06:20:00IT运维版块每日发帖之星
日期:2016-05-08 06:20:00IT运维版块每日发帖之星
日期:2016-05-13 06:20:00IT运维版块每日发帖之星
日期:2016-05-28 06:20:00每日论坛发贴之星
日期:2016-05-28 06:20:00
41 [报告]
发表于 2009-12-08 13:15 |只看该作者
至于怎么inline hook, 方法也很多 , 加jmp或push, ret指令就ok,


那就是WIN下同样需要找到函数的入口地址吧

论坛徽章:
0
42 [报告]
发表于 2009-12-08 13:17 |只看该作者
有些内核函数是导出的, 没导出的从/proc/kallsyms查就ok了。 怎么查vupiggy贴过代码了。

论坛徽章:
0
43 [报告]
发表于 2009-12-08 13:24 |只看该作者
原帖由 Godbach 于 2009-12-8 13:15 发表


那就是WIN下同样需要找到函数的入口地址吧


win下不是很了解, 可以通过解析pe结构也是可以的

论坛徽章:
0
44 [报告]
发表于 2009-12-08 20:18 |只看该作者
这个下次看

论坛徽章:
8
2015年辞旧岁徽章
日期:2015-03-03 16:54:15午马
日期:2015-02-04 12:00:07羊年新春福章
日期:2015-02-04 11:57:56双子座
日期:2014-12-02 11:44:59金牛座
日期:2014-10-08 16:47:08狮子座
日期:2014-08-29 13:37:46巳蛇
日期:2014-08-26 17:32:29NBA常规赛纪念章
日期:2015-05-04 22:32:03
45 [报告]
发表于 2009-12-24 15:41 |只看该作者

回复 #1 Godbach 的帖子

哈哈 好文章啊

论坛徽章:
36
IT运维版块每日发帖之星
日期:2016-04-10 06:20:00IT运维版块每日发帖之星
日期:2016-04-16 06:20:0015-16赛季CBA联赛之广东
日期:2016-04-16 19:59:32IT运维版块每日发帖之星
日期:2016-04-18 06:20:00IT运维版块每日发帖之星
日期:2016-04-19 06:20:00每日论坛发贴之星
日期:2016-04-19 06:20:00IT运维版块每日发帖之星
日期:2016-04-25 06:20:00IT运维版块每日发帖之星
日期:2016-05-06 06:20:00IT运维版块每日发帖之星
日期:2016-05-08 06:20:00IT运维版块每日发帖之星
日期:2016-05-13 06:20:00IT运维版块每日发帖之星
日期:2016-05-28 06:20:00每日论坛发贴之星
日期:2016-05-28 06:20:00
46 [报告]
发表于 2010-01-19 11:26 |只看该作者
修改了1楼中的一个小错误,CR0的WP bit是bit16,而不是bit20. 该位置位的时候是只读模式,清0之后有写权限。
参见intel的手册:
WP Write Protect (bit 16 of CR0) — When set, inhibits supervisor-level procedures
from writing into read-only pages; when clear, allows supervisor-level
procedures to write into read-only pages (regardless of the U/S bit setting;
see Section 4.1.3 and Section 4.6). This flag facilitates implementation of the
copy-on-write method of creating a new process (forking) used by operating
systems such as UNIX.

论坛徽章:
0
47 [报告]
发表于 2010-01-19 12:51 |只看该作者
原帖由 Godbach 于 2010-1-19 11:26 发表
修改了1楼中的一个小错误,CR0的WP bit是bit16,而不是bit20. 该位置位的时候是只读模式,清0之后有写权限。
参见intel的手册:


楼主的那个代码是从abl*版主那借鉴过来的, 原始的代码就有问题。 我也贴一个自己写的宏:


  1. #define CLEAR_CR0       asm ("pushl %eax\n\t"                   \
  2.                                 "movl %cr0, %eax\n\t"           \
  3.                                 "andl $0xfffeffff, %eax\n\t"    \
  4.                                 "movl %eax, %cr0\n\t"           \
  5.                                 "popl %eax");

  6. #define SET_CR0         asm ("pushl %eax\n\t"                   \
  7.                                 "movl %cr0, %eax\n\t"           \
  8.                                 "orl $0x00010000, %eax\n\t"     \
  9.                                 "movl %eax, %cr0\n\t"           \
  10.                                 "popl %eax");
复制代码

评分

参与人数 1可用积分 +15 收起 理由
Godbach + 15 我很赞同

查看全部评分

论坛徽章:
36
IT运维版块每日发帖之星
日期:2016-04-10 06:20:00IT运维版块每日发帖之星
日期:2016-04-16 06:20:0015-16赛季CBA联赛之广东
日期:2016-04-16 19:59:32IT运维版块每日发帖之星
日期:2016-04-18 06:20:00IT运维版块每日发帖之星
日期:2016-04-19 06:20:00每日论坛发贴之星
日期:2016-04-19 06:20:00IT运维版块每日发帖之星
日期:2016-04-25 06:20:00IT运维版块每日发帖之星
日期:2016-05-06 06:20:00IT运维版块每日发帖之星
日期:2016-05-08 06:20:00IT运维版块每日发帖之星
日期:2016-05-13 06:20:00IT运维版块每日发帖之星
日期:2016-05-28 06:20:00每日论坛发贴之星
日期:2016-05-28 06:20:00
48 [报告]
发表于 2010-01-19 12:54 |只看该作者

回复 #47 W.Z.T 的帖子

呵呵,是啊。应该是albcamus兄的笔误吧。本来0xfffeffff就是bit16清0的。

论坛徽章:
36
IT运维版块每日发帖之星
日期:2016-04-10 06:20:00IT运维版块每日发帖之星
日期:2016-04-16 06:20:0015-16赛季CBA联赛之广东
日期:2016-04-16 19:59:32IT运维版块每日发帖之星
日期:2016-04-18 06:20:00IT运维版块每日发帖之星
日期:2016-04-19 06:20:00每日论坛发贴之星
日期:2016-04-19 06:20:00IT运维版块每日发帖之星
日期:2016-04-25 06:20:00IT运维版块每日发帖之星
日期:2016-05-06 06:20:00IT运维版块每日发帖之星
日期:2016-05-08 06:20:00IT运维版块每日发帖之星
日期:2016-05-13 06:20:00IT运维版块每日发帖之星
日期:2016-05-28 06:20:00每日论坛发贴之星
日期:2016-05-28 06:20:00
49 [报告]
发表于 2010-01-19 12:55 |只看该作者
刚刚去WZT兄的博客上学习了。很佩服WZT兄做了那么多安全方面的研究。

论坛徽章:
0
50 [报告]
发表于 2010-01-19 13:06 |只看该作者
原帖由 W.Z.T 于 2010-1-19 12:51 发表


楼主的那个代码是从abl*版主那借鉴过来的, 原始的代码就有问题。 我也贴一个自己写的宏:


#define CLEAR_CR0       asm ("pushl %eax\n\t"                   \
                                "m ...

刚看了w.z.t  hi.baidu上的最新的一篇文章...深有感触!!!看的心里酸酸的
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP