在Linux内核中进行文件的读写操作,在一般情况下
不推荐这样操作,但在不得已时,也是可以实现的.
#include<linux/kernel.h>#include <linux/module.h>
#include <linux/init.h>
#include <linux/fs.h>
#include <linux/string.h>
#include <linux/mm.h>
#include <linux/syscalls.h>
#include <asm/unistd.h>
#include <asm/uaccess.h>
#define MY_FILE"/root/LogFile"
char buf[128];
struct file*file= NULL;
static int __init init(void)
{
mm_segment_t old_fs;
if(file==NULL)
file = filp_open(MY_FILE, O_RDWR| O_APPEND| O_CREAT, 0644);
if (IS_ERR(file)){
printk("error occured while opening file %s, exiting...\n", MY_FILE);
return 0;
}
old_fs = get_fs();
set_fs(KERNEL_DS);
file->f_op->write(file,(char*)buf,sizeof(buf),&file->f_pos);
set_fs(old_fs);
return 0;
}
static void __exit fini(void)
{
if(file!=NULL)
filp_close(file,NULL);
}
module_init(init);
module_exit(fini);
MODULE_LICENSE("GPL");
注意的地方:
set_fs(get_ds())函数的作用是设置进程能访问的虚拟地址的空间范围。
如果不设置,系统会认为是用户空间,只有3G,所以在内核时,特别是
在调用其它的系统调用时,也必须如此,否则,就会出错!!!!!!!