免费注册 查看新帖 |

Chinaunix

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

关于劫持系统调用 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2006-11-10 16:30 |只看该作者 |倒序浏览
附件是一个劫持exit的系统调用的Module,但是为什么不起作用呢?
而我在内核中自己加了一个Mycall的系统调用,然后用同样的方法劫持就可以劫持。
这是为什么呢?
请赐教!  我的内核是2.6.15

[ 本帖最后由 zqx431 于 2006-11-10 16:31 编辑 ]

exit.tar

10 KB, 下载次数: 39

论坛徽章:
0
2 [报告]
发表于 2006-11-10 21:33 |只看该作者
直接根据system.map中的地址修改不行吗?

论坛徽章:
0
3 [报告]
发表于 2006-11-13 14:16 |只看该作者
可以直接根据system.map中的地址修改。我实验了。

另外我还找到一下方法:

static void get_sys_call_table1(void) {
        unsigned long* ptr;
        int i;
        int arr[4];
        ptr=(unsigned long *)((init_mm.end_code + 4) & 0xfffffffc);
        while((unsigned long )ptr < (unsigned long)init_mm.end_data)
        {
                if (*ptr == (unsigned long *)sys_open) { /* The hit has happend! */
                      printk (KERN_INFO" -> matching detected at %p\n", ptr);
                        /* The pointers mast point to kernel code section... */
                        for(i = 0; i < 4 ;i++)
                        {
                                arr[i]=*(ptr+i);
                                arr[i]=(arr[i] >> 16) & 0x0000ffff;
                        }
                        /* And they does not mast match... */
                        if(arr[0] != arr[2] || arr[1] != arr[3])
                        {
                                sys_call_table=(ptr-__NR_open);
                                break;
                        }

                }
        ptr++; /* The next one... */
        }
        printk (KERN_INFO"[1] sys_call_table1 base found at: 0x%p\n",sys_call_table);
}

其中为什么要进行arr[i]=(arr[i] >> 16) & 0x0000ffff;这个操作,什么意思?
if(arr[0] != arr[2] || arr[1] != arr[3])???

论坛徽章:
0
4 [报告]
发表于 2006-11-17 10:34 |只看该作者
这类例子多了,CU就有很多,自己搜索搜索吧(呵呵,偷个懒,我当初就是自己google的)
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP