这是我从内核写入文件的代码。(我知道直接从内核读写不是一个好主意,但这只是一个测试)。
static void write_startup_file(char *startstring)
mm_segment_t oldfs;
struct file *f;
loff_t pos=0;
f = filp_open("/bin/startupcheck",O_WRONLY|O_CREAT, 0644);
oldfs = get_fs();
set_fs (KERNEL_DS);
if(f)
vfs_write(f,startstring, strlen(startstring), &pos);
set_fs(oldfs);
filp_close(f, NULL);
printk(KERN_CRIT "Unable to open startfile...\n");
而我在另一个函数ourVeryOwnFunction()
中调用它,如
if(dbval==NULL) { write_startup_file("FAILED");}
其中dbval
是一个正在读取的值。但当我编译内核并运行它时(我在vmware上运行它)。我得到的内核恐慌是here
很明显,我做错了什么。希望得到一些帮助。谢谢。