您的位置:首页 > 运维架构 > Linux

Linux 内核文件操作

2016-01-25 14:13 513 查看
正常思路是应用里读取文件内容,再通过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;
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  kernel filp_open 文件