drivers中file_operations的mmap操作的作用是:
将设备驱动内核空间的内存映射到用户空间里,能够经过用户空间中的mmap体系调用替代体系调用write和read。意图是进步读写功率。
体系调用mmap:
void* mmap (caddr_t addr, size_t len, int prot, int flags, off_t offset)
其间addr一般为NULL,意图是使内核自动分配可用的虚拟空间地址,并经过回来值回来,并与MAP_FAILED比较;
prot一般为PROT_WRITE | PROT_READ; flags为MAP_SHARED或MAP_PRIVATE之一;offset表明从设备文件都开端多大偏移处映射,一般为0。
文件操作mmap :
int (*mmap) (struct file* filp, struct vm_area_struct* vma)
界说struct vm_operaTIons_struct xxx_vm_ops = {
.open = xxx_vm_open,
.close = xxx_vm_close,
.nopage = xxx_vm_nopage,
};
编写mmap文件操作函数的方法有两种:
一.运用remap_pfn_range一次性请求,不需要界说nopage函数
1.在mmap中调用remap_pfn_range;
2.在mmap中对vma->vm_ops进行附值;
3.在mmap结尾处自动调用vm_ops中的open;
二.界说nopage函数,在产生缺页时由内核请求内存中的物理页,由driver在nopage中将page与vma挂钩
1.mmap中除了对vma->vm_ops进行附值和自动调用vm_ops中的open外;
2.将设备内存首要按PAGE_SIZE对齐,终究只将页对齐的设备内存映射到用户空间中。然后将对齐操作处理后的虚拟地址逐页进行SetPageReserved(virt_to_page(virt_addr))保存(可选)
3.在nopage函数中,首要核算缺页的虚拟内存地址实践的内存页物理地址与设备文件开端处的偏移量offset;然后比较该偏移量是否超越映射的设备文件巨细;最终将该缺页地址的虚拟地址变换成页帧号并请求该页。