1。进入正题前,先说明内核拷贝的一个问题
对于读写等接口 最需要注意的一点是:这种类型接口会调用copy_to_user 或者 copy_from_user
这两个是进行用户空间拷贝
在X86体系结构中 内核调用这个接口必须设置FS段寄存器的值 因为整个拷贝是通过(段寄存器:偏移值寄存器)定位的
FS原来指向用户空间,而DS指向内核空间的段,需要将FS更改成内核空间,完成拷贝操作后,再更改回来。
mm_segment_t oldfs;
oldfs = get_fs();
set_fs(get_ds());
/*
进行内核拷贝
*/
set_fs(oldfs);
下面以文件操作为例
2。在内核中打开文件
当然不能直接调用open() 会莫名其妙不透明的给用户进程安装一个fd,虽然一般不会有恶劣影响,但是相当dirty
规范的做法是调用filp_open() 返回一个file结构指针,保存好别丢了
读写都的传这个指针
同理读写也就直接调用对应驱动的读写
文件关闭调用filp_close()
以上所有调用中,凡是涉及到内核和用户空间拷贝的,通通按照1的做法加到调用的前后,确保拷贝能正常进行。