码迷,mamicode.com
首页 > 其他好文 > 详细

copy_from_user/copy_to_user函数中的buf參数释疑

时间:2017-05-10 21:19:13      阅读:135      评论:0      收藏:0      [点我收藏+]

标签:read   fops   void   from   center   技术分享   enter   实验   div   

从開始了解内核開始就一直在疑惑

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參数释疑

标签:read   fops   void   from   center   技术分享   enter   实验   div   

原文地址:http://www.cnblogs.com/jzdwajue/p/6838034.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!