正常思路是应用里读取文件内容,再通过ioctl、write等方式把文件buffer传送到内核,内核里不推荐使用对文件IO直接操作,但是要使用还是可以的。
思路如下:
一、filp_open打开获取句柄,判断指针
二、切换到内核态
三、读取/写入
四、关闭,切换到原来状态
filp_open打开错误返回的并不是NULL,要使用IS_ERR()判断指针是否错误。
测试的时候我用echo update.bin>/dev/xx-device,一直返回错误。单从指针是判断不出错误码。需要从PTR_ERR()获取错误码,读到错误码一直为-2,对照linux错误表里解释为No such file or directiory,仔细看log,原来是echo 自动会内容最后加回车,所以没找到文件。
以下附带个例子,希望对大家调试有帮助。
static char* filp_sample(const char *path, int *len)
{
mm_segment_t old;
struct file * fp = NULL;
char *save;
int size;
struct kstat stat;
loff_t pos=0;
fp = filp_open(real_path, O_RDONLY , 0);
if (IS_ERR(fp))
{
printk("open %s failed,errno:%d\n", path, (int)PTR_ERR(fp));
goto fail;
}
old = get_fs();
set_fs(KERNEL_DS);
vfs_getattr(&fp->f_path, &stat);
size = stat.size;
*len = size;
save = kzalloc(size, GFP_KERNEL);
if (!save)
{
goto fail;
}
vfs_read(fp, save, size, &pos);
filp_close(fp, NULL);
set_fs(old);
return save;
fail:
set_fs(old);
if (!IS_ERR(fp))
filp_close(fp, NULL);
return NULL;
}