首页 > 代码库 > copy_from_user/copy_to_user函数中的buf參数释疑
copy_from_user/copy_to_user函数中的buf參数释疑
从開始了解内核開始就一直在疑惑
unsigned long copy_to_user(void __user *to, const void *from, unsigned long n);
这里面的from指针是什么?从用户空间的read到内核空间fops中的read函数过来后,这个值是否经过了转换?是物理地址还是直接是用户进程地址空间中的虚拟地址?
今天特地做了个实验,最后得出答案是后者,from的值就是用户进程地址空间中的虚拟地址。
kernel要想得到详细的物理地址还须要进行一系列的权限检查,最后经过页表转换才行
这是在用户空间进行的測试。
代码是
printf("the address in userspace: %x\n", yourmsg);
在用户空间输出地址结果例如以下:
而在内核模块中的代码是:
printk(KERN_ALERT "in kernel space: %x\n", buf);
结果输出例如以下:
能够看到无论在内核空间还是进程空间,值都是bfad8554。得证。
copy_from_user/copy_to_user函数中的buf參数释疑
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。