免费注册 查看新帖 |

Chinaunix

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

[内核模块] 截获文件操作,通过修改vfs文件系统的函数 [复制链接]

论坛徽章:
0
11 [报告]
发表于 2013-08-26 15:38 |只看该作者
在截获文件操作这个模块,如何获取文件的操作模式?file->f_mode的返回值为什么是int,如何转换为“read”,“write”?

论坛徽章:
6
金牛座
日期:2013-10-08 10:19:10技术图书徽章
日期:2013-10-14 16:24:09CU十二周年纪念徽章
日期:2013-10-24 15:41:34狮子座
日期:2013-11-24 19:26:19未羊
日期:2014-01-23 15:50:002015年亚洲杯之阿联酋
日期:2015-05-09 14:36:15
12 [报告]
发表于 2013-08-26 19:19 |只看该作者
回复 11# luocaizhu
在截获文件操作这个模块,如何获取文件的操作模式?file->f_mode的返回值为什么是int,如何转换为“read”,“write”?


看include/linux/fs.h文件

FMODE_READ/FMODE_WRITE

论坛徽章:
22
丑牛
日期:2014-08-15 14:32:0015-16赛季CBA联赛之同曦
日期:2017-12-14 15:28:14黑曼巴
日期:2017-08-10 08:14:342017金鸡报晓
日期:2017-02-08 10:39:42黑曼巴
日期:2016-11-15 15:48:38CU十四周年纪念徽章
日期:2016-11-09 13:19:1015-16赛季CBA联赛之同曦
日期:2016-04-08 18:00:03平安夜徽章
日期:2015-12-26 00:06:30程序设计版块每日发帖之星
日期:2015-12-03 06:20:002015七夕节徽章
日期:2015-08-21 11:06:17IT运维版块每日发帖之星
日期:2015-08-09 06:20:002015亚冠之吉达阿赫利
日期:2015-07-03 08:39:42
13 [报告]
发表于 2013-08-26 21:12 |只看该作者
都是搞x86的人啊。好孤独的感觉

论坛徽章:
0
14 [报告]
发表于 2013-08-28 16:38 |只看该作者
参考这个代码修改内核,截获文件操作,http://www.java123.net/detail/view-402565.html,但是不能捕获所有一类型的文件操作(比如我修改的是ext3),一直都只能截获到两个进程的 pid is 7506,comm is rpmq;
pid is 7600,comm is yum-updatesd-he,不知道什么原因呢?

论坛徽章:
6
金牛座
日期:2013-10-08 10:19:10技术图书徽章
日期:2013-10-14 16:24:09CU十二周年纪念徽章
日期:2013-10-24 15:41:34狮子座
日期:2013-11-24 19:26:19未羊
日期:2014-01-23 15:50:002015年亚洲杯之阿联酋
日期:2015-05-09 14:36:15
15 [报告]
发表于 2013-08-29 14:26 |只看该作者
回复 14# luocaizhu
strace跟踪一下其他进程的系统调用,看看是否走到了你hook的流程?

   

论坛徽章:
0
16 [报告]
发表于 2013-08-29 15:46 |只看该作者
本帖最后由 luocaizhu 于 2013-09-04 14:32 编辑

恩,问题解决了,把代码中必须打开具体的普通文件,不可以是目录文件,不知道是什么原因呢,是不是创建目录和文件的inode不一样吧?!

论坛徽章:
1
拜羊年徽章
日期:2015-03-03 16:15:43
17 [报告]
发表于 2013-08-30 07:11 |只看该作者
回复 13# amarant

Which processor family are you working on:  ARM or MIPS?


   

论坛徽章:
0
18 [报告]
发表于 2013-08-30 14:36 |只看该作者
参考代码http://www.java123.net/detail/view-402565.html,我在函数中加入了写入文件操作,系统崩溃,单独测试文件读写模块没有问题,加入到这个截获io模块,在这个地方系统就崩溃了(其他代码测试过没问题),不知道什么原因呢,请高手指教,代码如下:ssize_t encry_read(struct file *file , char *buf , size_t count , loff_t *ppos)
{

char buf1[10] ;
    mm_segment_t old_fs;old_fs = get_fs();
struct file *log_file=NULL;
               if(log_file == NULL)
                log_file = filp_open("/usr/tmp/file_test", O_RDWR | O_APPEND | O_CREAT, 0644);
        if (IS_ERR(log_file)) {
                printk("error occured while opening file , exiting...\n");
                return 0;
        }

    sprintf(buf1,"myname");      
        
        set_fs(KERNEL_DS);
       log_file->f_op->write(log_file, (char *)buf1, sizeof(buf1), &log_file->f_pos);

        set_fs(old_fs);
        filp_close(log_file, NULL);  

论坛徽章:
6
金牛座
日期:2013-10-08 10:19:10技术图书徽章
日期:2013-10-14 16:24:09CU十二周年纪念徽章
日期:2013-10-24 15:41:34狮子座
日期:2013-11-24 19:26:19未羊
日期:2014-01-23 15:50:002015年亚洲杯之阿联酋
日期:2015-05-09 14:36:15
19 [报告]
发表于 2013-08-30 14:47 |只看该作者
回复 18# luocaizhu
写入文件的操作是会睡眠的,不知道你使用的地方是否考虑这个因素。另外可否把panic信息,内核版本说一下

   

论坛徽章:
22
丑牛
日期:2014-08-15 14:32:0015-16赛季CBA联赛之同曦
日期:2017-12-14 15:28:14黑曼巴
日期:2017-08-10 08:14:342017金鸡报晓
日期:2017-02-08 10:39:42黑曼巴
日期:2016-11-15 15:48:38CU十四周年纪念徽章
日期:2016-11-09 13:19:1015-16赛季CBA联赛之同曦
日期:2016-04-08 18:00:03平安夜徽章
日期:2015-12-26 00:06:30程序设计版块每日发帖之星
日期:2015-12-03 06:20:002015七夕节徽章
日期:2015-08-21 11:06:17IT运维版块每日发帖之星
日期:2015-08-09 06:20:002015亚冠之吉达阿赫利
日期:2015-07-03 08:39:42
20 [报告]
发表于 2013-08-30 18:38 |只看该作者
回复 17# linuxfellow


    mips
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP