系统调用在linux中的iomapped内存失败.
发布时间:2020-12-13 22:52:27 所属栏目:Linux 来源:网络整理
导读:我将一些io内存映射到驱动程序中的vmalloced区域.我也使用flag(ioremap_page_range中的PAGE_SHARED)与用户进程共享此区域. 现在我可以将这个共享内存访问到用户空间.我可以写这个记忆.但是,如果我将此内存作为缓冲区传递给系统调用(如recv或send),则调用将因
我将一些io内存映射到驱动程序中的vmalloced区域.我也使用flag(ioremap_page_range中的PAGE_SHARED)与用户进程共享此区域.
现在我可以将这个共享内存访问到用户空间.我可以写这个记忆.但是,如果我将此内存作为缓冲区传递给系统调用(如recv或send),则调用将因内存不足而失败(内存未映射到用户进程). 但是,我确信我的缓冲区没有任何问题.因此,我共享内存和错误检查系统调用的方式似乎存在一些冲突. 驱动代码: shared_buf = __get_vm_area(size,VM_IOREMAP,VMALLOCS_START,VMALLOC_END); ioremap_page_range(shared_buf->addr,size,phy_addr_of_io,PAGE_SHARED); 之后,我进行ioctl调用并将此shared_buf-> addr传递给用户空间应用程序. ret = recv(sockfd,shared_buf->area,0) and I get an error "bad addr". 而不是如果我尝试 ret = recv(sockfd,local_buf,0); memcpy(shared_buf->addr,size); Then it goes without issues. (免责声明:我确实在未完成IOCTL的线程中使用了shared_buf->区域.但是它是相同的过程.) 谁能看到错误? 解决方法
系统调用all验证传入的指针是否在地址空间的用户部分中. vmalloc空间不在此用户部分;因此,您不能将其用于系统调用.更重要的是,不要让用户进程直接访问vmalloc地址空间中的内存.那只是在惹麻烦.并且可能非常不安全 – 其他进程也可以访问吗?写
an mmapable file instead.
(编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |