linux应用层和内核层通过字符设备读写进行双向通信

一、是什么?

read:
filp:文件结构指针 buf是用户空间内存的地址 count 要读的字节数 f_pos是读位置相对于文件开头的便宜
write:
filp:文件结构体指针 buf是用户空间内存的地址 count 要写的字节数 f_pos是写位置相对于文件开头的偏移
内核和用户空间内存复制:
传递多个数据:
unsignd long copy_from_user(void*to,const void__usr*from,unsigned long count);
unsignd long copy_to_user(void __user*to,const void*from,unsignd long count);

传递单个数据:
如果是简单的类型 char ing long 
int val; 内核空间整形变量
get_user(val,(int*)arg);    //用户到内核 ,arg是用户空间的地址
put_user(val,(int*)arg);  //内核到用户  arg是用户空间的地址

使用文件私有数据:
大多数驱动将文件的私有数据priva_data指向设备结构体,再用read(),ioctl(),llseek访问设备.
static int globalmem_open(struct inode*inode,struct file*filp)
{
   
    filp->private_data = globalmem_devp;
	return 0;
}
seek函数:
seek()函数对文件定位的开始地址可以是文件开头(SEEK_SET,0) 当前位置(SEEK_CUR,1)
和文件尾(SEEK_END,2)

二、使用步骤

1.引入库

代码如下(示例):

#include<linux/module.h>
#include<linux/fs.h>
#include<linux/init.h>
#include<linux/cdev.h>
#include<linux/slab.h>
#include<linux/uaccess.h>
#include<linux/device.h>

static int debug = 1;
module_param(debug,int,0644);
MODULE_PARM_DESC(debug,"enable debuging infomation");
#define dprintk(args...)\
        if(debug){
      \
			printk(KERN_DEBUG args);\
		}
		
#define GLOBALMEM_SIZE  0x1000
<
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

今天6点半起床10点半睡觉和今天早晚运动

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值