linux内核 – Copy_from_user的内部工作
发布时间:2021-01-24 09:04:44 所属栏目:Linux 来源:互联网
导读:有没有人可以解释一下copy_from_user函数是如何工作的?它是否使用任何缓冲区,还是有内存映射完成,考虑到内核有权访问用户空间mem的事实. copy_from_user()的实现高度依赖于体系结构. 在x86和x86-64上,只需直接从用户空间地址读取并写入内核空间地址,同时临时
有没有人可以解释一下copy_from_user函数是如何工作的?它是否使用任何缓冲区,还是有内存映射完成,考虑到内核有权访问用户空间mem的事实. 解决方法copy_from_user()的实现高度依赖于体系结构.在x86和x86-64上,只需直接从用户空间地址读取并写入内核空间地址,同时临时禁用SMAP(超级用户模式访问防护)(如果已配置).其中的棘手之处在于,将copy_from_user()代码放入特殊区域,以便页面故障处理程序可以识别何时发生故障.在copy_from_user()中发生的内存保护错误并不会像进程中的任何其他进程上下文代码一样触发进程,或者如果在中断环境中发生内核,就会像内核一样崩溃.一个向呼叫者返回-EFAULT的代码路径. (编辑:4S站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
推荐文章
站长推荐
- 使用gold vs ld链接器时使用的glibc/pthreads中的
- linux – 如何在.zip文件中使用grep
- linux – 使用什么语言的cPanel / WHM面板服务器
- linux – 用于安装AWS CLI工具的Bash脚本
- linux – 对象文件的objdump输出中的标志
- 期望在Linux中,fd 打开文件描述符的最大数量是否
- 如何以编程方式获取屏幕DPI(linux,mac)?
- linux – lockfile-create在bash脚本中不起作用
- Linux / Unix Command: bunzip2--reference
- 如何将activerecord结果转换为包含root的哈希数组
热点阅读