Linux内核和用户空间数据交互copy_to_user和copy_from_user
一、Copy_to_user功能:用于将内核空间的数据拷贝到用户空间。函数原型:unsigned long copy_to_user(void __user *to, const void *from, unsigned long n);*to是用户空间的指针,*from是内核空间指针,n表示从内核空间向用户空间拷贝数据的字节数如果数据拷贝成功,则返回零;否则,返回没有拷贝成功的数据字...
一、copy_to_user
功能:用于将内核空间的数据拷贝到用户空间。
函数原型:unsigned long copy_to_user(void __user *to, const void *from, unsigned long n);
*to是用户空间的指针,
*from是内核空间指针,
n表示从内核空间向用户空间拷贝数据的字节数
如果数据拷贝成功,则返回零;否则,返回没有拷贝成功的数据字节数。
二、copy_from_user
功能:用于将用户空间的数据传送到内核空间。
函数原型:unsigned long copy_from_user(void * to, const void __user * from, unsigned long n)
第一个参数to是内核空间的数据目标地址指针,
第二个参数from是用户空间的数据源地址指针,
第三个参数n是数据的长度。
如果数据拷贝成功,则返回零;否则,返回没有拷贝成功的数据字节数。
此函数将from指针指向的用户空间地址开始的连续n个字节的数据发送到to指针指向的内核空间地址
例子:
struct as2056_rmsg *rmsg = NULL;
char *buffer = NULL;
//申请内存空间存放数据,
//申请的空间大小跟as2056_rmsg 结构体一样
rmsg = kmalloc(sizeof(struct as2056_rmsg), GFP_KERNEL); //切记,要申请内存空间才能使用
if(rmsg == NULL) {
printk("error: allo\n");
return -EFAULT;
}
//从用户空间拷贝as2056_rmsg 结构体指向的数据到内核空间的指针rmsg当中,成功则返回零;
//否则,返回没有拷贝成功的数据字节数。
ret = copy_from_user(rmsg, (struct as2056_rmsg *)arg, sizeof(struct as2056_rmsg));
if(ret) {
kfree(rmsg);
printk("copy write mesg from user error, ret = %d\n", ret);
return -EFAULT;
}
//申请内存空间存放数据,申请的空间大小跟rmsg->rlen一致
buffer = kmalloc(rmsg->rlen, GFP_KERNEL); //切记,要申请内存空间才能使用
if(buffer == NULL) {
kfree(rmsg);
printk("error: allo\n");
return -EFAULT;
}
//从内核空间buffer拷贝数据到用户空间rmsg->buf,成功则返回零;
//否则,返回没有拷贝成功的数据字节数。
ret = copy_to_user(rmsg->buf, buffer, rmsg->rlen);
if(ret) {
kfree(buffer);
kfree(rmsg);
printk("copy data to user failed = %d\n", ret);
return -EFAULT;
}
开放原子开发者工作坊旨在鼓励更多人参与开源活动,与志同道合的开发者们相互交流开发经验、分享开发心得、获取前沿技术趋势。工作坊有多种形式的开发者活动,如meetup、训练营等,主打技术交流,干货满满,真诚地邀请各位开发者共同参与!
更多推荐
所有评论(0)