免费注册 查看新帖 |

Chinaunix

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

get system call table in x86-64 Linux - 欢迎测试并报BUG [复制链接]

论坛徽章:
0
11 [报告]
发表于 2008-02-19 11:56 |只看该作者
谢谢
看了两个文档,讲cr0寄存器,
主要就是将WP位清为0,这时候可以改写只读的page,即可以修改syscall_table的page
不知道这么理解对不对。

论坛徽章:
0
12 [报告]
发表于 2008-02-19 11:57 |只看该作者
还是amd的讲的清楚一些,intel的太难懂了

论坛徽章:
0
13 [报告]
发表于 2008-12-20 12:18 |只看该作者
64位下需要修改cr0寄存器的第16位。
楼主的代码找的地址,后32位是正确的,与/boot/System.map中一致。但是前32位就有问题了。

论坛徽章:
3
金牛座
日期:2014-06-14 22:04:062015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:49:45
14 [报告]
发表于 2008-12-20 22:11 |只看该作者
原帖由 anhongkui 于 2008-2-19 11:57 发表
还是amd的讲的清楚一些,intel的太难懂了



能提供AMD相关详细手册么?

论坛徽章:
0
15 [报告]
发表于 2008-12-20 22:26 |只看该作者
这个工作似乎进一步,用户程序能够不通过Socket接口直接从网卡抓包,就有了非纸上的意义。

论坛徽章:
0
16 [报告]
发表于 2008-12-22 14:31 |只看该作者
原帖由 caravsapm70 于 2008-12-20 12:18 发表
64位下需要修改cr0寄存器的第16位。
楼主的代码找的地址,后32位是正确的,与/boot/System.map中一致。但是前32位就有问题了。



cr0.WP和32位、64位没什么关系, 都一样。

哪个符号的前32位错了? sys_call_table还是ia32_sys_call_table?

PS, 这个例子就是当时刚买了一台AMD64的笔记本, 练手的。  真正想知道这两个syscall table的地址,简单的无以复加: 直接读MSR_LSTAR和MSR_CSTAR这两个MSR寄存器就行了。

论坛徽章:
0
17 [报告]
发表于 2010-12-06 09:10 |只看该作者
你少了个这个:最后那行。。。。所以得到的地址与/boot/System.map中的不一致,
We obtain :
        readkmem (sc_asm,sys_call_off,CALLOFF);
        p = (char*)memmem (sc_asm,CALLOFF,"\xff\x14\xc5",3);
        sct = *(unsigned long*)(p+3);
        sct = (sct & 0x00000000ffffffff) | 0xffffffff00000000;

论坛徽章:
0
18 [报告]
发表于 2010-12-06 09:13 |只看该作者
本帖最后由 renyuan000 于 2010-12-06 10:11 编辑

http://developer.amd.com/documentation/guides/Pages/default.aspx
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP